50 lines
1.4 KiB
Rust
50 lines
1.4 KiB
Rust
|
use crate::ctx::Context;
|
||
|
use crate::dbs::Auth;
|
||
|
use crate::dbs::Runtime;
|
||
|
use crate::sql::value::Value;
|
||
|
|
||
|
#[derive(Clone, Debug, Default, Eq, PartialEq)]
|
||
|
pub struct Session {
|
||
|
pub au: Auth, // Authentication info
|
||
|
pub ip: Option<String>, // Session ip address
|
||
|
pub or: Option<String>, // Session origin
|
||
|
pub id: Option<String>, // Session id
|
||
|
pub ns: Option<String>, // Namespace
|
||
|
pub db: Option<String>, // Database
|
||
|
pub sc: Option<String>, // Scope
|
||
|
pub sd: Option<Value>, // Scope auth data
|
||
|
}
|
||
|
|
||
|
impl Session {
|
||
|
pub fn context(&self) -> Runtime {
|
||
|
let mut ctx = Context::background();
|
||
|
// Add session value
|
||
|
let key = String::from("session");
|
||
|
let val: Value = self.into();
|
||
|
ctx.add_value(key, val);
|
||
|
// Add scope value
|
||
|
let key = String::from("scope");
|
||
|
let val: Value = self.sc.to_owned().into();
|
||
|
ctx.add_value(key, val);
|
||
|
// Add auth data
|
||
|
let key = String::from("auth");
|
||
|
let val: Value = self.sd.to_owned().into();
|
||
|
ctx.add_value(key, val);
|
||
|
// Output context
|
||
|
ctx.freeze()
|
||
|
}
|
||
|
}
|
||
|
|
||
|
impl Into<Value> for &Session {
|
||
|
fn into(self) -> Value {
|
||
|
Value::from(map! {
|
||
|
"ip".to_string() => self.ip.to_owned().into(),
|
||
|
"or".to_string() => self.or.to_owned().into(),
|
||
|
"id".to_string() => self.id.to_owned().into(),
|
||
|
"ns".to_string() => self.ns.to_owned().into(),
|
||
|
"db".to_string() => self.db.to_owned().into(),
|
||
|
"sc".to_string() => self.sc.to_owned().into(),
|
||
|
})
|
||
|
}
|
||
|
}
|