address review comments mostly

This commit is contained in:
phiresky 2023-08-10 16:23:24 +00:00
parent c2ec41fd01
commit bdbb499c9d
7 changed files with 27 additions and 58 deletions

View file

@ -211,11 +211,7 @@ where
.map(|e| Some(e.into())) .map(|e| Some(e.into()))
.collect(), .collect(),
send_all_instances: send_targets.all_instances, send_all_instances: send_targets.all_instances,
send_community_followers_of: send_targets send_community_followers_of: send_targets.community_followers_of.map(|e| e.0),
.community_followers_of
.into_iter()
.map(|e| Some(e.0))
.collect(),
actor_type: actor.actor_type(), actor_type: actor.actor_type(),
actor_apub_id: actor.id().into(), actor_apub_id: actor.id().into(),
}; };

View file

@ -31,12 +31,9 @@ impl SentActivity {
.await .await
} }
pub async fn read(pool: &mut DbPool<'_>, object_id: i64) -> Result<Self, Error> { pub async fn read(pool: &mut DbPool<'_>, object_id: i64) -> Result<Self, Error> {
use crate::schema::sent_activity::dsl::{id, sent_activity}; use crate::schema::sent_activity::dsl::sent_activity;
let conn = &mut get_conn(pool).await?; let conn = &mut get_conn(pool).await?;
sent_activity sent_activity.find(object_id).first::<Self>(conn).await
.filter(id.eq(object_id))
.first::<Self>(conn)
.await
} }
} }
@ -115,7 +112,7 @@ mod tests {
.into(), .into(),
actor_type: ActorType::Person, actor_type: ActorType::Person,
send_all_instances: false, send_all_instances: false,
send_community_followers_of: vec![], send_community_followers_of: None,
send_inboxes: vec![], send_inboxes: vec![],
}; };

View file

