mirror of
https://github.com/LemmyNet/lemmy.git
synced 2024-06-02 21:49:22 +00:00
56 lines
1.5 KiB
Rust
56 lines
1.5 KiB
Rust
use crate::Perform;
|
|
use actix_web::web::Data;
|
|
use lemmy_api_common::{
|
|
context::LemmyContext,
|
|
person::{AddAdmin, AddAdminResponse},
|
|
utils::{is_admin, local_user_view_from_jwt},
|
|
};
|
|
use lemmy_db_schema::{
|
|
source::{
|
|
moderator::{ModAdd, ModAddForm},
|
|
person::{Person, PersonUpdateForm},
|
|
},
|
|
traits::Crud,
|
|
};
|
|
use lemmy_db_views_actor::structs::PersonView;
|
|
use lemmy_utils::error::LemmyError;
|
|
|
|
#[async_trait::async_trait(?Send)]
|
|
impl Perform for AddAdmin {
|
|
type Response = AddAdminResponse;
|
|
|
|
#[tracing::instrument(skip(context))]
|
|
async fn perform(&self, context: &Data<LemmyContext>) -> Result<AddAdminResponse, LemmyError> {
|
|
let mut conn = context.conn().await?;
|
|
|
|
let data: &AddAdmin = self;
|
|
let local_user_view = local_user_view_from_jwt(&data.auth, context).await?;
|
|
|
|
// Make sure user is an admin
|
|
is_admin(&local_user_view)?;
|
|
|
|
let added = data.added;
|
|
let added_person_id = data.person_id;
|
|
let added_admin = Person::update(
|
|
&mut conn,
|
|
added_person_id,
|
|
&PersonUpdateForm::builder().admin(Some(added)).build(),
|
|
)
|
|
.await
|
|
.map_err(|e| LemmyError::from_error_message(e, "couldnt_update_user"))?;
|
|
|
|
// Mod tables
|
|
let form = ModAddForm {
|
|
mod_person_id: local_user_view.person.id,
|
|
other_person_id: added_admin.id,
|
|
removed: Some(!data.added),
|
|
};
|
|
|
|
ModAdd::create(&mut conn, &form).await?;
|
|
|
|
let admins = PersonView::admins(&mut conn).await?;
|
|
|
|
Ok(AddAdminResponse { admins })
|
|
}
|
|
}
|