mirror of
https://github.com/LemmyNet/lemmy.git
synced 2025-01-11 12:35:54 +00:00
address review comments mostly
This commit is contained in:
parent
c2ec41fd01
commit
bdbb499c9d
7 changed files with 27 additions and 58 deletions
|
@ -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(),
|
||||||
};
|
};
|
||||||
|
|
|
@ -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![],
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -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>,
|
||||||
|
|
|
@ -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,
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue