Struct pallet_msa::pallet::Pallet

source ·
pub struct Pallet<T>(/* private fields */);
Expand description

The Pallet struct, the main type that implements traits and standalone functions within the pallet.

Implementations§

source§

impl<T: Config> Pallet<T>

source

pub fn create(origin: OriginFor<T>) -> DispatchResult

Creates an MSA for the Origin (sender of the transaction). Origin is assigned an MSA ID.

Events
Errors
source

pub fn create_sponsored_account_with_delegation( origin: OriginFor<T>, delegator_key: T::AccountId, proof: MultiSignature, add_provider_payload: AddProvider ) -> DispatchResult

Origin MSA creates an MSA on behalf of delegator_key, creates a Delegation with the delegator_key’s MSA as the Delegator and origin as Provider. Deposits events MsaCreated and DelegationGranted.

Remarks
  • Origin MUST be the provider
  • Signatures should be over the AddProvider struct
Events
Errors
source

pub fn create_provider( origin: OriginFor<T>, provider_name: Vec<u8> ) -> DispatchResult

Adds an association between MSA id and ProviderRegistryEntry. As of now, the only piece of metadata we are recording is provider name.

Events
Errors
source

pub fn grant_delegation( origin: OriginFor<T>, delegator_key: T::AccountId, proof: MultiSignature, add_provider_payload: AddProvider ) -> DispatchResult

Creates a new Delegation for an existing MSA, with origin as the Provider and delegator_key is the delegator. Since it is being sent on the Delegator’s behalf, it requires the Delegator to authorize the new Delegation.

Remarks
  • Origin MUST be the provider
  • Signatures should be over the AddProvider struct
Events
Errors
source

pub fn revoke_delegation_by_delegator( origin: OriginFor<T>, provider_msa_id: MessageSourceId ) -> DispatchResult

Delegator (Origin) MSA terminates a delegation relationship with the Provider MSA. Deposits eventDelegationRevoked.

Events
Errors
source

pub fn add_public_key_to_msa( origin: OriginFor<T>, msa_owner_public_key: T::AccountId, msa_owner_proof: MultiSignature, new_key_owner_proof: MultiSignature, add_key_payload: AddKeyData<T> ) -> DispatchResult

Adds a new public key to an existing Message Source Account (MSA). This functionality enables the MSA owner to manage multiple keys for their account or rotate keys for enhanced security.

The origin parameter represents the account from which the function is called and can be either the MSA owner’s account or a delegated provider’s account, depending on the intended use.

The function requires two signatures: msa_owner_proof and new_key_owner_proof, which serve as proofs of ownership for the existing MSA and the new public key account, respectively. This ensures that a new key cannot be added without permission of both the MSA owner and the owner of the new key.

The necessary information for the key addition, the new public key and the MSA ID, is contained in the add_key_payload parameter of type AddKeyData. It also contains an expiration block number for both proofs, ensuring they are valid and must be greater than the current block.

Events
Errors
source

pub fn delete_msa_public_key( origin: OriginFor<T>, public_key_to_delete: T::AccountId ) -> DispatchResult

Remove a key associated with an MSA by expiring it at the current block.

Remarks
  • Removal of key deletes the association of the key with the MSA.
  • The key can be re-added to same or another MSA if needed.
Events
Errors
source

pub fn revoke_delegation_by_provider( origin: OriginFor<T>, delegator: MessageSourceId ) -> DispatchResult

Provider MSA terminates Delegation with a Delegator MSA by expiring the Delegation at the current block.

Events
Errors
source

pub fn revoke_schema_permissions( origin: OriginFor<T>, provider_msa_id: MessageSourceId, schema_ids: Vec<SchemaId> ) -> DispatchResult

👎Deprecated since 1.3.0: revoke_schema_permissions() has been deprecated.

Revokes a list of schema permissions to a provider. Attempting to revoke a Schemas that have already been revoked are ignored.

Events
Errors
  • NoKeyExists - If there is not MSA for origin.
  • DelegationNotFound - If there is not delegation relationship between Origin and Delegator or Origin and Delegator are the same.
  • SchemaNotGranted - If attempting to revoke a schema that has not previously been granted.
source

pub fn retire_msa(origin: OriginFor<T>) -> DispatchResult

Retires a MSA

