pub struct DidLayer<M, I> {
pub launcher_id: Bytes32,
pub recovery_list_hash: Option<Bytes32>,
pub num_verifications_required: u64,
pub metadata: M,
pub inner_puzzle: I,
}Expand description
The DID Layer keeps track of metadata and handles recovery capabilities.
It’s typically an inner layer of the SingletonLayer.
Fields§
§launcher_id: Bytes32The unique launcher id for the DID. Also referred to as the DID id.
recovery_list_hash: Option<Bytes32>The tree hash of an optional list of recovery DIDs.
num_verifications_required: u64The number of verifications required to recover the DID.
metadata: MMetadata associated with the DID. This is often just () for DIDs without metadata.
inner_puzzle: IThe inner puzzle layer, commonly used for determining ownership.
Implementations§
Trait Implementations§
source§impl<M, I> Layer for DidLayer<M, I>
impl<M, I> Layer for DidLayer<M, I>
source§type Solution = DidSolution<<I as Layer>::Solution>
type Solution = DidSolution<<I as Layer>::Solution>
Most of the time, this is an actual CLVM type representing the solution.
However, you can also use a helper struct and customize
Layer::construct_solution and Layer::parse_solution.source§fn parse_puzzle(
allocator: &Allocator,
puzzle: Puzzle,
) -> Result<Option<Self>, DriverError>
fn parse_puzzle( allocator: &Allocator, puzzle: Puzzle, ) -> Result<Option<Self>, DriverError>
Parses this layer from the given puzzle, returning
None if the puzzle doesn’t match.
An error is returned if the puzzle should have matched but couldn’t be parsed.source§fn parse_solution(
allocator: &Allocator,
solution: NodePtr,
) -> Result<Self::Solution, DriverError>
fn parse_solution( allocator: &Allocator, solution: NodePtr, ) -> Result<Self::Solution, DriverError>
Parses the
Layer::Solution type from a CLVM solution pointer.source§fn construct_puzzle(
&self,
ctx: &mut SpendContext,
) -> Result<NodePtr, DriverError>
fn construct_puzzle( &self, ctx: &mut SpendContext, ) -> Result<NodePtr, DriverError>
Constructs the full curried puzzle for this layer.
Ideally, the puzzle itself should be cached in the
SpendContext.source§fn construct_solution(
&self,
ctx: &mut SpendContext,
solution: Self::Solution,
) -> Result<NodePtr, DriverError>
fn construct_solution( &self, ctx: &mut SpendContext, solution: Self::Solution, ) -> Result<NodePtr, DriverError>
Constructs the full solution for this layer.
Can be used to construct the solution from a helper struct, if it’s not directly a CLVM type.
It’s also possible to influence the solution based on the puzzle, if needed.
source§fn construct_spend(
&self,
ctx: &mut SpendContext,
solution: Self::Solution,
) -> Result<Spend, DriverError>
fn construct_spend( &self, ctx: &mut SpendContext, solution: Self::Solution, ) -> Result<Spend, DriverError>
Creates a spend for this layer.
source§fn construct_coin_spend(
&self,
ctx: &mut SpendContext,
coin: Coin,
solution: Self::Solution,
) -> Result<CoinSpend, DriverError>
fn construct_coin_spend( &self, ctx: &mut SpendContext, coin: Coin, solution: Self::Solution, ) -> Result<CoinSpend, DriverError>
Creates a coin spend for this layer.
source§impl<M, I> ToTreeHash for DidLayer<M, I>where
M: ToTreeHash,
I: ToTreeHash,
impl<M, I> ToTreeHash for DidLayer<M, I>where
M: ToTreeHash,
I: ToTreeHash,
impl<M: Copy, I: Copy> Copy for DidLayer<M, I>
impl<M: Eq, I: Eq> Eq for DidLayer<M, I>
impl<M, I> StructuralPartialEq for DidLayer<M, I>
Auto Trait Implementations§
impl<M, I> Freeze for DidLayer<M, I>
impl<M, I> RefUnwindSafe for DidLayer<M, I>where
M: RefUnwindSafe,
I: RefUnwindSafe,
impl<M, I> Send for DidLayer<M, I>
impl<M, I> Sync for DidLayer<M, I>
impl<M, I> Unpin for DidLayer<M, I>
impl<M, I> UnwindSafe for DidLayer<M, I>where
M: UnwindSafe,
I: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit)