X-Git-Url: http://these/git/?a=blobdiff_plain;f=crates%2Fapi%2Fsrc%2Fsite%2Fregistration_applications%2Flist.rs;h=aeff9f97f0a634f1889a3fec96232263ea8d2976;hb=c8063f3267cf2b3622f1fdc69128c6b55feefbbc;hp=bd5170d6a2db1159078d9d856514e8cce1955890;hpb=3951a16447fdccfde3b0ec2ef8fcbf9f89562adc;p=lemmy.git diff --git a/crates/api/src/site/registration_applications/list.rs b/crates/api/src/site/registration_applications/list.rs index bd5170d6..aeff9f97 100644 --- a/crates/api/src/site/registration_applications/list.rs +++ b/crates/api/src/site/registration_applications/list.rs @@ -1,54 +1,43 @@ use crate::Perform; use actix_web::web::Data; use lemmy_api_common::{ - blocking, - get_local_user_view_from_jwt, - is_admin, + context::LemmyContext, site::{ListRegistrationApplications, ListRegistrationApplicationsResponse}, + utils::{is_admin, local_user_view_from_jwt}, }; -use lemmy_db_schema::source::site::Site; -use lemmy_db_views::registration_application_view::RegistrationApplicationQueryBuilder; -use lemmy_utils::{ConnectionId, LemmyError}; -use lemmy_websocket::LemmyContext; +use lemmy_db_schema::source::local_site::LocalSite; +use lemmy_db_views::registration_application_view::RegistrationApplicationQuery; +use lemmy_utils::error::LemmyError; /// Lists registration applications, filterable by undenied only. #[async_trait::async_trait(?Send)] impl Perform for ListRegistrationApplications { type Response = ListRegistrationApplicationsResponse; - async fn perform( - &self, - context: &Data, - _websocket_id: Option, - ) -> Result { + async fn perform(&self, context: &Data) -> Result { let data = self; - let local_user_view = - get_local_user_view_from_jwt(&data.auth, context.pool(), context.secret()).await?; + let local_user_view = local_user_view_from_jwt(&data.auth, context).await?; + let local_site = LocalSite::read(&mut context.pool()).await?; // Make sure user is an admin is_admin(&local_user_view)?; - let unread_only = data.unread_only; - let verified_email_only = blocking(context.pool(), Site::read_local_site) - .await?? - .require_email_verification; + let unread_only = data.unread_only.unwrap_or_default(); + let verified_email_only = local_site.require_email_verification; let page = data.page; let limit = data.limit; - let registration_applications = blocking(context.pool(), move |conn| { - RegistrationApplicationQueryBuilder::create(conn) - .unread_only(unread_only) - .verified_email_only(verified_email_only) - .page(page) - .limit(limit) - .list() - }) - .await??; + let registration_applications = RegistrationApplicationQuery { + unread_only, + verified_email_only, + page, + limit, + } + .list(&mut context.pool()) + .await?; - let res = Self::Response { + Ok(Self::Response { registration_applications, - }; - - Ok(res) + }) } }