When a user wants to disassociate themselves from Frequency, they can retire their MSA for free provided that: (1) They own the MSA (2) The MSA is not a registered provider. (3) They retire their user handle (if they have one) (4) There is only one account key (5) The user has already deleted all delegations to providers

This does not currently remove any messages related to the MSA.

Events
Errors
source

pub fn propose_to_be_provider( origin: OriginFor<T>, provider_name: Vec<u8> ) -> DispatchResult

Propose to be a provider. Creates a proposal for council approval to create a provider from a MSA

Errors
source

pub fn create_provider_via_governance( origin: OriginFor<T>, provider_key: T::AccountId, provider_name: Vec<u8> ) -> DispatchResult

Create a provider by means of governance approval

Events
Errors
source§

impl<T: Config> Pallet<T>

source

pub fn create_account<F>( key: T::AccountId, on_success: F ) -> Result<(MessageSourceId, T::AccountId), DispatchError>
where F: FnOnce(MessageSourceId) -> DispatchResult,

source

pub fn get_next_msa_id() -> Result<MessageSourceId, DispatchError>

Generate the next MSA Id

Errors
source

pub fn set_msa_identifier(identifier: MessageSourceId) -> DispatchResult

Set the current identifier in storage

source

pub fn create_registered_provider( provider_id: ProviderId, name: BoundedVec<u8, T::MaxProviderNameSize> ) -> DispatchResult

Create Register Provider

source

pub fn grant_permissions_for_schemas( delegator_id: DelegatorId, provider_id: ProviderId, schema_ids: Vec<SchemaId> ) -> DispatchResult

Adds a list of schema permissions to a delegation relationship.

source

pub fn revoke_permissions_for_schemas( delegator_id: DelegatorId, provider_id: ProviderId, schema_ids: Vec<SchemaId> ) -> DispatchResult

Revokes a list of schema permissions from a delegation relationship.

source

pub fn add_key<F>( msa_id: MessageSourceId, key: &T::AccountId, on_success: F ) -> DispatchResult
where F: FnOnce(MessageSourceId) -> DispatchResult,

source

pub fn ensure_all_schema_ids_are_valid( schema_ids: &Vec<SchemaId> ) -> DispatchResult

source

pub fn is_registered_provider(msa_id: MessageSourceId) -> bool

Returns if provider is registered by checking if the ProviderToRegistryEntry contains the MSA id

source

pub fn ensure_valid_registered_provider( delegator_key: &T::AccountId, provider_key: &T::AccountId ) -> Result<(ProviderId, DelegatorId), DispatchError>

Checks that a provider and delegator keys are valid and that a provider and delegator are not the same and that a provider has authorized a delegator to create a delegation relationship.

Errors
source

pub fn ensure_msa_owner( who: &T::AccountId, msa_id: MessageSourceId ) -> DispatchResult

Checks that the MSA for who is the same as msa_id

Errors
source

pub fn verify_signature( signature: &MultiSignature, signer: &T::AccountId, payload: Vec<u8> ) -> DispatchResult

Verify the signature was signed by signer on payload by a wallet Note the wrap_binary_data follows the Polkadot wallet pattern of wrapping with <Byte> tags.

Errors
source

pub fn add_provider( provider_id: ProviderId, delegator_id: DelegatorId, schema_ids: Vec<SchemaId> ) -> DispatchResult

Add a provider to a delegator with the default permissions

Errors
source

pub fn upsert_schema_permissions( provider_id: ProviderId, delegator_id: DelegatorId, schema_ids: Vec<SchemaId> ) -> DispatchResult

Modify delegation’s schema permissions

Errors
source

pub fn create_provider_for( provider_msa_id: MessageSourceId, provider_name: Vec<u8> ) -> DispatchResult

Adds an association between MSA id and ProviderRegistryEntry. As of now, the only piece of metadata we are recording is provider name.

Events
Errors
source

pub fn try_mutate_delegation<R, E: From<DispatchError>>( delegator_id: DelegatorId, provider_id: ProviderId, f: impl FnOnce(&mut Delegation<SchemaId, BlockNumberFor<T>, T::MaxSchemaGrantsPerDelegation>, bool) -> Result<R, E> ) -> Result<R, E>

