Enum hdi::flat_op::OpRecord

source ·
pub enum OpRecord<ET: UnitEnum, LT> {
Show 18 variants CreateEntry { app_entry: ET, action: Create, }, CreatePrivateEntry { app_entry_type: <ET as UnitEnum>::Unit, action: Create, }, CreateAgent { agent: AgentPubKey, action: Create, }, CreateCapClaim { action: Create, }, CreateCapGrant { action: Create, }, UpdateEntry { original_action_hash: ActionHash, original_entry_hash: EntryHash, app_entry: ET, action: Update, }, UpdatePrivateEntry { original_action_hash: ActionHash, original_entry_hash: EntryHash, app_entry_type: <ET as UnitEnum>::Unit, action: Update, }, UpdateAgent { original_key: AgentPubKey, new_key: AgentPubKey, original_action_hash: ActionHash, action: Update, }, UpdateCapClaim { original_action_hash: ActionHash, original_entry_hash: EntryHash, action: Update, }, UpdateCapGrant { original_action_hash: ActionHash, original_entry_hash: EntryHash, action: Update, }, DeleteEntry { original_action_hash: ActionHash, original_entry_hash: EntryHash, action: Delete, }, CreateLink { base_address: AnyLinkableHash, target_address: AnyLinkableHash, tag: LinkTag, link_type: LT, action: CreateLink, }, DeleteLink { original_action_hash: ActionHash, base_address: AnyLinkableHash, action: DeleteLink, }, Dna { dna_hash: DnaHash, action: Dna, }, OpenChain { previous_dna_hash: DnaHash, action: OpenChain, }, CloseChain { new_dna_hash: DnaHash, action: CloseChain, }, AgentValidationPkg { membrane_proof: Option<MembraneProof>, action: AgentValidationPkg, }, InitZomesComplete { action: InitZomesComplete, },
}
Expand description

Data specific to the [Op::StoreRecord] operation.

Variants§

§

CreateEntry

This operation stores the [Record] for an app defined entry type.

Fields

§app_entry: ET

The app defined entry type with the deserialized [Entry] data.

§action: Create

The Create action that creates the entry

§

CreatePrivateEntry

This operation stores the [Record] for an app defined private entry type.

Fields

§app_entry_type: <ET as UnitEnum>::Unit

The unit version of the app defined entry type. Note it is not possible to deserialize the full entry type here because we don’t have the [Entry] data.

§action: Create

The Create action that creates the entry

§

CreateAgent

This operation stores the [Record] for an AgentPubKey that has been created.

Fields

§agent: AgentPubKey

The agent that was created

§action: Create

The Create action that creates the entry

§

CreateCapClaim

This operation stores the [Record] for a Capability Claim that has been created.

Fields

§action: Create

The Create action that creates the [crate::CapClaim]

§

CreateCapGrant

This operation stores the [Record] for a Capability Grant that has been created.

Fields

§action: Create

The Create action that creates the [crate::CapGrant]

§

UpdateEntry

This operation stores the [Record] for an updated app defined entry type.

Fields

§original_action_hash: ActionHash

The hash of the [Action] that created the original entry

§original_entry_hash: EntryHash

The hash of the original entry

§app_entry: ET

The app defined entry type with the deserialized [Entry] data from the new entry. Note the new entry type is always the same as the original entry type however the data may have changed.

§action: Update

The Update action that updates the entry

§

UpdatePrivateEntry

This operation stores the [Record] for an updated app defined private entry type.

Fields

§original_action_hash: ActionHash

The hash of the [Action] that created the original entry

§original_entry_hash: EntryHash

The hash of the original entry

§app_entry_type: <ET as UnitEnum>::Unit

The unit version of the app defined entry type. Note the new entry type is always the same as the original entry type however the data may have changed.

§action: Update

The Update action that updates the entry

§

UpdateAgent

This operation stores the [Record] for an updated AgentPubKey.

Fields

§original_key: AgentPubKey

The original AgentPubKey.

§new_key: AgentPubKey

The new AgentPubKey.

§original_action_hash: ActionHash

The hash of the [Action] that created the original key

§action: Update

The Update action that updates the entry

§

UpdateCapClaim

This operation stores the [Record] for an updated Capability Claim.

Fields

§original_action_hash: ActionHash

The hash of the [Action] that created the original [crate::CapClaim]

§original_entry_hash: EntryHash

The hash of the original [crate::CapClaim]

§action: Update

The Update action that updates the [crate::CapClaim]

§

UpdateCapGrant

This operation stores the [Record] for an updated Capability Grant.

Fields

§original_action_hash: ActionHash

The hash of the [Action] that created the original [crate::CapGrant]

§original_entry_hash: EntryHash

The hash of the original [crate::CapGrant]

§action: Update

