Remove PerformApub trait (#3423)
* Remove PerformApub trait This is completely useless now that websocket is gone. In the future I also plan to remove Perform and PerformCrud traits, but it will be difficult to do that while still compiling crates in parallel. * params need to use query
This commit is contained in:
parent
682ca55e0c
commit
3578dab67f
9 changed files with 458 additions and 553 deletions
|
@ -5,8 +5,6 @@ use lemmy_api_common::{
|
||||||
CommentResponse,
|
CommentResponse,
|
||||||
DistinguishComment,
|
DistinguishComment,
|
||||||
GetComment,
|
GetComment,
|
||||||
GetComments,
|
|
||||||
GetCommentsResponse,
|
|
||||||
ListCommentReports,
|
ListCommentReports,
|
||||||
ListCommentReportsResponse,
|
ListCommentReportsResponse,
|
||||||
ResolveCommentReport,
|
ResolveCommentReport,
|
||||||
|
@ -15,7 +13,6 @@ use lemmy_api_common::{
|
||||||
community::{
|
community::{
|
||||||
CommunityResponse,
|
CommunityResponse,
|
||||||
CreateCommunity,
|
CreateCommunity,
|
||||||
GetCommunity,
|
|
||||||
GetCommunityResponse,
|
GetCommunityResponse,
|
||||||
ListCommunities,
|
ListCommunities,
|
||||||
ListCommunitiesResponse,
|
ListCommunitiesResponse,
|
||||||
|
@ -39,8 +36,6 @@ use lemmy_api_common::{
|
||||||
GetBannedPersons,
|
GetBannedPersons,
|
||||||
GetCaptcha,
|
GetCaptcha,
|
||||||
GetCaptchaResponse,
|
GetCaptchaResponse,
|
||||||
GetPersonDetails,
|
|
||||||
GetPersonDetailsResponse,
|
|
||||||
GetPersonMentions,
|
GetPersonMentions,
|
||||||
GetPersonMentionsResponse,
|
GetPersonMentionsResponse,
|
||||||
GetReplies,
|
GetReplies,
|
||||||
|
@ -66,8 +61,6 @@ use lemmy_api_common::{
|
||||||
post::{
|
post::{
|
||||||
GetPost,
|
GetPost,
|
||||||
GetPostResponse,
|
GetPostResponse,
|
||||||
GetPosts,
|
|
||||||
GetPostsResponse,
|
|
||||||
GetSiteMetadata,
|
GetSiteMetadata,
|
||||||
GetSiteMetadataResponse,
|
GetSiteMetadataResponse,
|
||||||
ListPostReports,
|
ListPostReports,
|
||||||
|
@ -110,10 +103,6 @@ use lemmy_api_common::{
|
||||||
PurgePerson,
|
PurgePerson,
|
||||||
PurgePost,
|
PurgePost,
|
||||||
RegistrationApplicationResponse,
|
RegistrationApplicationResponse,
|
||||||
ResolveObject,
|
|
||||||
ResolveObjectResponse,
|
|
||||||
Search,
|
|
||||||
SearchResponse,
|
|
||||||
SiteResponse,
|
SiteResponse,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -122,10 +111,6 @@ impl SendActivity for Register {
|
||||||
type Response = LoginResponse;
|
type Response = LoginResponse;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl SendActivity for GetPersonDetails {
|
|
||||||
type Response = GetPersonDetailsResponse;
|
|
||||||
}
|
|
||||||
|
|
||||||
impl SendActivity for GetPrivateMessages {
|
impl SendActivity for GetPrivateMessages {
|
||||||
type Response = PrivateMessagesResponse;
|
type Response = PrivateMessagesResponse;
|
||||||
}
|
}
|
||||||
|
@ -142,10 +127,6 @@ impl SendActivity for GetSite {
|
||||||
type Response = GetSiteResponse;
|
type Response = GetSiteResponse;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl SendActivity for GetCommunity {
|
|
||||||
type Response = GetCommunityResponse;
|
|
||||||
}
|
|
||||||
|
|
||||||
impl SendActivity for ListCommunities {
|
impl SendActivity for ListCommunities {
|
||||||
type Response = ListCommunitiesResponse;
|
type Response = ListCommunitiesResponse;
|
||||||
}
|
}
|
||||||
|
@ -158,18 +139,10 @@ impl SendActivity for GetPost {
|
||||||
type Response = GetPostResponse;
|
type Response = GetPostResponse;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl SendActivity for GetPosts {
|
|
||||||
type Response = GetPostsResponse;
|
|
||||||
}
|
|
||||||
|
|
||||||
impl SendActivity for GetComment {
|
impl SendActivity for GetComment {
|
||||||
type Response = CommentResponse;
|
type Response = CommentResponse;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl SendActivity for GetComments {
|
|
||||||
type Response = GetCommentsResponse;
|
|
||||||
}
|
|
||||||
|
|
||||||
impl SendActivity for Login {
|
impl SendActivity for Login {
|
||||||
type Response = LoginResponse;
|
type Response = LoginResponse;
|
||||||
}
|
}
|
||||||
|
@ -286,14 +259,6 @@ impl SendActivity for PurgeComment {
|
||||||
type Response = PurgeItemResponse;
|
type Response = PurgeItemResponse;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl SendActivity for Search {
|
|
||||||
type Response = SearchResponse;
|
|
||||||
}
|
|
||||||
|
|
||||||
impl SendActivity for ResolveObject {
|
|
||||||
type Response = ResolveObjectResponse;
|
|
||||||
}
|
|
||||||
|
|
||||||
impl SendActivity for TransferCommunity {
|
impl SendActivity for TransferCommunity {
|
||||||
type Response = GetCommunityResponse;
|
type Response = GetCommunityResponse;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,10 @@
|
||||||
use crate::{
|
use crate::{
|
||||||
api::{listing_type_with_default, PerformApub},
|
api::listing_type_with_default,
|
||||||
fetcher::resolve_actor_identifier,
|
fetcher::resolve_actor_identifier,
|
||||||
objects::community::ApubCommunity,
|
objects::community::ApubCommunity,
|
||||||
};
|
};
|
||||||
use activitypub_federation::config::Data;
|
use activitypub_federation::config::Data;
|
||||||
|
use actix_web::web::{Json, Query};
|
||||||
use lemmy_api_common::{
|
use lemmy_api_common::{
|
||||||
comment::{GetComments, GetCommentsResponse},
|
comment::{GetComments, GetCommentsResponse},
|
||||||
context::LemmyContext,
|
context::LemmyContext,
|
||||||
|
@ -16,61 +17,58 @@ use lemmy_db_schema::{
|
||||||
use lemmy_db_views::comment_view::CommentQuery;
|
use lemmy_db_views::comment_view::CommentQuery;
|
||||||
use lemmy_utils::error::LemmyError;
|
use lemmy_utils::error::LemmyError;
|
||||||
|
|
||||||
#[async_trait::async_trait]
|
#[tracing::instrument(skip(context))]
|
||||||
impl PerformApub for GetComments {
|
pub async fn list_comments(
|
||||||
type Response = GetCommentsResponse;
|
data: Query<GetComments>,
|
||||||
|
context: Data<LemmyContext>,
|
||||||
|
) -> Result<Json<GetCommentsResponse>, LemmyError> {
|
||||||
|
let local_user_view = local_user_view_from_jwt_opt(data.auth.as_ref(), &context).await;
|
||||||
|
let local_site = LocalSite::read(context.pool()).await?;
|
||||||
|
check_private_instance(&local_user_view, &local_site)?;
|
||||||
|
|
||||||
#[tracing::instrument(skip(context))]
|
let community_id = if let Some(name) = &data.community_name {
|
||||||
async fn perform(&self, context: &Data<LemmyContext>) -> Result<GetCommentsResponse, LemmyError> {
|
resolve_actor_identifier::<ApubCommunity, Community>(name, &context, &None, true)
|
||||||
let data: &GetComments = self;
|
|
||||||
let local_user_view = local_user_view_from_jwt_opt(data.auth.as_ref(), context).await;
|
|
||||||
let local_site = LocalSite::read(context.pool()).await?;
|
|
||||||
check_private_instance(&local_user_view, &local_site)?;
|
|
||||||
|
|
||||||
let community_id = if let Some(name) = &data.community_name {
|
|
||||||
resolve_actor_identifier::<ApubCommunity, Community>(name, context, &None, true)
|
|
||||||
.await
|
|
||||||
.ok()
|
|
||||||
.map(|c| c.id)
|
|
||||||
} else {
|
|
||||||
data.community_id
|
|
||||||
};
|
|
||||||
let sort = data.sort;
|
|
||||||
let max_depth = data.max_depth;
|
|
||||||
let saved_only = data.saved_only;
|
|
||||||
let page = data.page;
|
|
||||||
let limit = data.limit;
|
|
||||||
let parent_id = data.parent_id;
|
|
||||||
|
|
||||||
let listing_type = listing_type_with_default(data.type_, &local_site, community_id)?;
|
|
||||||
|
|
||||||
// If a parent_id is given, fetch the comment to get the path
|
|
||||||
let parent_path = if let Some(parent_id) = parent_id {
|
|
||||||
Some(Comment::read(context.pool(), parent_id).await?.path)
|
|
||||||
} else {
|
|
||||||
None
|
|
||||||
};
|
|
||||||
|
|
||||||
let parent_path_cloned = parent_path.clone();
|
|
||||||
let post_id = data.post_id;
|
|
||||||
let local_user = local_user_view.map(|l| l.local_user);
|
|
||||||
let comments = CommentQuery::builder()
|
|
||||||
.pool(context.pool())
|
|
||||||
.listing_type(Some(listing_type))
|
|
||||||
.sort(sort)
|
|
||||||
.max_depth(max_depth)
|
|
||||||
.saved_only(saved_only)
|
|
||||||
.community_id(community_id)
|
|
||||||
.parent_path(parent_path_cloned)
|
|
||||||
.post_id(post_id)
|
|
||||||
.local_user(local_user.as_ref())
|
|
||||||
.page(page)
|
|
||||||
.limit(limit)
|
|
||||||
.build()
|
|
||||||
.list()
|
|
||||||
.await
|
.await
|
||||||
.map_err(|e| LemmyError::from_error_message(e, "couldnt_get_comments"))?;
|
.ok()
|
||||||
|
.map(|c| c.id)
|
||||||
|
} else {
|
||||||
|
data.community_id
|
||||||
|
};
|
||||||
|
let sort = data.sort;
|
||||||
|
let max_depth = data.max_depth;
|
||||||
|
let saved_only = data.saved_only;
|
||||||
|
let page = data.page;
|
||||||
|
let limit = data.limit;
|
||||||
|
let parent_id = data.parent_id;
|
||||||
|
|
||||||
Ok(GetCommentsResponse { comments })
|
let listing_type = listing_type_with_default(data.type_, &local_site, community_id)?;
|
||||||
}
|
|
||||||
|
// If a parent_id is given, fetch the comment to get the path
|
||||||
|
let parent_path = if let Some(parent_id) = parent_id {
|
||||||
|
Some(Comment::read(context.pool(), parent_id).await?.path)
|
||||||
|
} else {
|
||||||
|
None
|
||||||
|
};
|
||||||
|
|
||||||
|
let parent_path_cloned = parent_path.clone();
|
||||||
|
let post_id = data.post_id;
|
||||||
|
let local_user = local_user_view.map(|l| l.local_user);
|
||||||
|
let comments = CommentQuery::builder()
|
||||||
|
.pool(context.pool())
|
||||||
|
.listing_type(Some(listing_type))
|
||||||
|
.sort(sort)
|
||||||
|
.max_depth(max_depth)
|
||||||
|
.saved_only(saved_only)
|
||||||
|
.community_id(community_id)
|
||||||
|
.parent_path(parent_path_cloned)
|
||||||
|
.post_id(post_id)
|
||||||
|
.local_user(local_user.as_ref())
|
||||||
|
.page(page)
|
||||||
|
.limit(limit)
|
||||||
|
.build()
|
||||||
|
.list()
|
||||||
|
.await
|
||||||
|
.map_err(|e| LemmyError::from_error_message(e, "couldnt_get_comments"))?;
|
||||||
|
|
||||||
|
Ok(Json(GetCommentsResponse { comments }))
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,10 @@
|
||||||
use crate::{
|
use crate::{
|
||||||
api::{listing_type_with_default, PerformApub},
|
api::listing_type_with_default,
|
||||||
fetcher::resolve_actor_identifier,
|
fetcher::resolve_actor_identifier,
|
||||||
objects::community::ApubCommunity,
|
objects::community::ApubCommunity,
|
||||||
};
|
};
|
||||||
use activitypub_federation::config::Data;
|
use activitypub_federation::config::Data;
|
||||||
|
use actix_web::web::{Json, Query};
|
||||||
use lemmy_api_common::{
|
use lemmy_api_common::{
|
||||||
context::LemmyContext,
|
context::LemmyContext,
|
||||||
post::{GetPosts, GetPostsResponse},
|
post::{GetPosts, GetPostsResponse},
|
||||||
|
@ -13,54 +14,50 @@ use lemmy_db_schema::source::{community::Community, local_site::LocalSite};
|
||||||
use lemmy_db_views::post_view::PostQuery;
|
use lemmy_db_views::post_view::PostQuery;
|
||||||
use lemmy_utils::error::LemmyError;
|
use lemmy_utils::error::LemmyError;
|
||||||
|
|
||||||
#[async_trait::async_trait]
|
#[tracing::instrument(skip(context))]
|
||||||
impl PerformApub for GetPosts {
|
pub async fn list_posts(
|
||||||
type Response = GetPostsResponse;
|
data: Query<GetPosts>,
|
||||||
|
context: Data<LemmyContext>,
|
||||||
|
) -> Result<Json<GetPostsResponse>, LemmyError> {
|
||||||
|
let local_user_view = local_user_view_from_jwt_opt(data.auth.as_ref(), &context).await;
|
||||||
|
let local_site = LocalSite::read(context.pool()).await?;
|
||||||
|
|
||||||
#[tracing::instrument(skip(context))]
|
check_private_instance(&local_user_view, &local_site)?;
|
||||||
async fn perform(&self, context: &Data<LemmyContext>) -> Result<GetPostsResponse, LemmyError> {
|
|
||||||
let data: &GetPosts = self;
|
|
||||||
let local_user_view = local_user_view_from_jwt_opt(data.auth.as_ref(), context).await;
|
|
||||||
let local_site = LocalSite::read(context.pool()).await?;
|
|
||||||
|
|
||||||
check_private_instance(&local_user_view, &local_site)?;
|
let sort = data.sort;
|
||||||
|
|
||||||
let sort = data.sort;
|
let page = data.page;
|
||||||
|
let limit = data.limit;
|
||||||
let page = data.page;
|
let community_id = if let Some(name) = &data.community_name {
|
||||||
let limit = data.limit;
|
resolve_actor_identifier::<ApubCommunity, Community>(name, &context, &None, true)
|
||||||
let community_id = if let Some(name) = &data.community_name {
|
|
||||||
resolve_actor_identifier::<ApubCommunity, Community>(name, context, &None, true)
|
|
||||||
.await
|
|
||||||
.ok()
|
|
||||||
.map(|c| c.id)
|
|
||||||
} else {
|
|
||||||
data.community_id
|
|
||||||
};
|
|
||||||
let saved_only = data.saved_only;
|
|
||||||
|
|
||||||
let listing_type = listing_type_with_default(data.type_, &local_site, community_id)?;
|
|
||||||
|
|
||||||
let is_mod_or_admin =
|
|
||||||
is_mod_or_admin_opt(context.pool(), local_user_view.as_ref(), community_id)
|
|
||||||
.await
|
|
||||||
.is_ok();
|
|
||||||
|
|
||||||
let posts = PostQuery::builder()
|
|
||||||
.pool(context.pool())
|
|
||||||
.local_user(local_user_view.map(|l| l.local_user).as_ref())
|
|
||||||
.listing_type(Some(listing_type))
|
|
||||||
.sort(sort)
|
|
||||||
.community_id(community_id)
|
|
||||||
.saved_only(saved_only)
|
|
||||||
.page(page)
|
|
||||||
.limit(limit)
|
|
||||||
.is_mod_or_admin(Some(is_mod_or_admin))
|
|
||||||
.build()
|
|
||||||
.list()
|
|
||||||
.await
|
.await
|
||||||
.map_err(|e| LemmyError::from_error_message(e, "couldnt_get_posts"))?;
|
.ok()
|
||||||
|
.map(|c| c.id)
|
||||||
|
} else {
|
||||||
|
data.community_id
|
||||||
|
};
|
||||||
|
let saved_only = data.saved_only;
|
||||||
|
|
||||||
Ok(GetPostsResponse { posts })
|
let listing_type = listing_type_with_default(data.type_, &local_site, community_id)?;
|
||||||
}
|
|
||||||
|
let is_mod_or_admin = is_mod_or_admin_opt(context.pool(), local_user_view.as_ref(), community_id)
|
||||||
|
.await
|
||||||
|
.is_ok();
|
||||||
|
|
||||||
|
let posts = PostQuery::builder()
|
||||||
|
.pool(context.pool())
|
||||||
|
.local_user(local_user_view.map(|l| l.local_user).as_ref())
|
||||||
|
.listing_type(Some(listing_type))
|
||||||
|
.sort(sort)
|
||||||
|
.community_id(community_id)
|
||||||
|
.saved_only(saved_only)
|
||||||
|
.page(page)
|
||||||
|
.limit(limit)
|
||||||
|
.is_mod_or_admin(Some(is_mod_or_admin))
|
||||||
|
.build()
|
||||||
|
.list()
|
||||||
|
.await
|
||||||
|
.map_err(|e| LemmyError::from_error_message(e, "couldnt_get_posts"))?;
|
||||||
|
|
||||||
|
Ok(Json(GetPostsResponse { posts }))
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,21 +1,12 @@
|
||||||
use activitypub_federation::config::Data;
|
|
||||||
use lemmy_api_common::context::LemmyContext;
|
|
||||||
use lemmy_db_schema::{newtypes::CommunityId, source::local_site::LocalSite, ListingType};
|
use lemmy_db_schema::{newtypes::CommunityId, source::local_site::LocalSite, ListingType};
|
||||||
use lemmy_utils::error::LemmyError;
|
use lemmy_utils::error::LemmyError;
|
||||||
|
|
||||||
mod list_comments;
|
pub mod list_comments;
|
||||||
mod list_posts;
|
pub mod list_posts;
|
||||||
mod read_community;
|
pub mod read_community;
|
||||||
mod read_person;
|
pub mod read_person;
|
||||||
mod resolve_object;
|
pub mod resolve_object;
|
||||||
mod search;
|
pub mod search;
|
||||||
|
|
||||||
#[async_trait::async_trait]
|
|
||||||
pub trait PerformApub {
|
|
||||||
type Response: serde::ser::Serialize + Send;
|
|
||||||
|
|
||||||
async fn perform(&self, context: &Data<LemmyContext>) -> Result<Self::Response, LemmyError>;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Returns default listing type, depending if the query is for frontpage or community.
|
/// Returns default listing type, depending if the query is for frontpage or community.
|
||||||
fn listing_type_with_default(
|
fn listing_type_with_default(
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
use crate::{
|
use crate::{fetcher::resolve_actor_identifier, objects::community::ApubCommunity};
|
||||||
api::PerformApub,
|
|
||||||
fetcher::resolve_actor_identifier,
|
|
||||||
objects::community::ApubCommunity,
|
|
||||||
};
|
|
||||||
use activitypub_federation::config::Data;
|
use activitypub_federation::config::Data;
|
||||||
|
use actix_web::web::{Json, Query};
|
||||||
use lemmy_api_common::{
|
use lemmy_api_common::{
|
||||||
community::{GetCommunity, GetCommunityResponse},
|
community::{GetCommunity, GetCommunityResponse},
|
||||||
context::LemmyContext,
|
context::LemmyContext,
|
||||||
|
@ -18,78 +15,68 @@ use lemmy_db_schema::source::{
|
||||||
use lemmy_db_views_actor::structs::{CommunityModeratorView, CommunityView};
|
use lemmy_db_views_actor::structs::{CommunityModeratorView, CommunityView};
|
||||||
use lemmy_utils::error::LemmyError;
|
use lemmy_utils::error::LemmyError;
|
||||||
|
|
||||||
#[async_trait::async_trait]
|
#[tracing::instrument(skip(context))]
|
||||||
impl PerformApub for GetCommunity {
|
pub async fn read_community(
|
||||||
type Response = GetCommunityResponse;
|
data: Query<GetCommunity>,
|
||||||
|
context: Data<LemmyContext>,
|
||||||
|
) -> Result<Json<GetCommunityResponse>, LemmyError> {
|
||||||
|
let local_user_view = local_user_view_from_jwt_opt(data.auth.as_ref(), &context).await;
|
||||||
|
let local_site = LocalSite::read(context.pool()).await?;
|
||||||
|
|
||||||
#[tracing::instrument(skip(context))]
|
if data.name.is_none() && data.id.is_none() {
|
||||||
async fn perform(
|
return Err(LemmyError::from_message("no_id_given"));
|
||||||
&self,
|
}
|
||||||
context: &Data<LemmyContext>,
|
|
||||||
) -> Result<GetCommunityResponse, LemmyError> {
|
|
||||||
let data: &GetCommunity = self;
|
|
||||||
let local_user_view = local_user_view_from_jwt_opt(data.auth.as_ref(), context).await;
|
|
||||||
let local_site = LocalSite::read(context.pool()).await?;
|
|
||||||
|
|
||||||
if data.name.is_none() && data.id.is_none() {
|
check_private_instance(&local_user_view, &local_site)?;
|
||||||
return Err(LemmyError::from_message("no_id_given"));
|
|
||||||
}
|
|
||||||
|
|
||||||
check_private_instance(&local_user_view, &local_site)?;
|
let person_id = local_user_view.as_ref().map(|u| u.person.id);
|
||||||
|
|
||||||
let person_id = local_user_view.as_ref().map(|u| u.person.id);
|
let community_id = match data.id {
|
||||||
|
Some(id) => id,
|
||||||
let community_id = match data.id {
|
None => {
|
||||||
Some(id) => id,
|
let name = data.name.clone().unwrap_or_else(|| "main".to_string());
|
||||||
None => {
|
resolve_actor_identifier::<ApubCommunity, Community>(&name, &context, &local_user_view, true)
|
||||||
let name = data.name.clone().unwrap_or_else(|| "main".to_string());
|
|
||||||
resolve_actor_identifier::<ApubCommunity, Community>(&name, context, &local_user_view, true)
|
|
||||||
.await
|
|
||||||
.map_err(|e| e.with_message("couldnt_find_community"))?
|
|
||||||
.id
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
let is_mod_or_admin =
|
|
||||||
is_mod_or_admin_opt(context.pool(), local_user_view.as_ref(), Some(community_id))
|
|
||||||
.await
|
.await
|
||||||
.is_ok();
|
.map_err(|e| e.with_message("couldnt_find_community"))?
|
||||||
|
.id
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
let community_view = CommunityView::read(
|
let is_mod_or_admin =
|
||||||
context.pool(),
|
is_mod_or_admin_opt(context.pool(), local_user_view.as_ref(), Some(community_id))
|
||||||
community_id,
|
.await
|
||||||
person_id,
|
.is_ok();
|
||||||
Some(is_mod_or_admin),
|
|
||||||
)
|
let community_view = CommunityView::read(
|
||||||
|
context.pool(),
|
||||||
|
community_id,
|
||||||
|
person_id,
|
||||||
|
Some(is_mod_or_admin),
|
||||||
|
)
|
||||||
|
.await
|
||||||
|
.map_err(|e| LemmyError::from_error_message(e, "couldnt_find_community"))?;
|
||||||
|
|
||||||
|
let moderators = CommunityModeratorView::for_community(context.pool(), community_id)
|
||||||
.await
|
.await
|
||||||
.map_err(|e| LemmyError::from_error_message(e, "couldnt_find_community"))?;
|
.map_err(|e| LemmyError::from_error_message(e, "couldnt_find_community"))?;
|
||||||
|
|
||||||
let moderators = CommunityModeratorView::for_community(context.pool(), community_id)
|
let site_id = Site::instance_actor_id_from_url(community_view.community.actor_id.clone().into());
|
||||||
.await
|
let mut site = Site::read_from_apub_id(context.pool(), &site_id.into()).await?;
|
||||||
.map_err(|e| LemmyError::from_error_message(e, "couldnt_find_community"))?;
|
// no need to include metadata for local site (its already available through other endpoints).
|
||||||
|
// this also prevents us from leaking the federation private key.
|
||||||
let site_id =
|
if let Some(s) = &site {
|
||||||
Site::instance_actor_id_from_url(community_view.community.actor_id.clone().into());
|
if s.actor_id.domain() == Some(context.settings().hostname.as_ref()) {
|
||||||
let mut site = Site::read_from_apub_id(context.pool(), &site_id.into()).await?;
|
site = None;
|
||||||
// no need to include metadata for local site (its already available through other endpoints).
|
|
||||||
// this also prevents us from leaking the federation private key.
|
|
||||||
if let Some(s) = &site {
|
|
||||||
if s.actor_id.domain() == Some(context.settings().hostname.as_ref()) {
|
|
||||||
site = None;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
let community_id = community_view.community.id;
|
|
||||||
let discussion_languages = CommunityLanguage::read(context.pool(), community_id).await?;
|
|
||||||
|
|
||||||
let res = GetCommunityResponse {
|
|
||||||
community_view,
|
|
||||||
site,
|
|
||||||
moderators,
|
|
||||||
discussion_languages,
|
|
||||||
};
|
|
||||||
|
|
||||||
// Return the jwt
|
|
||||||
Ok(res)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let community_id = community_view.community.id;
|
||||||
|
let discussion_languages = CommunityLanguage::read(context.pool(), community_id).await?;
|
||||||
|
|
||||||
|
Ok(Json(GetCommunityResponse {
|
||||||
|
community_view,
|
||||||
|
site,
|
||||||
|
moderators,
|
||||||
|
discussion_languages,
|
||||||
|
}))
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
use crate::{api::PerformApub, fetcher::resolve_actor_identifier, objects::person::ApubPerson};
|
use crate::{fetcher::resolve_actor_identifier, objects::person::ApubPerson};
|
||||||
use activitypub_federation::config::Data;
|
use activitypub_federation::config::Data;
|
||||||
|
use actix_web::web::{Json, Query};
|
||||||
use lemmy_api_common::{
|
use lemmy_api_common::{
|
||||||
context::LemmyContext,
|
context::LemmyContext,
|
||||||
person::{GetPersonDetails, GetPersonDetailsResponse},
|
person::{GetPersonDetails, GetPersonDetailsResponse},
|
||||||
|
@ -13,108 +14,101 @@ use lemmy_db_views::{comment_view::CommentQuery, post_view::PostQuery};
|
||||||
use lemmy_db_views_actor::structs::{CommunityModeratorView, PersonView};
|
use lemmy_db_views_actor::structs::{CommunityModeratorView, PersonView};
|
||||||
use lemmy_utils::error::LemmyError;
|
use lemmy_utils::error::LemmyError;
|
||||||
|
|
||||||
#[async_trait::async_trait]
|
#[tracing::instrument(skip(context))]
|
||||||
impl PerformApub for GetPersonDetails {
|
pub async fn read_person(
|
||||||
type Response = GetPersonDetailsResponse;
|
data: Query<GetPersonDetails>,
|
||||||
|
context: Data<LemmyContext>,
|
||||||
#[tracing::instrument(skip(self, context))]
|
) -> Result<Json<GetPersonDetailsResponse>, LemmyError> {
|
||||||
async fn perform(
|
// Check to make sure a person name or an id is given
|
||||||
&self,
|
if data.username.is_none() && data.person_id.is_none() {
|
||||||
context: &Data<LemmyContext>,
|
return Err(LemmyError::from_message("no_id_given"));
|
||||||
) -> Result<GetPersonDetailsResponse, LemmyError> {
|
|
||||||
let data: &GetPersonDetails = self;
|
|
||||||
|
|
||||||
// Check to make sure a person name or an id is given
|
|
||||||
if data.username.is_none() && data.person_id.is_none() {
|
|
||||||
return Err(LemmyError::from_message("no_id_given"));
|
|
||||||
}
|
|
||||||
|
|
||||||
let local_user_view = local_user_view_from_jwt_opt(data.auth.as_ref(), context).await;
|
|
||||||
let local_site = LocalSite::read(context.pool()).await?;
|
|
||||||
let is_admin = local_user_view.as_ref().map(|luv| is_admin(luv).is_ok());
|
|
||||||
|
|
||||||
check_private_instance(&local_user_view, &local_site)?;
|
|
||||||
|
|
||||||
let person_details_id = match data.person_id {
|
|
||||||
Some(id) => id,
|
|
||||||
None => {
|
|
||||||
if let Some(username) = &data.username {
|
|
||||||
resolve_actor_identifier::<ApubPerson, Person>(username, context, &local_user_view, true)
|
|
||||||
.await
|
|
||||||
.map_err(|e| e.with_message("couldnt_find_that_username_or_email"))?
|
|
||||||
.id
|
|
||||||
} else {
|
|
||||||
return Err(LemmyError::from_message(
|
|
||||||
"couldnt_find_that_username_or_email",
|
|
||||||
));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// You don't need to return settings for the user, since this comes back with GetSite
|
|
||||||
// `my_user`
|
|
||||||
let person_view = PersonView::read(context.pool(), person_details_id).await?;
|
|
||||||
|
|
||||||
let sort = data.sort;
|
|
||||||
let page = data.page;
|
|
||||||
let limit = data.limit;
|
|
||||||
let saved_only = data.saved_only;
|
|
||||||
let community_id = data.community_id;
|
|
||||||
let local_user = local_user_view.map(|l| l.local_user);
|
|
||||||
let local_user_clone = local_user.clone();
|
|
||||||
|
|
||||||
let posts_query = PostQuery::builder()
|
|
||||||
.pool(context.pool())
|
|
||||||
.sort(sort)
|
|
||||||
.saved_only(saved_only)
|
|
||||||
.local_user(local_user.as_ref())
|
|
||||||
.community_id(community_id)
|
|
||||||
.is_mod_or_admin(is_admin)
|
|
||||||
.page(page)
|
|
||||||
.limit(limit);
|
|
||||||
|
|
||||||
// If its saved only, you don't care what creator it was
|
|
||||||
// Or, if its not saved, then you only want it for that specific creator
|
|
||||||
let posts = if !saved_only.unwrap_or(false) {
|
|
||||||
posts_query
|
|
||||||
.creator_id(Some(person_details_id))
|
|
||||||
.build()
|
|
||||||
.list()
|
|
||||||
} else {
|
|
||||||
posts_query.build().list()
|
|
||||||
}
|
|
||||||
.await?;
|
|
||||||
|
|
||||||
let comments_query = CommentQuery::builder()
|
|
||||||
.pool(context.pool())
|
|
||||||
.local_user(local_user_clone.as_ref())
|
|
||||||
.sort(sort.map(post_to_comment_sort_type))
|
|
||||||
.saved_only(saved_only)
|
|
||||||
.show_deleted_and_removed(Some(false))
|
|
||||||
.community_id(community_id)
|
|
||||||
.page(page)
|
|
||||||
.limit(limit);
|
|
||||||
|
|
||||||
// If its saved only, you don't care what creator it was
|
|
||||||
// Or, if its not saved, then you only want it for that specific creator
|
|
||||||
let comments = if !saved_only.unwrap_or(false) {
|
|
||||||
comments_query
|
|
||||||
.creator_id(Some(person_details_id))
|
|
||||||
.build()
|
|
||||||
.list()
|
|
||||||
} else {
|
|
||||||
comments_query.build().list()
|
|
||||||
}
|
|
||||||
.await?;
|
|
||||||
|
|
||||||
let moderates = CommunityModeratorView::for_person(context.pool(), person_details_id).await?;
|
|
||||||
|
|
||||||
// Return the jwt
|
|
||||||
Ok(GetPersonDetailsResponse {
|
|
||||||
person_view,
|
|
||||||
moderates,
|
|
||||||
comments,
|
|
||||||
posts,
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let local_user_view = local_user_view_from_jwt_opt(data.auth.as_ref(), &context).await;
|
||||||
|
let local_site = LocalSite::read(context.pool()).await?;
|
||||||
|
let is_admin = local_user_view.as_ref().map(|luv| is_admin(luv).is_ok());
|
||||||
|
|
||||||
|
check_private_instance(&local_user_view, &local_site)?;
|
||||||
|
|
||||||
|
let person_details_id = match data.person_id {
|
||||||
|
Some(id) => id,
|
||||||
|
None => {
|
||||||
|
if let Some(username) = &data.username {
|
||||||
|
resolve_actor_identifier::<ApubPerson, Person>(username, &context, &local_user_view, true)
|
||||||
|
.await
|
||||||
|
.map_err(|e| e.with_message("couldnt_find_that_username_or_email"))?
|
||||||
|
.id
|
||||||
|
} else {
|
||||||
|
return Err(LemmyError::from_message(
|
||||||
|
"couldnt_find_that_username_or_email",
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// You don't need to return settings for the user, since this comes back with GetSite
|
||||||
|
// `my_user`
|
||||||
|
let person_view = PersonView::read(context.pool(), person_details_id).await?;
|
||||||
|
|
||||||
|
let sort = data.sort;
|
||||||
|
let page = data.page;
|
||||||
|
let limit = data.limit;
|
||||||
|
let saved_only = data.saved_only;
|
||||||
|
let community_id = data.community_id;
|
||||||
|
let local_user = local_user_view.map(|l| l.local_user);
|
||||||
|
let local_user_clone = local_user.clone();
|
||||||
|
|
||||||
|
let posts_query = PostQuery::builder()
|
||||||
|
.pool(context.pool())
|
||||||
|
.sort(sort)
|
||||||
|
.saved_only(saved_only)
|
||||||
|
.local_user(local_user.as_ref())
|
||||||
|
.community_id(community_id)
|
||||||
|
.is_mod_or_admin(is_admin)
|
||||||
|
.page(page)
|
||||||
|
.limit(limit);
|
||||||
|
|
||||||
|
// If its saved only, you don't care what creator it was
|
||||||
|
// Or, if its not saved, then you only want it for that specific creator
|
||||||
|
let posts = if !saved_only.unwrap_or(false) {
|
||||||
|
posts_query
|
||||||
|
.creator_id(Some(person_details_id))
|
||||||
|
.build()
|
||||||
|
.list()
|
||||||
|
} else {
|
||||||
|
posts_query.build().list()
|
||||||
|
}
|
||||||
|
.await?;
|
||||||
|
|
||||||
|
let comments_query = CommentQuery::builder()
|
||||||
|
.pool(context.pool())
|
||||||
|
.local_user(local_user_clone.as_ref())
|
||||||
|
.sort(sort.map(post_to_comment_sort_type))
|
||||||
|
.saved_only(saved_only)
|
||||||
|
.show_deleted_and_removed(Some(false))
|
||||||
|
.community_id(community_id)
|
||||||
|
.page(page)
|
||||||
|
.limit(limit);
|
||||||
|
|
||||||
|
// If its saved only, you don't care what creator it was
|
||||||
|
// Or, if its not saved, then you only want it for that specific creator
|
||||||
|
let comments = if !saved_only.unwrap_or(false) {
|
||||||
|
comments_query
|
||||||
|
.creator_id(Some(person_details_id))
|
||||||
|
.build()
|
||||||
|
.list()
|
||||||
|
} else {
|
||||||
|
comments_query.build().list()
|
||||||
|
}
|
||||||
|
.await?;
|
||||||
|
|
||||||
|
let moderates = CommunityModeratorView::for_person(context.pool(), person_details_id).await?;
|
||||||
|
|
||||||
|
// Return the jwt
|
||||||
|
Ok(Json(GetPersonDetailsResponse {
|
||||||
|
person_view,
|
||||||
|
moderates,
|
||||||
|
comments,
|
||||||
|
posts,
|
||||||
|
}))
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,6 @@
|
||||||
use crate::{
|
use crate::fetcher::search::{search_query_to_object_id, SearchableObjects};
|
||||||
api::PerformApub,
|
|
||||||
fetcher::search::{search_query_to_object_id, SearchableObjects},
|
|
||||||
};
|
|
||||||
use activitypub_federation::config::Data;
|
use activitypub_federation::config::Data;
|
||||||
|
use actix_web::web::{Json, Query};
|
||||||
use diesel::NotFound;
|
use diesel::NotFound;
|
||||||
use lemmy_api_common::{
|
use lemmy_api_common::{
|
||||||
context::LemmyContext,
|
context::LemmyContext,
|
||||||
|
@ -14,34 +12,29 @@ use lemmy_db_views::structs::{CommentView, PostView};
|
||||||
use lemmy_db_views_actor::structs::{CommunityView, PersonView};
|
use lemmy_db_views_actor::structs::{CommunityView, PersonView};
|
||||||
use lemmy_utils::error::LemmyError;
|
use lemmy_utils::error::LemmyError;
|
||||||
|
|
||||||
#[async_trait::async_trait]
|
#[tracing::instrument(skip(context))]
|
||||||
impl PerformApub for ResolveObject {
|
pub async fn resolve_object(
|
||||||
type Response = ResolveObjectResponse;
|
data: Query<ResolveObject>,
|
||||||
|
context: Data<LemmyContext>,
|
||||||
|
) -> Result<Json<ResolveObjectResponse>, LemmyError> {
|
||||||
|
let local_user_view = local_user_view_from_jwt(&data.auth, &context).await?;
|
||||||
|
let local_site = LocalSite::read(context.pool()).await?;
|
||||||
|
let person_id = local_user_view.person.id;
|
||||||
|
check_private_instance(&Some(local_user_view), &local_site)?;
|
||||||
|
|
||||||
#[tracing::instrument(skip(context))]
|
let res = search_query_to_object_id(&data.q, &context)
|
||||||
async fn perform(
|
.await
|
||||||
&self,
|
.map_err(|e| e.with_message("couldnt_find_object"))?;
|
||||||
context: &Data<LemmyContext>,
|
convert_response(res, person_id, context.pool())
|
||||||
) -> Result<ResolveObjectResponse, LemmyError> {
|
.await
|
||||||
let local_user_view = local_user_view_from_jwt(&self.auth, context).await?;
|
.map_err(|e| e.with_message("couldnt_find_object"))
|
||||||
let local_site = LocalSite::read(context.pool()).await?;
|
|
||||||
let person_id = local_user_view.person.id;
|
|
||||||
check_private_instance(&Some(local_user_view), &local_site)?;
|
|
||||||
|
|
||||||
let res = search_query_to_object_id(&self.q, context)
|
|
||||||
.await
|
|
||||||
.map_err(|e| e.with_message("couldnt_find_object"))?;
|
|
||||||
convert_response(res, person_id, context.pool())
|
|
||||||
.await
|
|
||||||
.map_err(|e| e.with_message("couldnt_find_object"))
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn convert_response(
|
async fn convert_response(
|
||||||
object: SearchableObjects,
|
object: SearchableObjects,
|
||||||
user_id: PersonId,
|
user_id: PersonId,
|
||||||
pool: &DbPool,
|
pool: &DbPool,
|
||||||
) -> Result<ResolveObjectResponse, LemmyError> {
|
) -> Result<Json<ResolveObjectResponse>, LemmyError> {
|
||||||
use SearchableObjects::*;
|
use SearchableObjects::*;
|
||||||
let removed_or_deleted;
|
let removed_or_deleted;
|
||||||
let mut res = ResolveObjectResponse::default();
|
let mut res = ResolveObjectResponse::default();
|
||||||
|
@ -67,5 +60,5 @@ async fn convert_response(
|
||||||
if removed_or_deleted {
|
if removed_or_deleted {
|
||||||
return Err(NotFound {}.into());
|
return Err(NotFound {}.into());
|
||||||
}
|
}
|
||||||
Ok(res)
|
Ok(Json(res))
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
use crate::{
|
use crate::{fetcher::resolve_actor_identifier, objects::community::ApubCommunity};
|
||||||
api::PerformApub,
|
|
||||||
fetcher::resolve_actor_identifier,
|
|
||||||
objects::community::ApubCommunity,
|
|
||||||
};
|
|
||||||
use activitypub_federation::config::Data;
|
use activitypub_federation::config::Data;
|
||||||
|
use actix_web::web::{Json, Query};
|
||||||
use lemmy_api_common::{
|
use lemmy_api_common::{
|
||||||
context::LemmyContext,
|
context::LemmyContext,
|
||||||
site::{Search, SearchResponse},
|
site::{Search, SearchResponse},
|
||||||
|
@ -18,78 +15,142 @@ use lemmy_db_views::{comment_view::CommentQuery, post_view::PostQuery};
|
||||||
use lemmy_db_views_actor::{community_view::CommunityQuery, person_view::PersonQuery};
|
use lemmy_db_views_actor::{community_view::CommunityQuery, person_view::PersonQuery};
|
||||||
use lemmy_utils::error::LemmyError;
|
use lemmy_utils::error::LemmyError;
|
||||||
|
|
||||||
#[async_trait::async_trait]
|
#[tracing::instrument(skip(context))]
|
||||||
impl PerformApub for Search {
|
pub async fn search(
|
||||||
type Response = SearchResponse;
|
data: Query<Search>,
|
||||||
|
context: Data<LemmyContext>,
|
||||||
|
) -> Result<Json<SearchResponse>, LemmyError> {
|
||||||
|
let local_user_view = local_user_view_from_jwt_opt(data.auth.as_ref(), &context).await;
|
||||||
|
let local_site = LocalSite::read(context.pool()).await?;
|
||||||
|
|
||||||
#[tracing::instrument(skip(context))]
|
check_private_instance(&local_user_view, &local_site)?;
|
||||||
async fn perform(&self, context: &Data<LemmyContext>) -> Result<SearchResponse, LemmyError> {
|
|
||||||
let data: &Search = self;
|
|
||||||
|
|
||||||
let local_user_view = local_user_view_from_jwt_opt(data.auth.as_ref(), context).await;
|
let is_admin = local_user_view.as_ref().map(|luv| is_admin(luv).is_ok());
|
||||||
let local_site = LocalSite::read(context.pool()).await?;
|
|
||||||
|
|
||||||
check_private_instance(&local_user_view, &local_site)?;
|
let mut posts = Vec::new();
|
||||||
|
let mut comments = Vec::new();
|
||||||
|
let mut communities = Vec::new();
|
||||||
|
let mut users = Vec::new();
|
||||||
|
|
||||||
let is_admin = local_user_view.as_ref().map(|luv| is_admin(luv).is_ok());
|
// TODO no clean / non-nsfw searching rn
|
||||||
|
|
||||||
let mut posts = Vec::new();
|
let q = data.q.clone();
|
||||||
let mut comments = Vec::new();
|
let page = data.page;
|
||||||
let mut communities = Vec::new();
|
let limit = data.limit;
|
||||||
let mut users = Vec::new();
|
let sort = data.sort;
|
||||||
|
let listing_type = data.listing_type;
|
||||||
|
let search_type = data.type_.unwrap_or(SearchType::All);
|
||||||
|
let community_id = if let Some(name) = &data.community_name {
|
||||||
|
resolve_actor_identifier::<ApubCommunity, Community>(name, &context, &local_user_view, false)
|
||||||
|
.await
|
||||||
|
.ok()
|
||||||
|
.map(|c| c.id)
|
||||||
|
} else {
|
||||||
|
data.community_id
|
||||||
|
};
|
||||||
|
let creator_id = data.creator_id;
|
||||||
|
let local_user = local_user_view.map(|l| l.local_user);
|
||||||
|
match search_type {
|
||||||
|
SearchType::Posts => {
|
||||||
|
posts = PostQuery::builder()
|
||||||
|
.pool(context.pool())
|
||||||
|
.sort(sort)
|
||||||
|
.listing_type(listing_type)
|
||||||
|
.community_id(community_id)
|
||||||
|
.creator_id(creator_id)
|
||||||
|
.local_user(local_user.as_ref())
|
||||||
|
.search_term(Some(q))
|
||||||
|
.is_mod_or_admin(is_admin)
|
||||||
|
.page(page)
|
||||||
|
.limit(limit)
|
||||||
|
.build()
|
||||||
|
.list()
|
||||||
|
.await?;
|
||||||
|
}
|
||||||
|
SearchType::Comments => {
|
||||||
|
comments = CommentQuery::builder()
|
||||||
|
.pool(context.pool())
|
||||||
|
.sort(sort.map(post_to_comment_sort_type))
|
||||||
|
.listing_type(listing_type)
|
||||||
|
.search_term(Some(q))
|
||||||
|
.community_id(community_id)
|
||||||
|
.creator_id(creator_id)
|
||||||
|
.local_user(local_user.as_ref())
|
||||||
|
.page(page)
|
||||||
|
.limit(limit)
|
||||||
|
.build()
|
||||||
|
.list()
|
||||||
|
.await?;
|
||||||
|
}
|
||||||
|
SearchType::Communities => {
|
||||||
|
communities = CommunityQuery::builder()
|
||||||
|
.pool(context.pool())
|
||||||
|
.sort(sort)
|
||||||
|
.listing_type(listing_type)
|
||||||
|
.search_term(Some(q))
|
||||||
|
.local_user(local_user.as_ref())
|
||||||
|
.is_mod_or_admin(is_admin)
|
||||||
|
.page(page)
|
||||||
|
.limit(limit)
|
||||||
|
.build()
|
||||||
|
.list()
|
||||||
|
.await?;
|
||||||
|
}
|
||||||
|
SearchType::Users => {
|
||||||
|
users = PersonQuery::builder()
|
||||||
|
.pool(context.pool())
|
||||||
|
.sort(sort)
|
||||||
|
.search_term(Some(q))
|
||||||
|
.page(page)
|
||||||
|
.limit(limit)
|
||||||
|
.build()
|
||||||
|
.list()
|
||||||
|
.await?;
|
||||||
|
}
|
||||||
|
SearchType::All => {
|
||||||
|
// If the community or creator is included, dont search communities or users
|
||||||
|
let community_or_creator_included =
|
||||||
|
data.community_id.is_some() || data.community_name.is_some() || data.creator_id.is_some();
|
||||||
|
|
||||||
// TODO no clean / non-nsfw searching rn
|
let local_user_ = local_user.clone();
|
||||||
|
posts = PostQuery::builder()
|
||||||
|
.pool(context.pool())
|
||||||
|
.sort(sort)
|
||||||
|
.listing_type(listing_type)
|
||||||
|
.community_id(community_id)
|
||||||
|
.creator_id(creator_id)
|
||||||
|
.local_user(local_user_.as_ref())
|
||||||
|
.search_term(Some(q))
|
||||||
|
.is_mod_or_admin(is_admin)
|
||||||
|
.page(page)
|
||||||
|
.limit(limit)
|
||||||
|
.build()
|
||||||
|
.list()
|
||||||
|
.await?;
|
||||||
|
|
||||||
let q = data.q.clone();
|
let q = data.q.clone();
|
||||||
let page = data.page;
|
|
||||||
let limit = data.limit;
|
let local_user_ = local_user.clone();
|
||||||
let sort = data.sort;
|
comments = CommentQuery::builder()
|
||||||
let listing_type = data.listing_type;
|
.pool(context.pool())
|
||||||
let search_type = data.type_.unwrap_or(SearchType::All);
|
.sort(sort.map(post_to_comment_sort_type))
|
||||||
let community_id = if let Some(name) = &data.community_name {
|
.listing_type(listing_type)
|
||||||
resolve_actor_identifier::<ApubCommunity, Community>(name, context, &local_user_view, false)
|
.search_term(Some(q))
|
||||||
.await
|
.community_id(community_id)
|
||||||
.ok()
|
.creator_id(creator_id)
|
||||||
.map(|c| c.id)
|
.local_user(local_user_.as_ref())
|
||||||
} else {
|
.page(page)
|
||||||
data.community_id
|
.limit(limit)
|
||||||
};
|
.build()
|
||||||
let creator_id = data.creator_id;
|
.list()
|
||||||
let local_user = local_user_view.map(|l| l.local_user);
|
.await?;
|
||||||
match search_type {
|
|
||||||
SearchType::Posts => {
|
let q = data.q.clone();
|
||||||
posts = PostQuery::builder()
|
|
||||||
.pool(context.pool())
|
communities = if community_or_creator_included {
|
||||||
.sort(sort)
|
vec![]
|
||||||
.listing_type(listing_type)
|
} else {
|
||||||
.community_id(community_id)
|
CommunityQuery::builder()
|
||||||
.creator_id(creator_id)
|
|
||||||
.local_user(local_user.as_ref())
|
|
||||||
.search_term(Some(q))
|
|
||||||
.is_mod_or_admin(is_admin)
|
|
||||||
.page(page)
|
|
||||||
.limit(limit)
|
|
||||||
.build()
|
|
||||||
.list()
|
|
||||||
.await?;
|
|
||||||
}
|
|
||||||
SearchType::Comments => {
|
|
||||||
comments = CommentQuery::builder()
|
|
||||||
.pool(context.pool())
|
|
||||||
.sort(sort.map(post_to_comment_sort_type))
|
|
||||||
.listing_type(listing_type)
|
|
||||||
.search_term(Some(q))
|
|
||||||
.community_id(community_id)
|
|
||||||
.creator_id(creator_id)
|
|
||||||
.local_user(local_user.as_ref())
|
|
||||||
.page(page)
|
|
||||||
.limit(limit)
|
|
||||||
.build()
|
|
||||||
.list()
|
|
||||||
.await?;
|
|
||||||
}
|
|
||||||
SearchType::Communities => {
|
|
||||||
communities = CommunityQuery::builder()
|
|
||||||
.pool(context.pool())
|
.pool(context.pool())
|
||||||
.sort(sort)
|
.sort(sort)
|
||||||
.listing_type(listing_type)
|
.listing_type(listing_type)
|
||||||
|
@ -100,10 +161,15 @@ impl PerformApub for Search {
|
||||||
.limit(limit)
|
.limit(limit)
|
||||||
.build()
|
.build()
|
||||||
.list()
|
.list()
|
||||||
.await?;
|
.await?
|
||||||
}
|
};
|
||||||
SearchType::Users => {
|
|
||||||
users = PersonQuery::builder()
|
let q = data.q.clone();
|
||||||
|
|
||||||
|
users = if community_or_creator_included {
|
||||||
|
vec![]
|
||||||
|
} else {
|
||||||
|
PersonQuery::builder()
|
||||||
.pool(context.pool())
|
.pool(context.pool())
|
||||||
.sort(sort)
|
.sort(sort)
|
||||||
.search_term(Some(q))
|
.search_term(Some(q))
|
||||||
|
@ -111,105 +177,32 @@ impl PerformApub for Search {
|
||||||
.limit(limit)
|
.limit(limit)
|
||||||
.build()
|
.build()
|
||||||
.list()
|
.list()
|
||||||
.await?;
|
.await?
|
||||||
}
|
};
|
||||||
SearchType::All => {
|
}
|
||||||
// If the community or creator is included, dont search communities or users
|
SearchType::Url => {
|
||||||
let community_or_creator_included =
|
posts = PostQuery::builder()
|
||||||
data.community_id.is_some() || data.community_name.is_some() || data.creator_id.is_some();
|
.pool(context.pool())
|
||||||
|
.sort(sort)
|
||||||
|
.listing_type(listing_type)
|
||||||
|
.community_id(community_id)
|
||||||
|
.creator_id(creator_id)
|
||||||
|
.url_search(Some(q))
|
||||||
|
.is_mod_or_admin(is_admin)
|
||||||
|
.page(page)
|
||||||
|
.limit(limit)
|
||||||
|
.build()
|
||||||
|
.list()
|
||||||
|
.await?;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
let local_user_ = local_user.clone();
|
// Return the jwt
|
||||||
posts = PostQuery::builder()
|
Ok(Json(SearchResponse {
|
||||||
.pool(context.pool())
|
type_: search_type,
|
||||||
.sort(sort)
|
comments,
|
||||||
.listing_type(listing_type)
|
posts,
|
||||||
.community_id(community_id)
|
communities,
|
||||||
.creator_id(creator_id)
|
users,
|
||||||
.local_user(local_user_.as_ref())
|
}))
|
||||||
.search_term(Some(q))
|
|
||||||
.is_mod_or_admin(is_admin)
|
|
||||||
.page(page)
|
|
||||||
.limit(limit)
|
|
||||||
.build()
|
|
||||||
.list()
|
|
||||||
.await?;
|
|
||||||
|
|
||||||
let q = data.q.clone();
|
|
||||||
|
|
||||||
let local_user_ = local_user.clone();
|
|
||||||
comments = CommentQuery::builder()
|
|
||||||
.pool(context.pool())
|
|
||||||
.sort(sort.map(post_to_comment_sort_type))
|
|
||||||
.listing_type(listing_type)
|
|
||||||
.search_term(Some(q))
|
|
||||||
.community_id(community_id)
|
|
||||||
.creator_id(creator_id)
|
|
||||||
.local_user(local_user_.as_ref())
|
|
||||||
.page(page)
|
|
||||||
.limit(limit)
|
|
||||||
.build()
|
|
||||||
.list()
|
|
||||||
.await?;
|
|
||||||
|
|
||||||
let q = data.q.clone();
|
|
||||||
|
|
||||||
communities = if community_or_creator_included {
|
|
||||||
vec![]
|
|
||||||
} else {
|
|
||||||
CommunityQuery::builder()
|
|
||||||
.pool(context.pool())
|
|
||||||
.sort(sort)
|
|
||||||
.listing_type(listing_type)
|
|
||||||
.search_term(Some(q))
|
|
||||||
.local_user(local_user.as_ref())
|
|
||||||
.is_mod_or_admin(is_admin)
|
|
||||||
.page(page)
|
|
||||||
.limit(limit)
|
|
||||||
.build()
|
|
||||||
.list()
|
|
||||||
.await?
|
|
||||||
};
|
|
||||||
|
|
||||||
let q = data.q.clone();
|
|
||||||
|
|
||||||
users = if community_or_creator_included {
|
|
||||||
vec![]
|
|
||||||
} else {
|
|
||||||
PersonQuery::builder()
|
|
||||||
.pool(context.pool())
|
|
||||||
.sort(sort)
|
|
||||||
.search_term(Some(q))
|
|
||||||
.page(page)
|
|
||||||
.limit(limit)
|
|
||||||
.build()
|
|
||||||
.list()
|
|
||||||
.await?
|
|
||||||
};
|
|
||||||
}
|
|
||||||
SearchType::Url => {
|
|
||||||
posts = PostQuery::builder()
|
|
||||||
.pool(context.pool())
|
|
||||||
.sort(sort)
|
|
||||||
.listing_type(listing_type)
|
|
||||||
.community_id(community_id)
|
|
||||||
.creator_id(creator_id)
|
|
||||||
.url_search(Some(q))
|
|
||||||
.is_mod_or_admin(is_admin)
|
|
||||||
.page(page)
|
|
||||||
.limit(limit)
|
|
||||||
.build()
|
|
||||||
.list()
|
|
||||||
.await?;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// Return the jwt
|
|
||||||
Ok(SearchResponse {
|
|
||||||
type_: search_type,
|
|
||||||
comments,
|
|
||||||
posts,
|
|
||||||
communities,
|
|
||||||
users,
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,6 @@ use lemmy_api_common::{
|
||||||
DistinguishComment,
|
DistinguishComment,
|
||||||
EditComment,
|
EditComment,
|
||||||
GetComment,
|
GetComment,
|
||||||
GetComments,
|
|
||||||
ListCommentReports,
|
ListCommentReports,
|
||||||
RemoveComment,
|
RemoveComment,
|
||||||
ResolveCommentReport,
|
ResolveCommentReport,
|
||||||
|
@ -23,7 +22,6 @@ use lemmy_api_common::{
|
||||||
DeleteCommunity,
|
DeleteCommunity,
|
||||||
EditCommunity,
|
EditCommunity,
|
||||||
FollowCommunity,
|
FollowCommunity,
|
||||||
GetCommunity,
|
|
||||||
HideCommunity,
|
HideCommunity,
|
||||||
ListCommunities,
|
ListCommunities,
|
||||||
RemoveCommunity,
|
RemoveCommunity,
|
||||||
|
@ -39,7 +37,6 @@ use lemmy_api_common::{
|
||||||
DeleteAccount,
|
DeleteAccount,
|
||||||
GetBannedPersons,
|
GetBannedPersons,
|
||||||
GetCaptcha,
|
GetCaptcha,
|
||||||
GetPersonDetails,
|
|
||||||
GetPersonMentions,
|
GetPersonMentions,
|
||||||
GetReplies,
|
GetReplies,
|
||||||
GetReportCount,
|
GetReportCount,
|
||||||
|
@ -62,7 +59,6 @@ use lemmy_api_common::{
|
||||||
EditPost,
|
EditPost,
|
||||||
FeaturePost,
|
FeaturePost,
|
||||||
GetPost,
|
GetPost,
|
||||||
GetPosts,
|
|
||||||
GetSiteMetadata,
|
GetSiteMetadata,
|
||||||
ListPostReports,
|
ListPostReports,
|
||||||
LockPost,
|
LockPost,
|
||||||
|
@ -95,12 +91,20 @@ use lemmy_api_common::{
|
||||||
PurgeCommunity,
|
PurgeCommunity,
|
||||||
PurgePerson,
|
PurgePerson,
|
||||||
PurgePost,
|
PurgePost,
|
||||||
ResolveObject,
|
|
||||||
Search,
|
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
use lemmy_api_crud::PerformCrud;
|
use lemmy_api_crud::PerformCrud;
|
||||||
use lemmy_apub::{api::PerformApub, SendActivity};
|
use lemmy_apub::{
|
||||||
|
api::{
|
||||||
|
list_comments::list_comments,
|
||||||
|
list_posts::list_posts,
|
||||||
|
read_community::read_community,
|
||||||
|
read_person::read_person,
|
||||||
|
resolve_object::resolve_object,
|
||||||
|
search::search,
|
||||||
|
},
|
||||||
|
SendActivity,
|
||||||
|
};
|
||||||
use lemmy_utils::rate_limit::RateLimitCell;
|
use lemmy_utils::rate_limit::RateLimitCell;
|
||||||
use serde::Deserialize;
|
use serde::Deserialize;
|
||||||
|
|
||||||
|
@ -124,12 +128,12 @@ pub fn config(cfg: &mut web::ServiceConfig, rate_limit: &RateLimitCell) {
|
||||||
.service(
|
.service(
|
||||||
web::resource("/search")
|
web::resource("/search")
|
||||||
.wrap(rate_limit.search())
|
.wrap(rate_limit.search())
|
||||||
.route(web::get().to(route_get_apub::<Search>)),
|
.route(web::get().to(search)),
|
||||||
)
|
)
|
||||||
.service(
|
.service(
|
||||||
web::resource("/resolve_object")
|
web::resource("/resolve_object")
|
||||||
.wrap(rate_limit.message())
|
.wrap(rate_limit.message())
|
||||||
.route(web::get().to(route_get_apub::<ResolveObject>)),
|
.route(web::get().to(resolve_object)),
|
||||||
)
|
)
|
||||||
// Community
|
// Community
|
||||||
.service(
|
.service(
|
||||||
|
@ -141,7 +145,7 @@ pub fn config(cfg: &mut web::ServiceConfig, rate_limit: &RateLimitCell) {
|
||||||
.service(
|
.service(
|
||||||
web::scope("/community")
|
web::scope("/community")
|
||||||
.wrap(rate_limit.message())
|
.wrap(rate_limit.message())
|
||||||
.route("", web::get().to(route_get_apub::<GetCommunity>))
|
.route("", web::get().to(read_community))
|
||||||
.route("", web::put().to(route_post_crud::<EditCommunity>))
|
.route("", web::put().to(route_post_crud::<EditCommunity>))
|
||||||
.route("/hide", web::put().to(route_post::<HideCommunity>))
|
.route("/hide", web::put().to(route_post::<HideCommunity>))
|
||||||
.route("/list", web::get().to(route_get_crud::<ListCommunities>))
|
.route("/list", web::get().to(route_get_crud::<ListCommunities>))
|
||||||
|
@ -186,7 +190,7 @@ pub fn config(cfg: &mut web::ServiceConfig, rate_limit: &RateLimitCell) {
|
||||||
)
|
)
|
||||||
.route("/lock", web::post().to(route_post::<LockPost>))
|
.route("/lock", web::post().to(route_post::<LockPost>))
|
||||||
.route("/feature", web::post().to(route_post::<FeaturePost>))
|
.route("/feature", web::post().to(route_post::<FeaturePost>))
|
||||||
.route("/list", web::get().to(route_get_apub::<GetPosts>))
|
.route("/list", web::get().to(list_posts))
|
||||||
.route("/like", web::post().to(route_post::<CreatePostLike>))
|
.route("/like", web::post().to(route_post::<CreatePostLike>))
|
||||||
.route("/save", web::put().to(route_post::<SavePost>))
|
.route("/save", web::put().to(route_post::<SavePost>))
|
||||||
.route("/report", web::post().to(route_post::<CreatePostReport>))
|
.route("/report", web::post().to(route_post::<CreatePostReport>))
|
||||||
|
@ -225,7 +229,7 @@ pub fn config(cfg: &mut web::ServiceConfig, rate_limit: &RateLimitCell) {
|
||||||
)
|
)
|
||||||
.route("/like", web::post().to(route_post::<CreateCommentLike>))
|
.route("/like", web::post().to(route_post::<CreateCommentLike>))
|
||||||
.route("/save", web::put().to(route_post::<SaveComment>))
|
.route("/save", web::put().to(route_post::<SaveComment>))
|
||||||
.route("/list", web::get().to(route_get_apub::<GetComments>))
|
.route("/list", web::get().to(list_comments))
|
||||||
.route("/report", web::post().to(route_post::<CreateCommentReport>))
|
.route("/report", web::post().to(route_post::<CreateCommentReport>))
|
||||||
.route(
|
.route(
|
||||||
"/report/resolve",
|
"/report/resolve",
|
||||||
|
@ -283,7 +287,7 @@ pub fn config(cfg: &mut web::ServiceConfig, rate_limit: &RateLimitCell) {
|
||||||
.service(
|
.service(
|
||||||
web::scope("/user")
|
web::scope("/user")
|
||||||
.wrap(rate_limit.message())
|
.wrap(rate_limit.message())
|
||||||
.route("", web::get().to(route_get_apub::<GetPersonDetails>))
|
.route("", web::get().to(read_person))
|
||||||
.route("/mention", web::get().to(route_get::<GetPersonMentions>))
|
.route("/mention", web::get().to(route_get::<GetPersonMentions>))
|
||||||
.route(
|
.route(
|
||||||
"/mention/mark_as_read",
|
"/mention/mark_as_read",
|
||||||
|
@ -398,23 +402,6 @@ where
|
||||||
perform::<Data>(data.0, context, apub_data).await
|
perform::<Data>(data.0, context, apub_data).await
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn route_get_apub<'a, Data>(
|
|
||||||
data: web::Query<Data>,
|
|
||||||
context: activitypub_federation::config::Data<LemmyContext>,
|
|
||||||
) -> Result<HttpResponse, Error>
|
|
||||||
where
|
|
||||||
Data: PerformApub
|
|
||||||
+ SendActivity<Response = <Data as PerformApub>::Response>
|
|
||||||
+ Clone
|
|
||||||
+ Deserialize<'a>
|
|
||||||
+ Send
|
|
||||||
+ 'static,
|
|
||||||
{
|
|
||||||
let res = data.perform(&context).await?;
|
|
||||||
SendActivity::send_activity(&data.0, &res, &context).await?;
|
|
||||||
Ok(HttpResponse::Ok().json(res))
|
|
||||||
}
|
|
||||||
|
|
||||||
async fn route_post<'a, Data>(
|
async fn route_post<'a, Data>(
|
||||||
data: web::Json<Data>,
|
data: web::Json<Data>,
|
||||||
context: web::Data<LemmyContext>,
|
context: web::Data<LemmyContext>,
|
||||||
|
|
Loading…
Reference in a new issue