lemmy/server/src/routes/federation.rs

58 lines
1.9 KiB
Rust
Raw Normal View History

use crate::apub::{
comment::get_apub_comment,
community::*,
inbox::{community_inbox::community_inbox, shared_inbox::shared_inbox, user_inbox::user_inbox},
post::get_apub_post,
user::*,
APUB_JSON_CONTENT_TYPE,
2020-05-16 14:04:08 +00:00
};
use actix_web::*;
use http_signature_normalization_actix::digest::middleware::VerifyDigest;
use lemmy_utils::settings::Settings;
use sha2::{Digest, Sha256};
pub fn config(cfg: &mut web::ServiceConfig) {
2020-03-18 21:09:00 +00:00
if Settings::get().federation.enabled {
2020-01-02 18:22:23 +00:00
println!("federation enabled, host is {}", Settings::get().hostname);
let digest_verifier = VerifyDigest::new(Sha256::new());
2020-01-02 18:22:23 +00:00
cfg
.service(
web::scope("/")
2020-04-22 18:56:31 +00:00
.guard(guard::Header("Accept", APUB_JSON_CONTENT_TYPE))
.route(
"/c/{community_name}",
web::get().to(get_apub_community_http),
)
.route(
"/c/{community_name}/followers",
web::get().to(get_apub_community_followers),
)
2020-04-24 19:55:54 +00:00
// TODO This is only useful for history which we aren't doing right now
// .route(
// "/c/{community_name}/outbox",
// web::get().to(get_apub_community_outbox),
// )
.route("/u/{user_name}", web::get().to(get_apub_user_http))
2020-05-13 17:21:32 +00:00
.route("/post/{post_id}", web::get().to(get_apub_post))
.route("/comment/{comment_id}", web::get().to(get_apub_comment)),
2020-04-14 15:37:23 +00:00
)
// Inboxes dont work with the header guard for some reason.
.service(
web::resource("/c/{community_name}/inbox")
.wrap(digest_verifier.clone())
.route(web::post().to(community_inbox)),
)
.service(
web::resource("/u/{user_name}/inbox")
.wrap(digest_verifier.clone())
.route(web::post().to(user_inbox)),
)
.service(
web::resource("/inbox")
.wrap(digest_verifier)
.route(web::post().to(shared_inbox)),
);
2020-01-02 18:22:23 +00:00
}
}