defmodule Pleroma.Web.ActivityPub.ActivityPubController do
use Pleroma.Web, :controller
- alias Pleroma.{User, Repo, Object}
+ alias Pleroma.{User, Repo, Object, Activity}
alias Pleroma.Web.ActivityPub.{ObjectView, UserView, Transmogrifier}
alias Pleroma.Web.ActivityPub.ActivityPub
+ alias Pleroma.Web.Federator
require Logger
# 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))
- with {:ok, _user} <- ap_enabled_actor(params["actor"]),
- {:ok, activity} <- Transmogrifier.handle_incoming(params) do
- json(conn, "ok")
- else
- e ->
- # Just drop those for now
- Logger.info("Unhandled activity")
- Logger.info(Poison.encode!(params, [pretty: 2]))
- json(conn, "ok")
- end
+ Federator.enqueue(:incoming_ap_doc, params)
+ 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
+ def inbox(conn, params) do
+ Logger.info("Signature error.")
+ Logger.info(inspect(conn.req_headers))
+ json(conn, "ok")
end
def errors(conn, _e) do