mirror of
https://github.com/LemmyNet/lemmy.git
synced 2024-05-09 13:32:39 +00:00
e8a52d3a5c
* Add markdown rule to add rel=nofollow for all links * Add markdown image rule to add local image proxy (fixes #1036) * comments * rewrite markdown image links working * add comment * perform markdown image processing in api/apub receivers * clippy * add db table to validate proxied links * rewrite link fields for avatar, banner etc * sql fmt * proxy links received over federation * add config option * undo post.url rewriting, move http route definition * add tests * proxy images through pictrs * testing * cleanup request.rs file * more cleanup (fixes #2611) * include url content type when sending post over apub (fixes #2611) * store post url content type in db * should be media_type * get rid of cache_remote_thumbnails setting, instead automatically take thumbnail from federation data if available. * fix tests * add setting disable_external_link_previews * federate post url as image depending on mime type * change setting again * machete * invert * support custom emoji * clippy * update defaults * add image proxy test, fix test * fix test * clippy * revert accidental changes * address review * clippy * Markdown link rule-dess (#4356) * Extracting opengraph_data to its own type. * A few additions for markdown-link-rule. --------- Co-authored-by: Nutomic <me@nutomic.com> * fix setting * use enum for image proxy setting * fix test configs * add config backwards compat * clippy * machete --------- Co-authored-by: Dessalines <dessalines@users.noreply.github.com>
125 lines
3.8 KiB
Rust
125 lines
3.8 KiB
Rust
use crate::{
|
|
activities::{
|
|
community::send_activity_in_community,
|
|
generate_activity_id,
|
|
verify_is_public,
|
|
verify_mod_action,
|
|
verify_person_in_community,
|
|
},
|
|
activity_lists::AnnouncableActivities,
|
|
insert_received_activity,
|
|
objects::{community::ApubCommunity, person::ApubPerson, read_from_string_or_source_opt},
|
|
protocol::{activities::community::update::UpdateCommunity, InCommunity},
|
|
};
|
|
use activitypub_federation::{
|
|
config::Data,
|
|
kinds::{activity::UpdateType, public},
|
|
traits::{ActivityHandler, Actor, Object},
|
|
};
|
|
use lemmy_api_common::context::LemmyContext;
|
|
use lemmy_db_schema::{
|
|
source::{
|
|
activity::ActivitySendTargets,
|
|
community::{Community, CommunityUpdateForm},
|
|
person::Person,
|
|
},
|
|
traits::Crud,
|
|
utils::naive_now,
|
|
};
|
|
use lemmy_utils::error::LemmyError;
|
|
use url::Url;
|
|
|
|
pub(crate) async fn send_update_community(
|
|
community: Community,
|
|
actor: Person,
|
|
context: Data<LemmyContext>,
|
|
) -> Result<(), LemmyError> {
|
|
let community: ApubCommunity = community.into();
|
|
let actor: ApubPerson = actor.into();
|
|
let id = generate_activity_id(
|
|
UpdateType::Update,
|
|
&context.settings().get_protocol_and_hostname(),
|
|
)?;
|
|
let update = UpdateCommunity {
|
|
actor: actor.id().into(),
|
|
to: vec![public()],
|
|
object: Box::new(community.clone().into_json(&context).await?),
|
|
cc: vec![community.id()],
|
|
kind: UpdateType::Update,
|
|
id: id.clone(),
|
|
audience: Some(community.id().into()),
|
|
};
|
|
|
|
let activity = AnnouncableActivities::UpdateCommunity(update);
|
|
send_activity_in_community(
|
|
activity,
|
|
&actor,
|
|
&community,
|
|
ActivitySendTargets::empty(),
|
|
true,
|
|
&context,
|
|
)
|
|
.await
|
|
}
|
|
|
|
#[async_trait::async_trait]
|
|
impl ActivityHandler for UpdateCommunity {
|
|
type DataType = LemmyContext;
|
|
type Error = LemmyError;
|
|
|
|
fn id(&self) -> &Url {
|
|
&self.id
|
|
}
|
|
|
|
fn actor(&self) -> &Url {
|
|
self.actor.inner()
|
|
}
|
|
|
|
#[tracing::instrument(skip_all)]
|
|
async fn verify(&self, context: &Data<Self::DataType>) -> Result<(), LemmyError> {
|
|
verify_is_public(&self.to, &self.cc)?;
|
|
let community = self.community(context).await?;
|
|
verify_person_in_community(&self.actor, &community, context).await?;
|
|
verify_mod_action(&self.actor, &community, context).await?;
|
|
ApubCommunity::verify(&self.object, &community.actor_id.clone().into(), context).await?;
|
|
Ok(())
|
|
}
|
|
|
|
#[tracing::instrument(skip_all)]
|
|
async fn receive(self, context: &Data<Self::DataType>) -> Result<(), LemmyError> {
|
|
insert_received_activity(&self.id, context).await?;
|
|
let community = self.community(context).await?;
|
|
|
|
let community_update_form = CommunityUpdateForm {
|
|
title: Some(self.object.name.unwrap_or(self.object.preferred_username)),
|
|
description: Some(read_from_string_or_source_opt(
|
|
&self.object.summary,
|
|
&None,
|
|
&self.object.source,
|
|
)),
|
|
removed: None,
|
|
published: self.object.published.map(Into::into),
|
|
updated: Some(self.object.updated.map(Into::into)),
|
|
deleted: None,
|
|
nsfw: Some(self.object.sensitive.unwrap_or(false)),
|
|
actor_id: Some(self.object.id.into()),
|
|
local: None,
|
|
private_key: None,
|
|
hidden: None,
|
|
public_key: Some(self.object.public_key.public_key_pem),
|
|
last_refreshed_at: Some(naive_now()),
|
|
icon: Some(self.object.icon.map(|i| i.url.into())),
|
|
banner: Some(self.object.image.map(|i| i.url.into())),
|
|
followers_url: Some(self.object.followers.into()),
|
|
inbox_url: Some(self.object.inbox.into()),
|
|
shared_inbox_url: Some(self.object.endpoints.map(|e| e.shared_inbox.into())),
|
|
moderators_url: self.object.attributed_to.map(Into::into),
|
|
posting_restricted_to_mods: self.object.posting_restricted_to_mods,
|
|
featured_url: self.object.featured.map(Into::into),
|
|
};
|
|
|
|
Community::update(&mut context.pool(), community.id, &community_update_form).await?;
|
|
Ok(())
|
|
}
|
|
}
|