Fix audience of private Undo(Like) activity
This commit is contained in:
parent
ecc4afe568
commit
aefed2479e
2 changed files with 43 additions and 24 deletions
|
@ -15,19 +15,29 @@ use crate::models::posts::types::{Post, Visibility};
|
|||
use crate::models::profiles::types::DbActorProfile;
|
||||
use crate::models::users::types::User;
|
||||
|
||||
pub fn get_like_note_audience(
|
||||
note_author_id: &str,
|
||||
note_visibility: &Visibility,
|
||||
) -> (Vec<String>, Vec<String>) {
|
||||
let mut primary_audience = vec![note_author_id.to_string()];
|
||||
if matches!(note_visibility, Visibility::Public) {
|
||||
primary_audience.push(AP_PUBLIC.to_string());
|
||||
};
|
||||
let secondary_audience = vec![];
|
||||
(primary_audience, secondary_audience)
|
||||
}
|
||||
|
||||
fn build_like_note(
|
||||
instance_url: &str,
|
||||
actor_profile: &DbActorProfile,
|
||||
note_id: &str,
|
||||
reaction_id: &Uuid,
|
||||
recipient_id: &str,
|
||||
is_public: bool,
|
||||
note_author_id: &str,
|
||||
note_visibility: &Visibility,
|
||||
) -> Activity {
|
||||
let activity_id = local_object_id(instance_url, reaction_id);
|
||||
let mut primary_audience = vec![recipient_id.to_string()];
|
||||
if is_public {
|
||||
primary_audience.push(AP_PUBLIC.to_string());
|
||||
};
|
||||
let (primary_audience, secondary_audience) =
|
||||
get_like_note_audience(note_author_id, note_visibility);
|
||||
let activity = create_activity(
|
||||
instance_url,
|
||||
&actor_profile.username,
|
||||
|
@ -35,22 +45,21 @@ fn build_like_note(
|
|||
activity_id,
|
||||
note_id,
|
||||
primary_audience,
|
||||
vec![],
|
||||
secondary_audience,
|
||||
);
|
||||
activity
|
||||
}
|
||||
|
||||
pub async fn get_like_note_recipients(
|
||||
_db_client: &impl GenericClient,
|
||||
instance_url: &str,
|
||||
_instance_url: &str,
|
||||
post: &Post,
|
||||
) -> Result<(Vec<Actor>, String), DatabaseError> {
|
||||
) -> Result<Vec<Actor>, DatabaseError> {
|
||||
let mut recipients: Vec<Actor> = Vec::new();
|
||||
let primary_recipient = post.author.actor_id(instance_url);
|
||||
if let Some(remote_actor) = post.author.actor_json.as_ref() {
|
||||
recipients.push(remote_actor.clone());
|
||||
};
|
||||
Ok((recipients, primary_recipient))
|
||||
Ok(recipients)
|
||||
}
|
||||
|
||||
pub async fn prepare_like_note(
|
||||
|
@ -60,19 +69,20 @@ pub async fn prepare_like_note(
|
|||
post: &Post,
|
||||
reaction_id: &Uuid,
|
||||
) -> Result<OutgoingActivity<Activity>, DatabaseError> {
|
||||
let (recipients, primary_recipient) = get_like_note_recipients(
|
||||
let recipients = get_like_note_recipients(
|
||||
db_client,
|
||||
&instance.url(),
|
||||
post,
|
||||
).await?;
|
||||
let note_id = post.get_object_id(&instance.url());
|
||||
let note_author_id = post.author.actor_id(&instance.url());
|
||||
let activity = build_like_note(
|
||||
&instance.url(),
|
||||
&user.profile,
|
||||
¬e_id,
|
||||
reaction_id,
|
||||
&primary_recipient,
|
||||
matches!(post.visibility, Visibility::Public),
|
||||
¬e_author_id,
|
||||
&post.visibility,
|
||||
);
|
||||
Ok(OutgoingActivity {
|
||||
instance,
|
||||
|
@ -102,7 +112,7 @@ mod tests {
|
|||
note_id,
|
||||
&reaction_id,
|
||||
note_author_id,
|
||||
true,
|
||||
&Visibility::Public,
|
||||
);
|
||||
assert_eq!(
|
||||
activity.id,
|
||||
|
|
|
@ -3,34 +3,39 @@ use uuid::Uuid;
|
|||
|
||||
use crate::activitypub::{
|
||||
activity::{create_activity, Activity},
|
||||
constants::AP_PUBLIC,
|
||||
deliverer::OutgoingActivity,
|
||||
identifiers::local_object_id,
|
||||
vocabulary::UNDO,
|
||||
};
|
||||
use crate::config::Instance;
|
||||
use crate::errors::DatabaseError;
|
||||
use crate::models::posts::types::Post;
|
||||
use crate::models::posts::types::{Post, Visibility};
|
||||
use crate::models::profiles::types::DbActorProfile;
|
||||
use crate::models::users::types::User;
|
||||
use super::like_note::get_like_note_recipients;
|
||||
use super::like_note::{
|
||||
get_like_note_audience,
|
||||
get_like_note_recipients,
|
||||
};
|
||||
|
||||
fn build_undo_like(
|
||||
instance_url: &str,
|
||||
actor_profile: &DbActorProfile,
|
||||
reaction_id: &Uuid,
|
||||
recipient_id: &str,
|
||||
note_author_id: &str,
|
||||
note_visibility: &Visibility,
|
||||
) -> Activity {
|
||||
let object_id = local_object_id(instance_url, reaction_id);
|
||||
let activity_id = format!("{}/undo", object_id);
|
||||
let (primary_audience, secondary_audience) =
|
||||
get_like_note_audience(note_author_id, note_visibility);
|
||||
create_activity(
|
||||
instance_url,
|
||||
&actor_profile.username,
|
||||
UNDO,
|
||||
activity_id,
|
||||
object_id,
|
||||
vec![AP_PUBLIC.to_string(), recipient_id.to_string()],
|
||||
vec![],
|
||||
primary_audience,
|
||||
secondary_audience,
|
||||
)
|
||||
}
|
||||
|
||||
|
@ -41,16 +46,18 @@ pub async fn prepare_undo_like_note(
|
|||
post: &Post,
|
||||
reaction_id: &Uuid,
|
||||
) -> Result<OutgoingActivity<Activity>, DatabaseError> {
|
||||
let (recipients, primary_recipient) = get_like_note_recipients(
|
||||
let recipients = get_like_note_recipients(
|
||||
db_client,
|
||||
&instance.url(),
|
||||
post,
|
||||
).await?;
|
||||
let note_author_id = post.author.actor_id(&instance.url());
|
||||
let activity = build_undo_like(
|
||||
&instance.url(),
|
||||
&user.profile,
|
||||
reaction_id,
|
||||
&primary_recipient,
|
||||
¬e_author_id,
|
||||
&post.visibility,
|
||||
);
|
||||
Ok(OutgoingActivity {
|
||||
instance,
|
||||
|
@ -63,6 +70,7 @@ pub async fn prepare_undo_like_note(
|
|||
#[cfg(test)]
|
||||
mod tests {
|
||||
use serde_json::json;
|
||||
use crate::activitypub::constants::AP_PUBLIC;
|
||||
use crate::utils::id::new_uuid;
|
||||
use super::*;
|
||||
|
||||
|
@ -78,6 +86,7 @@ mod tests {
|
|||
&author,
|
||||
&reaction_id,
|
||||
note_author_id,
|
||||
&Visibility::Public,
|
||||
);
|
||||
assert_eq!(
|
||||
activity.id,
|
||||
|
@ -87,6 +96,6 @@ mod tests {
|
|||
activity.object,
|
||||
format!("{}/objects/{}", INSTANCE_URL, reaction_id),
|
||||
);
|
||||
assert_eq!(activity.to.unwrap(), json!([AP_PUBLIC, note_author_id]));
|
||||
assert_eq!(activity.to.unwrap(), json!([note_author_id, AP_PUBLIC]));
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue