Add context to mastodonAPI.
This commit is contained in:
parent
fc10875895
commit
8672d4d12b
|
@ -61,6 +61,19 @@ def get_status(%{assigns: %{user: user}} = conn, %{"id" => id}) do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def get_context(%{assigns: %{user: user}} = conn, %{"id" => id}) do
|
||||||
|
with %Activity{} = activity <- Repo.get(Activity, id),
|
||||||
|
activities <- ActivityPub.fetch_activities_for_context(activity.data["object"]["context"]),
|
||||||
|
%{true: ancestors, false: descendants} <- Enum.group_by(activities, fn (%{id: id}) -> id < activity.id end) do
|
||||||
|
result = %{
|
||||||
|
ancestors: StatusView.render("index.json", for: user, activities: ancestors, as: :activity) |> Enum.reverse,
|
||||||
|
descendants: StatusView.render("index.json", for: user, activities: descendants, as: :activity) |> Enum.reverse,
|
||||||
|
}
|
||||||
|
|
||||||
|
json(conn, result)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def post_status(%{assigns: %{user: user}} = conn, %{"status" => status} = params) do
|
def post_status(%{assigns: %{user: user}} = conn, %{"status" => status} = params) do
|
||||||
l = status |> String.trim |> String.length
|
l = status |> String.trim |> String.length
|
||||||
|
|
||||||
|
|
|
@ -47,6 +47,7 @@ def user_fetcher(username) do
|
||||||
get "/timelines/public", MastodonAPIController, :public_timeline
|
get "/timelines/public", MastodonAPIController, :public_timeline
|
||||||
|
|
||||||
get "/statuses/:id", MastodonAPIController, :get_status
|
get "/statuses/:id", MastodonAPIController, :get_status
|
||||||
|
get "/statuses/:id/context", MastodonAPIController, :get_context
|
||||||
end
|
end
|
||||||
|
|
||||||
scope "/api/v1", Pleroma.Web.MastodonAPI do
|
scope "/api/v1", Pleroma.Web.MastodonAPI do
|
||||||
|
|
Loading…
Reference in a new issue