2019-01-16 07:15:13 -07:00
|
|
|
# Pleroma: A lightweight social networking server
|
2019-07-12 10:42:54 -06:00
|
|
|
|
2021-01-12 23:49:20 -07:00
|
|
|
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
|
2019-01-16 07:15:13 -07:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
2019-01-17 23:32:52 -07:00
|
|
|
|
2019-01-15 13:00:22 -07:00
|
|
|
defmodule Pleroma.Web.Metadata.Providers.TwitterCard do
|
2019-02-11 16:59:04 -07:00
|
|
|
alias Pleroma.User
|
2021-06-09 08:58:29 -06:00
|
|
|
alias Pleroma.Web.MediaProxy
|
2019-01-17 01:00:02 -07:00
|
|
|
alias Pleroma.Web.Metadata
|
2019-02-11 16:59:04 -07:00
|
|
|
alias Pleroma.Web.Metadata.Providers.Provider
|
|
|
|
alias Pleroma.Web.Metadata.Utils
|
2019-01-15 13:25:28 -07:00
|
|
|
|
2023-08-15 04:22:18 -06:00
|
|
|
use Pleroma.Web, :verified_routes
|
|
|
|
|
2019-01-15 13:25:28 -07:00
|
|
|
@behaviour Provider
|
2019-07-12 10:42:54 -06:00
|
|
|
@media_types ["image", "audio", "video"]
|
2019-01-15 13:25:28 -07:00
|
|
|
|
|
|
|
@impl Provider
|
2019-07-12 10:42:54 -06:00
|
|
|
def build_tags(%{activity_id: id, object: object, user: user}) do
|
2024-04-11 22:16:47 -06:00
|
|
|
attachments =
|
|
|
|
if Utils.visible?(object) do
|
|
|
|
build_attachments(id, object)
|
|
|
|
else
|
|
|
|
[]
|
|
|
|
end
|
|
|
|
|
|
|
|
scrubbed_content =
|
|
|
|
if Utils.visible?(object) do
|
|
|
|
Utils.scrub_html_and_truncate(object)
|
|
|
|
else
|
|
|
|
"Content cannot be displayed."
|
|
|
|
end
|
2019-02-11 16:59:04 -07:00
|
|
|
|
|
|
|
[
|
2019-07-12 10:42:54 -06:00
|
|
|
title_tag(user),
|
2022-12-19 12:40:08 -07:00
|
|
|
{:meta, [name: "twitter:description", content: scrubbed_content], []}
|
2019-02-11 16:59:04 -07:00
|
|
|
] ++
|
|
|
|
if attachments == [] or Metadata.activity_nsfw?(object) do
|
|
|
|
[
|
2019-07-12 10:42:54 -06:00
|
|
|
image_tag(user),
|
2022-12-19 12:40:08 -07:00
|
|
|
{:meta, [name: "twitter:card", content: "summary"], []}
|
2019-02-11 16:59:04 -07:00
|
|
|
]
|
|
|
|
else
|
|
|
|
attachments
|
2019-01-15 13:00:22 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-01-15 13:25:28 -07:00
|
|
|
@impl Provider
|
2019-02-11 16:59:04 -07:00
|
|
|
def build_tags(%{user: user}) do
|
2024-04-11 22:16:47 -06:00
|
|
|
if Utils.visible?(user) do
|
|
|
|
with truncated_bio = Utils.scrub_html_and_truncate(user.bio) do
|
|
|
|
[
|
|
|
|
title_tag(user),
|
|
|
|
{:meta, [name: "twitter:description", content: truncated_bio], []},
|
|
|
|
image_tag(user),
|
|
|
|
{:meta, [name: "twitter:card", content: "summary"], []}
|
|
|
|
]
|
|
|
|
end
|
|
|
|
else
|
|
|
|
[]
|
2019-02-11 16:59:04 -07:00
|
|
|
end
|
2019-01-15 13:00:22 -07:00
|
|
|
end
|
|
|
|
|
2019-07-12 10:42:54 -06:00
|
|
|
defp title_tag(user) do
|
2022-12-19 12:40:08 -07:00
|
|
|
{:meta, [name: "twitter:title", content: Utils.user_name_string(user)], []}
|
2019-07-12 10:42:54 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
def image_tag(user) do
|
2024-04-11 22:16:47 -06:00
|
|
|
if Utils.visible?(user) do
|
|
|
|
{:meta, [name: "twitter:image", content: MediaProxy.preview_url(User.avatar_url(user))], []}
|
|
|
|
else
|
|
|
|
{:meta, [name: "twitter:image", content: ""], []}
|
|
|
|
end
|
2019-07-12 10:42:54 -06:00
|
|
|
end
|
|
|
|
|
2019-02-24 11:53:49 -07:00
|
|
|
defp build_attachments(id, %{data: %{"attachment" => attachments}}) do
|
2019-02-11 16:59:04 -07:00
|
|
|
Enum.reduce(attachments, [], fn attachment, acc ->
|
|
|
|
rendered_tags =
|
|
|
|
Enum.reduce(attachment["url"], [], fn url, acc ->
|
2019-07-12 10:42:54 -06:00
|
|
|
case Utils.fetch_media_type(@media_types, url["mediaType"]) do
|
2019-02-11 16:59:04 -07:00
|
|
|
"audio" ->
|
|
|
|
[
|
2022-12-19 12:40:08 -07:00
|
|
|
{:meta, [name: "twitter:card", content: "player"], []},
|
|
|
|
{:meta, [name: "twitter:player:width", content: "480"], []},
|
|
|
|
{:meta, [name: "twitter:player:height", content: "80"], []},
|
|
|
|
{:meta, [name: "twitter:player", content: player_url(id)], []}
|
2019-02-11 16:59:04 -07:00
|
|
|
| acc
|
|
|
|
]
|
|
|
|
|
2021-06-09 10:09:14 -06:00
|
|
|
# Not using preview_url for this. It saves bandwidth, but the image dimensions will
|
|
|
|
# be wrong. We generate it on the fly and have no way to capture or analyze the
|
2021-06-09 10:58:51 -06:00
|
|
|
# image to get the dimensions. This can be an issue for apps/FEs rendering images
|
|
|
|
# in timelines too, but you can get clever with the aspect ratio metadata as a
|
|
|
|
# workaround.
|
2019-02-11 16:59:04 -07:00
|
|
|
"image" ->
|
|
|
|
[
|
2022-12-19 12:40:08 -07:00
|
|
|
{:meta, [name: "twitter:card", content: "summary_large_image"], []},
|
2019-02-11 16:59:04 -07:00
|
|
|
{:meta,
|
|
|
|
[
|
2022-12-19 12:40:08 -07:00
|
|
|
name: "twitter:player",
|
2021-06-09 08:58:29 -06:00
|
|
|
content: MediaProxy.url(url["href"])
|
2021-06-08 15:31:12 -06:00
|
|
|
], []}
|
2019-02-11 16:59:04 -07:00
|
|
|
| acc
|
|
|
|
]
|
2021-06-08 15:31:12 -06:00
|
|
|
|> maybe_add_dimensions(url)
|
2019-02-11 16:59:04 -07:00
|
|
|
|
|
|
|
"video" ->
|
2021-06-08 15:31:12 -06:00
|
|
|
# fallback to old placeholder values
|
|
|
|
height = url["height"] || 480
|
|
|
|
width = url["width"] || 480
|
|
|
|
|
2019-02-11 16:59:04 -07:00
|
|
|
[
|
2022-12-19 12:40:08 -07:00
|
|
|
{:meta, [name: "twitter:card", content: "player"], []},
|
|
|
|
{:meta, [name: "twitter:player", content: player_url(id)], []},
|
|
|
|
{:meta, [name: "twitter:player:width", content: "#{width}"], []},
|
|
|
|
{:meta, [name: "twitter:player:height", content: "#{height}"], []},
|
|
|
|
{:meta, [name: "twitter:player:stream", content: MediaProxy.url(url["href"])],
|
2021-06-09 10:06:53 -06:00
|
|
|
[]},
|
2022-12-19 12:40:08 -07:00
|
|
|
{:meta, [name: "twitter:player:stream:content_type", content: url["mediaType"]],
|
|
|
|
[]}
|
2019-02-11 16:59:04 -07:00
|
|
|
| acc
|
|
|
|
]
|
|
|
|
|
|
|
|
_ ->
|
|
|
|
acc
|
|
|
|
end
|
2019-01-15 13:00:22 -07:00
|
|
|
end)
|
2019-02-11 16:59:04 -07:00
|
|
|
|
|
|
|
acc ++ rendered_tags
|
2019-01-15 13:00:22 -07:00
|
|
|
end)
|
|
|
|
end
|
2019-07-08 05:05:57 -06:00
|
|
|
|
2019-07-08 03:16:32 -06:00
|
|
|
defp build_attachments(_id, _object), do: []
|
2019-02-19 09:39:42 -07:00
|
|
|
|
|
|
|
defp player_url(id) do
|
2023-08-15 04:22:18 -06:00
|
|
|
url(~p[/notice/#{id}/embed_player])
|
2019-02-19 09:39:42 -07:00
|
|
|
end
|
2021-06-08 15:31:12 -06:00
|
|
|
|
|
|
|
# Videos have problems without dimensions, but we used to not provide WxH for images.
|
|
|
|
# A default (read: incorrect) fallback for images is likely to cause rendering bugs.
|
|
|
|
defp maybe_add_dimensions(metadata, url) do
|
|
|
|
cond do
|
|
|
|
!is_nil(url["height"]) && !is_nil(url["width"]) ->
|
|
|
|
metadata ++
|
|
|
|
[
|
2022-12-19 12:40:08 -07:00
|
|
|
{:meta, [name: "twitter:player:width", content: "#{url["width"]}"], []},
|
|
|
|
{:meta, [name: "twitter:player:height", content: "#{url["height"]}"], []}
|
2021-06-08 15:31:12 -06:00
|
|
|
]
|
|
|
|
|
|
|
|
true ->
|
|
|
|
metadata
|
|
|
|
end
|
|
|
|
end
|
2019-01-15 13:00:22 -07:00
|
|
|
end
|