Struct odra_modules::access::Ownable

source ·
pub struct Ownable { /* 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() function.

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 Ownable

source

pub fn init(&mut self)

Initializes the module setting the caller as the initial owner.

source

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

Transfers ownership of the module to new_owner. 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 get_owner(&self) -> Address

Returns the address of the current owner.

source

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

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

source

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

Returns the optional address of the current owner.

source

pub fn unchecked_transfer_ownership(&mut self, new_owner: Option<Address>)

Unchecked version of the ownership transfer. It emits an event and sets the new owner.

Trait Implementations§

source§

impl HasEntrypoints for Ownable

source§

fn entrypoints() -> Vec<Entrypoint>

Returns the list of contract’s entrypoints.
source§

impl HasEvents for Ownable

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 Ownable

source§

fn ident() -> String

Returns the contract’s ident.
source§

impl Module for Ownable

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 SchemaCustomTypes for Ownable

source§

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

Returns a vector of optional CustomTypes.
source§

impl SchemaEntrypoints for Ownable

source§

fn schema_entrypoints() -> Vec<Entrypoint>

Returns a vector of Entrypoints.
source§

impl SchemaErrors for Ownable

source§

fn schema_errors() -> Vec<UserError>

Returns a vector of UserErrors.
source§

impl SchemaEvents for Ownable

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§

§

impl Freeze for Ownable

§

impl !RefUnwindSafe for Ownable

§

impl !Send for Ownable

§

impl !Sync for Ownable

§

impl Unpin for Ownable

§

impl !UnwindSafe for Ownable

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

source§

fn from(t: T) -> T

Returns the argument unchanged.

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

§

type Output = T

Should always be Self
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.