fabaccess-bffh/bffhd/capnp/user.rs

135 lines
4.1 KiB
Rust
Raw Normal View History

2022-03-21 00:01:50 +01:00
use crate::authorization::permissions::Permission;
2022-05-05 15:50:44 +02:00
use crate::session::SessionHandle;
2022-03-21 00:01:50 +01:00
use crate::users::{db, UserRef};
2022-11-04 17:25:17 +01:00
use api::user_capnp::user::{self, self_service, manage, admin};
2022-05-05 15:50:44 +02:00
use capnp::capability::Promise;
use capnp_rpc::pry;
2022-03-21 00:01:50 +01:00
#[derive(Clone)]
pub struct User {
2022-03-12 17:31:53 +01:00
session: SessionHandle,
2022-03-21 00:01:50 +01:00
user: UserRef,
2022-03-12 17:31:53 +01:00
}
impl User {
2022-03-21 00:01:50 +01:00
pub fn new(session: SessionHandle, user: UserRef) -> Self {
Self { session, user }
}
2022-03-21 00:01:50 +01:00
pub fn new_self(session: SessionHandle) -> Self {
let user = session.get_user_ref();
Self::new(session, user)
}
2022-04-26 23:21:43 +02:00
pub fn build(session: SessionHandle, builder: user::Builder) {
2022-03-21 00:01:50 +01:00
let this = Self::new_self(session);
let user = this.session.get_user();
Self::fill(&this.session, user, builder);
2022-03-21 00:01:50 +01:00
}
2022-11-04 17:25:17 +01:00
pub fn fill(session: &SessionHandle, user: db::User) -> Self {
2022-03-21 00:01:50 +01:00
builder.set_username(user.id.as_str());
// We have permissions on ourself
let is_me = &session.get_user_ref().id == &user.id;
let client = Self::new(session.clone(), UserRef::new(user.id));
2022-03-21 00:01:50 +01:00
if is_me || session.has_perm(Permission::new("bffh.users.info")) {
2022-03-21 00:01:50 +01:00
builder.set_info(capnp_rpc::new_client(client.clone()));
}
if is_me {
builder.set_manage(capnp_rpc::new_client(client.clone()));
}
if session.has_perm(Permission::new("bffh.users.admin")) {
2022-03-21 00:01:50 +01:00
builder.set_admin(capnp_rpc::new_client(client.clone()));
}
}
}
2022-11-04 17:25:17 +01:00
impl user::Server for User {
fn roles(
&mut self,
2022-11-04 17:25:17 +01:00
_: user::RolesParams,
mut result: user::RolesResults,
2022-03-21 00:01:50 +01:00
) -> Promise<(), ::capnp::Error> {
if let Some(user) = self.session.users.get_user(self.user.get_username()) {
let mut builder = result.get().init_roles(user.userdata.roles.len() as u32);
for (i, role) in user.userdata.roles.into_iter().enumerate() {
let mut b = builder.reborrow().get(i as u32);
b.set_name(role.as_str());
}
2022-03-21 00:01:50 +01:00
}
Promise::ok(())
}
}
impl manage::Server for User {
fn add_role(
&mut self,
2022-11-04 17:25:17 +01:00
param: manage::AddRoleParams,
_: manage::AddRoleResults,
2022-03-21 00:01:50 +01:00
) -> Promise<(), ::capnp::Error> {
let rolename = pry!(pry!(pry!(param.get()).get_role()).get_name());
if let Some(_role) = self.session.roles.get(rolename) {
2022-05-05 15:50:44 +02:00
let mut target = self
.session
.users
.get_user(self.user.get_username())
.unwrap();
2022-03-21 00:01:50 +01:00
// Only update if needed
if !target.userdata.roles.iter().any(|r| r.as_str() == rolename) {
target.userdata.roles.push(rolename.to_string());
2022-05-05 15:50:44 +02:00
self.session
.users
.put_user(self.user.get_username(), &target);
2022-03-21 00:01:50 +01:00
}
}
Promise::ok(())
}
fn remove_role(
&mut self,
2022-11-04 17:25:17 +01:00
param: manage::RemoveRoleParams,
_: manage::RemoveRoleResults,
2022-03-21 00:01:50 +01:00
) -> Promise<(), ::capnp::Error> {
let rolename = pry!(pry!(pry!(param.get()).get_role()).get_name());
if let Some(_role) = self.session.roles.get(rolename) {
2022-05-05 15:50:44 +02:00
let mut target = self
.session
.users
.get_user(self.user.get_username())
.unwrap();
2022-03-21 00:01:50 +01:00
// Only update if needed
if target.userdata.roles.iter().any(|r| r.as_str() == rolename) {
target.userdata.roles.retain(|r| r.as_str() != rolename);
2022-05-05 15:50:44 +02:00
self.session
.users
.put_user(self.user.get_username(), &target);
2022-03-21 00:01:50 +01:00
}
}
Promise::ok(())
}
2022-11-04 17:25:17 +01:00
}
impl admin::Server for User {
fn setpw(
&mut self,
2022-11-04 17:25:17 +01:00
param: admin::SetpwParams,
_: admin::SetpwResults,
) -> Promise<(), ::capnp::Error> {
let new_pw = pry!(pry!(param.get()).get_new_pwd());
let uid = self.user.get_username();
if let Some(mut user) = self.session.users.get_user(uid) {
user.set_pw(new_pw.as_bytes());
self.session.users.put_user(uid, &user);
}
Promise::ok(())
}
}