diff options
author | kaniini <nenolod@gmail.com> | 2019-03-04 13:25:32 +0000 |
---|---|---|
committer | kaniini <nenolod@gmail.com> | 2019-03-04 13:25:32 +0000 |
commit | 10248d86a2ca333de8a44e28ab0b8cee70b5d5dd (patch) | |
tree | 1ae993e2febcd5624cf5b044776a4fdc97043c23 /lib/pleroma/web/common_api | |
parent | c63a45cd0e6078ec8e5e5434dd04f0e7227f95ed (diff) | |
parent | 594694607cce6e6afc8261911e44273cb3cb03c0 (diff) | |
download | pleroma-10248d86a2ca333de8a44e28ab0b8cee70b5d5dd.tar.gz |
Merge branch 'unify-follow' into 'develop'
Unify follow code with CommonAPI
Closes #690
See merge request pleroma/pleroma!889
Diffstat (limited to 'lib/pleroma/web/common_api')
-rw-r--r-- | lib/pleroma/web/common_api/common_api.ex | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/lib/pleroma/web/common_api/common_api.ex b/lib/pleroma/web/common_api/common_api.ex index 7114d6de6..55a9c2572 100644 --- a/lib/pleroma/web/common_api/common_api.ex +++ b/lib/pleroma/web/common_api/common_api.ex @@ -14,6 +14,19 @@ defmodule Pleroma.Web.CommonAPI do import Pleroma.Web.CommonAPI.Utils + def follow(follower, followed) do + with {:ok, follower} <- User.maybe_direct_follow(follower, followed), + {:ok, activity} <- ActivityPub.follow(follower, followed), + {:ok, follower, followed} <- + User.wait_and_refresh( + Pleroma.Config.get([:activitypub, :follow_handshake_timeout]), + follower, + followed + ) do + {:ok, follower, followed, activity} + end + end + def delete(activity_id, user) do with %Activity{data: %{"object" => %{"id" => object_id}}} <- Repo.get(Activity, activity_id), %Object{} = object <- Object.normalize(object_id), |