mirror of
https://github.com/LemmyNet/lemmy.git
synced 2025-01-10 03:55:54 +00:00
d075acce43
- Diesel ordinarily throws an error when no results are returned for a single fetch, which is a bit confusing. This PR ensures that the missing value cases are all caught, and wrapped with new LemmyErrors, rather than diesel errors. - Fixes #4601
50 lines
1.5 KiB
Rust
50 lines
1.5 KiB
Rust
use crate::{
|
|
http::{
|
|
check_community_public,
|
|
create_apub_response,
|
|
create_apub_tombstone_response,
|
|
redirect_remote_object,
|
|
},
|
|
objects::post::ApubPost,
|
|
};
|
|
use activitypub_federation::{config::Data, traits::Object};
|
|
use actix_web::{web, HttpResponse};
|
|
use lemmy_api_common::context::LemmyContext;
|
|
use lemmy_db_schema::{
|
|
newtypes::PostId,
|
|
source::{community::Community, post::Post},
|
|
traits::Crud,
|
|
};
|
|
use lemmy_utils::{error::LemmyResult, LemmyErrorType};
|
|
use serde::Deserialize;
|
|
|
|
#[derive(Deserialize)]
|
|
pub(crate) struct PostQuery {
|
|
post_id: String,
|
|
}
|
|
|
|
/// Return the ActivityPub json representation of a local post over HTTP.
|
|
#[tracing::instrument(skip_all)]
|
|
pub(crate) async fn get_apub_post(
|
|
info: web::Path<PostQuery>,
|
|
context: Data<LemmyContext>,
|
|
) -> LemmyResult<HttpResponse> {
|
|
let id = PostId(info.post_id.parse::<i32>()?);
|
|
// Can't use PostView here because it excludes deleted/removed/local-only items
|
|
let post: ApubPost = Post::read(&mut context.pool(), id)
|
|
.await?
|
|
.ok_or(LemmyErrorType::CouldntFindPost)?
|
|
.into();
|
|
let community = Community::read(&mut context.pool(), post.community_id)
|
|
.await?
|
|
.ok_or(LemmyErrorType::CouldntFindCommunity)?;
|
|
check_community_public(&community)?;
|
|
|
|
if !post.local {
|
|
Ok(redirect_remote_object(&post.ap_id))
|
|
} else if !post.deleted && !post.removed {
|
|
create_apub_response(&post.into_json(&context).await?)
|
|
} else {
|
|
create_apub_tombstone_response(post.ap_id.clone())
|
|
}
|
|
}
|