aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/web/common_api
diff options
context:
space:
mode:
authorkaniini <nenolod@gmail.com>2019-03-04 13:25:32 +0000
committerkaniini <nenolod@gmail.com>2019-03-04 13:25:32 +0000
commit10248d86a2ca333de8a44e28ab0b8cee70b5d5dd (patch)
tree1ae993e2febcd5624cf5b044776a4fdc97043c23 /lib/pleroma/web/common_api
parentc63a45cd0e6078ec8e5e5434dd04f0e7227f95ed (diff)
parent594694607cce6e6afc8261911e44273cb3cb03c0 (diff)
downloadpleroma-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.ex13
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),