#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ExistenceProof {
#[prost(bytes="vec", tag="1")]
pub key: ::prost::alloc::vec::Vec<u8>,
#[prost(bytes="vec", tag="2")]
pub value: ::prost::alloc::vec::Vec<u8>,
#[prost(message, optional, tag="3")]
pub leaf: ::core::option::Option<LeafOp>,
#[prost(message, repeated, tag="4")]
pub path: ::prost::alloc::vec::Vec<InnerOp>,
}
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct NonExistenceProof {
#[prost(bytes="vec", tag="1")]
pub key: ::prost::alloc::vec::Vec<u8>,
#[prost(message, optional, tag="2")]
pub left: ::core::option::Option<ExistenceProof>,
#[prost(message, optional, tag="3")]
pub right: ::core::option::Option<ExistenceProof>,
}
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct CommitmentProof {
#[prost(oneof="commitment_proof::Proof", tags="1, 2, 3, 4")]
pub proof: ::core::option::Option<commitment_proof::Proof>,
}
pub mod commitment_proof {
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Clone, PartialEq, ::prost::Oneof)]
pub enum Proof {
#[prost(message, tag="1")]
Exist(super::ExistenceProof),
#[prost(message, tag="2")]
Nonexist(super::NonExistenceProof),
#[prost(message, tag="3")]
Batch(super::BatchProof),
#[prost(message, tag="4")]
Compressed(super::CompressedBatchProof),
}
}
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Eq)]
#[cfg_attr(feature = "json-schema", derive(::schemars::JsonSchema))]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct LeafOp {
#[prost(enumeration="HashOp", tag="1")]
pub hash: i32,
#[prost(enumeration="HashOp", tag="2")]
#[serde(default)]
pub prehash_key: i32,
#[prost(enumeration="HashOp", tag="3")]
pub prehash_value: i32,
#[prost(enumeration="LengthOp", tag="4")]
pub length: i32,
#[prost(bytes="vec", tag="5")]
#[serde(with = "crate::base64")]
#[cfg_attr(feature = "json-schema", schemars(with = "String"))]
pub prefix: ::prost::alloc::vec::Vec<u8>,
}
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[cfg_attr(feature = "json-schema", derive(::schemars::JsonSchema))]
#[derive(Eq)]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct InnerOp {
#[prost(enumeration="HashOp", tag="1")]
pub hash: i32,
#[prost(bytes="vec", tag="2")]
#[serde(with = "crate::base64")]
#[cfg_attr(feature = "json-schema", schemars(with = "String"))]
pub prefix: ::prost::alloc::vec::Vec<u8>,
#[prost(bytes="vec", tag="3")]
#[serde(with = "crate::base64")]
#[cfg_attr(feature = "json-schema", schemars(with = "String"))]
pub suffix: ::prost::alloc::vec::Vec<u8>,
}
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Eq)]
#[cfg_attr(feature = "json-schema", derive(::schemars::JsonSchema))]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ProofSpec {
#[prost(message, optional, tag="1")]
pub leaf_spec: ::core::option::Option<LeafOp>,
#[prost(message, optional, tag="2")]
pub inner_spec: ::core::option::Option<InnerSpec>,
#[prost(int32, tag="3")]
#[serde(default)]
pub max_depth: i32,
#[prost(int32, tag="4")]
#[serde(default)]
pub min_depth: i32,
}
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Eq)]
#[cfg_attr(feature = "json-schema", derive(::schemars::JsonSchema))]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct InnerSpec {
#[prost(int32, repeated, tag="1")]
pub child_order: ::prost::alloc::vec::Vec<i32>,
#[prost(int32, tag="2")]
pub child_size: i32,
#[prost(int32, tag="3")]
pub min_prefix_length: i32,
#[prost(int32, tag="4")]
pub max_prefix_length: i32,
#[prost(bytes="vec", tag="5")]
#[serde(default)]
#[serde(with = "crate::base64")]
#[cfg_attr(feature = "json-schema", schemars(with = "String"))]
pub empty_child: ::prost::alloc::vec::Vec<u8>,
#[prost(enumeration="HashOp", tag="6")]
pub hash: i32,
}
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct BatchProof {
#[prost(message, repeated, tag="1")]
pub entries: ::prost::alloc::vec::Vec<BatchEntry>,
}
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct BatchEntry {
#[prost(oneof="batch_entry::Proof", tags="1, 2")]
pub proof: ::core::option::Option<batch_entry::Proof>,
}
pub mod batch_entry {
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Clone, PartialEq, ::prost::Oneof)]
pub enum Proof {
#[prost(message, tag="1")]
Exist(super::ExistenceProof),
#[prost(message, tag="2")]
Nonexist(super::NonExistenceProof),
}
}
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct CompressedBatchProof {
#[prost(message, repeated, tag="1")]
pub entries: ::prost::alloc::vec::Vec<CompressedBatchEntry>,
#[prost(message, repeated, tag="2")]
pub lookup_inners: ::prost::alloc::vec::Vec<InnerOp>,
}
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct CompressedBatchEntry {
#[prost(oneof="compressed_batch_entry::Proof", tags="1, 2")]
pub proof: ::core::option::Option<compressed_batch_entry::Proof>,
}
pub mod compressed_batch_entry {
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Clone, PartialEq, ::prost::Oneof)]
pub enum Proof {
#[prost(message, tag="1")]
Exist(super::CompressedExistenceProof),
#[prost(message, tag="2")]
Nonexist(super::CompressedNonExistenceProof),
}
}
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct CompressedExistenceProof {
#[prost(bytes="vec", tag="1")]
pub key: ::prost::alloc::vec::Vec<u8>,
#[prost(bytes="vec", tag="2")]
pub value: ::prost::alloc::vec::Vec<u8>,
#[prost(message, optional, tag="3")]
pub leaf: ::core::option::Option<LeafOp>,
#[prost(int32, repeated, tag="4")]
pub path: ::prost::alloc::vec::Vec<i32>,
}
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct CompressedNonExistenceProof {
#[prost(bytes="vec", tag="1")]
pub key: ::prost::alloc::vec::Vec<u8>,
#[prost(message, optional, tag="2")]
pub left: ::core::option::Option<CompressedExistenceProof>,
#[prost(message, optional, tag="3")]
pub right: ::core::option::Option<CompressedExistenceProof>,
}
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Clone, Copy, Debug, PartialEq, Eq, Hash, PartialOrd, Ord, ::prost::Enumeration)]
#[repr(i32)]
pub enum HashOp {
NoHash = 0,
Sha256 = 1,
Sha512 = 2,
Keccak = 3,
Ripemd160 = 4,
Bitcoin = 5,
Sha512256 = 6,
}
impl HashOp {
pub fn as_str_name(&self) -> &'static str {
match self {
HashOp::NoHash => "NO_HASH",
HashOp::Sha256 => "SHA256",
HashOp::Sha512 => "SHA512",
HashOp::Keccak => "KECCAK",
HashOp::Ripemd160 => "RIPEMD160",
HashOp::Bitcoin => "BITCOIN",
HashOp::Sha512256 => "SHA512_256",
}
}
}
#[derive(::serde::Serialize, ::serde::Deserialize)]
#[derive(Clone, Copy, Debug, PartialEq, Eq, Hash, PartialOrd, Ord, ::prost::Enumeration)]
#[repr(i32)]
pub enum LengthOp {
NoPrefix = 0,
VarProto = 1,
VarRlp = 2,
Fixed32Big = 3,
Fixed32Little = 4,
Fixed64Big = 5,
Fixed64Little = 6,
Require32Bytes = 7,
Require64Bytes = 8,
}
impl LengthOp {
pub fn as_str_name(&self) -> &'static str {
match self {
LengthOp::NoPrefix => "NO_PREFIX",
LengthOp::VarProto => "VAR_PROTO",
LengthOp::VarRlp => "VAR_RLP",
LengthOp::Fixed32Big => "FIXED32_BIG",
LengthOp::Fixed32Little => "FIXED32_LITTLE",
LengthOp::Fixed64Big => "FIXED64_BIG",
LengthOp::Fixed64Little => "FIXED64_LITTLE",
LengthOp::Require32Bytes => "REQUIRE_32_BYTES",
LengthOp::Require64Bytes => "REQUIRE_64_BYTES",
}
}
}