Mutates the delegation relationship storage item only when the supplied function returns an ‘Ok()’ result. The callback function ‘f’ takes the value (a delegation) and a reference to a boolean variable. This callback sets the boolean variable to ‘true’ if the value is to be inserted and to ‘false’ if it is to be updated.

source

pub fn delete_key_for_msa( msa_id: MessageSourceId, key: &T::AccountId ) -> DispatchResult

Deletes a key associated with a given MSA

Errors
source

pub fn revoke_provider( provider_id: ProviderId, delegator_id: DelegatorId ) -> DispatchResult

Revoke the grant for permissions from the delegator to the provider

Errors
source

pub fn get_owner_of(key: &T::AccountId) -> Option<MessageSourceId>

Retrieves the MSA Id for a given AccountId

source

pub fn ensure_valid_msa_key( key: &T::AccountId ) -> Result<MessageSourceId, DispatchError>

Retrieve MSA Id associated with key or return NoKeyExists

source

pub fn get_granted_schemas_by_msa_id( delegator: DelegatorId, provider: Option<ProviderId> ) -> Result<Vec<DelegationResponse<SchemaId, BlockNumberFor<T>>>, DispatchError>

Get a list of Schema Ids that a provider has been granted access to

Errors
source

pub fn register_signature( signature: &MultiSignature, signature_expires_at: BlockNumberFor<T> ) -> DispatchResult

Adds a signature to the PayloadSignatureRegistryList Check that mortality_block is within bounds. If so, proceed and add the new entry. Raises SignatureAlreadySubmitted if the signature exists in the registry. Raises SignatureRegistryLimitExceeded if the oldest signature of the list has not yet expired.

