mirror of
https://github.com/LemmyNet/activitypub-federation-rust.git
synced 2024-09-27 14:00:19 +00:00
7b0b830597
* First iteration of secure mode federation support * signing_actor: take request by reference * Implement secure mode fetch as a global config parameter * Implement secure mode federation example in actix-web example * fix clippy lints
31 lines
935 B
Rust
31 lines
935 B
Rust
//! Utilities for using this library with actix-web framework
|
|
|
|
pub mod inbox;
|
|
#[doc(hidden)]
|
|
pub mod middleware;
|
|
|
|
use crate::{
|
|
config::Data,
|
|
error::Error,
|
|
http_signatures::{self, verify_body_hash},
|
|
traits::{Actor, Object},
|
|
};
|
|
use actix_web::{web::Bytes, HttpRequest};
|
|
use serde::Deserialize;
|
|
|
|
/// Checks whether the request is signed by an actor of type A, and returns
|
|
/// the actor in question if a valid signature is found.
|
|
pub async fn signing_actor<A>(
|
|
request: &HttpRequest,
|
|
body: Option<Bytes>,
|
|
data: &Data<<A as Object>::DataType>,
|
|
) -> Result<A, <A as Object>::Error>
|
|
where
|
|
A: Object + Actor,
|
|
<A as Object>::Error: From<Error> + From<anyhow::Error>,
|
|
for<'de2> <A as Object>::Kind: Deserialize<'de2>,
|
|
{
|
|
verify_body_hash(request.headers().get("Digest"), &body.unwrap_or_default())?;
|
|
|
|
http_signatures::signing_actor(request.headers(), request.method(), request.uri(), data).await
|
|
}
|