* init * Fix bank proto messages * missing conversions * remove casttype for addresses * Fix tests * Fix consaddress * more test fixes * Fix tests * fixed tests * migrate missing proto declarations * format * Fix format * Fix alignment * Fix more tests * Fix ibc merge issue * Fix fmt * Fix more tests * Fix missing address declarations * Fix staking tests * Fix more tests * Fix config * fixed tests * Fix more tests * Update staking grpc tests * Fix merge issue * fixed failing tests in x/distr * fixed sim tests * fixed failing tests * Fix bugs * Add logs * fixed slashing issue * Fix staking grpc tests * Fix all bank tests :) * Fix tests in distribution * Fix more tests in distr * Fix slashing tests * Fix statking tests * Fix evidence tests * Fix gov tests * Fix bug in create vesting account * Fix test * remove fmt * fixed gov tests * fixed x/ibc tests * fixed x/ibc-transfer tests * fixed staking tests * fixed staking tests * fixed test * fixed distribution issue * fix pagination test * fmt * lint * fix build * fix format * revert tally tests * revert tally tests * lint * Fix sim test * revert * revert * fixed tally issue * fix tests * revert * fmt * refactor * remove `GetAddress()` * remove fmt * revert fmt.Striger usage * Fix tests * Fix rest test * disable interfacer lint check * make proto-format * add nolint rule * remove stray println Co-authored-by: aleem1314 <aleem.md789@gmail.com> Co-authored-by: atheesh <atheesh@vitwit.com>
66 lines
2.0 KiB
Protocol Buffer
66 lines
2.0 KiB
Protocol Buffer
syntax = "proto3";
|
|
package ibc.commitment;
|
|
|
|
option go_package = "github.com/cosmos/cosmos-sdk/x/ibc/23-commitment/types";
|
|
|
|
import "gogoproto/gogo.proto";
|
|
import "tendermint/crypto/proof.proto";
|
|
|
|
// MerkleRoot defines a merkle root hash.
|
|
// In the Cosmos SDK, the AppHash of a block header becomes the root.
|
|
message MerkleRoot {
|
|
option (gogoproto.goproto_getters) = false;
|
|
|
|
bytes hash = 1;
|
|
}
|
|
|
|
// MerklePrefix is merkle path prefixed to the key.
|
|
// The constructed key from the Path and the key will be append(Path.KeyPath,
|
|
// append(Path.KeyPrefix, key...))
|
|
message MerklePrefix {
|
|
bytes key_prefix = 1 [(gogoproto.moretags) = "yaml:\"key_prefix\""];
|
|
}
|
|
|
|
// MerklePath is the path used to verify commitment proofs, which can be an
|
|
// arbitrary structured object (defined by a commitment type).
|
|
message MerklePath {
|
|
option (gogoproto.goproto_stringer) = false;
|
|
|
|
KeyPath key_path = 1 [(gogoproto.nullable) = false, (gogoproto.moretags) = "yaml:\"key_path\""];
|
|
}
|
|
|
|
// MerkleProof is a wrapper type that contains a merkle proof.
|
|
// It demonstrates membership or non-membership for an element or set of
|
|
// elements, verifiable in conjunction with a known commitment root. Proofs
|
|
// should be succinct.
|
|
message MerkleProof {
|
|
tendermint.crypto.ProofOps proof = 1;
|
|
}
|
|
|
|
// KeyPath defines a slice of keys
|
|
message KeyPath {
|
|
option (gogoproto.goproto_stringer) = false;
|
|
option (gogoproto.goproto_getters) = false;
|
|
|
|
repeated Key keys = 1;
|
|
}
|
|
|
|
// Key defines a proof Key
|
|
message Key {
|
|
option (gogoproto.goproto_getters) = false;
|
|
|
|
bytes name = 1 [(gogoproto.customname) = "name"];
|
|
KeyEncoding enc = 2 [(gogoproto.customname) = "enc"];
|
|
}
|
|
|
|
// KeyEncoding defines the encoding format of a key's bytes.
|
|
enum KeyEncoding {
|
|
option (gogoproto.goproto_enum_stringer) = false;
|
|
option (gogoproto.goproto_enum_prefix) = false;
|
|
|
|
// URL encoding
|
|
KEY_ENCODING_URL_UNSPECIFIED = 0 [(gogoproto.enumvalue_customname) = "URL"];
|
|
// Hex encoding
|
|
KEY_ENCODING_HEX = 1 [(gogoproto.enumvalue_customname) = "HEX"];
|
|
}
|