Apub inbox rewrite (#1652)
* start to implement apub inbox routing lib
* got something that almost works
* it compiles!
* implemented some more
* move library code to separate crate (most of it)
* convert private message handlers
* convert all comment receivers (except undo comment)
* convert post receiver
* add verify trait
* convert community receivers
* add cc field for all activities which i forgot before
* convert inbox functions, add missing checks
* convert undo like/dislike receivers
* convert undo_delete and undo_remove receivers
* move block/unblock activities
* convert remaining activity receivers
* reimplement http signature verification and other checks
* also use actor type for routing, VerifyActivity and SendActivity traits
* cleanup and restructure apub_receive code
* wip: try to fix activity routing
* implement a (very bad) derive macro for activityhandler
* working activity routing!
* rework pm verify(), fix tests and confirm manually
also remove inbox username check which was broken
* rework following verify(), fix tests and test manually
* fix post/comment create/update, rework voting
* Rewrite remove/delete post/comment, fix tests, test manually
* Rework and fix (un)block user, announce, update post
* some code cleanup
* rework delete/remove activity receivers (still quite messy)
* rewrite, test and fix add/remove mod, update community handlers
* add docs for ActivityHandler derive macro
* dont try to compile macro comments
2021-07-17 16:08:46 +00:00
|
|
|
use crate::{
|
|
|
|
activities::{
|
|
|
|
comment::{create::CreateComment, update::UpdateComment},
|
|
|
|
community::{
|
|
|
|
add_mod::AddMod,
|
|
|
|
block_user::BlockUserFromCommunity,
|
|
|
|
undo_block_user::UndoBlockUserFromCommunity,
|
|
|
|
},
|
|
|
|
deletion::{
|
|
|
|
delete::DeletePostCommentOrCommunity,
|
|
|
|
undo_delete::UndoDeletePostCommentOrCommunity,
|
|
|
|
},
|
|
|
|
post::{create::CreatePost, update::UpdatePost},
|
|
|
|
removal::{
|
|
|
|
remove::RemovePostCommentCommunityOrMod,
|
|
|
|
undo_remove::UndoRemovePostCommentOrCommunity,
|
|
|
|
},
|
|
|
|
verify_activity,
|
|
|
|
verify_community,
|
|
|
|
voting::{
|
|
|
|
dislike::DislikePostOrComment,
|
|
|
|
like::LikePostOrComment,
|
|
|
|
undo_dislike::UndoDislikePostOrComment,
|
|
|
|
undo_like::UndoLikePostOrComment,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
http::is_activity_already_known,
|
2021-07-17 16:20:44 +00:00
|
|
|
insert_activity,
|
Apub inbox rewrite (#1652)
* start to implement apub inbox routing lib
* got something that almost works
* it compiles!
* implemented some more
* move library code to separate crate (most of it)
* convert private message handlers
* convert all comment receivers (except undo comment)
* convert post receiver
* add verify trait
* convert community receivers
* add cc field for all activities which i forgot before
* convert inbox functions, add missing checks
* convert undo like/dislike receivers
* convert undo_delete and undo_remove receivers
* move block/unblock activities
* convert remaining activity receivers
* reimplement http signature verification and other checks
* also use actor type for routing, VerifyActivity and SendActivity traits
* cleanup and restructure apub_receive code
* wip: try to fix activity routing
* implement a (very bad) derive macro for activityhandler
* working activity routing!
* rework pm verify(), fix tests and confirm manually
also remove inbox username check which was broken
* rework following verify(), fix tests and test manually
* fix post/comment create/update, rework voting
* Rewrite remove/delete post/comment, fix tests, test manually
* Rework and fix (un)block user, announce, update post
* some code cleanup
* rework delete/remove activity receivers (still quite messy)
* rewrite, test and fix add/remove mod, update community handlers
* add docs for ActivityHandler derive macro
* dont try to compile macro comments
2021-07-17 16:08:46 +00:00
|
|
|
};
|
|
|
|
use activitystreams::activity::kind::AnnounceType;
|
|
|
|
use lemmy_apub_lib::{ActivityCommonFields, ActivityHandler, PublicUrl};
|
|
|
|
use lemmy_utils::LemmyError;
|
|
|
|
use lemmy_websocket::LemmyContext;
|
|
|
|
use serde::{Deserialize, Serialize};
|
|
|
|
use url::Url;
|
|
|
|
|
|
|
|
#[derive(Clone, Debug, Deserialize, Serialize, ActivityHandler)]
|
|
|
|
#[serde(untagged)]
|
|
|
|
pub enum AnnouncableActivities {
|
|
|
|
CreateComment(CreateComment),
|
|
|
|
UpdateComment(UpdateComment),
|
|
|
|
CreatePost(CreatePost),
|
|
|
|
UpdatePost(UpdatePost),
|
|
|
|
LikePostOrComment(LikePostOrComment),
|
|
|
|
DislikePostOrComment(DislikePostOrComment),
|
|
|
|
UndoLikePostOrComment(UndoLikePostOrComment),
|
|
|
|
UndoDislikePostOrComment(UndoDislikePostOrComment),
|
|
|
|
DeletePostCommentOrCommunity(DeletePostCommentOrCommunity),
|
|
|
|
UndoDeletePostCommentOrCommunity(UndoDeletePostCommentOrCommunity),
|
|
|
|
RemovePostCommentCommunityOrMod(RemovePostCommentCommunityOrMod),
|
|
|
|
UndoRemovePostCommentOrCommunity(UndoRemovePostCommentOrCommunity),
|
|
|
|
BlockUserFromCommunity(BlockUserFromCommunity),
|
|
|
|
UndoBlockUserFromCommunity(UndoBlockUserFromCommunity),
|
|
|
|
AddMod(AddMod),
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
|
|
|
#[serde(rename_all = "camelCase")]
|
|
|
|
pub struct AnnounceActivity {
|
|
|
|
to: PublicUrl,
|
|
|
|
object: AnnouncableActivities,
|
|
|
|
cc: Vec<Url>,
|
|
|
|
#[serde(rename = "type")]
|
|
|
|
kind: AnnounceType,
|
|
|
|
#[serde(flatten)]
|
|
|
|
common: ActivityCommonFields,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[async_trait::async_trait(?Send)]
|
|
|
|
impl ActivityHandler for AnnounceActivity {
|
|
|
|
async fn verify(
|
|
|
|
&self,
|
|
|
|
context: &LemmyContext,
|
|
|
|
request_counter: &mut i32,
|
|
|
|
) -> Result<(), LemmyError> {
|
|
|
|
verify_activity(self.common())?;
|
|
|
|
verify_community(&self.common.actor, context, request_counter).await?;
|
|
|
|
self.object.verify(context, request_counter).await?;
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
async fn receive(
|
|
|
|
&self,
|
|
|
|
context: &LemmyContext,
|
|
|
|
request_counter: &mut i32,
|
|
|
|
) -> Result<(), LemmyError> {
|
|
|
|
if is_activity_already_known(context.pool(), self.object.common().id_unchecked()).await? {
|
|
|
|
return Ok(());
|
|
|
|
}
|
|
|
|
insert_activity(
|
|
|
|
self.object.common().id_unchecked(),
|
|
|
|
self.object.clone(),
|
|
|
|
false,
|
|
|
|
true,
|
|
|
|
context.pool(),
|
|
|
|
)
|
|
|
|
.await?;
|
|
|
|
self.object.receive(context, request_counter).await
|
|
|
|
}
|
|
|
|
|
|
|
|
fn common(&self) -> &ActivityCommonFields {
|
|
|
|
&self.common
|
|
|
|
}
|
|
|
|
}
|