1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
5 defmodule Pleroma.Web.StaticFE.StaticFEController do
6 use Pleroma.Web, :controller
8 alias Pleroma.Web.ActivityPub.ActivityPub
9 alias Pleroma.Web.StaticFE.ActivityRepresenter
10 alias Pleroma.Web.StaticFE.UserRepresenter
14 def show_notice(conn, %{"notice_id" => notice_id}) do
15 with {:ok, data} <- ActivityRepresenter.represent(notice_id) do
16 context = data.object.data["context"]
17 activities = ActivityPub.fetch_activities_for_context(context, %{})
20 for a <- Enum.reverse(activities) do
21 ActivityRepresenter.prepare_activity(data.user, a)
22 |> Map.put(:selected, a.object.id == data.object.id)
26 |> put_layout(:static_fe)
28 |> put_view(Pleroma.Web.StaticFE.StaticFEView)
29 |> render("conversation.html", %{data: data})
38 def show_user(conn, %{"username_or_id" => username_or_id}) do
39 with {:ok, data} <- UserRepresenter.represent(username_or_id) do
41 |> put_layout(:static_fe)
43 |> put_view(Pleroma.Web.StaticFE.StaticFEView)
44 |> render("profile.html", %{data: data})
53 def show(%{path_info: ["notice", notice_id]} = conn, _params),
54 do: show_notice(conn, %{"notice_id" => notice_id})
56 def show(%{path_info: ["users", user_id]} = conn, _params),
57 do: show_user(conn, %{"username_or_id" => user_id})
59 def show(%{path_info: [user_id]} = conn, _params),
60 do: show_user(conn, %{"username_or_id" => user_id})
62 # Fallback for unhandled types
63 def show(conn, _params) do