The Update action that updates the [crate::CapGrant]

§

DeleteEntry

This operation stores the [Record] for a deleted app defined entry type.

Fields

§original_action_hash: ActionHash

The hash of the [Action] that created the original entry

§original_entry_hash: EntryHash

The hash of the original entry

§action: Delete

The Delete action that creates the entry

This operation stores the [Record] for a new link.

Fields

§base_address: AnyLinkableHash

The base address of the link.

§target_address: AnyLinkableHash

The target address of the link.

§tag: LinkTag

The link’s tag.

§link_type: LT

The app defined link type of this link.

§action: CreateLink

The CreateLink action that creates this link

This operation stores the [Record] for a deleted link and contains the original link’s [Action] hash.

Fields

§original_action_hash: ActionHash

The deleted links CreateLink [Action].

§base_address: AnyLinkableHash

The base address where this link is stored. This is the base address of the link that is being deleted.

§action: DeleteLink

The DeleteLink action that deletes the link

§

Dna

This operation stores the [Record] for an [Action::Dna].

Fields

§dna_hash: DnaHash

The hash of the DNA

§action: Dna

The Dna action

§

OpenChain

This operation stores the [Record] for an [Action::OpenChain] and contains the previous chains’s DnaHash.

Fields

§previous_dna_hash: DnaHash

Hash of the previous DNA that we are migrating from

§action: OpenChain

The OpenChain action

§

CloseChain

This operation stores the [Record] for an [Action::CloseChain] and contains the new chains’s DnaHash.

Fields

§new_dna_hash: DnaHash

Hash of the new DNA that we are migrating to

§action: CloseChain

The CloseChain action

§

AgentValidationPkg

This operation stores the [Record] for an [Action::AgentValidationPkg] and contains the membrane proof if there is one.

Fields

§membrane_proof: Option<MembraneProof>

The membrane proof proving that the agent is allowed to participate in this DNA

§

InitZomesComplete

This operation stores the [Record] for an [Action::InitZomesComplete].

Fields

Trait Implementations§

source§

impl<ET: Clone + UnitEnum, LT: Clone> Clone for OpRecord<ET, LT>

source§

fn clone(&self) -> OpRecord<ET, LT>

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<ET: Debug + UnitEnum, LT: Debug> Debug for OpRecord<ET, LT>

source§

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

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

impl<ET: PartialEq + UnitEnum, LT: PartialEq> PartialEq for OpRecord<ET, LT>

source§

fn eq(&self, other: &OpRecord<ET, LT>) -> 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<ET: Eq + UnitEnum, LT: Eq> Eq for OpRecord<ET, LT>

source§

impl<ET: UnitEnum, LT> StructuralPartialEq for OpRecord<ET, LT>

Auto Trait Implementations§

§

impl<ET, LT> Freeze for OpRecord<ET, LT>
where ET: Freeze, <ET as UnitEnum>::Unit: Freeze, LT: Freeze,

§

impl<ET, LT> RefUnwindSafe for OpRecord<ET, LT>

§

impl<ET, LT> Send for OpRecord<ET, LT>
where ET: Send, <ET as UnitEnum>::Unit: Send, LT: Send,

§

impl<ET, LT> Sync for OpRecord<ET, LT>
where ET: Sync, <ET as UnitEnum>::Unit: Sync, LT: Sync,

§

impl<ET, LT> Unpin for OpRecord<ET, LT>
where ET: Unpin, <ET as UnitEnum>::Unit: Unpin, LT: Unpin,

§

impl<ET, LT> UnwindSafe for OpRecord<ET, LT>
where ET: UnwindSafe, <ET as UnitEnum>::Unit: UnwindSafe, LT: UnwindSafe,

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

§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
source§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
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§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

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

impl<F, W, T, D> Deserialize<With<T, W>, D> for F
where W: DeserializeWith<F, T, D>, D: Fallible + ?Sized, F: ?Sized,

source§

fn deserialize( &self, deserializer: &mut D, ) -> Result<With<T, W>, <D as Fallible>::Error>

Deserializes using the given deserializer
source§

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

source§

fn __clone_box(&self, _: Private) -> *mut ()

source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
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> IntoEither for T

source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
source§

impl<T> LayoutRaw for T

source§

fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>

Gets the layout of the type.
source§

impl<T> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Pointee for T

§

type Metadata = ()

The type for metadata in pointers and references to Self.
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<T> Upcastable for T
where T: Any + Send + Sync + 'static,

source§

fn upcast_any_ref(&self) -> &(dyn Any + 'static)

upcast ref
source§

fn upcast_any_mut(&mut self) -> &mut (dyn Any + 'static)

upcast mut ref
source§

fn upcast_any_box(self: Box<T>) -> Box<dyn Any>

upcast boxed dyn
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