-
Notifications
You must be signed in to change notification settings - Fork 3.7k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #1335 from zmanian/bech32_spec
Added a bech32 spec doc
- Loading branch information
Showing
1 changed file
with
25 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
# Bech32 on Cosmos | ||
|
||
The Cosmos network prefers to use the Bech32 address format whereever users must handle binary data. Bech32 encoding provides robust integrity checks on data and the human readable part(HRP) provides contextual hints that can assist UI developers with providing informative error messages. | ||
|
||
In the Cosmos network, keys and addresses may refer to a number of different roles in the network like accounts, validators etc. | ||
|
||
|
||
## HRP table | ||
|
||
| HRP | Definition | | ||
| ------------- |:-------------:| | ||
| `cosmosaccaddr` | Cosmos Account Address | | ||
| `cosmosaccpub` | Cosmos Account Public Key | | ||
| `cosmosvaladdr` | Cosmos Consensus Address | | ||
| `cosmosvalpub` | Cosmos Consensus Public Key| | ||
|
||
## Encoding | ||
|
||
While all user facing interfaces to Cosmos software should exposed bech32 interfaces, many internal interfaces encode binary value in hex or base64 encoded form. | ||
|
||
To covert between other binary reprsentation of addresses and keys, it is important to first apply the Amino enocoding process before bech32 encoding. | ||
|
||
A complete implementation of the Amino serialization format is unncessary in most cases. Simply prepending bytes from this [table](https://github.com/tendermint/tendermint/blob/master/docs/spec/blockchain/encoding.md#public-key-cryptography) to the bytestring payload before bech32 encoding will sufficient for compatible representation. | ||
|
||
|