]> Untitled Git - lemmy.git/blobdiff - crates/apub/src/http/routes.rs
Implement separate mod activities for feature, lock post (#2716)
[lemmy.git] / crates / apub / src / http / routes.rs
index ea54cd482b2003d47985f5f9962d1730f5f3233d..4d4941f534d83def72239d750e30a34a87b8e02c 100644 (file)
@@ -2,6 +2,7 @@ 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,
@@ -11,51 +12,58 @@ use crate::http::{
   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_inbox, get_apub_site_outbox},
+};
+use actix_web::{
+  guard::{Guard, GuardContext},
+  http::{header, Method},
+  web,
 };
-use actix_web::{dev::RequestHead, guard::Guard, http::Method, *};
 use http_signature_normalization_actix::digest::middleware::VerifyDigest;
-use lemmy_utils::settings::structs::Settings;
 use sha2::{Digest, Sha256};
 
-pub fn config(cfg: &mut web::ServiceConfig, settings: &Settings) {
-  if settings.federation.enabled {
-    println!("federation enabled, host is {}", settings.hostname);
-
-    cfg
-      .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}/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));
+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("")
-        .wrap(VerifyDigest::new(Sha256::new()))
-        .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)),
-    );
-  }
+  cfg.service(
+    web::scope("")
+      .wrap(VerifyDigest::new(Sha256::new()))
+      .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))
+      .route("/site_inbox", web::post().to(get_apub_site_inbox)),
+  );
 }
 
 /// Without this, things like webfinger or RSS feeds stop working, as all requests seem to get
@@ -64,15 +72,12 @@ pub fn config(cfg: &mut web::ServiceConfig, settings: &Settings) {
 struct InboxRequestGuard;
 
 impl Guard for InboxRequestGuard {
-  fn check(&self, request: &RequestHead) -> bool {
-    if request.method != Method::POST {
+  fn check(&self, ctx: &GuardContext) -> bool {
+    if ctx.head().method != Method::POST {
       return false;
     }
-    if let Some(val) = request.headers.get("Content-Type") {
-      return val
-        .to_str()
-        .expect("Content-Type header contains non-ascii chars.")
-        .starts_with("application/");
+    if let Some(val) = ctx.head().headers.get(header::CONTENT_TYPE) {
+      return val.as_bytes().starts_with(b"application/");
     }
     false
   }