Add frame_support::crypto::ecdsa::Public.to_eth_address() (k256-based) and use it in pallets#11087
Add frame_support::crypto::ecdsa::Public.to_eth_address() (k256-based) and use it in pallets#11087
frame_support::crypto::ecdsa::Public.to_eth_address() (k256-based) and use it in pallets#11087Conversation
…it, contracts Ext interface
athei
left a comment
There was a problem hiding this comment.
First round. Didn't look at the contracts changes, yet.
Co-authored-by: Alexander Theißen <alex.theissen@me.com>
sp_core::ecdsa::Public.to_eth_address() (k256-based) and use it in palletsframe_support::crypto::ecdsa::Public.to_eth_address() (k256-based) and use it in pallets
|
Had to put this new function into @shawntabrizi please advise if the place for it is chosen correctly. |
athei
left a comment
There was a problem hiding this comment.
Please add some tests in the new ecdsa file.
a70d756 to
34779f8
Compare
athei
left a comment
There was a problem hiding this comment.
For the CI try to merge master and see if that helps.
bkchr
left a comment
There was a problem hiding this comment.
Didn't check the benchmarking code in detail.
Some general points, please never use unwrap in the runtime! Either expect with a proof or remove. In your case here you need to remove all of them.
Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com>
frame/support/src/crypto/ecdsa.rs
Outdated
| <[u8; 20]>::try_from( | ||
| sp_io::hashing::keccak_256(&uncompressed.as_bytes()[1..])[12..].as_ref(), | ||
| ) | ||
| .expect("failed to take last 20 bytes of a keccak_256 hash") |
There was a problem hiding this comment.
Why do you still us an expect here? I already gave you a solution where you would not need this anymore.
There was a problem hiding this comment.
your version didn't compile
There was a problem hiding this comment.
Yeah it failed, but the solution wasn't that complicated. I pushed a commit to fix this.
…ased) and use it in pallets (paritytech#11087) * `ecdsa::Public::to_eth_address` + test, beefy-mmr `convert()` to use it, contracts Ext interface * `seal_ecdsa_to_eth_address` all but benchmark done * `seal_ecdsa_to_eth_address` + wasm test * `seal_ecdsa_to_eth_address` + benchmark * fixed dependencies * Apply suggestions from code review Co-authored-by: Alexander Theißen <alex.theissen@me.com> * fixes from review paritytech#1 * ecdsa::Public(*pk).to_eth_address() moved to frame_support and contracts to use it * beefy-mmr to use newly added frame_support function for convertion * a doc fix * import fix * benchmark fix-1 (still fails) * benchmark fixed * Apply suggestions from code review Co-authored-by: Alexander Theißen <alex.theissen@me.com> * fixes on Alex T feedback * to_eth_address() put into extension trait for sp-core::ecdsa::Public * Update frame/support/src/crypto/ecdsa.rs Co-authored-by: Alexander Theißen <alex.theissen@me.com> * Update frame/contracts/src/wasm/mod.rs Co-authored-by: Alexander Theißen <alex.theissen@me.com> * fixes on issues pointed out in review * benchmark errors fixed * fmt fix * EcdsaRecoverFailed err docs updated * Apply suggestions from code review Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * make applied suggestions compile * get rid of unwrap() in runtime * Remove expect Co-authored-by: Alexander Theißen <alex.theissen@me.com> Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> Co-authored-by: Bastian Köcher <info@kchr.de>
…ased) and use it in pallets (paritytech#11087) * `ecdsa::Public::to_eth_address` + test, beefy-mmr `convert()` to use it, contracts Ext interface * `seal_ecdsa_to_eth_address` all but benchmark done * `seal_ecdsa_to_eth_address` + wasm test * `seal_ecdsa_to_eth_address` + benchmark * fixed dependencies * Apply suggestions from code review Co-authored-by: Alexander Theißen <alex.theissen@me.com> * fixes from review #1 * ecdsa::Public(*pk).to_eth_address() moved to frame_support and contracts to use it * beefy-mmr to use newly added frame_support function for convertion * a doc fix * import fix * benchmark fix-1 (still fails) * benchmark fixed * Apply suggestions from code review Co-authored-by: Alexander Theißen <alex.theissen@me.com> * fixes on Alex T feedback * to_eth_address() put into extension trait for sp-core::ecdsa::Public * Update frame/support/src/crypto/ecdsa.rs Co-authored-by: Alexander Theißen <alex.theissen@me.com> * Update frame/contracts/src/wasm/mod.rs Co-authored-by: Alexander Theißen <alex.theissen@me.com> * fixes on issues pointed out in review * benchmark errors fixed * fmt fix * EcdsaRecoverFailed err docs updated * Apply suggestions from code review Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * make applied suggestions compile * get rid of unwrap() in runtime * Remove expect Co-authored-by: Alexander Theißen <alex.theissen@me.com> Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> Co-authored-by: Bastian Köcher <info@kchr.de>
…ased) and use it in pallets (paritytech#11087) * `ecdsa::Public::to_eth_address` + test, beefy-mmr `convert()` to use it, contracts Ext interface * `seal_ecdsa_to_eth_address` all but benchmark done * `seal_ecdsa_to_eth_address` + wasm test * `seal_ecdsa_to_eth_address` + benchmark * fixed dependencies * Apply suggestions from code review Co-authored-by: Alexander Theißen <alex.theissen@me.com> * fixes from review #1 * ecdsa::Public(*pk).to_eth_address() moved to frame_support and contracts to use it * beefy-mmr to use newly added frame_support function for convertion * a doc fix * import fix * benchmark fix-1 (still fails) * benchmark fixed * Apply suggestions from code review Co-authored-by: Alexander Theißen <alex.theissen@me.com> * fixes on Alex T feedback * to_eth_address() put into extension trait for sp-core::ecdsa::Public * Update frame/support/src/crypto/ecdsa.rs Co-authored-by: Alexander Theißen <alex.theissen@me.com> * Update frame/contracts/src/wasm/mod.rs Co-authored-by: Alexander Theißen <alex.theissen@me.com> * fixes on issues pointed out in review * benchmark errors fixed * fmt fix * EcdsaRecoverFailed err docs updated * Apply suggestions from code review Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * make applied suggestions compile * get rid of unwrap() in runtime * Remove expect Co-authored-by: Alexander Theißen <alex.theissen@me.com> Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> Co-authored-by: Bastian Köcher <info@kchr.de>
As a follow-up to #10883 and a pre-requisite to ink#1068, this PR:
pub fn to_eth_address(&self) -> Result<[u8; 20], ()>tosp_core::ecdsa::Publicframe_support::crypto::ecdsafn convert(a: beefy_primitives::crypto::AuthorityId) -> Vec<u8>inpallet-beefy-mmrto use itseal_to_eth_addresstopallet-contractsAPI which uses it