Struct ContainerId

Source
pub struct ContainerId(/* private fields */);
Expand description

Unique data container identifier

Trait Implementations§

Source§

impl AsMut<<ContainerId as Wrapper>::Inner> for ContainerId

Source§

fn as_mut(&mut self) -> &mut <Self as Wrapper>::Inner

Converts this type into a mutable reference of the (usually inferred) input type.
Source§

impl AsRef<<ContainerId as Wrapper>::Inner> for ContainerId

Source§

fn as_ref(&self) -> &<Self as Wrapper>::Inner

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl Borrow<<ContainerId as Wrapper>::Inner> for ContainerId

Source§

fn borrow(&self) -> &<Self as Wrapper>::Inner

Immutably borrows from an owned value. Read more
Source§

impl Borrow<[u8]> for ContainerId

Source§

fn borrow(&self) -> &[u8]

Immutably borrows from an owned value. Read more
Source§

impl BorrowMut<<ContainerId as Wrapper>::Inner> for ContainerId

Source§

fn borrow_mut(&mut self) -> &mut <Self as Wrapper>::Inner

Mutably borrows from an owned value. Read more
Source§

impl Clone for ContainerId

Source§

fn clone(&self) -> ContainerId

Returns a duplicate of the value. Read more
1.0.0 · Source§

const fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<Msg> CommitVerify<Msg, PrehashedProtocol> for ContainerId
where Msg: AsRef<[u8]>,

Source§

fn commit(msg: &Msg) -> ContainerId

Creates a commitment to a byte representation of a given message
Source§

fn verify(&self, msg: &Msg) -> bool

Verifies commitment against the message; default implementation just repeats the commitment to the message and check it against the self.
Source§

impl Debug for ContainerId

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for ContainerId

Source§

fn default() -> ContainerId

Returns the “default value” for a type. Read more
Source§

impl Deref for ContainerId

Source§

type Target = <ContainerId as Wrapper>::Inner

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.
Source§

impl DerefMut for ContainerId

Source§

fn deref_mut(&mut self) -> &mut Self::Target

Mutably dereferences the value.
Source§

impl Display for ContainerId

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl From<ContainerId> for Hash<ContainerIdTag>

Source§

fn from(wrapped: ContainerId) -> Self

Converts to this type from the input type.
Source§

impl From<Hash<ContainerIdTag>> for ContainerId

Source§

fn from(v: Hash<ContainerIdTag>) -> Self

Converts to this type from the input type.
Source§

impl FromStr for ContainerId

Source§

type Err = Error

The associated error which can be returned from parsing.
Source§

fn from_str(s: &str) -> Result<Self, Self::Err>

Parses a string s to return a value of this type. Read more
Source§

impl Hash for ContainerId

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl Ord for ContainerId

Source§

fn cmp(&self, other: &ContainerId) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl PartialEq for ContainerId

Source§

fn eq(&self, other: &ContainerId) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

const fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialOrd for ContainerId

Source§

fn partial_cmp(&self, other: &ContainerId) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl Strategy for ContainerId

Source§

type Strategy = UsingStrict

Specific strategy. List of supported strategies: Read more
Source§

impl Strategy for ContainerId

Source§

const HRP: &'static str = STORM_CONTAINER_ID_HRP

Bech32 HRP prefix used by a type
Source§

type Strategy = UsingStrictEncoding

Specific strategy used for automatic implementation of all Bech32-related traits.
Source§

impl StrictDecode for ContainerId

Source§

fn strict_decode<D: Read>(d: D) -> Result<Self, Error>

Decode with the given std::io::Read instance; must either construct an instance or return implementation-specific error type.
Source§

fn strict_deserialize(data: impl AsRef<[u8]>) -> Result<Self, Error>

Tries to deserialize byte array into the current type using StrictDecode::strict_decode. If there are some data remains in the buffer once deserialization is completed, fails with Error::DataNotEntirelyConsumed. Use io::Cursor over the buffer and StrictDecode::strict_decode to avoid such failures.
Source§

fn strict_file_load(path: impl AsRef<Path>) -> Result<Self, Error>

Reads data from file at path and reconstructs object from it. Fails with Error::DataNotEntirelyConsumed if file contains remaining data after the object reconstruction.
Source§

impl StrictEncode for ContainerId

Source§

fn strict_encode<E: Write>(&self, e: E) -> Result<usize, Error>

