-
Notifications
You must be signed in to change notification settings - Fork 345
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
decode multisig acc #882
Comments
Your are right. However, encoding a publich key as bech32 is a very bad idea. bech32 is only valid up to a length of 90 characters (for good reason). So the string you posted there is not valid as it is 156 characters long. I know there was a time when Cosmos SDK APIs encoded pubkeys as bech32. That was a bad idea, which was reverted as far as I know. So the real question here is: why do you have bech32 encoded pubkeys and how to get rid of this encoding entirely? |
Seems right now cosmos sdk works using bech32 Also, multisig pubkey contains encoded pubkeys from all participants + threshold, thus it can't be like regular acc pubkey in terms of length Also, there is code for construction multisig pubkey in the same file below cosmjs/packages/amino/src/encoding.ts Line 100 in b227992
Default bench32 decoder by default has no limit, so it can decode correctly such addresses.
So, is it all make sense? If so, I can create PR |
Could you report this as a bug in Cosmos SDK please? You can refer to this spec: "A Bech32 string is at most 90 characters long and consists of" https://github.com/bitcoin/bips/blob/master/bip-0173.mediawiki
Yes. This is why it should not be encoded as bech32.
It can, I know. This doesn't mean this should ever be done in practice.
Jupp. It's fair to encode this to raw binary, but when used in bech32 the trouble begins.
Mixed feelings. We are fixing other people's bugs by this. |
Uh, seems it is already in v0.43 cosmos/cosmos-sdk#7477 |
Haha, our test data is already full of this for the other direction: https://github.com/cosmos/cosmjs/blob/v0.26.0/packages/amino/src/testutils.spec.ts#L35-L76 I give up. Feel free to create a PR using that test data. See how it is used here in the other direction: https://github.com/cosmos/cosmjs/blob/v0.26.0/packages/amino/src/encoding.spec.ts#L149-L161 |
Please note #883 |
Released as part of 0.26.1 |
function
decodeBech32Pubkey
can't decode multisig keys of next formatbostrompub1ytql0csgqgfzd666axrjzqm4p586gn8vrm6958zd4c9lje8xeahzcf35mwsjw3gaxn7xnhe9eufzd666axrjzqcc9h5ms6x96eg23e4hxghnvwn7xwtuhgeupvg0lgppn7d6dkyaxc66dhat
seems multisig branch is missed
cosmjs/packages/amino/src/encoding.ts
Line 37 in b227992
The text was updated successfully, but these errors were encountered: