-
Notifications
You must be signed in to change notification settings - Fork 992
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
tx: sign hash of code rather than full code blob #807
Conversation
* murisi/smaller-signing: tx: sign hash of code rather than full code blob
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I added another commit that fixes the whitelisting issue caught by tests - for the VP host env function get_tx_code_hash
we have to return the code hash unsalted. About that, why is the timestamp salt added to the code hash for signature in first place? The signature is over the whole SigningTx
which also includes the timestamp.
In the first run, there was also a failure from tx_unbond test - it's just invalid input data to the test function - in PoS we either have to limit the input to non-zero amounts or allow 0 bonds/unbonds to be executed. In here, this can be safely ignored.
This is in preparation for the other half of the Ledger app support, which is not yet ported, where we encrypt each tx field separately in an EncryptedTx. EncryptedTx now uses the timestamp as a nonce; each field needs to be nonced individually for that part. I may even add it to the data blob, since this may repeat too... |
49b70ce
to
f4f39ef
Compare
ca31d61
to
7309e7e
Compare
…nto main * namada/murisi/smaller-signing: proto/types: remove an & to placate 1.65 clippy changelog: add #807 tx: sign hash of code rather than full code blob
…nto main * namada/murisi/smaller-signing: proto/types: remove an & to placate 1.65 clippy changelog: add #807 tx: sign hash of code rather than full code blob
Namada 0.11.0 * tag 'v0.11.0': (195 commits) Namada 0.11.0 wasm: update checksums.json wasm_for_tests: rebuild all fix default chain IDs lengths make fmt s/anoma/namada in all files apps: s/anoma/namada/ in paths wasm: update checksums.json [ci] wasm checksums update changelog: add #733 docs/overview: update deps graph and add a generated one too pos: replace generic types with concrete types from core update paths for core split and apply many small fixes add new crate "namada_core" for core types, storage_api, tx_env, vp_env proto/types: remove an & to placate 1.65 clippy changelog: add #807 tx: sign hash of code rather than full code blob maint: fix incorrect clippy placation in previous merge fix: use multitoken credit_tokens() in tests maint: patch funty 1.2.0 ci: update rust/docker image Fix changelog Fix up for namada v0.10.1 Add changelog Add check-abcipp command Use ferveo-tpke flag to stop tendermint-rpc being pulled into wasm First attempt at fixing shared abcipp deleted out of date TS docs changelog: add #797 [ci] wasm checksums update changelog: add #707 remove comments to self convert to tm voting power in `update_epoch` client: replace voting power with bonded stake in queries, etc fix pos state machine test clean up naming of "validator total deltas" -> "validator deltas" fix client voting power query fix `TendermintValidator::power` clippy: suppress unused validation vars (may need later) fmt + cleanup after cherrypicking commits from #388 more voting_power removal and accurate variable renaming keep voting_power as a possible client query change `validator_total_deltas` -> `validator_deltas` Update wasm tx_(un)bond with VotingPower removal refactor VotingPower out of PoS VP continue refactoring away VotingPower refactor out VotingPower(Delta) in pos crate, distinguish total and validator deltas rename slash rate params with `min`, update default `PosParam` values Update tests/src/vm_host_env/tx.rs Update shared/src/ledger/parameters/mod.rs changelog: add #775 [feat]: Renamed 'fee' CLI arguments to 'gas'. make: clean any existing WASM files before WASM build changelog: add #719 changelog: add #674 pos: use method governance: added method, fmt, clippy changelog: add #570 [ci] wasm checksums update changelog: add #708 remove `min_duration` from `ParametersConfig` remove `staked_ratio` and `pos_inflation_amount` from `ParametersConfig` update comments [ci] wasm checksums update fmt and includes updates to accommodate `tm_votes_per_token` relative to namnam Update rewards parameters and distribution update toml files with latest parameters and values fix arb_amount to max out at max tm voting power (fix wasm test bug) storage change: last inflation rate -> last inflation token amount fix: write all fields in Parameters storage in `init_storage` fix initial staked ratio parameter at genesis update rust_decimal version + fmt clean comments and toml files of basis points fix correct inner type of ValidationError::TotalVotingPowerTooLarge more decimal_mult function uses add fns to multiply Decimal and integer type, return truncated integer remove BasisPoints and change relevant parameters to Decimal type documentation updates + unused imports removal rename reward_rate -> inflation_rate for pos specify read or write intentions for parameters storage keys add target_staked_ratio to PoS params update max inflation rate in params (formerly max_staking_rewards_rate) rename `votes_per_token` to `tm_votes_per_token` since this will only be used to interface with tendermint add new parameters needed for rewards PD controller to the Parameters storage add max_staking_reward_rate to PosParams clarify+rename 'epoch_storage_key' as 'epoch_duration_storage_key' changelog: add #695 [ci] wasm checksums update addressing 2nd round of review comments async tx to change validator commission rate [ci] wasm checksums update changelog: add #763 pos/vp: do not return early on unknown permitted key changelog: add #582 add vp validator to wasms fix: critical flaw in pos VP that was prematurely returning true add max commission rate info to validation and pos state machine test validator VP that checks source and signature for a commission rate change tx changes in response to review comments ...
Namada 0.11.0 * tag 'v0.11.0': (195 commits) Namada 0.11.0 wasm: update checksums.json wasm_for_tests: rebuild all fix default chain IDs lengths make fmt s/anoma/namada in all files apps: s/anoma/namada/ in paths wasm: update checksums.json [ci] wasm checksums update changelog: add #733 docs/overview: update deps graph and add a generated one too pos: replace generic types with concrete types from core update paths for core split and apply many small fixes add new crate "namada_core" for core types, storage_api, tx_env, vp_env proto/types: remove an & to placate 1.65 clippy changelog: add #807 tx: sign hash of code rather than full code blob maint: fix incorrect clippy placation in previous merge fix: use multitoken credit_tokens() in tests maint: patch funty 1.2.0 ci: update rust/docker image Fix changelog Fix up for namada v0.10.1 Add changelog Add check-abcipp command Use ferveo-tpke flag to stop tendermint-rpc being pulled into wasm First attempt at fixing shared abcipp deleted out of date TS docs changelog: add #797 [ci] wasm checksums update changelog: add #707 remove comments to self convert to tm voting power in `update_epoch` client: replace voting power with bonded stake in queries, etc fix pos state machine test clean up naming of "validator total deltas" -> "validator deltas" fix client voting power query fix `TendermintValidator::power` clippy: suppress unused validation vars (may need later) fmt + cleanup after cherrypicking commits from #388 more voting_power removal and accurate variable renaming keep voting_power as a possible client query change `validator_total_deltas` -> `validator_deltas` Update wasm tx_(un)bond with VotingPower removal refactor VotingPower out of PoS VP continue refactoring away VotingPower refactor out VotingPower(Delta) in pos crate, distinguish total and validator deltas rename slash rate params with `min`, update default `PosParam` values Update tests/src/vm_host_env/tx.rs Update shared/src/ledger/parameters/mod.rs changelog: add #775 [feat]: Renamed 'fee' CLI arguments to 'gas'. make: clean any existing WASM files before WASM build changelog: add #719 changelog: add #674 pos: use method governance: added method, fmt, clippy changelog: add #570 [ci] wasm checksums update changelog: add #708 remove `min_duration` from `ParametersConfig` remove `staked_ratio` and `pos_inflation_amount` from `ParametersConfig` update comments [ci] wasm checksums update fmt and includes updates to accommodate `tm_votes_per_token` relative to namnam Update rewards parameters and distribution update toml files with latest parameters and values fix arb_amount to max out at max tm voting power (fix wasm test bug) storage change: last inflation rate -> last inflation token amount fix: write all fields in Parameters storage in `init_storage` fix initial staked ratio parameter at genesis update rust_decimal version + fmt clean comments and toml files of basis points fix correct inner type of ValidationError::TotalVotingPowerTooLarge more decimal_mult function uses add fns to multiply Decimal and integer type, return truncated integer remove BasisPoints and change relevant parameters to Decimal type documentation updates + unused imports removal rename reward_rate -> inflation_rate for pos specify read or write intentions for parameters storage keys add target_staked_ratio to PoS params update max inflation rate in params (formerly max_staking_rewards_rate) rename `votes_per_token` to `tm_votes_per_token` since this will only be used to interface with tendermint add new parameters needed for rewards PD controller to the Parameters storage add max_staking_reward_rate to PosParams clarify+rename 'epoch_storage_key' as 'epoch_duration_storage_key' changelog: add #695 [ci] wasm checksums update addressing 2nd round of review comments async tx to change validator commission rate [ci] wasm checksums update changelog: add #763 pos/vp: do not return early on unknown permitted key changelog: add #582 add vp validator to wasms fix: critical flaw in pos VP that was prematurely returning true add max commission rate info to validation and pos state machine test validator VP that checks source and signature for a commission rate change tx changes in response to review comments ...
Namada 0.11.0 * tag 'v0.11.0': (195 commits) Namada 0.11.0 wasm: update checksums.json wasm_for_tests: rebuild all fix default chain IDs lengths make fmt s/anoma/namada in all files apps: s/anoma/namada/ in paths wasm: update checksums.json [ci] wasm checksums update changelog: add #733 docs/overview: update deps graph and add a generated one too pos: replace generic types with concrete types from core update paths for core split and apply many small fixes add new crate "namada_core" for core types, storage_api, tx_env, vp_env proto/types: remove an & to placate 1.65 clippy changelog: add #807 tx: sign hash of code rather than full code blob maint: fix incorrect clippy placation in previous merge fix: use multitoken credit_tokens() in tests maint: patch funty 1.2.0 ci: update rust/docker image Fix changelog Fix up for namada v0.10.1 Add changelog Add check-abcipp command Use ferveo-tpke flag to stop tendermint-rpc being pulled into wasm First attempt at fixing shared abcipp deleted out of date TS docs changelog: add #797 [ci] wasm checksums update changelog: add #707 remove comments to self convert to tm voting power in `update_epoch` client: replace voting power with bonded stake in queries, etc fix pos state machine test clean up naming of "validator total deltas" -> "validator deltas" fix client voting power query fix `TendermintValidator::power` clippy: suppress unused validation vars (may need later) fmt + cleanup after cherrypicking commits from #388 more voting_power removal and accurate variable renaming keep voting_power as a possible client query change `validator_total_deltas` -> `validator_deltas` Update wasm tx_(un)bond with VotingPower removal refactor VotingPower out of PoS VP continue refactoring away VotingPower refactor out VotingPower(Delta) in pos crate, distinguish total and validator deltas rename slash rate params with `min`, update default `PosParam` values Update tests/src/vm_host_env/tx.rs Update shared/src/ledger/parameters/mod.rs changelog: add #775 [feat]: Renamed 'fee' CLI arguments to 'gas'. make: clean any existing WASM files before WASM build changelog: add #719 changelog: add #674 pos: use method governance: added method, fmt, clippy changelog: add #570 [ci] wasm checksums update changelog: add #708 remove `min_duration` from `ParametersConfig` remove `staked_ratio` and `pos_inflation_amount` from `ParametersConfig` update comments [ci] wasm checksums update fmt and includes updates to accommodate `tm_votes_per_token` relative to namnam Update rewards parameters and distribution update toml files with latest parameters and values fix arb_amount to max out at max tm voting power (fix wasm test bug) storage change: last inflation rate -> last inflation token amount fix: write all fields in Parameters storage in `init_storage` fix initial staked ratio parameter at genesis update rust_decimal version + fmt clean comments and toml files of basis points fix correct inner type of ValidationError::TotalVotingPowerTooLarge more decimal_mult function uses add fns to multiply Decimal and integer type, return truncated integer remove BasisPoints and change relevant parameters to Decimal type documentation updates + unused imports removal rename reward_rate -> inflation_rate for pos specify read or write intentions for parameters storage keys add target_staked_ratio to PoS params update max inflation rate in params (formerly max_staking_rewards_rate) rename `votes_per_token` to `tm_votes_per_token` since this will only be used to interface with tendermint add new parameters needed for rewards PD controller to the Parameters storage add max_staking_reward_rate to PosParams clarify+rename 'epoch_storage_key' as 'epoch_duration_storage_key' changelog: add #695 [ci] wasm checksums update addressing 2nd round of review comments async tx to change validator commission rate [ci] wasm checksums update changelog: add #763 pos/vp: do not return early on unknown permitted key changelog: add #582 add vp validator to wasms fix: critical flaw in pos VP that was prematurely returning true add max commission rate info to validation and pos state machine test validator VP that checks source and signature for a commission rate change tx changes in response to review comments ...
Namada 0.11.0 * tag 'v0.11.0': (195 commits) Namada 0.11.0 wasm: update checksums.json wasm_for_tests: rebuild all fix default chain IDs lengths make fmt s/anoma/namada in all files apps: s/anoma/namada/ in paths wasm: update checksums.json [ci] wasm checksums update changelog: add #733 docs/overview: update deps graph and add a generated one too pos: replace generic types with concrete types from core update paths for core split and apply many small fixes add new crate "namada_core" for core types, storage_api, tx_env, vp_env proto/types: remove an & to placate 1.65 clippy changelog: add #807 tx: sign hash of code rather than full code blob maint: fix incorrect clippy placation in previous merge fix: use multitoken credit_tokens() in tests maint: patch funty 1.2.0 ci: update rust/docker image Fix changelog Fix up for namada v0.10.1 Add changelog Add check-abcipp command Use ferveo-tpke flag to stop tendermint-rpc being pulled into wasm First attempt at fixing shared abcipp deleted out of date TS docs changelog: add #797 [ci] wasm checksums update changelog: add #707 remove comments to self convert to tm voting power in `update_epoch` client: replace voting power with bonded stake in queries, etc fix pos state machine test clean up naming of "validator total deltas" -> "validator deltas" fix client voting power query fix `TendermintValidator::power` clippy: suppress unused validation vars (may need later) fmt + cleanup after cherrypicking commits from #388 more voting_power removal and accurate variable renaming keep voting_power as a possible client query change `validator_total_deltas` -> `validator_deltas` Update wasm tx_(un)bond with VotingPower removal refactor VotingPower out of PoS VP continue refactoring away VotingPower refactor out VotingPower(Delta) in pos crate, distinguish total and validator deltas rename slash rate params with `min`, update default `PosParam` values Update tests/src/vm_host_env/tx.rs Update shared/src/ledger/parameters/mod.rs changelog: add #775 [feat]: Renamed 'fee' CLI arguments to 'gas'. make: clean any existing WASM files before WASM build changelog: add #719 changelog: add #674 pos: use method governance: added method, fmt, clippy changelog: add #570 [ci] wasm checksums update changelog: add #708 remove `min_duration` from `ParametersConfig` remove `staked_ratio` and `pos_inflation_amount` from `ParametersConfig` update comments [ci] wasm checksums update fmt and includes updates to accommodate `tm_votes_per_token` relative to namnam Update rewards parameters and distribution update toml files with latest parameters and values fix arb_amount to max out at max tm voting power (fix wasm test bug) storage change: last inflation rate -> last inflation token amount fix: write all fields in Parameters storage in `init_storage` fix initial staked ratio parameter at genesis update rust_decimal version + fmt clean comments and toml files of basis points fix correct inner type of ValidationError::TotalVotingPowerTooLarge more decimal_mult function uses add fns to multiply Decimal and integer type, return truncated integer remove BasisPoints and change relevant parameters to Decimal type documentation updates + unused imports removal rename reward_rate -> inflation_rate for pos specify read or write intentions for parameters storage keys add target_staked_ratio to PoS params update max inflation rate in params (formerly max_staking_rewards_rate) rename `votes_per_token` to `tm_votes_per_token` since this will only be used to interface with tendermint add new parameters needed for rewards PD controller to the Parameters storage add max_staking_reward_rate to PosParams clarify+rename 'epoch_storage_key' as 'epoch_duration_storage_key' changelog: add #695 [ci] wasm checksums update addressing 2nd round of review comments async tx to change validator commission rate [ci] wasm checksums update changelog: add #763 pos/vp: do not return early on unknown permitted key changelog: add #582 add vp validator to wasms fix: critical flaw in pos VP that was prematurely returning true add max commission rate info to validation and pos state machine test validator VP that checks source and signature for a commission rate change tx changes in response to review comments ...
Namada 0.11.0 * tag 'v0.11.0': (195 commits) Namada 0.11.0 wasm: update checksums.json wasm_for_tests: rebuild all fix default chain IDs lengths make fmt s/anoma/namada in all files apps: s/anoma/namada/ in paths wasm: update checksums.json [ci] wasm checksums update changelog: add #733 docs/overview: update deps graph and add a generated one too pos: replace generic types with concrete types from core update paths for core split and apply many small fixes add new crate "namada_core" for core types, storage_api, tx_env, vp_env proto/types: remove an & to placate 1.65 clippy changelog: add #807 tx: sign hash of code rather than full code blob maint: fix incorrect clippy placation in previous merge fix: use multitoken credit_tokens() in tests maint: patch funty 1.2.0 ci: update rust/docker image Fix changelog Fix up for namada v0.10.1 Add changelog Add check-abcipp command Use ferveo-tpke flag to stop tendermint-rpc being pulled into wasm First attempt at fixing shared abcipp deleted out of date TS docs changelog: add #797 [ci] wasm checksums update changelog: add #707 remove comments to self convert to tm voting power in `update_epoch` client: replace voting power with bonded stake in queries, etc fix pos state machine test clean up naming of "validator total deltas" -> "validator deltas" fix client voting power query fix `TendermintValidator::power` clippy: suppress unused validation vars (may need later) fmt + cleanup after cherrypicking commits from #388 more voting_power removal and accurate variable renaming keep voting_power as a possible client query change `validator_total_deltas` -> `validator_deltas` Update wasm tx_(un)bond with VotingPower removal refactor VotingPower out of PoS VP continue refactoring away VotingPower refactor out VotingPower(Delta) in pos crate, distinguish total and validator deltas rename slash rate params with `min`, update default `PosParam` values Update tests/src/vm_host_env/tx.rs Update shared/src/ledger/parameters/mod.rs changelog: add #775 [feat]: Renamed 'fee' CLI arguments to 'gas'. make: clean any existing WASM files before WASM build changelog: add #719 changelog: add #674 pos: use method governance: added method, fmt, clippy changelog: add #570 [ci] wasm checksums update changelog: add #708 remove `min_duration` from `ParametersConfig` remove `staked_ratio` and `pos_inflation_amount` from `ParametersConfig` update comments [ci] wasm checksums update fmt and includes updates to accommodate `tm_votes_per_token` relative to namnam Update rewards parameters and distribution update toml files with latest parameters and values fix arb_amount to max out at max tm voting power (fix wasm test bug) storage change: last inflation rate -> last inflation token amount fix: write all fields in Parameters storage in `init_storage` fix initial staked ratio parameter at genesis update rust_decimal version + fmt clean comments and toml files of basis points fix correct inner type of ValidationError::TotalVotingPowerTooLarge more decimal_mult function uses add fns to multiply Decimal and integer type, return truncated integer remove BasisPoints and change relevant parameters to Decimal type documentation updates + unused imports removal rename reward_rate -> inflation_rate for pos specify read or write intentions for parameters storage keys add target_staked_ratio to PoS params update max inflation rate in params (formerly max_staking_rewards_rate) rename `votes_per_token` to `tm_votes_per_token` since this will only be used to interface with tendermint add new parameters needed for rewards PD controller to the Parameters storage add max_staking_reward_rate to PosParams clarify+rename 'epoch_storage_key' as 'epoch_duration_storage_key' changelog: add #695 [ci] wasm checksums update addressing 2nd round of review comments async tx to change validator commission rate [ci] wasm checksums update changelog: add #763 pos/vp: do not return early on unknown permitted key changelog: add #582 add vp validator to wasms fix: critical flaw in pos VP that was prematurely returning true add max commission rate info to validation and pos state machine test validator VP that checks source and signature for a commission rate change tx changes in response to review comments ...
* bat/eth-0.11.0-merge: (205 commits) tiny refactor vote_extensions [chore]: Added some docstrings Makefile: add core to clippy-abcipp and test-unit-abcipp and fix shared [fix] abcipp ethereum_events unit test [feat]: Fixed up the abcipp feature flag [fix]: Fixed FinalizeBlock method more abcipp fixes fix `make check-abcipp` and `make clippy-abcipp` fix 0.11.0 merge move eth-bridge types and storage mods to core Namada 0.11.0 wasm: update checksums.json wasm_for_tests: rebuild all fix default chain IDs lengths make fmt s/anoma/namada in all files apps: s/anoma/namada/ in paths wasm: update checksums.json [ci] wasm checksums update changelog: add #733 docs/overview: update deps graph and add a generated one too pos: replace generic types with concrete types from core update paths for core split and apply many small fixes add new crate "namada_core" for core types, storage_api, tx_env, vp_env proto/types: remove an & to placate 1.65 clippy changelog: add #807 tx: sign hash of code rather than full code blob maint: fix incorrect clippy placation in previous merge fix: use multitoken credit_tokens() in tests maint: patch funty 1.2.0 ci: update rust/docker image Fix changelog Fix up for namada v0.10.1 Add changelog Add check-abcipp command Use ferveo-tpke flag to stop tendermint-rpc being pulled into wasm First attempt at fixing shared abcipp deleted out of date TS docs changelog: add #797 [ci] wasm checksums update changelog: add #707 remove comments to self convert to tm voting power in `update_epoch` client: replace voting power with bonded stake in queries, etc fix pos state machine test clean up naming of "validator total deltas" -> "validator deltas" fix client voting power query fix `TendermintValidator::power` clippy: suppress unused validation vars (may need later) fmt + cleanup after cherrypicking commits from #388 more voting_power removal and accurate variable renaming keep voting_power as a possible client query change `validator_total_deltas` -> `validator_deltas` Update wasm tx_(un)bond with VotingPower removal refactor VotingPower out of PoS VP continue refactoring away VotingPower refactor out VotingPower(Delta) in pos crate, distinguish total and validator deltas rename slash rate params with `min`, update default `PosParam` values Update tests/src/vm_host_env/tx.rs Update shared/src/ledger/parameters/mod.rs changelog: add #775 [feat]: Renamed 'fee' CLI arguments to 'gas'. make: clean any existing WASM files before WASM build changelog: add #719 changelog: add #674 pos: use method governance: added method, fmt, clippy changelog: add #570 [ci] wasm checksums update changelog: add #708 remove `min_duration` from `ParametersConfig` remove `staked_ratio` and `pos_inflation_amount` from `ParametersConfig` update comments [ci] wasm checksums update fmt and includes updates to accommodate `tm_votes_per_token` relative to namnam Update rewards parameters and distribution update toml files with latest parameters and values fix arb_amount to max out at max tm voting power (fix wasm test bug) storage change: last inflation rate -> last inflation token amount fix: write all fields in Parameters storage in `init_storage` fix initial staked ratio parameter at genesis update rust_decimal version + fmt clean comments and toml files of basis points fix correct inner type of ValidationError::TotalVotingPowerTooLarge more decimal_mult function uses add fns to multiply Decimal and integer type, return truncated integer remove BasisPoints and change relevant parameters to Decimal type documentation updates + unused imports removal rename reward_rate -> inflation_rate for pos specify read or write intentions for parameters storage keys add target_staked_ratio to PoS params update max inflation rate in params (formerly max_staking_rewards_rate) rename `votes_per_token` to `tm_votes_per_token` since this will only be used to interface with tendermint add new parameters needed for rewards PD controller to the Parameters storage add max_staking_reward_rate to PosParams clarify+rename 'epoch_storage_key' as 'epoch_duration_storage_key' changelog: add #695 [ci] wasm checksums update addressing 2nd round of review comments ...
No description provided.