Enum miden_objects::assets::Asset

source ·
pub enum Asset {
    Fungible(FungibleAsset),
    NonFungible(NonFungibleAsset),
}
Expand description

A fungible or a non-fungible asset.

All assets are encoded using a single word (4 elements) such that it is easy to determine the type of an asset both inside and outside Miden VM. Specifically: Element 1 will be:

  • ZERO for a fungible asset
  • non-ZERO for a non-fungible asset The 3rd most significant bit will be:
  • 1 for a fungible asset
  • 0 for a non-fungible asset

The above properties guarantee that there can never be a collision between a fungible and a non-fungible asset.

The methodology for constructing fungible and non-fungible assets is described below.

§Fungible assets

The most significant element of a fungible asset is set to the ID of the faucet which issued the asset. This guarantees the properties described above (the 3rd most significant bit is ONE).

The least significant element is set to the amount of the asset. This amount cannot be greater than 2^63 - 1 and thus requires 63-bits to store.

Elements 1 and 2 are set to ZERO.

It is impossible to find a collision between two fungible assets issued by different faucets as the faucet_id is included in the description of the asset and this is guaranteed to be different for each faucet as per the faucet creation logic.

§Non-fungible assets

The 4 elements of non-fungible assets are computed as follows:

  • First the asset data is hashed. This compresses an asset of an arbitrary length to 4 field elements: [d0, d1, d2, d3].
  • d1 is then replaced with the faucet_id which issues the asset: [d0, faucet_id, d2, d3].
  • Lastly, the 3rd most significant bit of d3 is set to ZERO.

It is impossible to find a collision between two non-fungible assets issued by different faucets as the faucet_id is included in the description of the non-fungible asset and this is guaranteed to be different as per the faucet creation logic. Collision resistance for non-fungible assets issued by the same faucet is ~2^95.

Variants§

§

Fungible(FungibleAsset)

§

NonFungible(NonFungibleAsset)

Implementations§

source§

impl Asset

source

pub fn is_same(&self, other: &Self) -> bool

Returns true if this asset is the same as the specified asset.

Two assets are defined to be the same if:

  • For fungible assets, if they were issued by the same faucet.
  • For non-fungible assets, if the assets are identical.
source

pub const fn is_fungible(&self) -> bool

Returns true if this asset is a fungible asset.

source

pub fn faucet_id(&self) -> AccountId

Returns ID of the faucet which issued this asset.

source

pub fn vault_key(&self) -> Word

Returns the key which is used to store this asset in the account vault.

source

pub fn unwrap_fungible(&self) -> FungibleAsset

Returns the inner fungible asset, or panics if the asset is not fungible.

source

pub fn unwrap_non_fungible(&mut self) -> NonFungibleAsset

Returns the inner non-fungible asset, or panics if the asset is fungible.

Trait Implementations§

source§

impl Clone for Asset

source§

fn clone(&self) -> Asset

Returns a copy of the value. Read more
1.0.0 · source§

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

Performs copy-assignment from source. Read more
source§

impl Debug for Asset

source§

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

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

impl Deserializable for Asset

source§

fn read_from<R: ByteReader>( source: &mut R ) -> Result<Self, DeserializationError>

Reads a sequence of bytes from the provided source, attempts to deserialize these bytes into Self, and returns the result. Read more
source§

fn read_from_bytes(bytes: &[u8]) -> Result<Self, DeserializationError>

Attempts to deserialize the provided bytes into Self and returns the result. Read more
source§

impl From<&Asset> for Word

source§

fn from(value: &Asset) -> Self

Converts to this type from the input type.
source§

impl From<&Asset> for [u8; 32]

source§

fn from(value: &Asset) -> Self

Converts to this type from the input type.
source§

impl From<Asset> for Word

source§

fn from(asset: Asset) -> Self

Converts to this type from the input type.
source§

impl From<Asset> for [u8; 32]

source§

fn from(asset: Asset) -> Self

Converts to this type from the input type.
source§

impl From<FungibleAsset> for Asset

source§

fn from(asset: FungibleAsset) -> Self

Converts to this type from the input type.
source§

impl From<NonFungibleAsset> for Asset

source§

fn from(asset: NonFungibleAsset) -> Self

Converts to this type from the input type.
source§

impl PartialEq for Asset

source§

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

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

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

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Serializable for Asset

source§

fn write_into<W: ByteWriter>(&self, target: &mut W)

Serializes self into bytes and writes these bytes into the target.
source§

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

Serializes self into a vector of bytes.
source§

fn get_size_hint(&self) -> usize

Returns an estimate of how many bytes are needed to represent self. Read more
source§

impl TryFrom<&[BaseElement; 4]> for Asset

§

type Error = AssetError

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

fn try_from(value: &Word) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl TryFrom<&[u8; 32]> for Asset

§

type Error = AssetError

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

fn try_from(value: &[u8; 32]) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl TryFrom<[BaseElement; 4]> for Asset

§

type Error = AssetError

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

fn try_from(value: Word) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl TryFrom<[u8; 32]> for Asset

§

type Error = AssetError

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

fn try_from(value: [u8; 32]) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl Copy for Asset

source§

impl Eq for Asset

source§

impl StructuralPartialEq for Asset

Auto Trait Implementations§

§

impl Freeze for Asset

§

impl RefUnwindSafe for Asset

§

impl Send for Asset

§

impl Sync for Asset

§

impl Unpin for Asset

§

impl UnwindSafe for Asset

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> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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<T> Same for T

§

type Output = T

Should always be Self
source§

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

§

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, U> TryFrom<U> for T
where U: Into<T>,

§

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>,

§

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<V, T> VZip<V> for T
where V: MultiLane<T>,

source§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more