pub struct Consignment<const TYPE: bool> {
    pub version: ContainerVer,
    pub transfer: bool,
    pub schema: SubSchema,
    pub ifaces: TinyOrdMap<IfaceId, IfacePair>,
    pub supplements: TinyOrdSet<ContractSuppl>,
    pub genesis: Genesis,
    pub terminals: SmallOrdSet<Terminal>,
    pub bundles: LargeVec<AnchoredBundle>,
    pub extensions: LargeVec<Extension>,
    pub attachments: SmallOrdMap<AttachId, MediumBlob>,
    pub signatures: TinyOrdMap<ContentId, ContentSigs>,
    /* private fields */
}
Expand description

Consignment represents contract-specific data, always starting with genesis, which must be valid under client-side-validation rules (i.e. internally consistent and properly committed into the commitment layer, like bitcoin blockchain or current state of the lightning channel).

All consignments-related procedures, including validation or merging consignments data into stash or schema-specific data storage, must start with endpoints and process up to the genesis. If any of the nodes within the consignments are not part of the paths connecting endpoints with the genesis, consignments validation will return [validation::Warning::ExcessiveNode] warning.

Fields§

§version: ContainerVer

Version.

§transfer: bool

Specifies whether the consignment contains information about state transfer (true), or it is just a consignment with an information about a contract.

§schema: SubSchema

Schema (plus root schema, if any) under which contract is issued.

§ifaces: TinyOrdMap<IfaceId, IfacePair>

Interfaces supported by the contract.

§supplements: TinyOrdSet<ContractSuppl>

Known supplements.

§genesis: Genesis

Genesis data.

§terminals: SmallOrdSet<Terminal>

Set of seals which are history terminals.

§bundles: LargeVec<AnchoredBundle>

Data on all anchored state transitions contained in the consignments.

§extensions: LargeVec<Extension>

Data on all state extensions contained in the consignments.

§attachments: SmallOrdMap<AttachId, MediumBlob>

Data containers coming with this consignment. For the purposes of in-memory consignments we are restricting the size of the containers to 24 bit value (RGB allows containers up to 32-bit values in size).

§signatures: TinyOrdMap<ContentId, ContentSigs>

Signatures on the pieces of content which are the part of the consignment.

Implementations§

source§

impl<const TYPE: bool> Consignment<TYPE>

source

pub fn new(schema: SubSchema, genesis: Genesis) -> Self

Panics

If the provided schema is not the one which is used by genesis.

source

pub fn schema_id(&self) -> SchemaId

source

pub fn root_schema_id(&self) -> Option<SchemaId>

source

pub fn contract_id(&self) -> ContractId

source

pub fn anchored_bundle(&self, bundle_id: BundleId) -> Option<&AnchoredBundle>

source

pub fn validation_status(&self) -> Option<&Status>

source

pub fn into_validation_status(self) -> Option<Status>

source

pub fn update_history<R: ResolveHeight>( &self, history: Option<&ContractHistory>, resolver: &mut R ) -> Result<ContractHistory, R::Error>

source

pub fn reveal_bundle_seal(&mut self, bundle_id: BundleId, revealed: GraphSeal)

source

pub fn into_contract(self) -> Contract

source§

impl Consignment<true>

source

pub fn transfer_id(&self) -> TransferId

source§

impl<const TYPE: bool> Consignment<TYPE>

source

pub fn validate<R: ResolveTx>( self, resolver: &mut R ) -> Result<Consignment<TYPE>, Consignment<TYPE>>

Trait Implementations§

source§

impl<const TYPE: bool> Clone for Consignment<TYPE>

source§

fn clone(&self) -> Consignment<TYPE>

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<const TYPE: bool> ConsignmentApi for Consignment<TYPE>

§

type BundleIter<'container> where Self: 'container = Iter<'container, AnchoredBundle>

source§

fn schema(&self) -> &SubSchema

source§

fn operation(&self, opid: OpId) -> Option<OpRef<'_>>

Retrieves reference to a operation (genesis, state transition or state extension) matching the provided id, or None otherwise
source§

fn genesis(&self) -> &Genesis

Contract genesis.
source§

fn transition(&self, opid: OpId) -> Option<&Transition>

Returns reference to a state transition, if known, matching the provided id. If id is unknown, or corresponds to other type of the operation (genesis or state extensions) a error is returned. Read more
source§

fn extension(&self, opid: OpId) -> Option<&Extension>

Returns reference to a state extension, if known, matching the provided id. If id is unknown, or corresponds to other type of the operation (genesis or state transition) a error is returned. Read more
source§

fn terminals(&self) -> BTreeSet<(BundleId, SecretSeal)>

The final state (“endpoints”) provided by this consignment. Read more
source§

fn anchored_bundles(&self) -> Self::BundleIter<'_>

Data on all anchored state transitions contained in the consignment
source§

fn bundle_by_id(&self, bundle_id: BundleId) -> Option<&TransitionBundle>

source§

fn op_ids_except(&self, ids: &BTreeSet<OpId>) -> BTreeSet<OpId>

source§

fn has_operation(&self, opid: OpId) -> bool

source§

fn known_transitions_by_bundle_id( &self, bundle_id: BundleId ) -> Option<Vec<&Transition>>

source§

impl<const TYPE: bool> Debug for Consignment<TYPE>

source§

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

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

impl<'de, const TYPE: bool> Deserialize<'de> for Consignment<TYPE>

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl<const TYPE: bool> Serialize for Consignment<TYPE>

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl<const TYPE: bool> StrictDecode for Consignment<TYPE>

source§

fn strict_decode(reader: &mut impl TypedRead) -> Result<Self, DecodeError>

source§

impl<const TYPE: bool> StrictDeserialize for Consignment<TYPE>

source§

fn from_strict_serialized<const MAX: usize>( ast_data: Confined<Vec<u8, Global>, 0, MAX> ) -> Result<Self, DeserializeError>

source§

fn strict_deserialize_from_file<const MAX: usize>( path: impl AsRef<Path> ) -> Result<Self, DeserializeError>

source§

impl<const TYPE: bool> StrictDumb for Consignment<TYPE>

source§

fn strict_dumb() -> Self

source§

impl<const TYPE: bool> StrictEncode for Consignment<TYPE>

source§

fn strict_encode<W: TypedWrite>(&self, writer: W) -> Result<W>

source§

impl<const TYPE: bool> StrictSerialize for Consignment<TYPE>

source§

impl<const TYPE: bool> StrictStruct for Consignment<TYPE>

source§

impl<const TYPE: bool> StrictType for Consignment<TYPE>

source§

const STRICT_LIB_NAME: &'static str = LIB_NAME_RGB_STD

source§

fn strict_name() -> Option<TypeName>

source§

impl<const TYPE: bool> StrictProduct for Consignment<TYPE>

Auto Trait Implementations§

§

impl<const TYPE: bool> RefUnwindSafe for Consignment<TYPE>

§

impl<const TYPE: bool> Send for Consignment<TYPE>

§

impl<const TYPE: bool> Sync for Consignment<TYPE>

§

impl<const TYPE: bool> Unpin for Consignment<TYPE>

§

impl<const TYPE: bool> UnwindSafe for Consignment<TYPE>

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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, U> Into<U> for Twhere 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> ToOwned for Twhere 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 Twhere 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 Twhere 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.
§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

§

fn vzip(self) -> V

source§

impl<T> DeserializeOwned for Twhere T: for<'de> Deserialize<'de>,