plug(Pleroma.Plugs.EnsurePublicOrAuthenticatedPlug)
# GET /api/v1/notifications
+ def index(conn, %{"account_id" => account_id} = params) do
+ case Pleroma.User.get_cached_by_id(account_id) do
+ %{ap_id: account_ap_id} ->
+ params =
+ params
+ |> Map.delete("account_id")
+ |> Map.put("account_ap_id", account_ap_id)
+
+ index(conn, params)
+
+ _ ->
+ conn
+ |> put_status(:not_found)
+ |> json(%{"error" => "Account is not found"})
+ end
+ end
+
def index(%{assigns: %{user: user}} = conn, params) do
notifications = MastodonAPI.get_notifications(user, params)
user
|> Notification.for_user_query(options)
|> restrict(:exclude_types, options)
- |> restrict(:account_id, options)
+ |> restrict(:account_ap_id, options)
|> Pagination.fetch_paginated(params)
end
reblogs: :boolean,
with_muted: :boolean,
with_move: :boolean,
- account_id: :string
+ account_ap_id: :string
}
changeset = cast({%{}, param_types}, params, Map.keys(param_types))
|> where([q, a], not fragment("? @> ARRAY[?->>'type']::varchar[]", ^ap_types, a.data))
end
- defp restrict(query, :account_id, %{account_id: account_id}) do
- case User.get_cached_by_id(account_id) do
- %{ap_id: ap_id} -> where(query, [n, a], a.actor == ^ap_id)
- _ -> where(query, [n, a], a.actor == "fake ap id")
- end
+ defp restrict(query, :account_ap_id, %{account_ap_id: account_ap_id}) do
+ where(query, [n, a], a.actor == ^account_ap_id)
end
defp restrict(query, _, _), do: query