Generic holochain mixin to include administrator and dynamic roles in any holochain application, using the progenitor pattern.
This mixin is built to target hc v0.0.42-alpha3
. It also depends on the holochain_anchors to be present and configured.
Known issue: due to updated entries not being propagated, this mixin won't actually work in a real environtment, since it depends on an update on the role entry to be propagated througout the network.
Here is the design for this mixin: https://hackmd.io/6xfwfSVYSGeZe3vQ_-1cWw?view.
Here you can find the documentation for this mixin: https://docs.rs/hcrolesmixin.
Add the following to your zomes cargo toml.
holochain_anchors = "0.2.1"
holochain_roles = "0.1.0"
Add the anchor entry definition to your zome.
rust
#[entry_def]
fn anchor_def() -> ValidatingEntryType {
holochain_anchors::anchor_definition()
}
Add the roles entry definition to your zome.
rust
#[entry_def]
fn roles_def() -> ValidatingEntryType {
holochain_roles::role_entry_def()
}
To assign a role, simply call the assign_role
function:
```rust
fn someotherpublicfunction(agentaddress: Address) { let myrolename = String::from("editor");
hc_roles_mixin::handlers::assign_role(&my_role_name, &agent_address)?;
...
} ```
Only agents that have the administrator role or the progenitor of the DNA can assign or unassign roles.
To assign an administrator role, call the assign_role
function with the imported administrator role name:
```rust
fn someotherpublicfunction(agentaddress: Address) { let myrolename = String::from(holochainroles::ADMINROLE_NAME);
hc_roles_mixin::handlers::assign_role(&my_role_name, &agent_address)?;
...
} ```
To check if a user has a certain role, you can use the validation has_agent_role
function:
```rust
validation: | validationdata: hdk::EntryValidationData
if !is_agent_permitted_to_create_this_entry {
return Err(String::from("Only editors can create a new entry"));
}
...
}
}
} ```
To get all role assignments for a certain agent, you can use the validation get_agent_roles
function:
```rust
fn somepublicfunction(agentaddress: Address) {
let roles: Vec
To get all role assignments for a certain agent, you can use the validation get_role_agents
function:
```rust
fn somepublicfunction(rolename: String) { let agents: Vec = hcrolesmixin::handlers::getroleagents(&rolename)?; } ```
To check if a user has a certain role, you can use the validation has_agent_role
function:
```rust
validation: | validationdata: hdk::EntryValidationData
if !is_agent_permitted_to_create_this_entry {
return Err(String::from("Only editors can create a new entry"));
}
...
}
}
} ```
To unassign a role, simply call the unassign_role
function:
```rust
fn someotherpublicfunction(agentaddress: Address) { let myrolename = String::from("editor");
hc_roles_mixin::handlers::unassign_role(&my_role_name, &agent_address)?;
...
} ```