context::LemmyContext,
request::purge_image_from_pictrs,
site::{PurgeItemResponse, PurgePerson},
- utils::{is_top_admin, local_user_view_from_jwt, purge_image_posts_for_person},
+ utils::{is_admin, local_user_view_from_jwt, purge_image_posts_for_person, sanitize_html_opt},
};
use lemmy_db_schema::{
source::{
},
traits::Crud,
};
-use lemmy_utils::{error::LemmyError, ConnectionId};
+use lemmy_utils::error::LemmyError;
#[async_trait::async_trait(?Send)]
impl Perform for PurgePerson {
type Response = PurgeItemResponse;
- #[tracing::instrument(skip(context, _websocket_id))]
- async fn perform(
- &self,
- context: &Data<LemmyContext>,
- _websocket_id: Option<ConnectionId>,
- ) -> Result<Self::Response, LemmyError> {
+ #[tracing::instrument(skip(context))]
+ async fn perform(&self, context: &Data<LemmyContext>) -> Result<Self::Response, LemmyError> {
let data: &Self = self;
let local_user_view = local_user_view_from_jwt(&data.auth, context).await?;
- // Only let the top admin purge an item
- is_top_admin(context.pool(), local_user_view.person.id).await?;
+ // Only let admin purge an item
+ is_admin(&local_user_view)?;
// Read the person to get their images
let person_id = data.person_id;
- let person = Person::read(context.pool(), person_id).await?;
+ let person = Person::read(&mut context.pool(), person_id).await?;
if let Some(banner) = person.banner {
purge_image_from_pictrs(context.client(), context.settings(), &banner)
purge_image_posts_for_person(
person_id,
- context.pool(),
+ &mut context.pool(),
context.settings(),
context.client(),
)
.await?;
- Person::delete(context.pool(), person_id).await?;
+ Person::delete(&mut context.pool(), person_id).await?;
// Mod tables
- let reason = data.reason.clone();
+ let reason = sanitize_html_opt(&data.reason);
let form = AdminPurgePersonForm {
admin_person_id: local_user_view.person.id,
reason,
};
- AdminPurgePerson::create(context.pool(), &form).await?;
+ AdminPurgePerson::create(&mut context.pool(), &form).await?;
Ok(PurgeItemResponse { success: true })
}