Use Comment::to_activity07() instead of to_activity()
This commit is contained in:
parent
b5e1076b0e
commit
771c157fe5
@ -11,24 +11,23 @@ use crate::{
|
|||||||
users::User,
|
users::User,
|
||||||
Connection, Error, Result, CONFIG,
|
Connection, Error, Result, CONFIG,
|
||||||
};
|
};
|
||||||
use activitypub::{link, object::Note};
|
|
||||||
use activitystreams::{
|
use activitystreams::{
|
||||||
activity::{Create as Create07, Delete},
|
activity::{Create, Delete},
|
||||||
base::{AnyBase, Base},
|
base::{AnyBase, Base},
|
||||||
iri_string::types::IriString,
|
iri_string::types::IriString,
|
||||||
link::{self as link07, kind::MentionType},
|
link::{self, kind::MentionType},
|
||||||
object::{Note as Note07, Tombstone},
|
object::{Note as Note07, Tombstone},
|
||||||
prelude::*,
|
prelude::*,
|
||||||
primitives::OneOrMany,
|
primitives::OneOrMany,
|
||||||
time::OffsetDateTime,
|
time::OffsetDateTime,
|
||||||
};
|
};
|
||||||
use chrono::{self, NaiveDateTime, TimeZone, Utc};
|
use chrono::{self, NaiveDateTime};
|
||||||
use diesel::{self, ExpressionMethods, QueryDsl, RunQueryDsl, SaveChangesDsl};
|
use diesel::{self, ExpressionMethods, QueryDsl, RunQueryDsl, SaveChangesDsl};
|
||||||
use plume_common::{
|
use plume_common::{
|
||||||
activity_pub::{
|
activity_pub::{
|
||||||
inbox::{AsActor, AsObject, FromId},
|
inbox::{AsActor, AsObject, FromId},
|
||||||
sign::Signer,
|
sign::Signer,
|
||||||
Id, IntoId, ToAsString, ToAsUri, PUBLIC_VISIBILITY,
|
IntoId, ToAsString, ToAsUri, PUBLIC_VISIBILITY,
|
||||||
},
|
},
|
||||||
utils,
|
utils,
|
||||||
};
|
};
|
||||||
@ -112,41 +111,6 @@ impl Comment {
|
|||||||
.unwrap_or(false)
|
.unwrap_or(false)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn to_activity(&self, conn: &DbConn) -> Result<Note> {
|
|
||||||
let author = User::get(conn, self.author_id)?;
|
|
||||||
let (html, mentions, _hashtags) = utils::md_to_html(
|
|
||||||
self.content.get().as_ref(),
|
|
||||||
Some(&Instance::get_local()?.public_domain),
|
|
||||||
true,
|
|
||||||
Some(Media::get_media_processor(conn, vec![&author])),
|
|
||||||
);
|
|
||||||
|
|
||||||
let mut note = Note::default();
|
|
||||||
let to = vec![Id::new(PUBLIC_VISIBILITY.to_string())];
|
|
||||||
|
|
||||||
note.object_props
|
|
||||||
.set_id_string(self.ap_url.clone().unwrap_or_default())?;
|
|
||||||
note.object_props
|
|
||||||
.set_summary_string(self.spoiler_text.clone())?;
|
|
||||||
note.object_props.set_content_string(html)?;
|
|
||||||
note.object_props
|
|
||||||
.set_in_reply_to_link(Id::new(self.in_response_to_id.map_or_else(
|
|
||||||
|| Ok(Post::get(conn, self.post_id)?.ap_url),
|
|
||||||
|id| Ok(Comment::get(conn, id)?.ap_url.unwrap_or_default()) as Result<String>,
|
|
||||||
)?))?;
|
|
||||||
note.object_props
|
|
||||||
.set_published_utctime(Utc.from_utc_datetime(&self.creation_date))?;
|
|
||||||
note.object_props.set_attributed_to_link(author.into_id())?;
|
|
||||||
note.object_props.set_to_link_vec(to)?;
|
|
||||||
note.object_props.set_tag_link_vec(
|
|
||||||
mentions
|
|
||||||
.into_iter()
|
|
||||||
.filter_map(|m| Mention::build_activity(conn, &m).ok())
|
|
||||||
.collect::<Vec<link::Mention>>(),
|
|
||||||
)?;
|
|
||||||
Ok(note)
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn to_activity07(&self, conn: &DbConn) -> Result<Note07> {
|
pub fn to_activity07(&self, conn: &DbConn) -> Result<Note07> {
|
||||||
let author = User::get(conn, self.author_id)?;
|
let author = User::get(conn, self.author_id)?;
|
||||||
let (html, mentions, _hashtags) = utils::md_to_html(
|
let (html, mentions, _hashtags) = utils::md_to_html(
|
||||||
@ -185,13 +149,13 @@ impl Comment {
|
|||||||
Ok(note)
|
Ok(note)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn create_activity07(&self, conn: &DbConn) -> Result<Create07> {
|
pub fn create_activity07(&self, conn: &DbConn) -> Result<Create> {
|
||||||
let author = User::get(conn, self.author_id)?;
|
let author = User::get(conn, self.author_id)?;
|
||||||
|
|
||||||
let note = self.to_activity07(conn)?;
|
let note = self.to_activity07(conn)?;
|
||||||
let note_clone = note.clone();
|
let note_clone = note.clone();
|
||||||
|
|
||||||
let mut act = Create07::new(
|
let mut act = Create::new(
|
||||||
author.into_id().parse::<IriString>()?,
|
author.into_id().parse::<IriString>()?,
|
||||||
Base::retract(note)?.into_generic()?,
|
Base::retract(note)?.into_generic()?,
|
||||||
);
|
);
|
||||||
@ -329,7 +293,7 @@ impl FromId<DbConn> for Comment {
|
|||||||
if let Some(tags) = note.tag() {
|
if let Some(tags) = note.tag() {
|
||||||
let author_url = &Post::get(conn, comm.post_id)?.get_authors(conn)?[0].ap_url;
|
let author_url = &Post::get(conn, comm.post_id)?.get_authors(conn)?[0].ap_url;
|
||||||
for tag in tags.iter() {
|
for tag in tags.iter() {
|
||||||
let m = tag.clone().extend::<link07::Mention, MentionType>()?; // FIXME: Don't clone
|
let m = tag.clone().extend::<link::Mention, MentionType>()?; // FIXME: Don't clone
|
||||||
if m.is_none() {
|
if m.is_none() {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -390,7 +354,7 @@ impl FromId<DbConn> for Comment {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl AsObject<User, Create07, &DbConn> for Comment {
|
impl AsObject<User, Create, &DbConn> for Comment {
|
||||||
type Error = Error;
|
type Error = Error;
|
||||||
type Output = Self;
|
type Output = Self;
|
||||||
|
|
||||||
@ -579,38 +543,6 @@ mod tests {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn to_activity() {
|
|
||||||
let conn = db();
|
|
||||||
conn.test_transaction::<_, Error, _>(|| {
|
|
||||||
let (comment, _posts, _users, _blogs) = prepare_activity(&conn);
|
|
||||||
let act = comment.to_activity(&conn)?;
|
|
||||||
|
|
||||||
let expected = json!({
|
|
||||||
"attributedTo": "https://plu.me/@/admin/",
|
|
||||||
"content": r###"<p dir="auto">My comment, mentioning to <a href="https://plu.me/@/user/" title="user">@user</a></p>
|
|
||||||
"###,
|
|
||||||
"id": format!("https://plu.me/~/BlogName/testing/comment/{}", comment.id),
|
|
||||||
"inReplyTo": "https://plu.me/~/BlogName/testing",
|
|
||||||
"published": format_datetime(&comment.creation_date),
|
|
||||||
"summary": "My CW",
|
|
||||||
"tag": [
|
|
||||||
{
|
|
||||||
"href": "https://plu.me/@/user/",
|
|
||||||
"name": "@user",
|
|
||||||
"type": "Mention"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"to": ["https://www.w3.org/ns/activitystreams#Public"],
|
|
||||||
"type": "Note"
|
|
||||||
});
|
|
||||||
|
|
||||||
assert_json_eq!(to_value(act)?, expected);
|
|
||||||
|
|
||||||
Ok(())
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn to_activity07() {
|
fn to_activity07() {
|
||||||
let conn = db();
|
let conn = db();
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
use crate::template_utils::Ructe;
|
use crate::template_utils::Ructe;
|
||||||
use activitypub::object::Note;
|
use activitystreams::object::Note;
|
||||||
use rocket::{
|
use rocket::{
|
||||||
request::LenientForm,
|
request::LenientForm,
|
||||||
response::{Flash, Redirect},
|
response::{Flash, Redirect},
|
||||||
@ -187,7 +187,7 @@ pub fn activity_pub(
|
|||||||
conn: DbConn,
|
conn: DbConn,
|
||||||
) -> Option<ActivityStream<Note>> {
|
) -> Option<ActivityStream<Note>> {
|
||||||
Comment::get(&conn, id)
|
Comment::get(&conn, id)
|
||||||
.and_then(|c| c.to_activity(&conn))
|
.and_then(|c| c.to_activity07(&conn))
|
||||||
.ok()
|
.ok()
|
||||||
.map(ActivityStream::new)
|
.map(ActivityStream::new)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user