mirror of
https://github.com/LemmyNet/lemmy.git
synced 2025-01-23 10:25:56 +00:00
reimplement http signature verification and other checks
This commit is contained in:
parent
8a071b7b07
commit
6d447c81cf
40 changed files with 229 additions and 264 deletions
|
@ -10,10 +10,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct CreateComment {
|
pub struct CreateComment {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: NoteExt,
|
object: NoteExt,
|
||||||
cc: Vec<Url>,
|
cc: Vec<Url>,
|
||||||
|
@ -24,9 +23,9 @@ pub struct CreateComment {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<CreateComment> {
|
impl VerifyActivity for Activity<CreateComment> {
|
||||||
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(self.id_unchecked(), &self.inner.actor)?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
self.inner.object.id(self.inner.actor.as_str())?;
|
self.inner.object.id(self.actor.as_str())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)
|
check_is_apub_id_valid(&self.actor, false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40,13 +39,12 @@ impl ReceiveActivity for Activity<CreateComment> {
|
||||||
let comment = Comment::from_apub(
|
let comment = Comment::from_apub(
|
||||||
&self.inner.object,
|
&self.inner.object,
|
||||||
context,
|
context,
|
||||||
self.inner.actor.clone(),
|
self.actor.clone(),
|
||||||
request_counter,
|
request_counter,
|
||||||
false,
|
false,
|
||||||
)
|
)
|
||||||
.await?;
|
.await?;
|
||||||
let recipients =
|
let recipients = get_notif_recipients(&self.actor, &comment, context, request_counter).await?;
|
||||||
get_notif_recipients(&self.inner.actor, &comment, context, request_counter).await?;
|
|
||||||
send_websocket_message(
|
send_websocket_message(
|
||||||
comment.id,
|
comment.id,
|
||||||
recipients,
|
recipients,
|
||||||
|
|
|
@ -9,10 +9,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct DeleteComment {
|
pub struct DeleteComment {
|
||||||
pub(in crate::activities::comment) actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
pub(in crate::activities::comment) object: Url,
|
pub(in crate::activities::comment) object: Url,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -23,9 +22,9 @@ pub struct DeleteComment {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<DeleteComment> {
|
impl VerifyActivity for Activity<DeleteComment> {
|
||||||
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.object)?;
|
verify_domains_match(&self.actor, &self.inner.object)?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)
|
check_is_apub_id_valid(&self.actor, false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,10 +6,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct DislikeComment {
|
pub struct DislikeComment {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
pub(in crate::activities::comment) object: Url,
|
pub(in crate::activities::comment) object: Url,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -20,8 +19,8 @@ pub struct DislikeComment {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<DislikeComment> {
|
impl VerifyActivity for Activity<DislikeComment> {
|
||||||
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)
|
check_is_apub_id_valid(&self.actor, false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34,7 +33,7 @@ impl ReceiveActivity for Activity<DislikeComment> {
|
||||||
) -> Result<(), LemmyError> {
|
) -> Result<(), LemmyError> {
|
||||||
like_or_dislike_comment(
|
like_or_dislike_comment(
|
||||||
-1,
|
-1,
|
||||||
&self.inner.actor,
|
&self.actor,
|
||||||
&self.inner.object,
|
&self.inner.object,
|
||||||
context,
|
context,
|
||||||
request_counter,
|
request_counter,
|
||||||
|
|
|
@ -6,10 +6,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct LikeComment {
|
pub struct LikeComment {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
pub(in crate::activities::comment) object: Url,
|
pub(in crate::activities::comment) object: Url,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -20,8 +19,8 @@ pub struct LikeComment {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<LikeComment> {
|
impl VerifyActivity for Activity<LikeComment> {
|
||||||
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)
|
check_is_apub_id_valid(&self.actor, false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34,7 +33,7 @@ impl ReceiveActivity for Activity<LikeComment> {
|
||||||
) -> Result<(), LemmyError> {
|
) -> Result<(), LemmyError> {
|
||||||
like_or_dislike_comment(
|
like_or_dislike_comment(
|
||||||
-1,
|
-1,
|
||||||
&self.inner.actor,
|
&self.actor,
|
||||||
&self.inner.object,
|
&self.inner.object,
|
||||||
context,
|
context,
|
||||||
request_counter,
|
request_counter,
|
||||||
|
|
|
@ -12,10 +12,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct RemoveComment {
|
pub struct RemoveComment {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
pub(in crate::activities::comment) object: Url,
|
pub(in crate::activities::comment) object: Url,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -26,9 +25,9 @@ pub struct RemoveComment {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<RemoveComment> {
|
impl VerifyActivity for Activity<RemoveComment> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
verify_mod_action(self.inner.actor.clone(), self.inner.cc[0].clone(), context).await
|
verify_mod_action(self.actor.clone(), self.inner.cc[0].clone(), context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -12,10 +12,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UndoDeleteComment {
|
pub struct UndoDeleteComment {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: Activity<DeleteComment>,
|
object: Activity<DeleteComment>,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -26,9 +25,9 @@ pub struct UndoDeleteComment {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UndoDeleteComment> {
|
impl VerifyActivity for Activity<UndoDeleteComment> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.object.inner.actor)?;
|
verify_domains_match(&self.actor, &self.inner.object.actor)?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
self.inner.object.verify(context).await
|
self.inner.object.verify(context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,10 +9,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UndoDislikeComment {
|
pub struct UndoDislikeComment {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: Activity<DislikeComment>,
|
object: Activity<DislikeComment>,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -23,9 +22,9 @@ pub struct UndoDislikeComment {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UndoDislikeComment> {
|
impl VerifyActivity for Activity<UndoDislikeComment> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.object.inner.object)?;
|
verify_domains_match(&self.actor, &self.inner.object.inner.object)?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
self.inner.object.verify(context).await
|
self.inner.object.verify(context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -38,7 +37,7 @@ impl ReceiveActivity for Activity<UndoDislikeComment> {
|
||||||
request_counter: &mut i32,
|
request_counter: &mut i32,
|
||||||
) -> Result<(), LemmyError> {
|
) -> Result<(), LemmyError> {
|
||||||
undo_like_or_dislike_comment(
|
undo_like_or_dislike_comment(
|
||||||
&self.inner.actor,
|
&self.actor,
|
||||||
&self.inner.object.inner.object,
|
&self.inner.object.inner.object,
|
||||||
context,
|
context,
|
||||||
request_counter,
|
request_counter,
|
||||||
|
|
|
@ -9,10 +9,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UndoLikeComment {
|
pub struct UndoLikeComment {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: Activity<LikeComment>,
|
object: Activity<LikeComment>,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -23,9 +22,9 @@ pub struct UndoLikeComment {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UndoLikeComment> {
|
impl VerifyActivity for Activity<UndoLikeComment> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.object.inner.object)?;
|
verify_domains_match(&self.actor, &self.inner.object.inner.object)?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
self.inner.object.verify(context).await
|
self.inner.object.verify(context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -38,7 +37,7 @@ impl ReceiveActivity for Activity<UndoLikeComment> {
|
||||||
request_counter: &mut i32,
|
request_counter: &mut i32,
|
||||||
) -> Result<(), LemmyError> {
|
) -> Result<(), LemmyError> {
|
||||||
undo_like_or_dislike_comment(
|
undo_like_or_dislike_comment(
|
||||||
&self.inner.actor,
|
&self.actor,
|
||||||
&self.inner.object.inner.object,
|
&self.inner.object.inner.object,
|
||||||
context,
|
context,
|
||||||
request_counter,
|
request_counter,
|
||||||
|
|
|
@ -15,10 +15,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UndoRemoveComment {
|
pub struct UndoRemoveComment {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: Activity<RemoveComment>,
|
object: Activity<RemoveComment>,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -29,9 +28,9 @@ pub struct UndoRemoveComment {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UndoRemoveComment> {
|
impl VerifyActivity for Activity<UndoRemoveComment> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
verify_mod_action(self.inner.actor.clone(), self.inner.cc[0].clone(), context).await?;
|
verify_mod_action(self.actor.clone(), self.inner.cc[0].clone(), context).await?;
|
||||||
self.inner.object.verify(context).await
|
self.inner.object.verify(context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,10 +10,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UpdateComment {
|
pub struct UpdateComment {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: NoteExt,
|
object: NoteExt,
|
||||||
cc: Vec<Url>,
|
cc: Vec<Url>,
|
||||||
|
@ -24,9 +23,9 @@ pub struct UpdateComment {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UpdateComment> {
|
impl VerifyActivity for Activity<UpdateComment> {
|
||||||
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(self.id_unchecked(), &self.inner.actor)?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
self.inner.object.id(self.inner.actor.as_str())?;
|
self.inner.object.id(self.actor.as_str())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)
|
check_is_apub_id_valid(&self.actor, false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40,14 +39,13 @@ impl ReceiveActivity for Activity<UpdateComment> {
|
||||||
let comment = Comment::from_apub(
|
let comment = Comment::from_apub(
|
||||||
&self.inner.object,
|
&self.inner.object,
|
||||||
context,
|
context,
|
||||||
self.inner.actor.clone(),
|
self.actor.clone(),
|
||||||
request_counter,
|
request_counter,
|
||||||
false,
|
false,
|
||||||
)
|
)
|
||||||
.await?;
|
.await?;
|
||||||
|
|
||||||
let recipients =
|
let recipients = get_notif_recipients(&self.actor, &comment, context, request_counter).await?;
|
||||||
get_notif_recipients(&self.inner.actor, &comment, context, request_counter).await?;
|
|
||||||
send_websocket_message(
|
send_websocket_message(
|
||||||
comment.id,
|
comment.id,
|
||||||
recipients,
|
recipients,
|
||||||
|
|
|
@ -16,10 +16,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct AddModToCommunity {
|
pub struct AddModToCommunity {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: Url,
|
object: Url,
|
||||||
target: Url,
|
target: Url,
|
||||||
|
@ -31,10 +30,10 @@ pub struct AddModToCommunity {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<AddModToCommunity> {
|
impl VerifyActivity for Activity<AddModToCommunity> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
verify_domains_match(&self.inner.target, &self.inner.cc[0])?;
|
verify_domains_match(&self.inner.target, &self.inner.cc[0])?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
verify_mod_action(self.inner.actor.clone(), self.inner.cc[0].clone(), context).await?;
|
verify_mod_action(self.actor.clone(), self.inner.cc[0].clone(), context).await?;
|
||||||
verify_add_remove_moderator_target(&self.inner.target, self.inner.cc[0].clone())
|
verify_add_remove_moderator_target(&self.inner.target, self.inner.cc[0].clone())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,7 +43,7 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
pub enum AnnouncableActivities {
|
pub enum AnnouncableActivities {
|
||||||
CreateComment(CreateComment),
|
CreateComment(CreateComment),
|
||||||
UpdateComment(UpdateComment),
|
UpdateComment(UpdateComment),
|
||||||
|
@ -93,10 +93,9 @@ impl ReceiveActivity for AnnouncableActivities {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct AnnounceActivity {
|
pub struct AnnounceActivity {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: Activity<AnnouncableActivities>,
|
object: Activity<AnnouncableActivities>,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -107,9 +106,9 @@ pub struct AnnounceActivity {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<AnnounceActivity> {
|
impl VerifyActivity for Activity<AnnounceActivity> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.cc[0])?;
|
verify_domains_match(&self.actor, &self.inner.cc[0])?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
self.inner.object.inner.verify(context).await
|
self.inner.object.inner.verify(context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,10 +17,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct BlockUserFromCommunity {
|
pub struct BlockUserFromCommunity {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
pub(in crate::activities::community) object: Url,
|
pub(in crate::activities::community) object: Url,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -31,9 +30,9 @@ pub struct BlockUserFromCommunity {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<BlockUserFromCommunity> {
|
impl VerifyActivity for Activity<BlockUserFromCommunity> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
verify_mod_action(self.inner.actor.clone(), self.inner.cc[0].clone(), context).await
|
verify_mod_action(self.actor.clone(), self.inner.cc[0].clone(), context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -20,10 +20,9 @@ use url::Url;
|
||||||
// We have two possibilities which need to be handled:
|
// We have two possibilities which need to be handled:
|
||||||
// 1. actor is remote mod, community id in object
|
// 1. actor is remote mod, community id in object
|
||||||
// 2. actor is community, cc is followers collection
|
// 2. actor is community, cc is followers collection
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct DeleteCommunity {
|
pub struct DeleteCommunity {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
pub(in crate::activities::community) object: Url,
|
pub(in crate::activities::community) object: Url,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -34,7 +33,7 @@ pub struct DeleteCommunity {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<DeleteCommunity> {
|
impl VerifyActivity for Activity<DeleteCommunity> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
let object = self.inner.object.clone();
|
let object = self.inner.object.clone();
|
||||||
let community = blocking(context.pool(), move |conn| {
|
let community = blocking(context.pool(), move |conn| {
|
||||||
Community::read_from_apub_id(conn, &object.into())
|
Community::read_from_apub_id(conn, &object.into())
|
||||||
|
@ -43,13 +42,13 @@ impl VerifyActivity for Activity<DeleteCommunity> {
|
||||||
// remote mod action on local community
|
// remote mod action on local community
|
||||||
if let Ok(c) = community {
|
if let Ok(c) = community {
|
||||||
verify_domains_match(&self.inner.object, &self.inner.cc[0])?;
|
verify_domains_match(&self.inner.object, &self.inner.cc[0])?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
verify_is_community_mod(self.inner.actor.clone(), c.actor_id(), context).await
|
verify_is_community_mod(self.actor.clone(), c.actor_id(), context).await
|
||||||
}
|
}
|
||||||
// community action sent to followers
|
// community action sent to followers
|
||||||
else {
|
else {
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.object)?;
|
verify_domains_match(&self.actor, &self.inner.object)?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.cc[0])
|
verify_domains_match(&self.actor, &self.inner.cc[0])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -69,8 +68,7 @@ impl ReceiveActivity for Activity<DeleteCommunity> {
|
||||||
let community_id = match community {
|
let community_id = match community {
|
||||||
Ok(c) => {
|
Ok(c) => {
|
||||||
// remote mod sent delete to local community, forward it to followers
|
// remote mod sent delete to local community, forward it to followers
|
||||||
let actor =
|
let actor = get_or_fetch_and_upsert_person(&self.actor, context, request_counter).await?;
|
||||||
get_or_fetch_and_upsert_person(&self.inner.actor, context, request_counter).await?;
|
|
||||||
c.send_delete(actor, context).await?;
|
c.send_delete(actor, context).await?;
|
||||||
c.id
|
c.id
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,10 +9,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct RemoveCommunity {
|
pub struct RemoveCommunity {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
pub(in crate::activities::community) object: Url,
|
pub(in crate::activities::community) object: Url,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -23,10 +22,10 @@ pub struct RemoveCommunity {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<RemoveCommunity> {
|
impl VerifyActivity for Activity<RemoveCommunity> {
|
||||||
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.object)?;
|
verify_domains_match(&self.actor, &self.inner.object)?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.cc[0])
|
verify_domains_match(&self.actor, &self.inner.cc[0])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -16,10 +16,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct RemoveModToCommunity {
|
pub struct RemoveModToCommunity {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: Url,
|
object: Url,
|
||||||
target: Url,
|
target: Url,
|
||||||
|
@ -31,10 +30,10 @@ pub struct RemoveModToCommunity {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<RemoveModToCommunity> {
|
impl VerifyActivity for Activity<RemoveModToCommunity> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
verify_domains_match(&self.inner.target, &self.inner.cc[0])?;
|
verify_domains_match(&self.inner.target, &self.inner.cc[0])?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
verify_mod_action(self.inner.actor.clone(), self.inner.cc[0].clone(), context).await?;
|
verify_mod_action(self.actor.clone(), self.inner.cc[0].clone(), context).await?;
|
||||||
verify_add_remove_moderator_target(&self.inner.target, self.inner.cc[0].clone())
|
verify_add_remove_moderator_target(&self.inner.target, self.inner.cc[0].clone())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,10 +15,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UndoBlockUserFromCommunity {
|
pub struct UndoBlockUserFromCommunity {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: Activity<BlockUserFromCommunity>,
|
object: Activity<BlockUserFromCommunity>,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -29,9 +28,9 @@ pub struct UndoBlockUserFromCommunity {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UndoBlockUserFromCommunity> {
|
impl VerifyActivity for Activity<UndoBlockUserFromCommunity> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
verify_mod_action(self.inner.actor.clone(), self.inner.cc[0].clone(), context).await?;
|
verify_mod_action(self.actor.clone(), self.inner.cc[0].clone(), context).await?;
|
||||||
self.inner.object.verify(context).await
|
self.inner.object.verify(context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,10 +24,9 @@ use url::Url;
|
||||||
// We have two possibilities which need to be handled:
|
// We have two possibilities which need to be handled:
|
||||||
// 1. actor is remote mod, community id in object
|
// 1. actor is remote mod, community id in object
|
||||||
// 2. actor is community, cc is followers collection
|
// 2. actor is community, cc is followers collection
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UndoDeleteCommunity {
|
pub struct UndoDeleteCommunity {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: Activity<DeleteCommunity>,
|
object: Activity<DeleteCommunity>,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -38,7 +37,7 @@ pub struct UndoDeleteCommunity {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UndoDeleteCommunity> {
|
impl VerifyActivity for Activity<UndoDeleteCommunity> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
let object = self.inner.object.inner.object.clone();
|
let object = self.inner.object.inner.object.clone();
|
||||||
let community = blocking(context.pool(), move |conn| {
|
let community = blocking(context.pool(), move |conn| {
|
||||||
Community::read_from_apub_id(conn, &object.into())
|
Community::read_from_apub_id(conn, &object.into())
|
||||||
|
@ -47,13 +46,13 @@ impl VerifyActivity for Activity<UndoDeleteCommunity> {
|
||||||
// remote mod action on local community
|
// remote mod action on local community
|
||||||
if let Ok(c) = community {
|
if let Ok(c) = community {
|
||||||
verify_domains_match(&self.inner.object.inner.object, &self.inner.cc[0])?;
|
verify_domains_match(&self.inner.object.inner.object, &self.inner.cc[0])?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
verify_is_community_mod(self.inner.actor.clone(), c.actor_id(), context).await?;
|
verify_is_community_mod(self.actor.clone(), c.actor_id(), context).await?;
|
||||||
}
|
}
|
||||||
// community action sent to followers
|
// community action sent to followers
|
||||||
else {
|
else {
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.object.inner.object)?;
|
verify_domains_match(&self.actor, &self.inner.object.inner.object)?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.cc[0])?;
|
verify_domains_match(&self.actor, &self.inner.cc[0])?;
|
||||||
}
|
}
|
||||||
self.inner.object.verify(context).await
|
self.inner.object.verify(context).await
|
||||||
}
|
}
|
||||||
|
@ -74,8 +73,7 @@ impl ReceiveActivity for Activity<UndoDeleteCommunity> {
|
||||||
let community_id = match community {
|
let community_id = match community {
|
||||||
Ok(c) => {
|
Ok(c) => {
|
||||||
// remote mod sent undo to local community, forward it to followers
|
// remote mod sent undo to local community, forward it to followers
|
||||||
let actor =
|
let actor = get_or_fetch_and_upsert_person(&self.actor, context, request_counter).await?;
|
||||||
get_or_fetch_and_upsert_person(&self.inner.actor, context, request_counter).await?;
|
|
||||||
c.send_delete(actor, context).await?;
|
c.send_delete(actor, context).await?;
|
||||||
c.id
|
c.id
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,10 +12,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UndoRemoveCommunity {
|
pub struct UndoRemoveCommunity {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: Activity<RemoveCommunity>,
|
object: Activity<RemoveCommunity>,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -26,10 +25,10 @@ pub struct UndoRemoveCommunity {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UndoRemoveCommunity> {
|
impl VerifyActivity for Activity<UndoRemoveCommunity> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.object.inner.object)?;
|
verify_domains_match(&self.actor, &self.inner.object.inner.object)?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.cc[0])?;
|
verify_domains_match(&self.actor, &self.inner.cc[0])?;
|
||||||
self.inner.object.verify(context).await
|
self.inner.object.verify(context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,10 +14,9 @@ use url::Url;
|
||||||
|
|
||||||
/// This activity is received from a remote community mod, and updates the description or other
|
/// This activity is received from a remote community mod, and updates the description or other
|
||||||
/// fields of a local community.
|
/// fields of a local community.
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UpdateCommunity {
|
pub struct UpdateCommunity {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: GroupExt,
|
object: GroupExt,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -28,10 +27,10 @@ pub struct UpdateCommunity {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UpdateCommunity> {
|
impl VerifyActivity for Activity<UpdateCommunity> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
self.inner.object.id(self.inner.cc[0].as_str())?;
|
self.inner.object.id(self.inner.cc[0].as_str())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
verify_is_community_mod(self.inner.actor.clone(), self.inner.cc[0].clone(), context).await
|
verify_is_community_mod(self.actor.clone(), self.inner.cc[0].clone(), context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -12,10 +12,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct AcceptFollowCommunity {
|
pub struct AcceptFollowCommunity {
|
||||||
actor: Url,
|
|
||||||
to: Url,
|
to: Url,
|
||||||
object: Activity<FollowCommunity>,
|
object: Activity<FollowCommunity>,
|
||||||
#[serde(rename = "type")]
|
#[serde(rename = "type")]
|
||||||
|
@ -25,8 +24,8 @@ pub struct AcceptFollowCommunity {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<AcceptFollowCommunity> {
|
impl VerifyActivity for Activity<AcceptFollowCommunity> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
self.inner.object.verify(context).await
|
self.inner.object.verify(context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -40,7 +39,7 @@ impl ReceiveActivity for Activity<AcceptFollowCommunity> {
|
||||||
request_counter: &mut i32,
|
request_counter: &mut i32,
|
||||||
) -> Result<(), LemmyError> {
|
) -> Result<(), LemmyError> {
|
||||||
let community =
|
let community =
|
||||||
get_or_fetch_and_upsert_community(&self.inner.actor, context, request_counter).await?;
|
get_or_fetch_and_upsert_community(&self.actor, context, request_counter).await?;
|
||||||
let person = get_or_fetch_and_upsert_person(&self.inner.to, context, request_counter).await?;
|
let person = get_or_fetch_and_upsert_person(&self.inner.to, context, request_counter).await?;
|
||||||
// This will throw an error if no follow was requested
|
// This will throw an error if no follow was requested
|
||||||
blocking(&context.pool(), move |conn| {
|
blocking(&context.pool(), move |conn| {
|
||||||
|
|
|
@ -17,10 +17,9 @@ use lemmy_utils::{location_info, LemmyError};
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct FollowCommunity {
|
pub struct FollowCommunity {
|
||||||
actor: Url,
|
|
||||||
to: Url,
|
to: Url,
|
||||||
pub(in crate::activities::follow) object: Url,
|
pub(in crate::activities::follow) object: Url,
|
||||||
#[serde(rename = "type")]
|
#[serde(rename = "type")]
|
||||||
|
@ -30,9 +29,9 @@ pub struct FollowCommunity {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<FollowCommunity> {
|
impl VerifyActivity for Activity<FollowCommunity> {
|
||||||
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
verify_domains_match(&self.inner.to, &self.inner.object)?;
|
verify_domains_match(&self.inner.to, &self.inner.object)?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)
|
check_is_apub_id_valid(&self.actor, false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -45,8 +44,7 @@ impl ReceiveActivity for Activity<FollowCommunity> {
|
||||||
) -> Result<(), LemmyError> {
|
) -> Result<(), LemmyError> {
|
||||||
let community =
|
let community =
|
||||||
get_or_fetch_and_upsert_community(&self.inner.object, context, request_counter).await?;
|
get_or_fetch_and_upsert_community(&self.inner.object, context, request_counter).await?;
|
||||||
let person =
|
let person = get_or_fetch_and_upsert_person(&self.actor, context, request_counter).await?;
|
||||||
get_or_fetch_and_upsert_person(&self.inner.actor, context, request_counter).await?;
|
|
||||||
let community_follower_form = CommunityFollowerForm {
|
let community_follower_form = CommunityFollowerForm {
|
||||||
community_id: community.id,
|
community_id: community.id,
|
||||||
person_id: person.id,
|
person_id: person.id,
|
||||||
|
|
|
@ -12,10 +12,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UndoFollowCommunity {
|
pub struct UndoFollowCommunity {
|
||||||
actor: Url,
|
|
||||||
to: Url,
|
to: Url,
|
||||||
object: Activity<FollowCommunity>,
|
object: Activity<FollowCommunity>,
|
||||||
#[serde(rename = "type")]
|
#[serde(rename = "type")]
|
||||||
|
@ -25,9 +24,9 @@ pub struct UndoFollowCommunity {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UndoFollowCommunity> {
|
impl VerifyActivity for Activity<UndoFollowCommunity> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
verify_domains_match(&self.inner.to, &self.inner.object.inner.object)?;
|
verify_domains_match(&self.inner.to, &self.inner.object.inner.object)?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
self.inner.object.verify(context).await
|
self.inner.object.verify(context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -41,8 +40,7 @@ impl ReceiveActivity for Activity<UndoFollowCommunity> {
|
||||||
) -> Result<(), LemmyError> {
|
) -> Result<(), LemmyError> {
|
||||||
let community =
|
let community =
|
||||||
get_or_fetch_and_upsert_community(&self.inner.to, context, request_counter).await?;
|
get_or_fetch_and_upsert_community(&self.inner.to, context, request_counter).await?;
|
||||||
let person =
|
let person = get_or_fetch_and_upsert_person(&self.actor, context, request_counter).await?;
|
||||||
get_or_fetch_and_upsert_person(&self.inner.actor, context, request_counter).await?;
|
|
||||||
|
|
||||||
let community_follower_form = CommunityFollowerForm {
|
let community_follower_form = CommunityFollowerForm {
|
||||||
community_id: community.id,
|
community_id: community.id,
|
||||||
|
|
|
@ -13,10 +13,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct CreatePost {
|
pub struct CreatePost {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: PageExt,
|
object: PageExt,
|
||||||
cc: Vec<Url>,
|
cc: Vec<Url>,
|
||||||
|
@ -27,9 +26,9 @@ pub struct CreatePost {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<CreatePost> {
|
impl VerifyActivity for Activity<CreatePost> {
|
||||||
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(self.id_unchecked(), &self.inner.actor)?;
|
verify_domains_match(self.id_unchecked(), &self.actor)?;
|
||||||
self.inner.object.id(self.inner.actor.as_str())?;
|
self.inner.object.id(self.actor.as_str())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)
|
check_is_apub_id_valid(&self.actor, false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40,8 +39,7 @@ impl ReceiveActivity for Activity<CreatePost> {
|
||||||
context: &LemmyContext,
|
context: &LemmyContext,
|
||||||
request_counter: &mut i32,
|
request_counter: &mut i32,
|
||||||
) -> Result<(), LemmyError> {
|
) -> Result<(), LemmyError> {
|
||||||
let person =
|
let person = get_or_fetch_and_upsert_person(&self.actor, context, request_counter).await?;
|
||||||
get_or_fetch_and_upsert_person(&self.inner.actor, context, request_counter).await?;
|
|
||||||
|
|
||||||
let post = Post::from_apub(
|
let post = Post::from_apub(
|
||||||
&self.inner.object,
|
&self.inner.object,
|
||||||
|
|
|
@ -9,10 +9,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct DeletePost {
|
pub struct DeletePost {
|
||||||
pub(in crate::activities::post) actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
pub(in crate::activities::post) object: Url,
|
pub(in crate::activities::post) object: Url,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -23,9 +22,9 @@ pub struct DeletePost {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<DeletePost> {
|
impl VerifyActivity for Activity<DeletePost> {
|
||||||
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.object)?;
|
verify_domains_match(&self.actor, &self.inner.object)?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)
|
check_is_apub_id_valid(&self.actor, false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,10 +6,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct DislikePost {
|
pub struct DislikePost {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
pub(in crate::activities::post) object: Url,
|
pub(in crate::activities::post) object: Url,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -20,8 +19,8 @@ pub struct DislikePost {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<DislikePost> {
|
impl VerifyActivity for Activity<DislikePost> {
|
||||||
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)
|
check_is_apub_id_valid(&self.actor, false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34,7 +33,7 @@ impl ReceiveActivity for Activity<DislikePost> {
|
||||||
) -> Result<(), LemmyError> {
|
) -> Result<(), LemmyError> {
|
||||||
like_or_dislike_post(
|
like_or_dislike_post(
|
||||||
-1,
|
-1,
|
||||||
&self.inner.actor,
|
&self.actor,
|
||||||
&self.inner.object,
|
&self.inner.object,
|
||||||
context,
|
context,
|
||||||
request_counter,
|
request_counter,
|
||||||
|
|
|
@ -6,10 +6,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct LikePost {
|
pub struct LikePost {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
pub(in crate::activities::post) object: Url,
|
pub(in crate::activities::post) object: Url,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -20,8 +19,8 @@ pub struct LikePost {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<LikePost> {
|
impl VerifyActivity for Activity<LikePost> {
|
||||||
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)
|
check_is_apub_id_valid(&self.actor, false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -32,13 +31,6 @@ impl ReceiveActivity for Activity<LikePost> {
|
||||||
context: &LemmyContext,
|
context: &LemmyContext,
|
||||||
request_counter: &mut i32,
|
request_counter: &mut i32,
|
||||||
) -> Result<(), LemmyError> {
|
) -> Result<(), LemmyError> {
|
||||||
like_or_dislike_post(
|
like_or_dislike_post(1, &self.actor, &self.inner.object, context, request_counter).await
|
||||||
1,
|
|
||||||
&self.inner.actor,
|
|
||||||
&self.inner.object,
|
|
||||||
context,
|
|
||||||
request_counter,
|
|
||||||
)
|
|
||||||
.await
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,10 +12,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct RemovePost {
|
pub struct RemovePost {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
pub(in crate::activities::post) object: Url,
|
pub(in crate::activities::post) object: Url,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -26,9 +25,9 @@ pub struct RemovePost {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<RemovePost> {
|
impl VerifyActivity for Activity<RemovePost> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
verify_mod_action(self.inner.actor.clone(), self.inner.cc[0].clone(), context).await
|
verify_mod_action(self.actor.clone(), self.inner.cc[0].clone(), context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -12,10 +12,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UndoDeletePost {
|
pub struct UndoDeletePost {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: Activity<DeletePost>,
|
object: Activity<DeletePost>,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -26,9 +25,9 @@ pub struct UndoDeletePost {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UndoDeletePost> {
|
impl VerifyActivity for Activity<UndoDeletePost> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.object.inner.actor)?;
|
verify_domains_match(&self.actor, &self.inner.object.actor)?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
self.inner.object.verify(context).await
|
self.inner.object.verify(context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,10 +9,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UndoDislikePost {
|
pub struct UndoDislikePost {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: Activity<DislikePost>,
|
object: Activity<DislikePost>,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -23,9 +22,9 @@ pub struct UndoDislikePost {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UndoDislikePost> {
|
impl VerifyActivity for Activity<UndoDislikePost> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.object.inner.object)?;
|
verify_domains_match(&self.actor, &self.inner.object.inner.object)?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
self.inner.object.verify(context).await
|
self.inner.object.verify(context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -38,7 +37,7 @@ impl ReceiveActivity for Activity<UndoDislikePost> {
|
||||||
request_counter: &mut i32,
|
request_counter: &mut i32,
|
||||||
) -> Result<(), LemmyError> {
|
) -> Result<(), LemmyError> {
|
||||||
undo_like_or_dislike_post(
|
undo_like_or_dislike_post(
|
||||||
&self.inner.actor,
|
&self.actor,
|
||||||
&self.inner.object.inner.object,
|
&self.inner.object.inner.object,
|
||||||
context,
|
context,
|
||||||
request_counter,
|
request_counter,
|
||||||
|
|
|
@ -9,10 +9,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UndoLikePost {
|
pub struct UndoLikePost {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: Activity<LikePost>,
|
object: Activity<LikePost>,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -23,9 +22,9 @@ pub struct UndoLikePost {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UndoLikePost> {
|
impl VerifyActivity for Activity<UndoLikePost> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.object.inner.object)?;
|
verify_domains_match(&self.actor, &self.inner.object.inner.object)?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
self.inner.object.verify(context).await
|
self.inner.object.verify(context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -38,7 +37,7 @@ impl ReceiveActivity for Activity<UndoLikePost> {
|
||||||
request_counter: &mut i32,
|
request_counter: &mut i32,
|
||||||
) -> Result<(), LemmyError> {
|
) -> Result<(), LemmyError> {
|
||||||
undo_like_or_dislike_post(
|
undo_like_or_dislike_post(
|
||||||
&self.inner.actor,
|
&self.actor,
|
||||||
&self.inner.object.inner.object,
|
&self.inner.object.inner.object,
|
||||||
context,
|
context,
|
||||||
request_counter,
|
request_counter,
|
||||||
|
|
|
@ -15,10 +15,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UndoRemovePost {
|
pub struct UndoRemovePost {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: Activity<RemovePost>,
|
object: Activity<RemovePost>,
|
||||||
cc: [Url; 1],
|
cc: [Url; 1],
|
||||||
|
@ -29,9 +28,9 @@ pub struct UndoRemovePost {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UndoRemovePost> {
|
impl VerifyActivity for Activity<UndoRemovePost> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
verify_mod_action(self.inner.actor.clone(), self.inner.cc[0].clone(), context).await?;
|
verify_mod_action(self.actor.clone(), self.inner.cc[0].clone(), context).await?;
|
||||||
self.inner.object.verify(context).await
|
self.inner.object.verify(context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,10 +22,9 @@ use lemmy_utils::{location_info, LemmyError};
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UpdatePost {
|
pub struct UpdatePost {
|
||||||
actor: Url,
|
|
||||||
to: PublicUrl,
|
to: PublicUrl,
|
||||||
object: PageExt,
|
object: PageExt,
|
||||||
cc: Vec<Url>,
|
cc: Vec<Url>,
|
||||||
|
@ -36,9 +35,9 @@ pub struct UpdatePost {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UpdatePost> {
|
impl VerifyActivity for Activity<UpdatePost> {
|
||||||
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(self.id_unchecked(), &self.inner.actor)?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
self.inner.object.id(self.inner.actor.as_str())?;
|
self.inner.object.id(self.actor.as_str())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)
|
check_is_apub_id_valid(&self.actor, false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -49,8 +48,7 @@ impl ReceiveActivity for Activity<UpdatePost> {
|
||||||
context: &LemmyContext,
|
context: &LemmyContext,
|
||||||
request_counter: &mut i32,
|
request_counter: &mut i32,
|
||||||
) -> Result<(), LemmyError> {
|
) -> Result<(), LemmyError> {
|
||||||
let person =
|
let person = get_or_fetch_and_upsert_person(&self.actor, context, request_counter).await?;
|
||||||
get_or_fetch_and_upsert_person(&self.inner.actor, context, request_counter).await?;
|
|
||||||
let temp_post = PostForm::from_apub(
|
let temp_post = PostForm::from_apub(
|
||||||
&self.inner.object,
|
&self.inner.object,
|
||||||
context,
|
context,
|
||||||
|
|
|
@ -10,10 +10,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct CreatePrivateMessage {
|
pub struct CreatePrivateMessage {
|
||||||
actor: Url,
|
|
||||||
to: Url,
|
to: Url,
|
||||||
object: NoteExt,
|
object: NoteExt,
|
||||||
#[serde(rename = "type")]
|
#[serde(rename = "type")]
|
||||||
|
@ -23,9 +22,9 @@ pub struct CreatePrivateMessage {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<CreatePrivateMessage> {
|
impl VerifyActivity for Activity<CreatePrivateMessage> {
|
||||||
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(self.id_unchecked(), &self.inner.actor)?;
|
verify_domains_match(self.id_unchecked(), &self.actor)?;
|
||||||
self.inner.object.id(self.inner.actor.as_str())?;
|
self.inner.object.id(self.actor.as_str())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)
|
check_is_apub_id_valid(&self.actor, false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -39,7 +38,7 @@ impl ReceiveActivity for Activity<CreatePrivateMessage> {
|
||||||
let private_message = PrivateMessage::from_apub(
|
let private_message = PrivateMessage::from_apub(
|
||||||
&self.inner.object,
|
&self.inner.object,
|
||||||
context,
|
context,
|
||||||
self.inner.actor.clone(),
|
self.actor.clone(),
|
||||||
request_counter,
|
request_counter,
|
||||||
false,
|
false,
|
||||||
)
|
)
|
||||||
|
|
|
@ -12,10 +12,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct DeletePrivateMessage {
|
pub struct DeletePrivateMessage {
|
||||||
actor: Url,
|
|
||||||
to: Url,
|
to: Url,
|
||||||
pub(in crate::activities::private_message) object: Url,
|
pub(in crate::activities::private_message) object: Url,
|
||||||
#[serde(rename = "type")]
|
#[serde(rename = "type")]
|
||||||
|
@ -25,9 +24,9 @@ pub struct DeletePrivateMessage {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<DeletePrivateMessage> {
|
impl VerifyActivity for Activity<DeletePrivateMessage> {
|
||||||
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.object)?;
|
verify_domains_match(&self.actor, &self.inner.object)?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)
|
check_is_apub_id_valid(&self.actor, false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -12,10 +12,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UndoDeletePrivateMessage {
|
pub struct UndoDeletePrivateMessage {
|
||||||
actor: Url,
|
|
||||||
to: Url,
|
to: Url,
|
||||||
object: Activity<DeletePrivateMessage>,
|
object: Activity<DeletePrivateMessage>,
|
||||||
#[serde(rename = "type")]
|
#[serde(rename = "type")]
|
||||||
|
@ -25,9 +24,9 @@ pub struct UndoDeletePrivateMessage {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UndoDeletePrivateMessage> {
|
impl VerifyActivity for Activity<UndoDeletePrivateMessage> {
|
||||||
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(&self.inner.actor, self.id_unchecked())?;
|
verify_domains_match(&self.actor, self.id_unchecked())?;
|
||||||
verify_domains_match(&self.inner.actor, &self.inner.object.id_unchecked())?;
|
verify_domains_match(&self.actor, &self.inner.object.id_unchecked())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)?;
|
check_is_apub_id_valid(&self.actor, false)?;
|
||||||
self.inner.object.verify(context).await
|
self.inner.object.verify(context).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,10 +10,9 @@ use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
use lemmy_websocket::{LemmyContext, UserOperationCrud};
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct UpdatePrivateMessage {
|
pub struct UpdatePrivateMessage {
|
||||||
actor: Url,
|
|
||||||
to: Url,
|
to: Url,
|
||||||
object: NoteExt,
|
object: NoteExt,
|
||||||
#[serde(rename = "type")]
|
#[serde(rename = "type")]
|
||||||
|
@ -23,9 +22,9 @@ pub struct UpdatePrivateMessage {
|
||||||
#[async_trait::async_trait(?Send)]
|
#[async_trait::async_trait(?Send)]
|
||||||
impl VerifyActivity for Activity<UpdatePrivateMessage> {
|
impl VerifyActivity for Activity<UpdatePrivateMessage> {
|
||||||
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
async fn verify(&self, _context: &LemmyContext) -> Result<(), LemmyError> {
|
||||||
verify_domains_match(self.id_unchecked(), &self.inner.actor)?;
|
verify_domains_match(self.id_unchecked(), &self.actor)?;
|
||||||
self.inner.object.id(self.inner.actor.as_str())?;
|
self.inner.object.id(self.actor.as_str())?;
|
||||||
check_is_apub_id_valid(&self.inner.actor, false)
|
check_is_apub_id_valid(&self.actor, false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -39,7 +38,7 @@ impl ReceiveActivity for Activity<UpdatePrivateMessage> {
|
||||||
let private_message = PrivateMessage::from_apub(
|
let private_message = PrivateMessage::from_apub(
|
||||||
&self.inner.object,
|
&self.inner.object,
|
||||||
context,
|
context,
|
||||||
self.inner.actor.clone(),
|
self.actor.clone(),
|
||||||
request_counter,
|
request_counter,
|
||||||
false,
|
false,
|
||||||
)
|
)
|
||||||
|
|
|
@ -1,22 +1,10 @@
|
||||||
use activitystreams::{
|
use crate::inbox::new_inbox_routing::Activity;
|
||||||
activity::ActorAndObjectRefExt,
|
use anyhow::{anyhow, Context};
|
||||||
base::{AsBase, Extends},
|
|
||||||
object::AsObject,
|
|
||||||
};
|
|
||||||
use actix_web::HttpRequest;
|
|
||||||
use anyhow::Context;
|
|
||||||
use lemmy_api_common::blocking;
|
use lemmy_api_common::blocking;
|
||||||
use lemmy_apub::{
|
|
||||||
check_is_apub_id_valid,
|
|
||||||
extensions::signatures::verify_signature,
|
|
||||||
fetcher::get_or_fetch_and_upsert_actor,
|
|
||||||
ActorType,
|
|
||||||
};
|
|
||||||
use lemmy_db_queries::{source::activity::Activity_, DbPool};
|
use lemmy_db_queries::{source::activity::Activity_, DbPool};
|
||||||
use lemmy_db_schema::source::activity::Activity;
|
use lemmy_db_schema::source::activity::Activity as DbActivity;
|
||||||
use lemmy_utils::{location_info, LemmyError};
|
use lemmy_utils::{location_info, settings::structs::Settings, LemmyError};
|
||||||
use lemmy_websocket::LemmyContext;
|
use std::fmt::Debug;
|
||||||
use serde::Serialize;
|
|
||||||
use url::Url;
|
use url::Url;
|
||||||
|
|
||||||
pub mod community_inbox;
|
pub mod community_inbox;
|
||||||
|
@ -30,7 +18,7 @@ pub(crate) async fn is_activity_already_known(
|
||||||
) -> Result<bool, LemmyError> {
|
) -> Result<bool, LemmyError> {
|
||||||
let activity_id = activity_id.to_owned().into();
|
let activity_id = activity_id.to_owned().into();
|
||||||
let existing = blocking(pool, move |conn| {
|
let existing = blocking(pool, move |conn| {
|
||||||
Activity::read_from_apub_id(&conn, &activity_id)
|
DbActivity::read_from_apub_id(&conn, &activity_id)
|
||||||
})
|
})
|
||||||
.await?;
|
.await?;
|
||||||
match existing {
|
match existing {
|
||||||
|
@ -39,24 +27,19 @@ pub(crate) async fn is_activity_already_known(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) async fn inbox_verify_http_signature<T, Kind>(
|
pub(in crate::inbox) fn assert_activity_not_local<T: Debug>(
|
||||||
activity: &T,
|
activity: &Activity<T>,
|
||||||
context: &LemmyContext,
|
) -> Result<(), LemmyError> {
|
||||||
request: HttpRequest,
|
let activity_domain = activity.id_unchecked().domain().context(location_info!())?;
|
||||||
request_counter: &mut i32,
|
|
||||||
) -> Result<Box<dyn ActorType>, LemmyError>
|
if activity_domain == Settings::get().hostname() {
|
||||||
where
|
return Err(
|
||||||
T: AsObject<Kind> + ActorAndObjectRefExt + Extends<Kind> + AsBase<Kind>,
|
anyhow!(
|
||||||
Kind: Serialize,
|
"Error: received activity which was sent by local instance: {:?}",
|
||||||
<T as Extends<Kind>>::Error: From<serde_json::Error> + Send + Sync + 'static,
|
activity
|
||||||
{
|
)
|
||||||
let actor_id = activity
|
.into(),
|
||||||
.actor()?
|
);
|
||||||
.to_owned()
|
}
|
||||||
.single_xsd_any_uri()
|
Ok(())
|
||||||
.context(location_info!())?;
|
|
||||||
check_is_apub_id_valid(&actor_id, false)?;
|
|
||||||
let actor = get_or_fetch_and_upsert_actor(&actor_id, &context, request_counter).await?;
|
|
||||||
verify_signature(&request, actor.as_ref())?;
|
|
||||||
Ok(actor)
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,12 +49,13 @@ use url::Url;
|
||||||
|
|
||||||
// TODO: would be nice if we could move this to lemmy_apub_lib crate. doing that gives error:
|
// TODO: would be nice if we could move this to lemmy_apub_lib crate. doing that gives error:
|
||||||
// "only traits defined in the current crate can be implemented for arbitrary types"
|
// "only traits defined in the current crate can be implemented for arbitrary types"
|
||||||
#[derive(Debug, Clone, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
#[serde(rename_all = "camelCase")]
|
#[serde(rename_all = "camelCase")]
|
||||||
pub struct Activity<Kind> {
|
pub struct Activity<Kind> {
|
||||||
#[serde(rename = "@context")]
|
#[serde(rename = "@context")]
|
||||||
context: OneOrMany<AnyBase>,
|
context: OneOrMany<AnyBase>,
|
||||||
id: Url,
|
id: Url,
|
||||||
|
pub(crate) actor: Url,
|
||||||
|
|
||||||
/// type-specific fields
|
/// type-specific fields
|
||||||
#[serde(flatten)]
|
#[serde(flatten)]
|
||||||
|
@ -71,7 +72,7 @@ impl<Kind> Activity<Kind> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, serde::Deserialize, serde::Serialize)]
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||||||
pub enum SharedInboxActivities {
|
pub enum SharedInboxActivities {
|
||||||
FollowCommunity(FollowCommunity),
|
FollowCommunity(FollowCommunity),
|
||||||
AcceptFollowCommunity(AcceptFollowCommunity),
|
AcceptFollowCommunity(AcceptFollowCommunity),
|
||||||
|
|
|
@ -1,17 +1,50 @@
|
||||||
use crate::inbox::new_inbox_routing::{Activity, SharedInboxActivities};
|
use crate::inbox::{
|
||||||
|
assert_activity_not_local,
|
||||||
|
is_activity_already_known,
|
||||||
|
new_inbox_routing::{Activity, SharedInboxActivities},
|
||||||
|
};
|
||||||
use actix_web::{web, HttpRequest, HttpResponse};
|
use actix_web::{web, HttpRequest, HttpResponse};
|
||||||
|
use lemmy_apub::{
|
||||||
|
check_is_apub_id_valid,
|
||||||
|
extensions::signatures::verify_signature,
|
||||||
|
fetcher::get_or_fetch_and_upsert_actor,
|
||||||
|
insert_activity,
|
||||||
|
};
|
||||||
use lemmy_apub_lib::{ReceiveActivity, VerifyActivity};
|
use lemmy_apub_lib::{ReceiveActivity, VerifyActivity};
|
||||||
use lemmy_utils::LemmyError;
|
use lemmy_utils::LemmyError;
|
||||||
use lemmy_websocket::LemmyContext;
|
use lemmy_websocket::LemmyContext;
|
||||||
|
|
||||||
pub async fn shared_inbox(
|
pub async fn shared_inbox(
|
||||||
_request: HttpRequest,
|
request: HttpRequest,
|
||||||
input: web::Json<Activity<SharedInboxActivities>>,
|
input: web::Json<Activity<SharedInboxActivities>>,
|
||||||
context: web::Data<LemmyContext>,
|
context: web::Data<LemmyContext>,
|
||||||
) -> Result<HttpResponse, LemmyError> {
|
) -> Result<HttpResponse, LemmyError> {
|
||||||
let activity = input.into_inner();
|
let activity = input.into_inner();
|
||||||
activity.inner.verify(&context).await?;
|
|
||||||
let request_counter = &mut 0;
|
// Do nothing if we received the same activity before
|
||||||
activity.inner.receive(&context, request_counter).await?;
|
if is_activity_already_known(context.pool(), &activity.id_unchecked()).await? {
|
||||||
todo!()
|
return Ok(HttpResponse::Ok().finish());
|
||||||
|
}
|
||||||
|
assert_activity_not_local(&activity)?;
|
||||||
|
check_is_apub_id_valid(&activity.actor, false)?;
|
||||||
|
activity.inner.verify(&context).await?;
|
||||||
|
|
||||||
|
let request_counter = &mut 0;
|
||||||
|
let actor = get_or_fetch_and_upsert_actor(&activity.actor, &context, request_counter).await?;
|
||||||
|
verify_signature(&request, actor.as_ref())?;
|
||||||
|
|
||||||
|
// Log the activity, so we avoid receiving and parsing it twice. Note that this could still happen
|
||||||
|
// if we receive the same activity twice in very quick succession.
|
||||||
|
insert_activity(
|
||||||
|
&activity.id_unchecked(),
|
||||||
|
activity.clone(),
|
||||||
|
false,
|
||||||
|
true,
|
||||||
|
context.pool(),
|
||||||
|
)
|
||||||
|
.await?;
|
||||||
|
|
||||||
|
// TODO: pass the actor in somehow
|
||||||
|
activity.inner.receive(&context, request_counter).await?;
|
||||||
|
return Ok(HttpResponse::Ok().finish());
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue