Blog outbox

This commit is contained in:
Bat 2018-04-29 18:49:56 +01:00
parent 5e6be0cf93
commit 4666cd3ee3
7 changed files with 70 additions and 2 deletions

View File

@ -1,6 +1,16 @@
use serde_json;
use activity_pub::actor::Actor; use activity_pub::actor::Actor;
use activity_pub::object::Object; use activity_pub::object::Object;
#[derive(Clone)]
pub struct Activity {}
impl Activity {
pub fn serialize(&self) -> serde_json::Value {
json!({})
}
}
pub struct Create<'a, T, U> where T: Actor + 'static, U: Object { pub struct Create<'a, T, U> where T: Actor + 'static, U: Object {
by: &'a T, by: &'a T,
object: U object: U

View File

@ -6,6 +6,8 @@ use serde_json;
pub mod activity; pub mod activity;
pub mod actor; pub mod actor;
pub mod object; pub mod object;
pub mod outbox;
pub mod sign;
pub mod webfinger; pub mod webfinger;
pub type ActivityPub = Content<Json>; pub type ActivityPub = Content<Json>;
@ -14,7 +16,7 @@ pub const CONTEXT_URL: &'static str = "https://www.w3.org/ns/activitystreams";
pub fn context() -> serde_json::Value { pub fn context() -> serde_json::Value {
json!([ json!([
"https://www.w3.org/ns/activitystreams", CONTEXT_URL,
"https://w3id.org/security/v1", "https://w3id.org/security/v1",
{ {
"manuallyApprovesFollowers": "as:manuallyApprovesFollowers", "manuallyApprovesFollowers": "as:manuallyApprovesFollowers",

View File

@ -0,0 +1,38 @@
use rocket::http::Status;
use rocket::response::{Response, Responder};
use rocket::request::Request;
use serde_json;
use activity_pub::{activity_pub, ActivityPub, context};
use activity_pub::activity::Activity;
pub struct Outbox {
id: String,
items: Vec<Activity>
}
impl Outbox {
pub fn new(id: String, items: Vec<Activity>) -> Outbox {
Outbox {
id: id,
items: items
}
}
fn serialize(&self) -> ActivityPub {
let items = self.items.clone();
activity_pub(json!({
"@context": context(),
"type": "OrderedCollection",
"id": self.id,
"totalItems": items.len(),
"orderedItems": items.into_iter().map(|i| i.serialize()).collect::<Vec<serde_json::Value>>()
}))
}
}
impl<'r> Responder<'r> for Outbox {
fn respond_to(self, request: &Request) -> Result<Response<'r>, Status> {
self.serialize().respond_to(request)
}
}

View File

@ -4,7 +4,7 @@ use chrono::Utc;
use openssl::sha::{sha256, sha512}; use openssl::sha::{sha256, sha512};
use serde_json; use serde_json;
// Comments are from the Mastodon source code, to knremow what to do. // (Comments are from the Mastodon source code, to remember what to do.)
pub trait Signer { pub trait Signer {
fn get_key_id(&self) -> String; fn get_key_id(&self) -> String;

View File

@ -79,6 +79,7 @@ fn main() {
routes::blogs::details, routes::blogs::details,
routes::blogs::activity_details, routes::blogs::activity_details,
routes::blogs::outbox,
routes::blogs::new, routes::blogs::new,
routes::blogs::create, routes::blogs::create,

View File

@ -1,6 +1,8 @@
use diesel::{self, QueryDsl, RunQueryDsl, ExpressionMethods, PgConnection}; use diesel::{self, QueryDsl, RunQueryDsl, ExpressionMethods, PgConnection};
use activity_pub::activity::Activity;
use activity_pub::actor::{Actor, ActorType}; use activity_pub::actor::{Actor, ActorType};
use activity_pub::outbox::Outbox;
use activity_pub::webfinger::*; use activity_pub::webfinger::*;
use models::instance::Instance; use models::instance::Instance;
use schema::blogs; use schema::blogs;
@ -65,6 +67,14 @@ impl Blog {
.get_result::<Blog>(conn).expect("Couldn't update inbox URL"); .get_result::<Blog>(conn).expect("Couldn't update inbox URL");
} }
} }
pub fn outbox(&self, conn: &PgConnection) -> Outbox {
Outbox::new(self.compute_outbox(conn), self.get_activities(conn))
}
fn get_activities(&self, conn: &PgConnection) -> Vec<Activity> {
vec![]
}
} }
impl Actor for Blog { impl Actor for Blog {

View File

@ -5,6 +5,7 @@ use std::collections::HashMap;
use activity_pub::ActivityPub; use activity_pub::ActivityPub;
use activity_pub::actor::Actor; use activity_pub::actor::Actor;
use activity_pub::outbox::Outbox;
use db_conn::DbConn; use db_conn::DbConn;
use models::blog_authors::*; use models::blog_authors::*;
use models::blogs::*; use models::blogs::*;
@ -55,3 +56,9 @@ fn create(conn: DbConn, data: Form<NewBlogForm>, user: User) -> Redirect {
Redirect::to(format!("/~/{}", slug).as_str()) Redirect::to(format!("/~/{}", slug).as_str())
} }
#[get("/~/<name>/outbox")]
fn outbox(name: String, conn: DbConn) -> Outbox {
let blog = Blog::find_by_actor_id(&*conn, name).unwrap();
blog.outbox(&*conn)
}