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
32 lines
1 KiB
Rust
32 lines
1 KiB
Rust
use crate::{
|
|
http::create_apub_response,
|
|
objects::instance::ApubSite,
|
|
protocol::collections::empty_outbox::EmptyOutbox,
|
|
};
|
|
use activitypub_federation::{config::Data, traits::Object};
|
|
use actix_web::HttpResponse;
|
|
use lemmy_api_common::context::LemmyContext;
|
|
use lemmy_db_views::structs::SiteView;
|
|
use lemmy_utils::{error::LemmyResult, LemmyErrorType};
|
|
use url::Url;
|
|
|
|
pub(crate) async fn get_apub_site_http(context: Data<LemmyContext>) -> LemmyResult<HttpResponse> {
|
|
let site: ApubSite = SiteView::read_local(&mut context.pool())
|
|
.await?
|
|
.ok_or(LemmyErrorType::LocalSiteNotSetup)?
|
|
.site
|
|
.into();
|
|
|
|
let apub = site.into_json(&context).await?;
|
|
create_apub_response(&apub)
|
|
}
|
|
|
|
#[tracing::instrument(skip_all)]
|
|
pub(crate) async fn get_apub_site_outbox(context: Data<LemmyContext>) -> LemmyResult<HttpResponse> {
|
|
let outbox_id = format!(
|
|
"{}/site_outbox",
|
|
context.settings().get_protocol_and_hostname()
|
|
);
|
|
let outbox = EmptyOutbox::new(Url::parse(&outbox_id)?)?;
|
|
create_apub_response(&outbox)
|
|
}
|