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
12 plug(:put_layout, :static_fe)
13 plug(:put_view, Pleroma.Web.StaticFE.StaticFEView)
15 action_fallback(:not_found)
17 def show_notice(%{assigns: %{notice_id: notice_id}} = conn, _params) do
18 with {:ok, data} <- ActivityRepresenter.represent(notice_id) do
19 context = data.object.data["context"]
20 activities = ActivityPub.fetch_activities_for_context(context, %{})
23 for a <- Enum.reverse(activities) do
24 ActivityRepresenter.prepare_activity(data.user, a)
25 |> Map.put(:selected, a.object.id == data.object.id)
28 render(conn, "conversation.html", data: data)
32 def show_user(%{assigns: %{username_or_id: username_or_id}} = conn, _params) do
33 with {:ok, data} <- UserRepresenter.represent(username_or_id) do
34 render(conn, "profile.html", data: data)
38 def assign_id(%{path_info: ["notice", notice_id]} = conn, _opts),
39 do: assign(conn, :notice_id, notice_id)
41 def assign_id(%{path_info: ["users", user_id]} = conn, _opts),
42 do: assign(conn, :username_or_id, user_id)
44 def assign_id(%{path_info: [user_id]} = conn, _opts),
45 do: assign(conn, :username_or_id, user_id)
47 def assign_id(conn, _opts), do: conn
49 # Fallback for unhandled types
50 def not_found(conn, _opts) do