@ -296,8 +296,10 @@ diesel::table! {
} }
diesel::table! { diesel::table! {
federation_queue_state (domain) { federation_queue_state (id) {
domain -> Text, id -> Int4,
#[max_length = 255]
domain -> Varchar,
last_successful_id -> Int8, last_successful_id -> Int8,
fail_count -> Int4, fail_count -> Int4,
last_retry -> Timestamptz, last_retry -> Timestamptz,
@ -806,7 +808,7 @@ diesel::table! {
sensitive -> Bool, sensitive -> Bool,
published -> Timestamp, published -> Timestamp,
send_inboxes -> Array<Nullable<Text>>, send_inboxes -> Array<Nullable<Text>>,
send_community_followers_of -> Array<Nullable<Int4>>, send_community_followers_of -> Nullable<Int4>,
send_all_instances -> Bool, send_all_instances -> Bool,
actor_type -> ActorTypeEnum, actor_type -> ActorTypeEnum,
actor_apub_id -> Nullable<Text>, actor_apub_id -> Nullable<Text>,

View file

@ -31,7 +31,7 @@ pub struct ActivitySendTargets {
/// send to these inboxes explicitly /// send to these inboxes explicitly
pub inboxes: HashSet<Url>, pub inboxes: HashSet<Url>,
/// send to all followers of these local communities /// send to all followers of these local communities
pub community_followers_of: HashSet<CommunityId>, pub community_followers_of: Option<CommunityId>,
/// send to all remote instances /// send to all remote instances
pub all_instances: bool, pub all_instances: bool,
} }
@ -48,7 +48,7 @@ impl ActivitySendTargets {
} }
pub fn to_local_community_followers(id: CommunityId) -> ActivitySendTargets { pub fn to_local_community_followers(id: CommunityId) -> ActivitySendTargets {
let mut a = ActivitySendTargets::empty(); let mut a = ActivitySendTargets::empty();
a.community_followers_of.insert(id); a.community_followers_of = Some(id);
a a
} }
pub fn to_all_instances() -> ActivitySendTargets { pub fn to_all_instances() -> ActivitySendTargets {
@ -76,41 +76,13 @@ pub struct SentActivity {
pub data: Value, pub data: Value,
pub sensitive: bool, pub sensitive: bool,
pub published: chrono::NaiveDateTime, pub published: chrono::NaiveDateTime,
#[diesel(deserialize_as = ArrayToHashSet<DbUrl>)] pub send_inboxes: Vec<Option<DbUrl>>,
pub send_inboxes: HashSet<DbUrl>, pub send_community_followers_of: Option<CommunityId>,
#[diesel(deserialize_as = ArrayToHashSet<CommunityId>)]
pub send_community_followers_of: HashSet<CommunityId>,
pub send_all_instances: bool, pub send_all_instances: bool,
pub actor_type: ActorType, pub actor_type: ActorType,
pub actor_apub_id: Option<DbUrl>, pub actor_apub_id: Option<DbUrl>,
} }
// wrapper to remove optional from array values and convert to hashset
pub struct ArrayToHashSet<T>(HashSet<T>);
impl<DB, T1, T2> Queryable<Array<Nullable<T2>>, DB> for ArrayToHashSet<T1>
where
DB: Backend,
T1: FromSql<T2, DB> + Hash + Eq,
Vec<std::option::Option<T1>>: FromSql<Array<Nullable<T2>>, DB>,
{
type Row = Vec<Option<T1>>;
fn build(row: Self::Row) -> diesel::deserialize::Result<Self> {
let res: diesel::deserialize::Result<HashSet<T1>> = row
.into_iter()
.map(|e| e.ok_or("array with null element".into()))
.collect();
res.map(ArrayToHashSet)
}
}
impl<T> From<ArrayToHashSet<T>> for HashSet<T> {
fn from(val: ArrayToHashSet<T>) -> Self {
val.0
}
}
#[derive(Insertable)] #[derive(Insertable)]
#[diesel(table_name = sent_activity)] #[diesel(table_name = sent_activity)]
pub struct SentActivityForm { pub struct SentActivityForm {
@ -118,7 +90,7 @@ pub struct SentActivityForm {
pub data: Value, pub data: Value,
pub sensitive: bool, pub sensitive: bool,
pub send_inboxes: Vec<Option<DbUrl>>, pub send_inboxes: Vec<Option<DbUrl>>,
pub send_community_followers_of: Vec<Option<i32>>, pub send_community_followers_of: Option<i32>,
pub send_all_instances: bool, pub send_all_instances: bool,
pub actor_type: ActorType, pub actor_type: ActorType,
pub actor_apub_id: DbUrl, pub actor_apub_id: DbUrl,

View file

@ -19,11 +19,11 @@ pub struct FederationQueueState {
impl FederationQueueState { impl FederationQueueState {
/// load or return a default empty value /// load or return a default empty value
pub async fn load(pool: &mut DbPool<'_>, domain_: &str) -> Result<FederationQueueState> { pub async fn load(pool: &mut DbPool<'_>, domain_: &str) -> Result<FederationQueueState> {
use lemmy_db_schema::schema::federation_queue_state::dsl::federation_queue_state; use lemmy_db_schema::schema::federation_queue_state::dsl::{domain, federation_queue_state};
let conn = &mut get_conn(pool).await?; let conn = &mut get_conn(pool).await?;
Ok( Ok(
federation_queue_state federation_queue_state
.find(&domain_) .filter(domain.eq(&domain_))
.select(FederationQueueState::as_select()) .select(FederationQueueState::as_select())
.get_result(conn) .get_result(conn)
.await .await

View file

@ -201,17 +201,18 @@ impl InstanceWorker {
inbox_urls.insert(site.inbox_url.inner().clone()); inbox_urls.insert(site.inbox_url.inner().clone());
} }
} }
for t in &activity.send_community_followers_of { if let Some(t) = &activity.send_community_followers_of {
if let Some(urls) = self.followed_communities.get(t) { if let Some(urls) = self.followed_communities.get(t) {
inbox_urls.extend(urls.iter().map(std::clone::Clone::clone)); inbox_urls.extend(urls.iter().map(std::clone::Clone::clone));
} }
} }
for inbox in &activity.send_inboxes { inbox_urls.extend(
if inbox.domain() != Some(&self.instance.domain) { activity
continue; .send_inboxes
} .iter()
inbox_urls.insert(inbox.inner().clone()); .filter_map(|e| e.as_ref())
} .filter_map(|u| (u.domain() == Some(&self.instance.domain)).then(|| u.inner().clone())),
);
inbox_urls inbox_urls
} }

View file

@ -7,7 +7,7 @@ CREATE TYPE actor_type_enum AS enum(
-- actor_apub_id only null for old entries before this migration -- actor_apub_id only null for old entries before this migration
ALTER TABLE sent_activity ALTER TABLE sent_activity
ADD COLUMN send_inboxes text[] NOT NULL DEFAULT '{}', -- list of specific inbox urls ADD COLUMN send_inboxes text[] NOT NULL DEFAULT '{}', -- list of specific inbox urls
ADD COLUMN send_community_followers_of integer[] NOT NULL DEFAULT '{}', ADD COLUMN send_community_followers_of integer DEFAULT NULL,
ADD COLUMN send_all_instances boolean NOT NULL DEFAULT FALSE, ADD COLUMN send_all_instances boolean NOT NULL DEFAULT FALSE,
ADD COLUMN actor_type actor_type_enum NOT NULL DEFAULT 'person', ADD COLUMN actor_type actor_type_enum NOT NULL DEFAULT 'person',
ADD COLUMN actor_apub_id text DEFAULT NULL; ADD COLUMN actor_apub_id text DEFAULT NULL;
@ -20,7 +20,8 @@ ALTER TABLE sent_activity
ALTER COLUMN actor_apub_id DROP DEFAULT; ALTER COLUMN actor_apub_id DROP DEFAULT;
CREATE TABLE federation_queue_state( CREATE TABLE federation_queue_state(
domain text PRIMARY KEY, id serial PRIMARY KEY,
domain varchar(255) NOT NULL UNIQUE,
last_successful_id bigint NOT NULL, last_successful_id bigint NOT NULL,
fail_count integer NOT NULL, fail_count integer NOT NULL,
last_retry timestamptz NOT NULL last_retry timestamptz NOT NULL