diff options
author | rtkay123 <dev@kanjala.com> | 2025-07-16 20:24:52 +0200 |
---|---|---|
committer | rtkay123 <dev@kanjala.com> | 2025-07-16 20:24:52 +0200 |
commit | 5fdb24b6a2cef7964a049e789ed90f883221d657 (patch) | |
tree | 84b69fdb8faa859797b38b45f952b9c6d7c50165 /src/server/routes | |
parent | 0a3040fba40d42c62ea70b7ccbade28e43ebaad5 (diff) | |
download | sellershut-5fdb24b6a2cef7964a049e789ed90f883221d657.tar.bz2 sellershut-5fdb24b6a2cef7964a049e789ed90f883221d657.zip |
feat: activity
Diffstat (limited to 'src/server/routes')
-rw-r--r-- | src/server/routes/users.rs | 20 | ||||
-rw-r--r-- | src/server/routes/users/post_inbox.rs | 16 |
2 files changed, 35 insertions, 1 deletions
diff --git a/src/server/routes/users.rs b/src/server/routes/users.rs index d3ce446..9c9a3bf 100644 --- a/src/server/routes/users.rs +++ b/src/server/routes/users.rs @@ -1,12 +1,30 @@ pub mod get_outbox; +pub mod post_inbox; pub mod get_user; pub mod webfinger; -use axum::{Router, routing::get}; +use activitypub_federation::traits::Activity; +use axum::{routing::{get, post}, Router}; +use serde::{Deserialize, Serialize}; + +use crate::server::activities::{accept::Accept, follow::Follow}; +use url::Url; +use activitypub_federation::config::Data; + +/// List of all activities which this actor can receive. +#[derive(Deserialize, Serialize, Debug)] +#[serde(untagged)] +#[enum_delegate::implement(Activity)] +pub enum PersonAcceptedActivities { + Follow(Follow), + Accept(Accept), +} + pub fn users_router() -> Router { Router::new() .route("/users/{username}", get(get_user::http_get_user)) .route("/users/{username}/outbox", get(get_outbox::http_get_outbox)) + .route("/users/{username}/inbox", post(post_inbox::http_post_user_inbox)) .route("/.well-known/webfinger", get(webfinger::webfinger)) } diff --git a/src/server/routes/users/post_inbox.rs b/src/server/routes/users/post_inbox.rs new file mode 100644 index 0000000..5e3258b --- /dev/null +++ b/src/server/routes/users/post_inbox.rs @@ -0,0 +1,16 @@ +use activitypub_federation::{axum::inbox::{receive_activity, ActivityData}, config::Data, protocol::context::WithContext}; +use axum::response::IntoResponse; + +use crate::{entity::user::User, server::routes::users::PersonAcceptedActivities, state::AppHandle}; + +pub async fn http_post_user_inbox( + data: Data<AppHandle>, + activity_data: ActivityData, +) -> impl IntoResponse { + receive_activity::<WithContext<PersonAcceptedActivities>, User, AppHandle>( + activity_data, + &data, + ) + .await +} + |