From c4fc656809d2122ffaa3a0266b896e579874db42 Mon Sep 17 00:00:00 2001 From: Trinity Pointard Date: Sun, 28 Oct 2018 10:05:02 +0100 Subject: [PATCH] Update mentions on remote post edition --- plume-models/src/posts.rs | 51 +++++++++++++++++++++++++++++++++++++-- src/routes/posts.rs | 11 +-------- 2 files changed, 50 insertions(+), 12 deletions(-) diff --git a/plume-models/src/posts.rs b/plume-models/src/posts.rs index 71c9a6a9..8eb1c418 100644 --- a/plume-models/src/posts.rs +++ b/plume-models/src/posts.rs @@ -389,9 +389,58 @@ impl Post { post.source = source.content; } + let mut hashtags = md_to_html(&post.source).2.into_iter().map(|s| s.to_camel_case()).collect::>(); + if let Some(serde_json::Value::Array(mention_tags)) = updated.object_props.tag.clone() { + let mut mentions = vec![]; + let mut tags = vec![]; + for tag in mention_tags.into_iter() { + serde_json::from_value::(tag.clone()) + .map(|m| mentions.push(m)) + .ok(); + + serde_json::from_value::(tag.clone()) + .map(|t| { + let tag_name = t.name_string().expect("Post::from_activity: tag name error"); + tags.push((t, hashtags.remove(&tag_name))); + }).ok(); + } + // Tag::from_activity(conn, t, post.id, bool); + // Mention::from_activity(conn, m, post.id, true, true) + post.update_mentions(conn, mentions); + } + post.update(conn); } + pub fn update_mentions(&self, conn: &Connection, mentions: Vec) { + let mentions = mentions.into_iter().map(|m| (m.link_props.href_string().ok() + .and_then(|ap_url| User::find_by_ap_url(conn, ap_url)) + .map(|u| u.id),m)) + .filter_map(|(id, m)| if let Some(id)=id {Some((m,id))} else {None}).collect::>(); + + let old_mentions = Mention::list_for_post(&conn, self.id); + let old_user_mentioned = old_mentions.iter() + .map(|m| m.mentioned_id).collect::>(); + for (m,id) in mentions.iter() { + if !old_user_mentioned.contains(&id) { + Mention::from_activity(&*conn, m.clone(), self.id, true, true); + } + } + + let new_mentions = mentions.into_iter().map(|(_m,id)| id).collect::>(); + for m in old_mentions.iter().filter(|m| !new_mentions.contains(&m.mentioned_id)) { + m.delete(&conn); + } + } + +/* pub fn update_hashtags_from_activity(&self, conn: &Connection, Vec/*create a build_activity for Tag, as in Mention,*/) { + unimplemented!(); + } + + pub fn update_tags_from_activity(&self, conn: &Connection, Vec) { + unimplemented!(); + } +*/ pub fn to_json(&self, conn: &Connection) -> serde_json::Value { let blog = self.get_blog(conn); json!({ @@ -452,7 +501,6 @@ impl FromActivity for Post { // save mentions and tags let mut hashtags = md_to_html(&post.source).2.into_iter().map(|s| s.to_camel_case()).collect::>(); - println!("{:?}", hashtags); if let Some(serde_json::Value::Array(tags)) = article.object_props.tag.clone() { for tag in tags.into_iter() { serde_json::from_value::(tag.clone()) @@ -462,7 +510,6 @@ impl FromActivity for Post { serde_json::from_value::(tag.clone()) .map(|t| { let tag_name = t.name_string().expect("Post::from_activity: tag name error"); - println!("{} : {}", tag_name, hashtags.contains(&tag_name)); Tag::from_activity(conn, t, post.id, hashtags.remove(&tag_name)); }) .ok(); diff --git a/src/routes/posts.rs b/src/routes/posts.rs index 8ebee612..e25f71fb 100644 --- a/src/routes/posts.rs +++ b/src/routes/posts.rs @@ -210,16 +210,7 @@ fn update(blog: String, slug: String, user: User, conn: DbConn, data: LenientFor let post = post.update_ap_url(&*conn); if post.published { - let old_mentions = Mention::list_for_post(&conn, post.id); - let old_user_mentioned = old_mentions.iter() - .filter_map(|m| User::get(&conn, m.mentioned_id).map(|u| u.get_fqn(&conn))) - .collect::>(); - for m in mentions.difference(&old_user_mentioned).into_iter() { - Mention::from_activity(&*conn, Mention::build_activity(&*conn, m.clone()), post.id, true, true); - } - for m in old_mentions.iter().filter(|m| !User::get(&conn, m.mentioned_id).map(|u| mentions.contains(&u.get_fqn(&conn))).unwrap_or(false)) { - m.delete(&conn); - } + post.update_mentions(&conn, mentions.into_iter().map(|m| Mention::build_activity(&conn, m)).collect()); } let old_tags = Tag::for_post(&*conn, post.id).into_iter().collect::>();