Nutomic
a00313e680
* Merge /site_inbox into /inbox (fixes #4137) Get rid of different inboxes, only use /inbox Remove shared_inbox_url db columns add code migration move to db migration, fixes machete fix sql drop inbox url unique constraints Dont create auth cookie in backend (#4136) dont change individual inboxes to shared inbox Dont send comment reply to user who has community blocked. Fixes #3684 (#4096) * Dont send comment reply to user who has community blocked. Fixes #3684 * Adding source instance block check. * Adding api test. * Addressing PR comments. * move site inbox rewrite to db * fix test * clippy * clippy 2 * fix test
80 lines
2.4 KiB
Rust
80 lines
2.4 KiB
Rust
use crate::http::{
|
|
comment::get_apub_comment,
|
|
community::{
|
|
community_inbox,
|
|
get_apub_community_featured,
|
|
get_apub_community_followers,
|
|
get_apub_community_http,
|
|
get_apub_community_moderators,
|
|
get_apub_community_outbox,
|
|
},
|
|
get_activity,
|
|
person::{get_apub_person_http, get_apub_person_outbox, person_inbox},
|
|
post::get_apub_post,
|
|
shared_inbox,
|
|
site::{get_apub_site_http, get_apub_site_outbox},
|
|
};
|
|
use actix_web::{
|
|
guard::{Guard, GuardContext},
|
|
http::{header, Method},
|
|
web,
|
|
};
|
|
|
|
pub fn config(cfg: &mut web::ServiceConfig) {
|
|
cfg
|
|
.route("/", web::get().to(get_apub_site_http))
|
|
.route("/site_outbox", web::get().to(get_apub_site_outbox))
|
|
.route(
|
|
"/c/{community_name}",
|
|
web::get().to(get_apub_community_http),
|
|
)
|
|
.route(
|
|
"/c/{community_name}/followers",
|
|
web::get().to(get_apub_community_followers),
|
|
)
|
|
.route(
|
|
"/c/{community_name}/outbox",
|
|
web::get().to(get_apub_community_outbox),
|
|
)
|
|
.route(
|
|
"/c/{community_name}/featured",
|
|
web::get().to(get_apub_community_featured),
|
|
)
|
|
.route(
|
|
"/c/{community_name}/moderators",
|
|
web::get().to(get_apub_community_moderators),
|
|
)
|
|
.route("/u/{user_name}", web::get().to(get_apub_person_http))
|
|
.route(
|
|
"/u/{user_name}/outbox",
|
|
web::get().to(get_apub_person_outbox),
|
|
)
|
|
.route("/post/{post_id}", web::get().to(get_apub_post))
|
|
.route("/comment/{comment_id}", web::get().to(get_apub_comment))
|
|
.route("/activities/{type_}/{id}", web::get().to(get_activity));
|
|
|
|
cfg.service(
|
|
web::scope("")
|
|
.guard(InboxRequestGuard)
|
|
.route("/c/{community_name}/inbox", web::post().to(community_inbox))
|
|
.route("/u/{user_name}/inbox", web::post().to(person_inbox))
|
|
.route("/inbox", web::post().to(shared_inbox)),
|
|
);
|
|
}
|
|
|
|
/// Without this, things like webfinger or RSS feeds stop working, as all requests seem to get
|
|
/// routed into the inbox service (because it covers the root path). So we filter out anything that
|
|
/// definitely can't be an inbox request (based on Accept header and request method).
|
|
struct InboxRequestGuard;
|
|
|
|
impl Guard for InboxRequestGuard {
|
|
fn check(&self, ctx: &GuardContext) -> bool {
|
|
if ctx.head().method != Method::POST {
|
|
return false;
|
|
}
|
|
if let Some(val) = ctx.head().headers.get(header::CONTENT_TYPE) {
|
|
return val.as_bytes().starts_with(b"application/");
|
|
}
|
|
false
|
|
}
|
|
}
|