2024-03-25 21:48:58 +01:00
|
|
|
use axum::{extract::{Path, Query, State}, http::StatusCode, Json};
|
2024-03-23 04:31:48 +01:00
|
|
|
|
2024-04-12 22:41:04 +02:00
|
|
|
use sea_orm::{ColumnTrait, Condition, Order, QueryFilter, QueryOrder, QuerySelect};
|
2024-04-12 20:01:47 +02:00
|
|
|
use crate::{errors::UpubError, model::{self, addressing::EmbeddedActivity}, routes::activitypub::{jsonld::LD, JsonLD, Pagination}, server::{auth::{AuthIdentity, Identity}, Context}, url};
|
2024-03-25 21:48:58 +01:00
|
|
|
|
|
|
|
pub async fn get(
|
|
|
|
State(ctx): State<Context>,
|
|
|
|
Path(id): Path<String>,
|
|
|
|
AuthIdentity(auth): AuthIdentity,
|
|
|
|
) -> Result<JsonLD<serde_json::Value>, StatusCode> {
|
|
|
|
match auth {
|
|
|
|
Identity::Anonymous => Err(StatusCode::FORBIDDEN),
|
|
|
|
Identity::Remote(_) => Err(StatusCode::FORBIDDEN),
|
|
|
|
Identity::Local(user) => if ctx.uid(id.clone()) == user {
|
2024-03-28 04:52:17 +01:00
|
|
|
Ok(JsonLD(ctx.ap_collection(&url!(ctx, "/users/{id}/inbox"), None).ld_context()))
|
2024-03-25 21:48:58 +01:00
|
|
|
} else {
|
|
|
|
Err(StatusCode::FORBIDDEN)
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn page(
|
|
|
|
State(ctx): State<Context>,
|
|
|
|
Path(id): Path<String>,
|
|
|
|
AuthIdentity(auth): AuthIdentity,
|
|
|
|
Query(page): Query<Pagination>,
|
2024-03-28 04:52:17 +01:00
|
|
|
) -> crate::Result<JsonLD<serde_json::Value>> {
|
2024-04-12 22:56:29 +02:00
|
|
|
let Identity::Local(uid) = auth else {
|
|
|
|
// local inbox is only for local users
|
|
|
|
return Err(UpubError::forbidden());
|
|
|
|
};
|
|
|
|
if uid != ctx.uid(id.clone()) {
|
|
|
|
return Err(UpubError::forbidden());
|
2024-03-25 21:48:58 +01:00
|
|
|
}
|
2024-04-12 22:56:29 +02:00
|
|
|
let limit = page.batch.unwrap_or(20).min(50);
|
|
|
|
let offset = page.offset.unwrap_or(0);
|
|
|
|
let activities = model::addressing::Entity::find_activities()
|
|
|
|
.filter(Condition::all().add(model::addressing::Column::Actor.eq(&uid)))
|
|
|
|
.order_by(model::addressing::Column::Published, Order::Asc)
|
|
|
|
.offset(offset)
|
|
|
|
.limit(limit)
|
|
|
|
.into_model::<EmbeddedActivity>()
|
|
|
|
.all(ctx.db())
|
|
|
|
.await?;
|
|
|
|
Ok(JsonLD(
|
|
|
|
ctx.ap_collection_page(
|
|
|
|
&url!(ctx, "/users/{id}/inbox/page"),
|
|
|
|
offset, limit,
|
|
|
|
activities
|
|
|
|
.into_iter()
|
|
|
|
.map(|x| x.into())
|
|
|
|
.collect()
|
|
|
|
).ld_context()
|
|
|
|
))
|
2024-03-25 21:48:58 +01:00
|
|
|
}
|
2024-03-23 04:31:48 +01:00
|
|
|
|
2024-03-25 02:00:57 +01:00
|
|
|
pub async fn post(
|
2024-03-23 04:31:48 +01:00
|
|
|
State(ctx): State<Context>,
|
|
|
|
Path(_id): Path<String>,
|
2024-04-13 01:49:04 +02:00
|
|
|
AuthIdentity(_auth): AuthIdentity,
|
|
|
|
Json(activity): Json<serde_json::Value>,
|
2024-03-27 04:00:27 +01:00
|
|
|
) -> Result<(), UpubError> {
|
2024-04-12 20:01:47 +02:00
|
|
|
// POSTing to user inboxes is effectively the same as POSTing to the main inbox
|
2024-04-13 01:49:04 +02:00
|
|
|
super::super::inbox::post(State(ctx), AuthIdentity(_auth), Json(activity)).await
|
2024-03-23 04:31:48 +01:00
|
|
|
}
|