Merge branch 'activitypub-dereference-activity-id' into 'develop'
Support activity+json request for activity See merge request pleroma/pleroma!641
This commit is contained in:
commit
e4afe1359b
3 changed files with 57 additions and 14 deletions
|
@ -54,6 +54,19 @@ def object(conn, %{"uuid" => uuid}) do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def activity(conn, %{"uuid" => uuid}) do
|
||||||
|
with ap_id <- o_status_url(conn, :activity, uuid),
|
||||||
|
%Activity{} = activity <- Activity.normalize(ap_id),
|
||||||
|
{_, true} <- {:public?, ActivityPub.is_public?(activity)} do
|
||||||
|
conn
|
||||||
|
|> put_resp_header("content-type", "application/activity+json")
|
||||||
|
|> json(ObjectView.render("object.json", %{object: activity}))
|
||||||
|
else
|
||||||
|
{:public?, false} ->
|
||||||
|
{:error, :not_found}
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def following(conn, %{"nickname" => nickname, "page" => page}) do
|
def following(conn, %{"nickname" => nickname, "page" => page}) do
|
||||||
with %User{} = user <- User.get_cached_by_nickname(nickname),
|
with %User{} = user <- User.get_cached_by_nickname(nickname),
|
||||||
{:ok, user} <- Pleroma.Web.WebFinger.ensure_keys_present(user) do
|
{:ok, user} <- Pleroma.Web.WebFinger.ensure_keys_present(user) do
|
||||||
|
|
|
@ -112,23 +112,27 @@ def object(conn, %{"uuid" => uuid}) do
|
||||||
end
|
end
|
||||||
|
|
||||||
def activity(conn, %{"uuid" => uuid}) do
|
def activity(conn, %{"uuid" => uuid}) do
|
||||||
with id <- o_status_url(conn, :activity, uuid),
|
if get_format(conn) == "activity+json" do
|
||||||
{_, %Activity{} = activity} <- {:activity, Activity.normalize(id)},
|
ActivityPubController.call(conn, :activity)
|
||||||
{_, true} <- {:public?, ActivityPub.is_public?(activity)},
|
|
||||||
%User{} = user <- User.get_cached_by_ap_id(activity.data["actor"]) do
|
|
||||||
case format = get_format(conn) do
|
|
||||||
"html" -> redirect(conn, to: "/notice/#{activity.id}")
|
|
||||||
_ -> represent_activity(conn, format, activity, user)
|
|
||||||
end
|
|
||||||
else
|
else
|
||||||
{:public?, false} ->
|
with id <- o_status_url(conn, :activity, uuid),
|
||||||
{:error, :not_found}
|
{_, %Activity{} = activity} <- {:activity, Activity.normalize(id)},
|
||||||
|
{_, true} <- {:public?, ActivityPub.is_public?(activity)},
|
||||||
|
%User{} = user <- User.get_cached_by_ap_id(activity.data["actor"]) do
|
||||||
|
case format = get_format(conn) do
|
||||||
|
"html" -> redirect(conn, to: "/notice/#{activity.id}")
|
||||||
|
_ -> represent_activity(conn, format, activity, user)
|
||||||
|
end
|
||||||
|
else
|
||||||
|
{:public?, false} ->
|
||||||
|
{:error, :not_found}
|
||||||
|
|
||||||
{:activity, nil} ->
|
{:activity, nil} ->
|
||||||
{:error, :not_found}
|
{:error, :not_found}
|
||||||
|
|
||||||
e ->
|
e ->
|
||||||
e
|
e
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -89,6 +89,32 @@ test "it returns 404 for tombstone objects", %{conn: conn} do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe "/activities/:uuid" do
|
||||||
|
test "it returns a json representation of the activity", %{conn: conn} do
|
||||||
|
activity = insert(:note_activity)
|
||||||
|
uuid = String.split(activity.data["id"], "/") |> List.last()
|
||||||
|
|
||||||
|
conn =
|
||||||
|
conn
|
||||||
|
|> put_req_header("accept", "application/activity+json")
|
||||||
|
|> get("/activities/#{uuid}")
|
||||||
|
|
||||||
|
assert json_response(conn, 200) == ObjectView.render("object.json", %{object: activity})
|
||||||
|
end
|
||||||
|
|
||||||
|
test "it returns 404 for non-public activities", %{conn: conn} do
|
||||||
|
activity = insert(:direct_note_activity)
|
||||||
|
uuid = String.split(activity.data["id"], "/") |> List.last()
|
||||||
|
|
||||||
|
conn =
|
||||||
|
conn
|
||||||
|
|> put_req_header("accept", "application/activity+json")
|
||||||
|
|> get("/activities/#{uuid}")
|
||||||
|
|
||||||
|
assert json_response(conn, 404)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
describe "/inbox" do
|
describe "/inbox" do
|
||||||
test "it inserts an incoming activity into the database", %{conn: conn} do
|
test "it inserts an incoming activity into the database", %{conn: conn} do
|
||||||
data = File.read!("test/fixtures/mastodon-post-activity.json") |> Poison.decode!()
|
data = File.read!("test/fixtures/mastodon-post-activity.json") |> Poison.decode!()
|
||||||
|
|
Loading…
Reference in a new issue