2024-09-26 01:45:10 +00:00
|
|
|
defmodule PostlandWeb.InboxController do
|
|
|
|
|
use PostlandWeb, :controller
|
|
|
|
|
|
|
|
|
|
require Logger
|
|
|
|
|
|
|
|
|
|
alias ActivityPub.Headers
|
|
|
|
|
alias Postland.Activities
|
|
|
|
|
|
|
|
|
|
def post(conn, params) do
|
|
|
|
|
if Headers.verify(conn.method, conn.request_path, conn.req_headers) do
|
|
|
|
|
case Activities.record_activity(params) do
|
|
|
|
|
{:ok, _activity} ->
|
2024-09-30 00:53:00 +00:00
|
|
|
send_resp(conn, 200, "ok")
|
|
|
|
|
|
2024-09-26 01:45:10 +00:00
|
|
|
error ->
|
|
|
|
|
Logger.error(error)
|
2024-09-30 00:53:00 +00:00
|
|
|
send_resp(conn, 422, "unprocessable_entity")
|
2024-09-26 01:45:10 +00:00
|
|
|
end
|
|
|
|
|
else
|
2024-09-30 00:53:00 +00:00
|
|
|
Logger.info("Failed to verify type=#{Map.get(params, "type")}")
|
|
|
|
|
|
|
|
|
|
send_resp(conn, 403, "forbidden")
|
2024-09-26 01:45:10 +00:00
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|