diff options
| -rw-r--r-- | CHANGELOG.md | 1 | ||||
| -rw-r--r-- | lib/pleroma/web/router.ex | 5 | ||||
| -rw-r--r-- | lib/pleroma/web/static_fe/static_fe_controller.ex | 9 | ||||
| -rw-r--r-- | test/pleroma/web/o_status/o_status_controller_test.exs | 50 | ||||
| -rw-r--r-- | test/pleroma/web/plugs/frontend_static_plug_test.exs | 2 | 
5 files changed, 67 insertions, 0 deletions
| diff --git a/CHANGELOG.md b/CHANGELOG.md index 8e97da189..ee9e04568 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -19,6 +19,7 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/).  ### Fixed  - Subscription(Bell) Notifications: Don't create from Pipeline Ingested replies  - Handle Reject for already-accepted Follows properly +- Display OpenGraph data on alternative notice routes.  ### Removed diff --git a/lib/pleroma/web/router.ex b/lib/pleroma/web/router.ex index 9ce35ad6b..e278036a2 100644 --- a/lib/pleroma/web/router.ex +++ b/lib/pleroma/web/router.ex @@ -650,6 +650,11 @@ defmodule Pleroma.Web.Router do      get("/activities/:uuid", OStatus.OStatusController, :activity)      get("/notice/:id", OStatus.OStatusController, :notice) +    # Notice compatibility routes for other frontends +    get("/@:nickname/:id", OStatus.OStatusController, :notice) +    get("/@:nickname/posts/:id", OStatus.OStatusController, :notice) +    get("/:nickname/status/:id", OStatus.OStatusController, :notice) +      # Mastodon compatibility routes      get("/users/:nickname/statuses/:id", OStatus.OStatusController, :object)      get("/users/:nickname/statuses/:id/activity", OStatus.OStatusController, :activity) diff --git a/lib/pleroma/web/static_fe/static_fe_controller.ex b/lib/pleroma/web/static_fe/static_fe_controller.ex index 50f0927a3..827c0a384 100644 --- a/lib/pleroma/web/static_fe/static_fe_controller.ex +++ b/lib/pleroma/web/static_fe/static_fe_controller.ex @@ -167,6 +167,15 @@ defmodule Pleroma.Web.StaticFE.StaticFEController do    defp assign_id(%{path_info: ["notice", notice_id]} = conn, _opts),      do: assign(conn, :notice_id, notice_id) +  defp assign_id(%{path_info: ["@" <> _nickname, notice_id]} = conn, _opts), +    do: assign(conn, :notice_id, notice_id) + +  defp assign_id(%{path_info: ["@" <> _nickname, "posts", notice_id]} = conn, _opts), +    do: assign(conn, :notice_id, notice_id) + +  defp assign_id(%{path_info: [_nickname, "status", notice_id]} = conn, _opts), +    do: assign(conn, :notice_id, notice_id) +    defp assign_id(%{path_info: ["users", user_id]} = conn, _opts),      do: assign(conn, :username_or_id, user_id) diff --git a/test/pleroma/web/o_status/o_status_controller_test.exs b/test/pleroma/web/o_status/o_status_controller_test.exs index 81d669837..41aef98b1 100644 --- a/test/pleroma/web/o_status/o_status_controller_test.exs +++ b/test/pleroma/web/o_status/o_status_controller_test.exs @@ -343,4 +343,54 @@ defmodule Pleroma.Web.OStatus.OStatusControllerTest do        |> response(200)      end    end + +  describe "notice compatibility routes" do +    test "Soapbox FE", %{conn: conn} do +      user = insert(:user) +      note_activity = insert(:note_activity, user: user) + +      resp = +        conn +        |> put_req_header("accept", "text/html") +        |> get("/@#{user.nickname}/posts/#{note_activity.id}") +        |> response(200) + +      expected = +        "<meta content=\"#{Endpoint.url()}/notice/#{note_activity.id}\" property=\"og:url\">" + +      assert resp =~ expected +    end + +    test "Mastodon", %{conn: conn} do +      user = insert(:user) +      note_activity = insert(:note_activity, user: user) + +      resp = +        conn +        |> put_req_header("accept", "text/html") +        |> get("/@#{user.nickname}/#{note_activity.id}") +        |> response(200) + +      expected = +        "<meta content=\"#{Endpoint.url()}/notice/#{note_activity.id}\" property=\"og:url\">" + +      assert resp =~ expected +    end + +    test "Twitter", %{conn: conn} do +      user = insert(:user) +      note_activity = insert(:note_activity, user: user) + +      resp = +        conn +        |> put_req_header("accept", "text/html") +        |> get("/#{user.nickname}/status/#{note_activity.id}") +        |> response(200) + +      expected = +        "<meta content=\"#{Endpoint.url()}/notice/#{note_activity.id}\" property=\"og:url\">" + +      assert resp =~ expected +    end +  end  end diff --git a/test/pleroma/web/plugs/frontend_static_plug_test.exs b/test/pleroma/web/plugs/frontend_static_plug_test.exs index 52379b86a..4b3925ad2 100644 --- a/test/pleroma/web/plugs/frontend_static_plug_test.exs +++ b/test/pleroma/web/plugs/frontend_static_plug_test.exs @@ -86,6 +86,8 @@ defmodule Pleroma.Web.Plugs.FrontendStaticPlugTest do        "objects",        "activities",        "notice", +      "@:nickname", +      ":nickname",        "users",        "tags",        "mailer", | 
