]> Untitled Git - lemmy.git/blob - crates/api/src/site/registration_applications/list.rs
Dont return error in case optional auth is invalid (#2879)
[lemmy.git] / crates / api / src / site / registration_applications / list.rs
1 use crate::Perform;
2 use actix_web::web::Data;
3 use lemmy_api_common::{
4   context::LemmyContext,
5   site::{ListRegistrationApplications, ListRegistrationApplicationsResponse},
6   utils::{is_admin, local_user_view_from_jwt},
7 };
8 use lemmy_db_schema::source::local_site::LocalSite;
9 use lemmy_db_views::registration_application_view::RegistrationApplicationQuery;
10 use lemmy_utils::{error::LemmyError, ConnectionId};
11
12 /// Lists registration applications, filterable by undenied only.
13 #[async_trait::async_trait(?Send)]
14 impl Perform for ListRegistrationApplications {
15   type Response = ListRegistrationApplicationsResponse;
16
17   async fn perform(
18     &self,
19     context: &Data<LemmyContext>,
20     _websocket_id: Option<ConnectionId>,
21   ) -> Result<Self::Response, LemmyError> {
22     let data = self;
23     let local_user_view = local_user_view_from_jwt(&data.auth, context).await?;
24     let local_site = LocalSite::read(context.pool()).await?;
25
26     // Make sure user is an admin
27     is_admin(&local_user_view)?;
28
29     let unread_only = data.unread_only;
30     let verified_email_only = local_site.require_email_verification;
31
32     let page = data.page;
33     let limit = data.limit;
34     let registration_applications = RegistrationApplicationQuery::builder()
35       .pool(context.pool())
36       .unread_only(unread_only)
37       .verified_email_only(Some(verified_email_only))
38       .page(page)
39       .limit(limit)
40       .build()
41       .list()
42       .await?;
43
44     let res = Self::Response {
45       registration_applications,
46     };
47
48     Ok(res)
49   }
50 }