Encoding change to Base64
Data encoding format changed from hex-encoded to Base64-encoded. Example:- Hex encoded:
BJSk2KCI4snP2Cw/ntDdgp8R25XJ2xg18KL67fyEAwgtPMpeq5APSUHrkv5wtgrFfpmcDivnP8HPGufyyXnByxo= - Base64 encoded:
0x0494a4d8a088e2c9cfd82c3f9ed0dd829f11db95c9db1835f0a2faedfc8403082d3cca5eab900f4941eb92fe70b60ac57e999c0e2be73fc1cf1ae7f2c979c1cb1a
Validator signing key and keyring
In Heimdall-v2, validator signing keys must be imported into the keyring before the node can sign transactions. This replaces the v1 approach of reading the key directly from a config file. From the Cosmos documentation:The keyring holds the private/public keypairs used to interact with a node. For instance, a validator key needs to be set up before running the blockchain node, so that blocks can be correctly signed. The private key can be stored in different locations, called “backends”, such as a file or the operating system’s own key storage.For details on keyring configuration, see the Cosmos SDK documentation. To import your validator private key into the keyring:
-
Get your Base64-encoded private key:
-
Convert the Base64-encoded key to hex:
-
Import the hex-encoded key into the keyring:
When you first import a key, you are prompted for a password. This password is required each time you sign a transaction.
-
When running a transaction command, specify
--fromwith the key name:
Vote extensions in each block
In Heimdall-v2, the first transaction of each block contains encoded vote extensions. To decode these, use the additional decode command provided inheimdalld.