aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorlain <lain@soykaf.club>2018-02-21 08:51:03 +0100
committerlain <lain@soykaf.club>2018-02-21 08:51:03 +0100
commitb52672294e8cbc6f1ff53b9c7193e55781db84a6 (patch)
tree38e4edd23f5ffc42672fec2326fe31e2ccfbb3a2 /lib
parent391b3e3586c65b4dc8ce515721e0fff877e854fb (diff)
downloadpleroma-b52672294e8cbc6f1ff53b9c7193e55781db84a6.tar.gz
Move incoming AP to Federator.
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/web/activity_pub/activity_pub_controller.ex28
-rw-r--r--lib/pleroma/web/federator/federator.ex24
2 files changed, 27 insertions, 25 deletions
diff --git a/lib/pleroma/web/activity_pub/activity_pub_controller.ex b/lib/pleroma/web/activity_pub/activity_pub_controller.ex
index 835e8bd9d..513758176 100644
--- a/lib/pleroma/web/activity_pub/activity_pub_controller.ex
+++ b/lib/pleroma/web/activity_pub/activity_pub_controller.ex
@@ -3,6 +3,7 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubController do
alias Pleroma.{User, Repo, Object, Activity}
alias Pleroma.Web.ActivityPub.{ObjectView, UserView, Transmogrifier}
alias Pleroma.Web.ActivityPub.ActivityPub
+ alias Pleroma.Web.Federator
require Logger
@@ -24,22 +25,8 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubController do
# TODO: Ensure that this inbox is a recipient of the message
def inbox(%{assigns: %{valid_signature: true}} = conn, params) do
- # File.write("/tmp/incoming.json", Poison.encode!(params))
- # Logger.info(Poison.encode!(params, [pretty: 2]))
- with {:ok, _user} <- ap_enabled_actor(params["actor"]),
- nil <- Activity.get_by_ap_id(params["id"]),
- {:ok, activity} <- Transmogrifier.handle_incoming(params) do
- json(conn, "ok")
- else
- %Activity{} ->
- Logger.info("Already had #{params["id"]}")
- json(conn, "ok")
- e ->
- # Just drop those for now
- Logger.info("Unhandled activity")
- Logger.info(Poison.encode!(params, [pretty: 2]))
- json(conn, "ok")
- end
+ Federator.enqeue(:incoming_ap_doc, params)
+ json(conn, "ok")
end
def inbox(conn, params) do
@@ -48,15 +35,6 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubController do
json(conn, "ok")
end
- def ap_enabled_actor(id) do
- user = User.get_by_ap_id(id)
- if User.ap_enabled?(user) do
- {:ok, user}
- else
- ActivityPub.make_user_from_ap_id(id)
- end
- end
-
def errors(conn, _e) do
conn
|> put_status(500)
diff --git a/lib/pleroma/web/federator/federator.ex b/lib/pleroma/web/federator/federator.ex
index b64b43c56..9f81264e4 100644
--- a/lib/pleroma/web/federator/federator.ex
+++ b/lib/pleroma/web/federator/federator.ex
@@ -3,6 +3,7 @@ defmodule Pleroma.Web.Federator do
alias Pleroma.User
alias Pleroma.Web.{WebFinger, Websub}
alias Pleroma.Web.ActivityPub.ActivityPub
+ alias Pleroma.Web.ActivityPub.Transmogrifier
require Logger
@websub Application.get_env(:pleroma, :websub)
@@ -66,6 +67,20 @@ defmodule Pleroma.Web.Federator do
@ostatus.handle_incoming(doc)
end
+ def handle(:incoming_ap_doc, params) do
+ with {:ok, _user} <- ap_enabled_actor(params["actor"]),
+ nil <- Activity.get_by_ap_id(params["id"]),
+ {:ok, activity} <- Transmogrifier.handle_incoming(params) do
+ else
+ %Activity{} ->
+ Logger.info("Already had #{params["id"]}")
+ e ->
+ # Just drop those for now
+ Logger.info("Unhandled activity")
+ Logger.info(Poison.encode!(params, [pretty: 2]))
+ end
+ end
+
def handle(:publish_single_ap, params) do
ActivityPub.publish_one(params)
end
@@ -145,4 +160,13 @@ defmodule Pleroma.Web.Federator do
def queue_pop([%{item: element} | queue]) do
{element, queue}
end
+
+ def ap_enabled_actor(id) do
+ user = User.get_by_ap_id(id)
+ if User.ap_enabled?(user) do
+ {:ok, user}
+ else
+ ActivityPub.make_user_from_ap_id(id)
+ end
+ end
end