spawn-wasm-erc721 0.1.4

A Rust library for creating ERC-721 compliant Non-Fungible Tokens (NFTs) with WebAssembly (WASM) support.
Documentation
# spawn-wasm-erc721

`spawn-wasm-erc721` is a Rust library designed to handle ownership and user roles for smart contracts in a WebAssembly (WASM) environment. This library provides essential functionality for role management, including assigning roles to users, checking role-based access, and transferring ownership.

## Features

- **Ownership Management**: Enables ownership transfer and ensures that only the owner can perform sensitive actions like role assignments.
- **Role-based Access Control**: Allows access to contract methods based on assigned roles.
- **WASM Compatibility**: Designed to work seamlessly in WebAssembly, allowing for easy integration into JavaScript-based environments.
- **Event Logging**: Logs important events like ownership transfers and role assignments to the browser console for easier debugging.

## Installation

To use the library, first add the following dependencies to your `Cargo.toml` file:

```toml
[dependencies]
wasm-bindgen = "0.2"
web-sys = { version = "0.3", features = ["console"] }
```

Also, ensure the following settings are added to your Cargo.toml for WebAssembly compilation:

```toml
[lib]
crate-type = ["cdylib"]

[profile.release]
lto = true

[package.metadata.wasm-pack.profile.release]
wasm-opt = ["-Oz"]
```
## Usage
Initialize RoleManager
To initialize the RoleManager struct with an owner:

```rust
use spawn_wasm_erc721::RoleManager;

let owner = "owner1".to_string();
let mut role_manager = RoleManager::new(owner);
```

## Assign a Role
Assign a role to a user, ensuring the caller is the owner:

```rust
role_manager.assign_role("owner1".to_string(), "admin".to_string(), "user1".to_string());
```

## Check Role-Based Access
Check if a user has access based on a specific role:

```rust
let has_access = role_manager.role_based_access("user1".to_string(), "admin".to_string());
```

## Transfer Ownership
Ownership can only be transferred by the current owner:

```rust
role_manager.transfer_ownership("owner1".to_string(), "new_owner".to_string());
```

## List Role Users
To list all users with a specific role:

```rust
let users = role_manager.list_role_users("admin".to_string());
```