2017-12-11 02:37:22 -07:00
|
|
|
defmodule Pleroma.Web.ActivityPub.ActivityPubController do
|
|
|
|
use Pleroma.Web, :controller
|
2018-02-18 14:37:44 -07:00
|
|
|
alias Pleroma.{User, Repo, Object, Activity}
|
2018-02-15 12:00:43 -07:00
|
|
|
alias Pleroma.Web.ActivityPub.{ObjectView, UserView, Transmogrifier}
|
2017-12-11 02:37:22 -07:00
|
|
|
alias Pleroma.Web.ActivityPub.ActivityPub
|
|
|
|
|
2018-02-18 04:51:35 -07:00
|
|
|
require Logger
|
|
|
|
|
2018-02-15 12:00:43 -07:00
|
|
|
action_fallback :errors
|
|
|
|
|
2017-12-11 02:37:22 -07:00
|
|
|
def user(conn, %{"nickname" => nickname}) do
|
2017-12-11 10:21:33 -07:00
|
|
|
with %User{} = user <- User.get_cached_by_nickname(nickname),
|
|
|
|
{:ok, user} <- Pleroma.Web.WebFinger.ensure_keys_present(user) do
|
2017-12-11 02:37:22 -07:00
|
|
|
json(conn, UserView.render("user.json", %{user: user}))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-12-11 10:21:33 -07:00
|
|
|
def object(conn, %{"uuid" => uuid}) do
|
|
|
|
with ap_id <- o_status_url(conn, :object, uuid),
|
|
|
|
%Object{} = object <- Object.get_cached_by_ap_id(ap_id) do
|
|
|
|
json(conn, ObjectView.render("object.json", %{object: object}))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-02-15 12:00:43 -07:00
|
|
|
# TODO: Ensure that this inbox is a recipient of the message
|
2017-12-12 02:17:50 -07:00
|
|
|
def inbox(%{assigns: %{valid_signature: true}} = conn, params) do
|
2018-02-15 12:00:43 -07:00
|
|
|
# File.write("/tmp/incoming.json", Poison.encode!(params))
|
2018-02-18 04:04:59 -07:00
|
|
|
with {:ok, _user} <- ap_enabled_actor(params["actor"]),
|
2018-02-18 14:37:44 -07:00
|
|
|
nil <- Activity.get_by_ap_id(params["id"]),
|
2018-02-18 04:04:59 -07:00
|
|
|
{:ok, activity} <- Transmogrifier.handle_incoming(params) do
|
2017-12-12 10:07:14 -07:00
|
|
|
json(conn, "ok")
|
2018-02-11 12:43:33 -07:00
|
|
|
else
|
2018-02-18 14:37:44 -07:00
|
|
|
%Activity{} ->
|
|
|
|
Logger.info("Already had #{params["id"]}")
|
|
|
|
json(conn, "ok")
|
2018-02-18 04:51:35 -07:00
|
|
|
e ->
|
|
|
|
# Just drop those for now
|
|
|
|
Logger.info("Unhandled activity")
|
|
|
|
Logger.info(Poison.encode!(params, [pretty: 2]))
|
|
|
|
json(conn, "ok")
|
2017-12-12 10:07:14 -07:00
|
|
|
end
|
2017-12-11 02:37:22 -07:00
|
|
|
end
|
2018-02-15 12:00:43 -07:00
|
|
|
|
2018-02-18 14:40:08 -07:00
|
|
|
def inbox(conn, params) do
|
|
|
|
Logger.info("Signature error.")
|
2018-02-18 14:41:38 -07:00
|
|
|
Logger.info(inspect(conn.req_headers))
|
2018-02-18 14:40:08 -07:00
|
|
|
json(conn, "ok")
|
|
|
|
end
|
2018-02-18 14:41:38 -07:00
|
|
|
|
2018-02-18 04:04:59 -07:00
|
|
|
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
|
|
|
|
|
2018-02-15 12:00:43 -07:00
|
|
|
def errors(conn, _e) do
|
|
|
|
conn
|
|
|
|
|> put_status(500)
|
|
|
|
|> json("error")
|
|
|
|
end
|
2017-12-11 02:37:22 -07:00
|
|
|
end
|