surrealdb/iam/entities/
roles.rsuse crate::iam::Error;
use crate::sql::Ident;
use cedar_policy::{Entity, EntityTypeName, EntityUid, RestrictedExpression};
use revision::revisioned;
use serde::{Deserialize, Serialize};
use std::str::FromStr;
#[derive(Hash, Clone, Default, Debug, Eq, PartialEq, PartialOrd, Serialize, Deserialize)]
#[revisioned(revision = 1)]
pub enum Role {
#[default]
Viewer,
Editor,
Owner,
}
impl std::fmt::Display for Role {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
match self {
Self::Viewer => write!(f, "Viewer"),
Self::Editor => write!(f, "Editor"),
Self::Owner => write!(f, "Owner"),
}
}
}
impl FromStr for Role {
type Err = Error;
fn from_str(s: &str) -> Result<Self, Self::Err> {
match s.to_ascii_lowercase().as_str() {
"viewer" => Ok(Self::Viewer),
"editor" => Ok(Self::Editor),
"owner" => Ok(Self::Owner),
_ => Err(Error::InvalidRole(s.to_string())),
}
}
}
impl std::convert::From<&str> for Role {
fn from(s: &str) -> Self {
Self::from_str(s).unwrap()
}
}
impl std::convert::From<String> for Role {
fn from(s: String) -> Self {
Self::from_str(&s).unwrap()
}
}
impl std::convert::From<&Ident> for Role {
fn from(id: &Ident) -> Self {
Role::from_str(id).unwrap()
}
}
impl std::convert::From<Role> for Ident {
fn from(role: Role) -> Self {
role.to_string().into()
}
}
impl std::convert::From<&Role> for EntityUid {
fn from(role: &Role) -> Self {
EntityUid::from_type_name_and_id(
EntityTypeName::from_str("Role").unwrap(),
format!("{}", role).parse().unwrap(),
)
}
}
impl std::convert::From<&Role> for Entity {
fn from(role: &Role) -> Self {
Entity::new(role.into(), Default::default(), Default::default())
}
}
impl std::convert::From<&Role> for RestrictedExpression {
fn from(role: &Role) -> Self {
format!("{}", EntityUid::from(role)).parse().unwrap()
}
}