surrealpatch/lib/src/iam/token.rs
Salvador Girones Gil 998b263517
[iam] RBAC and multiple root users (#2176)
Co-authored-by: Przemyslaw Hugh Kaznowski <hughkaznowski@protonmail.com>
Co-authored-by: Tobie Morgan Hitchcock <tobie@surrealdb.com>
2023-07-29 18:47:25 +00:00

110 lines
3.2 KiB
Rust

use crate::sql::Object;
use crate::sql::Value;
use jsonwebtoken::{Algorithm, Header};
use once_cell::sync::Lazy;
use serde::{Deserialize, Serialize};
pub static HEADER: Lazy<Header> = Lazy::new(|| Header::new(Algorithm::HS512));
#[derive(Debug, Default, Serialize, Deserialize, Clone)]
pub struct Claims {
#[serde(skip_serializing_if = "Option::is_none")]
pub iat: Option<i64>,
#[serde(skip_serializing_if = "Option::is_none")]
pub nbf: Option<i64>,
#[serde(skip_serializing_if = "Option::is_none")]
pub exp: Option<i64>,
#[serde(skip_serializing_if = "Option::is_none")]
pub iss: Option<String>,
#[serde(alias = "ns")]
#[serde(alias = "NS")]
#[serde(rename = "NS")]
#[serde(alias = "https://surrealdb.com/ns")]
#[serde(alias = "https://surrealdb.com/namespace")]
#[serde(skip_serializing_if = "Option::is_none")]
pub ns: Option<String>,
#[serde(alias = "db")]
#[serde(alias = "DB")]
#[serde(rename = "DB")]
#[serde(alias = "https://surrealdb.com/db")]
#[serde(alias = "https://surrealdb.com/database")]
#[serde(skip_serializing_if = "Option::is_none")]
pub db: Option<String>,
#[serde(alias = "sc")]
#[serde(alias = "SC")]
#[serde(rename = "SC")]
#[serde(alias = "https://surrealdb.com/sc")]
#[serde(alias = "https://surrealdb.com/scope")]
#[serde(skip_serializing_if = "Option::is_none")]
pub sc: Option<String>,
#[serde(alias = "tk")]
#[serde(alias = "TK")]
#[serde(rename = "TK")]
#[serde(alias = "https://surrealdb.com/tk")]
#[serde(alias = "https://surrealdb.com/token")]
#[serde(skip_serializing_if = "Option::is_none")]
pub tk: Option<String>,
#[serde(alias = "id")]
#[serde(alias = "ID")]
#[serde(rename = "ID")]
#[serde(alias = "https://surrealdb.com/id")]
#[serde(alias = "https://surrealdb.com/record")]
#[serde(skip_serializing_if = "Option::is_none")]
pub id: Option<String>,
#[serde(alias = "rl")]
#[serde(alias = "RL")]
#[serde(rename = "RL")]
#[serde(alias = "https://surrealdb.com/rl")]
#[serde(alias = "https://surrealdb.com/roles")]
#[serde(skip_serializing_if = "Option::is_none")]
pub roles: Option<Vec<String>>,
}
impl From<Claims> for Value {
fn from(v: Claims) -> Value {
// Set default value
let mut out = Object::default();
// Add iss field if set
if let Some(iss) = v.iss {
out.insert("iss".to_string(), iss.into());
}
// Add iat field if set
if let Some(iat) = v.iat {
out.insert("iat".to_string(), iat.into());
}
// Add nbf field if set
if let Some(nbf) = v.nbf {
out.insert("nbf".to_string(), nbf.into());
}
// Add exp field if set
if let Some(exp) = v.exp {
out.insert("exp".to_string(), exp.into());
}
// Add NS field if set
if let Some(ns) = v.ns {
out.insert("NS".to_string(), ns.into());
}
// Add DB field if set
if let Some(db) = v.db {
out.insert("DB".to_string(), db.into());
}
// Add SC field if set
if let Some(sc) = v.sc {
out.insert("SC".to_string(), sc.into());
}
// Add TK field if set
if let Some(tk) = v.tk {
out.insert("TK".to_string(), tk.into());
}
// Add ID field if set
if let Some(id) = v.id {
out.insert("ID".to_string(), id.into());
}
// Add RL field if set
if let Some(role) = v.roles {
out.insert("RL".to_string(), role.into());
}
// Return value
out.into()
}
}