diff options
author | lain <lain@soykaf.club> | 2018-02-17 14:55:44 +0100 |
---|---|---|
committer | lain <lain@soykaf.club> | 2018-02-17 14:55:44 +0100 |
commit | e7b73359e352ed585613feeb61a48df3dd6d2cb3 (patch) | |
tree | fda0eabb7ad7c41b7f13ecaff62ea85f5dc0c7ed /lib | |
parent | 5682e48a253e40791b0b723f8cebf605c9cf7b63 (diff) | |
download | pleroma-e7b73359e352ed585613feeb61a48df3dd6d2cb3.tar.gz pleroma-e7b73359e352ed585613feeb61a48df3dd6d2cb3.zip |
ActivityPub: Partly handle incoming follows.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/web/activity_pub/transmogrifier.ex | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/lib/pleroma/web/activity_pub/transmogrifier.ex b/lib/pleroma/web/activity_pub/transmogrifier.ex index c4b6a79e0..f4af3aed3 100644 --- a/lib/pleroma/web/activity_pub/transmogrifier.ex +++ b/lib/pleroma/web/activity_pub/transmogrifier.ex @@ -38,6 +38,20 @@ defmodule Pleroma.Web.ActivityPub.Transmogrifier do end end + def handle_incoming(%{"type" => "Follow", "object" => followed, "actor" => follower, "id" => id}) do + with %User{} = followed <- User.get_cached_by_ap_id(followed), + %User{} = follower <- User.get_or_fetch_by_ap_id(follower), + {:ok, activity} <- ActivityPub.follow(follower, followed, id, false) do + # TODO: Send an "Accept" activity. + User.follow(follower, followed) + {:ok, activity} + else + _e -> :error + end + end + + def handle_incoming(_), do: :error + @doc """ internal -> Mastodon |