Struct spawn_access_control::RoleManager

source ·
pub struct RoleManager { /* private fields */ }
Expand description

§RoleManager: A Library for Managing Ownership and Roles in WASM

RoleManager provides a secure mechanism to manage ownership, roles, and access control in WebAssembly (WASM) environments.

§Features:

  • Ownership transfer
  • Role assignment and removal
  • Role-based access control (RBAC)

§Usage:

RoleManager is designed to manage contract ownership and roles, ensuring only authorized users can perform certain actions.

§Example

let mut role_manager = RoleManager::new("admin");
role_manager.assign_role("admin", "editor", "user1").unwrap();
assert!(role_manager.has_role("editor", "user1"));

Implementations§

source§

impl RoleManager

source

pub fn new(owner: &str) -> RoleManager

Creates a new RoleManager with the specified owner.

§Arguments
  • owner - A string slice that holds the initial owner of the contract.
§Example
let manager = RoleManager::new("admin");
source

pub fn get_owner(&self) -> String

Returns the current owner of the contract.

§Example
let owner = role_manager.get_owner();
source

pub fn transfer_ownership( &mut self, current_owner: &str, new_owner: &str, ) -> Result<(), String>

Transfers ownership to a new user.

Only the current owner can transfer ownership.

§Arguments
  • current_owner - The current owner’s ID.
  • new_owner - The new owner’s ID.
§Returns
  • Ok(()) on success.
  • Err with a message if the current owner is incorrect.
source

pub fn assign_role( &mut self, owner: &str, role: &str, user: &str, ) -> Result<(), String>

Assigns a role to a user.

Only the current owner can assign roles.

§Arguments
  • owner - The current owner’s ID.
  • role - The role to be assigned (e.g., “admin”).
  • user - The user who will receive the role.
§Returns
  • Ok(()) on success.
  • Err if the user already has the role or if the owner is incorrect.
source

pub fn remove_role( &mut self, owner: &str, role: &str, user: &str, ) -> Result<(), String>

Removes a role from a user.

Only the current owner can remove roles.

§Arguments
  • owner - The current owner’s ID.
  • role - The role to be removed.
  • user - The user from whom the role will be removed.
§Returns
  • Ok(()) on success.
  • Err if the user doesn’t have the role or if the owner is incorrect.
source

pub fn has_role(&self, role: &str, user: &str) -> bool

Checks if a user has a specific role.

§Arguments
  • role - The role to check (e.g., “admin”).
  • user - The user to check.
§Returns
  • true if the user has the role.
  • false if the user does not have the role.
source

pub fn is_owner(&self, user: &str) -> Result<bool, String>

Verifies if a user is the owner.

§Arguments
  • user - The user to check.
§Returns
  • Ok(true) if the user is the owner.
  • Err with a message if the user is not the owner.
source

pub fn role_based_access(&self, user: &str, role: &str) -> bool

Provides role-based access control.

§Arguments
  • user - The user requesting access.
  • role - The required role for access.
§Returns
  • true if the user is the owner or has the role.
  • false otherwise.
source

pub fn list_role_users(&self, role: &str) -> Vec<String>

Lists all users for a given role.

§Arguments
  • role - The role to list users for.
§Returns
  • A Vec<String> containing all users with the specified role.

Trait Implementations§

source§

impl From<RoleManager> for JsValue

source§

fn from(value: RoleManager) -> Self

Converts to this type from the input type.
source§

impl FromWasmAbi for RoleManager

source§

type Abi = u32

The wasm ABI type that this converts from when coming back out from the ABI boundary.
source§

unsafe fn from_abi(js: u32) -> Self

Recover a Self from Self::Abi. Read more
source§

impl IntoWasmAbi for RoleManager

source§

type Abi = u32

The wasm ABI type that this converts into when crossing the ABI boundary.
source§

fn into_abi(self) -> u32

Convert self into Self::Abi so that it can be sent across the wasm ABI boundary.
source§

impl LongRefFromWasmAbi for RoleManager

source§

type Abi = u32

Same as RefFromWasmAbi::Abi
source§

type Anchor = RcRef<RoleManager>

Same as RefFromWasmAbi::Anchor
source§

unsafe fn long_ref_from_abi(js: Self::Abi) -> Self::Anchor

Same as RefFromWasmAbi::ref_from_abi
source§

impl OptionFromWasmAbi for RoleManager

source§

fn is_none(abi: &Self::Abi) -> bool

Tests whether the argument is a “none” instance. If so it will be deserialized as None, and otherwise it will be passed to FromWasmAbi.
source§

impl OptionIntoWasmAbi for RoleManager

source§

fn none() -> Self::Abi

Returns an ABI instance indicating “none”, which JS will interpret as the None branch of this option. Read more
source§

impl RefFromWasmAbi for RoleManager

source§

type Abi = u32

The wasm ABI type references to Self are recovered from.
source§

type Anchor = RcRef<RoleManager>

The type that holds the reference to Self for the duration of the invocation of the function that has an &Self parameter. This is required to ensure that the lifetimes don’t persist beyond one function call, and so that they remain anonymous.
source§

unsafe fn ref_from_abi(js: Self::Abi) -> Self::Anchor

Recover a Self::Anchor from Self::Abi. Read more
source§

impl RefMutFromWasmAbi for RoleManager

source§

type Abi = u32

Same as RefFromWasmAbi::Abi
source§

type Anchor = RcRefMut<RoleManager>

Same as RefFromWasmAbi::Anchor
source§

unsafe fn ref_mut_from_abi(js: Self::Abi) -> Self::Anchor

Same as RefFromWasmAbi::ref_from_abi
source§

impl TryFromJsValue for RoleManager

source§

type Error = JsValue

The type returned in the event of a conversion error.
source§

fn try_from_js_value(value: JsValue) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl VectorFromWasmAbi for RoleManager

source§

type Abi = <Box<[JsValue]> as FromWasmAbi>::Abi

source§

unsafe fn vector_from_abi(js: Self::Abi) -> Box<[RoleManager]>

source§

impl VectorIntoJsValue for RoleManager

source§

impl VectorIntoWasmAbi for RoleManager

source§

impl WasmDescribe for RoleManager

source§

impl WasmDescribeVector for RoleManager

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<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> ReturnWasmAbi for T
where T: IntoWasmAbi,

source§

type Abi = <T as IntoWasmAbi>::Abi

Same as IntoWasmAbi::Abi
source§

fn return_abi(self) -> <T as ReturnWasmAbi>::Abi

Same as IntoWasmAbi::into_abi, except that it may throw and never return in the case of Err.
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.