Ownable2Step

Struct Ownable2Step 

Source
pub struct Ownable2Step { /* private fields */ }
Expand description

This module provides a straightforward access control feature that enables exclusive access to particular functions by an account, known as the owner. The account that initiates contract deployment is automatically assigned as the owner. However, ownership can be transferred later by using the transfer_ownership() and accept_ownership() functions.

You can use this module as a standalone contract or integrate it into a custom module by adding it as a field.

When used in a custom module, the only_owner() function is available, allowing you to restrict function usage to the owner.

Implementations§

Source§

impl Ownable2Step

Source

pub fn init(&mut self, owner: Address)

Initializes the module setting an owner as the initial owner.

Source

pub fn get_owner(&self) -> Address

Returns the address of the current owner.

Source

pub fn get_pending_owner(&self) -> Option<Address>

Returns the address of the pending owner.

Source

pub fn transfer_ownership(&mut self, new_owner: &Address)

Starts the ownership transfer of the module to a new_owner. Replaces the pending_ownerif there is one.

This function can only be accessed by the current owner of the module.

Source

pub fn renounce_ownership(&mut self)

If the contract’s owner chooses to renounce their ownership, the contract will no longer have an owner. This means that any functions that can only be accessed by the owner will no longer be available.

The function can only be called by the current owner, and it will permanently remove the owner’s privileges.

Source

pub fn accept_ownership(&mut self)

The new owner accepts the ownership transfer. Replaces the current owner and clears the pending owner.

Source

pub fn assert_owner(&self, address: &Address)

Reverts with if the function called by any account other than the owner.

Trait Implementations§

Source§

impl HasEntrypoints for Ownable2Step

Source§

fn entrypoints() -> Vec<Entrypoint>

Returns the list of contract’s entrypoints.
Source§

impl HasEvents for Ownable2Step

Source§

fn events() -> Vec<Event>

Returns a list of Events used by the contract.
Source§

fn event_schemas() -> BTreeMap<String, Schema>

Returns a map of event schemas used by the contract.
Source§

impl HasIdent for Ownable2Step

Source§

fn ident() -> String

Returns the contract’s ident.
Source§

impl Module for Ownable2Step

Source§

fn new(env: Rc<ContractEnv>) -> Self

Creates a new instance of the module with the given contract environment.
Source§

fn env(&self) -> Rc<ContractEnv>

Returns the contract environment associated with the module.
Source§

impl OdraContract for Ownable2Step

Source§

type HostRef = Ownable2StepHostRef

The host reference type.
Source§

type ContractRef = Ownable2StepContractRef

The contract reference type.
Source§

type InitArgs = Ownable2StepInitArgs

The init args type.
Source§

type UpgradeArgs = NoArgs

The upgrade args type.
Source§

impl SchemaCustomTypes for Ownable2Step

Source§

fn schema_types() -> Vec<Option<CustomType>>

Returns a vector of optional CustomTypes.
Source§

impl SchemaEntrypoints for Ownable2Step

Source§

fn schema_entrypoints() -> Vec<Entrypoint>

Returns a vector of Entrypoints.
Source§

impl SchemaErrors for Ownable2Step

Source§

fn schema_errors() -> Vec<UserError>

Returns a vector of UserErrors.
Source§

impl SchemaEvents for Ownable2Step

Source§

fn schema_events() -> Vec<Event>

Returns a vector of Events.
Source§

fn custom_types() -> Vec<Option<CustomType>>

Returns a vector of CustomTypes. Read more

Auto Trait Implementations§

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<R> Deployer<R> for R
where R: OdraContract,

Source§

fn deploy( env: &HostEnv, init_args: <R as OdraContract>::InitArgs, ) -> <R as OdraContract>::HostRef

Deploys a contract with given init args. Read more
Source§

fn try_deploy( env: &HostEnv, init_args: <R as OdraContract>::InitArgs, ) -> Result<<R as OdraContract>::HostRef, OdraError>

Tries to deploy a contract with given init args. Read more
Source§

fn deploy_with_cfg( env: &HostEnv, init_args: <R as OdraContract>::InitArgs, cfg: InstallConfig, ) -> <R as OdraContract>::HostRef

Deploys a contract with given init args and configuration. Read more
Source§

fn try_deploy_with_cfg( env: &HostEnv, init_args: <R as OdraContract>::InitArgs, cfg: InstallConfig, ) -> Result<<R as OdraContract>::HostRef, OdraError>

Tries to deploy a contract with given init args and configuration. Read more
Source§

fn try_upgrade( env: &HostEnv, contract_to_upgrade: Address, upgrade_args: <R as OdraContract>::UpgradeArgs, ) -> Result<<R as OdraContract>::HostRef, OdraError>

Tries to upgrade a contract with given init args.
Source§

fn try_upgrade_with_cfg( env: &HostEnv, contract_to_upgrade: Address, upgrade_args: <R as OdraContract>::UpgradeArgs, cfg: UpgradeConfig, ) -> Result<<R as OdraContract>::HostRef, OdraError>

Tries to upgrade a contract with given init args and configuration
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> HostRefLoader<<T as OdraContract>::HostRef> for T
where T: OdraContract,

Source§

fn load(env: &HostEnv, address: Address) -> <T as OdraContract>::HostRef

Loads an existing contract from the host environment.
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> Revertible for T
where T: Module,

Source§

fn revert<E>(&self, error: E) -> !
where E: Into<OdraError>,

Reverts the contract execution with the given error.
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

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

Source§

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