Identify incoming followers-only posts
This commit is contained in:
parent
50630c004a
commit
9bc8997fb5
2 changed files with 41 additions and 16 deletions
|
@ -3,7 +3,6 @@ use crate::models::posts::types::Visibility;
|
||||||
use crate::models::profiles::types::DbActorProfile;
|
use crate::models::profiles::types::DbActorProfile;
|
||||||
|
|
||||||
pub fn get_note_visibility(
|
pub fn get_note_visibility(
|
||||||
note_id: &str,
|
|
||||||
author: &DbActorProfile,
|
author: &DbActorProfile,
|
||||||
primary_audience: Vec<String>,
|
primary_audience: Vec<String>,
|
||||||
secondary_audience: Vec<String>,
|
secondary_audience: Vec<String>,
|
||||||
|
@ -12,30 +11,32 @@ pub fn get_note_visibility(
|
||||||
secondary_audience.contains(&AP_PUBLIC.to_string()) {
|
secondary_audience.contains(&AP_PUBLIC.to_string()) {
|
||||||
Visibility::Public
|
Visibility::Public
|
||||||
} else {
|
} else {
|
||||||
// Treat all notes that aren't public-addressed as direct messages
|
let maybe_followers = author.actor_json.as_ref()
|
||||||
log::warn!(
|
.and_then(|actor| actor.followers.as_ref());
|
||||||
"processing non-public note {} attributed to {}; primary audience {:?}; secondary audience {:?}",
|
if let Some(followers) = maybe_followers {
|
||||||
note_id,
|
if primary_audience.contains(&followers) ||
|
||||||
author.username,
|
secondary_audience.contains(&followers) {
|
||||||
primary_audience,
|
Visibility::Followers
|
||||||
secondary_audience,
|
} else {
|
||||||
);
|
Visibility::Direct
|
||||||
Visibility::Direct
|
}
|
||||||
|
} else {
|
||||||
|
Visibility::Direct
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
|
use crate::activitypub::actor::Actor;
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_get_note_visibility_public() {
|
fn test_get_note_visibility_public() {
|
||||||
let object_id = "https://example.com/test";
|
|
||||||
let author = DbActorProfile::default();
|
let author = DbActorProfile::default();
|
||||||
let primary_audience = vec![AP_PUBLIC.to_string()];
|
let primary_audience = vec![AP_PUBLIC.to_string()];
|
||||||
let secondary_audience = vec![];
|
let secondary_audience = vec![];
|
||||||
let visibility = get_note_visibility(
|
let visibility = get_note_visibility(
|
||||||
object_id,
|
|
||||||
&author,
|
&author,
|
||||||
primary_audience,
|
primary_audience,
|
||||||
secondary_audience,
|
secondary_audience,
|
||||||
|
@ -43,14 +44,32 @@ mod tests {
|
||||||
assert_eq!(visibility, Visibility::Public);
|
assert_eq!(visibility, Visibility::Public);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_get_note_visibility_followers() {
|
||||||
|
let author_followers = "https://example.com/users/author/followers";
|
||||||
|
let author = DbActorProfile {
|
||||||
|
actor_json: Some(Actor {
|
||||||
|
followers: Some(author_followers.to_string()),
|
||||||
|
..Default::default()
|
||||||
|
}),
|
||||||
|
..Default::default()
|
||||||
|
};
|
||||||
|
let primary_audience = vec![author_followers.to_string()];
|
||||||
|
let secondary_audience = vec![];
|
||||||
|
let visibility = get_note_visibility(
|
||||||
|
&author,
|
||||||
|
primary_audience,
|
||||||
|
secondary_audience,
|
||||||
|
);
|
||||||
|
assert_eq!(visibility, Visibility::Followers);
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_get_note_visibility_direct() {
|
fn test_get_note_visibility_direct() {
|
||||||
let object_id = "https://example.com/test";
|
|
||||||
let author = DbActorProfile::default();
|
let author = DbActorProfile::default();
|
||||||
let primary_audience = vec!["https://example.com/users/1".to_string()];
|
let primary_audience = vec!["https://example.com/users/1".to_string()];
|
||||||
let secondary_audience = vec![];
|
let secondary_audience = vec![];
|
||||||
let visibility = get_note_visibility(
|
let visibility = get_note_visibility(
|
||||||
object_id,
|
|
||||||
&author,
|
&author,
|
||||||
primary_audience,
|
primary_audience,
|
||||||
secondary_audience,
|
secondary_audience,
|
||||||
|
|
|
@ -17,7 +17,7 @@ use crate::models::posts::queries::{
|
||||||
delete_post,
|
delete_post,
|
||||||
};
|
};
|
||||||
use crate::models::posts::tags::normalize_tag;
|
use crate::models::posts::tags::normalize_tag;
|
||||||
use crate::models::posts::types::{Post, PostCreateData};
|
use crate::models::posts::types::{Post, PostCreateData, Visibility};
|
||||||
use crate::models::profiles::queries::{
|
use crate::models::profiles::queries::{
|
||||||
get_profile_by_actor_id,
|
get_profile_by_actor_id,
|
||||||
get_profile_by_acct,
|
get_profile_by_acct,
|
||||||
|
@ -379,11 +379,17 @@ pub async fn process_note(
|
||||||
None => vec![],
|
None => vec![],
|
||||||
};
|
};
|
||||||
let visibility = get_note_visibility(
|
let visibility = get_note_visibility(
|
||||||
&object.id,
|
|
||||||
&author,
|
&author,
|
||||||
primary_audience,
|
primary_audience,
|
||||||
secondary_audience,
|
secondary_audience,
|
||||||
);
|
);
|
||||||
|
if visibility != Visibility::Public {
|
||||||
|
log::warn!(
|
||||||
|
"processing note with visibility {:?} attributed to {}",
|
||||||
|
visibility,
|
||||||
|
author.username,
|
||||||
|
);
|
||||||
|
};
|
||||||
let post_data = PostCreateData {
|
let post_data = PostCreateData {
|
||||||
content: content_cleaned,
|
content: content_cleaned,
|
||||||
in_reply_to_id,
|
in_reply_to_id,
|
||||||
|
|
Loading…
Reference in a new issue