Example list:

  • 1,2 (oldest)
  • 2,3
  • 3,4
  • 4 (newest in pointer storage)`
Errors

Trait Implementations§

source§

impl<T: Config> BeforeAllRuntimeMigrations for Pallet<T>

source§

fn before_all_runtime_migrations() -> Weight

Something that should happen before runtime migrations are executed.
source§

impl<T: Config> BlockNumberProvider for Pallet<T>

§

type BlockNumber = <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number

Type of BlockNumber to provide.
source§

fn current_block_number() -> Self::BlockNumber

Returns the current block number. Read more
§

fn set_block_number(_block: Self::BlockNumber)

Utility function only to be used in benchmarking scenarios or tests, to be implemented optionally, else a noop. Read more
source§

impl<T: Config> Callable<T> for Pallet<T>

source§

impl<T> Clone for Pallet<T>

source§

fn clone(&self) -> Self

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<T> Debug for Pallet<T>

source§

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

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

impl<T: Config> DelegationValidator for Pallet<T>

source§

fn ensure_valid_delegation( provider_id: ProviderId, delegator_id: DelegatorId, block_number: Option<BlockNumberFor<T>> ) -> Result<Delegation<SchemaId, BlockNumberFor<T>, T::MaxSchemaGrantsPerDelegation>, DispatchError>

Check that the delegator has an active delegation to the provider. block_number: Provide None to know if the delegation is active at the current block. Provide Some(N) to know if the delegation was or will be active at block N.

Errors
§

type BlockNumber = <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number

Type for block number.
§

type MaxSchemaGrantsPerDelegation = <T as Config>::MaxSchemaGrantsPerDelegation

Type for maximum number of schemas that can be granted to a provider.
§

type SchemaId = u16

Schema Id is the unique identifier for a Schema
source§

impl<T: Config> GetStorageVersion for Pallet<T>

§

type InCodeStorageVersion = StorageVersion

This type is generated by the pallet macro. Read more
source§

fn in_code_storage_version() -> Self::InCodeStorageVersion

Returns the in-code storage version as specified in the storage_version attribute, or [NoStorageVersionSet] if the attribute is missing.
source§

fn on_chain_storage_version() -> StorageVersion

Returns the storage version of the pallet as last set in the actual on-chain storage.
§

fn current_storage_version() -> Self::InCodeStorageVersion

👎Deprecated: This method has been renamed to in_code_storage_version and will be removed after March 2024.
DEPRECATED: Use [Self::current_storage_version] instead. Read more
source§

impl<T: Config> Hooks<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>

source§

fn on_initialize(_block_number: BlockNumberFor<T>) -> Weight

Block initialization hook. This is called at the very beginning of block execution. Read more
source§

fn offchain_worker(block_number: BlockNumberFor<T>)

Implementing this function on a pallet allows you to perform long-running tasks that are dispatched as separate threads, and entirely independent of the main blockchain execution. Read more
§

fn on_finalize(_n: BlockNumber)

Block finalization hook. This is called at the very end of block execution. Read more
§

fn on_idle(_n: BlockNumber, _remaining_weight: Weight) -> Weight

Hook to consume a block’s idle time. This will run when the block is being finalized (before [Hooks::on_finalize]). Read more
§

fn on_poll(_n: BlockNumber, _weight: &mut WeightMeter)

A hook to run logic after inherent application. Read more
§

fn on_runtime_upgrade() -> Weight

Hook executed when a code change (aka. a “runtime upgrade”) is detected by the FRAME Executive pallet. Read more
§

fn integrity_test()

Check the integrity of this pallet’s configuration. Read more
source§

impl<T: Config> IntegrityTest for Pallet<T>

source§

fn integrity_test()

See [Hooks::integrity_test].
source§

impl<T: Config> MsaLookup for Pallet<T>

§

type AccountId = <T as Config>::AccountId

The association between key and MSA
source§

fn get_msa_id(key: &Self::AccountId) -> Option<MessageSourceId>

Gets the MSA Id associated with this AccountId if any
source§

impl<T: Config> MsaValidator for Pallet<T>

§

type AccountId = <T as Config>::AccountId

The association between key and MSA
source§

fn ensure_valid_msa_key( key: &T::AccountId ) -> Result<MessageSourceId, DispatchError>

Check that a key is associated to an MSA and returns key information. Returns a [DispatchError] if there is no MSA associated with the key
source§

impl<T: Config> OffchainWorker<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>

source§

fn offchain_worker(n: BlockNumberFor<T>)

This function is being called after every block import (when fully synced). Read more
source§

impl<T: Config> OnFinalize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>

source§

fn on_finalize(n: BlockNumberFor<T>)

See [Hooks::on_finalize].
source§

impl<T: Config> OnGenesis for Pallet<T>

source§

fn on_genesis()

Something that should happen at genesis.
source§

impl<T: Config> OnIdle<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>

source§

fn on_idle(n: BlockNumberFor<T>, remaining_weight: Weight) -> Weight

See [Hooks::on_idle].
source§

impl<T: Config> OnInitialize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>

source§

fn on_initialize(n: BlockNumberFor<T>) -> Weight

See [Hooks::on_initialize].
source§

impl<T: Config> OnPoll<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>

source§

fn on_poll(n: BlockNumberFor<T>, weight: &mut WeightMeter)

Code to execute every now and then at the beginning of the block after inherent application. Read more
source§

impl<T: Config> OnRuntimeUpgrade for Pallet<T>

source§

fn on_runtime_upgrade() -> Weight

See [Hooks::on_runtime_upgrade].
source§

impl<T: Config> PalletInfoAccess for Pallet<T>

source§

fn index() -> usize

Index of the pallet as configured in the runtime.
source§

fn name() -> &'static str

Name of the pallet as configured in the runtime.
source§

fn name_hash() -> [u8; 16]

Two128 hash of name.
source§

fn module_name() -> &'static str

Name of the Rust module containing the pallet.
source§

fn crate_version() -> CrateVersion

Version of the crate containing the pallet.
source§

impl<T: Config> PalletsInfoAccess for Pallet<T>

source§

fn count() -> usize

The number of pallets’ information that this type represents. Read more
source§

fn infos() -> Vec<PalletInfoData>

All of the pallets’ information that this type represents.
source§

impl<T> PartialEq for Pallet<T>

source§

fn eq(&self, other: &Self) -> 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<T: Config> ProviderLookup for Pallet<T>

§

type BlockNumber = <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number

Type for block number.
§

type MaxSchemaGrantsPerDelegation = <T as Config>::MaxSchemaGrantsPerDelegation

Type for maximum number of schemas that can be granted to a provider.
§

type SchemaId = u16

Schema Id is the unique identifier for a Schema
source§

fn get_delegation_of( delegator: DelegatorId, provider: ProviderId ) -> Option<Delegation<SchemaId, Self::BlockNumber, Self::MaxSchemaGrantsPerDelegation>>

Gets the relationship information for this delegator, provider pair
source§

impl<T: Config> SchemaGrantValidator<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>

source§

fn ensure_valid_schema_grant( provider: ProviderId, delegator: DelegatorId, schema_id: SchemaId, block_number: BlockNumberFor<T> ) -> DispatchResult

Check if provider is allowed to publish for a given schema_id for a given delegator

Errors
source§

impl<T: Config> StorageInfoTrait for Pallet<T>

source§

fn storage_info() -> Vec<StorageInfo>

source§

impl<T: Config> TargetValidator for Pallet<T>

source§

fn validate(target: MessageSourceId) -> bool

Checks if an MSA is a valid target.
source§

impl<T: Config> WhitelistedStorageKeys for Pallet<T>

source§

fn whitelisted_storage_keys() -> Vec<TrackedStorageKey>

Returns a Vec<TrackedStorageKey> indicating the storage keys that should be whitelisted during benchmarking. This means that those keys will be excluded from the benchmarking performance calculation.
source§

impl<T> Eq for Pallet<T>

Auto Trait Implementations§

§

impl<T> RefUnwindSafe for Pallet<T>
where T: RefUnwindSafe,

§

impl<T> Send for Pallet<T>
where T: Send,

§

impl<T> Sync for Pallet<T>
where T: Sync,

§

impl<T> Unpin for Pallet<T>
where T: Unpin,

§

impl<T> UnwindSafe for Pallet<T>
where T: 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> 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
§

impl<T> CheckedConversion for T

§

fn checked_from<T>(t: T) -> Option<Self>
where Self: TryFrom<T>,

Convert from a value of T into an equivalent instance of Option<Self>. Read more
§

fn checked_into<T>(self) -> Option<T>
where Self: TryInto<T>,

Consume self to return Some equivalent value of Option<T>. Read more
§

impl<T> Conv for T

§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
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

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

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

§

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

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

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

§

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

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

impl<T> FmtForward for T

§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

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

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

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
§

impl<T, U> IntoKey<U> for T
where U: FromKey<T>,

§

fn into_key(self) -> U

§

impl<T> IsType<T> for T

§

fn from_ref(t: &T) -> &T

Cast reference.
§

fn into_ref(&self) -> &T

Cast reference.
§

fn from_mut(t: &mut T) -> &mut T

Cast mutable reference.
§

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

Cast mutable reference.
§

impl<T, Outer> IsWrappedBy<Outer> for T
where Outer: AsRef<T> + AsMut<T> + From<T>, T: From<Outer>,

§

fn from_ref(outer: &Outer) -> &T

Get a reference to the inner from the outer.

§

fn from_mut(outer: &mut Outer) -> &mut T

Get a mutable reference to the inner from the outer.

§

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

§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

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

Initializes a with the given initializer. Read more
§

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

Dereferences the given pointer. Read more
§

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

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

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

impl<T> Same for T

§

type Output = T

Should always be Self
§

impl<T> SaturatedConversion for T

§

fn saturated_from<T>(t: T) -> Self
where Self: UniqueSaturatedFrom<T>,

Convert from a value of T into an equivalent instance of Self. Read more
§

fn saturated_into<T>(self) -> T
where Self: UniqueSaturatedInto<T>,

Consume self to return an equivalent value of T. Read more
§

impl<T> Tap for T

§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
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
§

impl<T> TryConv for T

§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. 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.
§

impl<T, U> TryIntoKey<U> for T
where U: TryFromKey<T>,

§

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

§

fn try_into_key(self) -> Result<U, <U as TryFromKey<T>>::Error>

§

impl<S, T> UncheckedInto<T> for S
where T: UncheckedFrom<S>,

§

fn unchecked_into(self) -> T

The counterpart to unchecked_from.
§

impl<T, S> UniqueSaturatedInto<T> for S
where T: Bounded, S: TryInto<T>,

§

fn unique_saturated_into(self) -> T

Consume self to return an equivalent value of T.
§

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

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

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

impl<T> JsonSchemaMaybe for T

§

impl<T> MaybeDebug for T
where T: Debug,

§

impl<T> MaybeRefUnwindSafe for T
where T: RefUnwindSafe,

§

impl<T> Member for T
where T: Send + Sync + Debug + Eq + PartialEq + Clone + 'static,