use crate::Perform;
use actix_web::web::Data;
use lemmy_api_common::{
- blocking,
- build_federated_instances,
- get_local_user_view_from_jwt,
- is_admin,
+ context::LemmyContext,
site::{GetSiteResponse, LeaveAdmin},
+ utils::{get_local_user_view_from_jwt, is_admin},
};
use lemmy_db_schema::{
source::{
+ actor_language::SiteLanguage,
+ language::Language,
moderator::{ModAdd, ModAddForm},
- person::Person,
+ person::{Person, PersonUpdateForm},
+ tagline::Tagline,
},
traits::Crud,
};
-use lemmy_db_views::site_view::SiteView;
-use lemmy_db_views_actor::person_view::PersonViewSafe;
-use lemmy_utils::{version, ConnectionId, LemmyError};
-use lemmy_websocket::LemmyContext;
+use lemmy_db_views::structs::{CustomEmojiView, SiteView};
+use lemmy_db_views_actor::structs::PersonView;
+use lemmy_utils::{error::LemmyError, version, ConnectionId};
#[async_trait::async_trait(?Send)]
impl Perform for LeaveAdmin {
is_admin(&local_user_view)?;
// Make sure there isn't just one admin (so if one leaves, there will still be one left)
- let admins = blocking(context.pool(), PersonViewSafe::admins).await??;
+ let admins = PersonView::admins(context.pool()).await?;
if admins.len() == 1 {
return Err(LemmyError::from_message("cannot_leave_admin"));
}
let person_id = local_user_view.person.id;
- blocking(context.pool(), move |conn| {
- Person::leave_admin(conn, person_id)
- })
- .await??;
+ Person::update(
+ context.pool(),
+ person_id,
+ &PersonUpdateForm::builder().admin(Some(false)).build(),
+ )
+ .await?;
// Mod tables
let form = ModAddForm {
removed: Some(true),
};
- blocking(context.pool(), move |conn| ModAdd::create(conn, &form)).await??;
+ ModAdd::create(context.pool(), &form).await?;
// Reread site and admins
- let site_view = blocking(context.pool(), SiteView::read_local).await??;
- let admins = blocking(context.pool(), PersonViewSafe::admins).await??;
+ let site_view = SiteView::read_local(context.pool()).await?;
+ let admins = PersonView::admins(context.pool()).await?;
- let federated_instances =
- build_federated_instances(context.pool(), &context.settings()).await?;
+ let all_languages = Language::read_all(context.pool()).await?;
+ let discussion_languages = SiteLanguage::read_local(context.pool()).await?;
+ let taglines = Tagline::get_all(context.pool(), site_view.local_site.id).await?;
+ let custom_emojis = CustomEmojiView::get_all(context.pool(), site_view.local_site.id).await?;
Ok(GetSiteResponse {
- site_view: Some(site_view),
+ site_view,
admins,
online: 0,
version: version::VERSION.to_string(),
my_user: None,
- federated_instances,
+ federated_instances: None,
+ all_languages,
+ discussion_languages,
+ taglines,
+ custom_emojis,
})
}
}