Merge branch 'activity-pub-metadata' into 'develop'
Add metadata provider for ActivityPub alternate links See merge request pleroma/pleroma!4286
This commit is contained in:
commit
4626a9280a
4 changed files with 64 additions and 0 deletions
1
changelog.d/activity-pub-metadata.add
Normal file
1
changelog.d/activity-pub-metadata.add
Normal file
|
@ -0,0 +1 @@
|
||||||
|
Add metadata provider for ActivityPub alternate links
|
|
@ -7,6 +7,7 @@ defmodule Pleroma.Web.Metadata do
|
||||||
|
|
||||||
def build_tags(params) do
|
def build_tags(params) do
|
||||||
providers = [
|
providers = [
|
||||||
|
Pleroma.Web.Metadata.Providers.ActivityPub,
|
||||||
Pleroma.Web.Metadata.Providers.RelMe,
|
Pleroma.Web.Metadata.Providers.RelMe,
|
||||||
Pleroma.Web.Metadata.Providers.RestrictIndexing
|
Pleroma.Web.Metadata.Providers.RestrictIndexing
|
||||||
| activated_providers()
|
| activated_providers()
|
||||||
|
|
22
lib/pleroma/web/metadata/providers/activity_pub.ex
Normal file
22
lib/pleroma/web/metadata/providers/activity_pub.ex
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
# Pleroma: A lightweight social networking server
|
||||||
|
# Copyright © 2017-2024 Pleroma Authors <https://pleroma.social/>
|
||||||
|
# SPDX-License-Identifier: AGPL-3.0-only
|
||||||
|
|
||||||
|
defmodule Pleroma.Web.Metadata.Providers.ActivityPub do
|
||||||
|
alias Pleroma.Web.Metadata.Providers.Provider
|
||||||
|
|
||||||
|
@behaviour Provider
|
||||||
|
|
||||||
|
@impl Provider
|
||||||
|
def build_tags(%{object: %{data: %{"id" => object_id}}}) do
|
||||||
|
[{:link, [rel: "alternate", type: "application/activity+json", href: object_id], []}]
|
||||||
|
end
|
||||||
|
|
||||||
|
@impl Provider
|
||||||
|
def build_tags(%{user: user}) do
|
||||||
|
[{:link, [rel: "alternate", type: "application/activity+json", href: user.ap_id], []}]
|
||||||
|
end
|
||||||
|
|
||||||
|
@impl Provider
|
||||||
|
def build_tags(_), do: []
|
||||||
|
end
|
40
test/pleroma/web/metadata/providers/activity_pub_test.exs
Normal file
40
test/pleroma/web/metadata/providers/activity_pub_test.exs
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
# Pleroma: A lightweight social networking server
|
||||||
|
# Copyright © 2017-2024 Pleroma Authors <https://pleroma.social/>
|
||||||
|
# SPDX-License-Identifier: AGPL-3.0-only
|
||||||
|
|
||||||
|
defmodule Pleroma.Web.Metadata.Providers.ActivityPubTest do
|
||||||
|
use Pleroma.DataCase
|
||||||
|
import Pleroma.Factory
|
||||||
|
|
||||||
|
alias Pleroma.Web.CommonAPI
|
||||||
|
alias Pleroma.Web.Metadata.Providers.ActivityPub
|
||||||
|
|
||||||
|
setup do: clear_config([Pleroma.Web.Metadata, :unfurl_nsfw])
|
||||||
|
|
||||||
|
test "it renders a link for user info" do
|
||||||
|
user = insert(:user)
|
||||||
|
res = ActivityPub.build_tags(%{user: user})
|
||||||
|
|
||||||
|
assert res == [
|
||||||
|
{:link, [rel: "alternate", type: "application/activity+json", href: user.ap_id], []}
|
||||||
|
]
|
||||||
|
end
|
||||||
|
|
||||||
|
test "it renders a link for a post" do
|
||||||
|
user = insert(:user)
|
||||||
|
{:ok, %{id: activity_id, object: object}} = CommonAPI.post(user, %{status: "hi"})
|
||||||
|
|
||||||
|
result = ActivityPub.build_tags(%{object: object, user: user, activity_id: activity_id})
|
||||||
|
|
||||||
|
assert [
|
||||||
|
{:link,
|
||||||
|
[rel: "alternate", type: "application/activity+json", href: object.data["id"]], []}
|
||||||
|
] == result
|
||||||
|
end
|
||||||
|
|
||||||
|
test "it returns an empty array for anything else" do
|
||||||
|
result = ActivityPub.build_tags(%{})
|
||||||
|
|
||||||
|
assert result == []
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in a new issue