Encode with the given std::io::Write instance; must return result with either amount of bytes encoded – or implementation-specific error type.
Source§

fn strict_serialize(&self) -> Result<Vec<u8>, Error>

Serializes data as a byte array using StrictEncode::strict_encode function
Source§

fn strict_file_save(&self, path: impl AsRef<Path>) -> Result<usize, Error>

Saves data to a file at a given path. If the file does not exists, attempts to create the file. If the file already exists, it gets truncated.
Source§

impl Wrapper for ContainerId

Source§

type Inner = Hash<ContainerIdTag>

Inner type wrapped by the current newtype
Source§

fn from_inner(inner: Self::Inner) -> Self

Instantiates wrapper type with the inner data
Source§

fn as_inner(&self) -> &Self::Inner

Returns reference to the inner representation for the wrapper type
Source§

fn as_inner_mut(&mut self) -> &mut Self::Inner

Returns a mutable reference to the inner representation for the wrapper type
Source§

fn into_inner(self) -> Self::Inner

Unwraps the wrapper returning the inner type
Source§

fn to_inner(&self) -> Self::Inner

Clones inner data of the wrapped type and return them
Source§

fn copy(&self) -> Self
where Self: Sized, Self::Inner: Copy,

Copies the wrapped type
Source§

impl Copy for ContainerId

Source§

impl Eq for ContainerId

Source§

impl StructuralPartialEq for ContainerId

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> CommitEncode for T

Source§

fn commit_encode<E>(&self, e: E) -> usize
where E: Write,

Encodes the data for the commitment by writing them directly into a io::Write writer instance
Source§

fn commit_serialize(&self) -> Vec<u8>

Serializes data for the commitment in-memory into a newly allocated array
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, Tag> FromBech32IdStr<Tag> for T
where T: HashType<Tag>, Tag: Tag,

Source§

fn from_bech32_id_str(s: &str) -> Result<T, Error>

Reconstructs the identifier type from the provided Bech32 id1... string
Source§

impl<T> FromBech32Str for T

Source§

const HRP: &'static str = T::HRP

Specifies which HRP is used by Bech32 string representing this data type
Source§

fn from_bech32_str(s: &str) -> Result<T, Error>

Constructs type from the provided Bech32 string, or fails with Error
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<H, Tag> TaggedHash<Tag> for H
where H: Wrapper<Inner = Hash<Tag>>, Tag: Tag + 'static,

Source§

fn hash(msg: impl AsRef<[u8]>) -> Self

Constructs tagged hash out of a given message data
Source§

fn from_hash(hash: impl Hash<Inner = [u8; 32]>) -> Self

Constructs tagged hash out of other hash type. Read more
Source§

fn from_hex(hex: &str) -> Result<Self, Error>

Constructs tagged hash from a given hexadecimal string
Source§

fn from_bytes(slice: impl AsRef<[u8]>) -> Result<Self, Error>

Constructs tagged hash from byte slice. If slice length is not equal to 32 bytes, fails with Error::InvalidLength (this is just a wrapper for sha256t::Hash::from_slice).
Source§

fn from_array(array: [u8; 32]) -> Self

Constructs tagged hash type from a fixed-size array of 32 bytes.
Source§

fn from_engine(engine: HashEngine) -> Self

Constructs tagged hash type from a hash engine.
Source§

fn as_slice(&self) -> &[u8]

Returns a reference to a slice representing internal hash data
Source§

fn into_array(self) -> [u8; 32]

Converts to a 32-byte slice array representing internal hash data
Source§

fn into_sha356t(self) -> Hash<Tag>

Converts current tagged hash type into a base sha256t::Hash type
Source§

fn into_sha256(self) -> Hash

Converts tagged hash type into basic SHA256 hash
Source§

fn to_vec(self) -> Vec<u8>

Constructs vector representation of the data in tagged hash
Source§

impl<T, Tag> ToBech32IdString<Tag> for T
where T: HashType<Tag>, Tag: Tag,

Source§

fn to_bech32_id_string(&self) -> String

Returns Bech32-encoded string in form of id1... representing the type
Source§

impl<T> ToBech32String for T

Source§

fn to_bech32_string(&self) -> String

Creates Bech32 string with appropriate type data representation
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> VerifyEq for T
where T: Eq,

Source§

fn verify_eq(&self, other: &T) -> bool

Verifies commit-equivalence of two instances of the same type.