浏览代码

Twittercard metadata for images should also include dimensions if available

warnings-as-errors
Mark Felder 2 年前
父节点
当前提交
d4ac9445cd
共有 2 个文件被更改,包括 16 次插入8 次删除
  1. +6
    -7
      lib/pleroma/web/metadata/providers/twitter_card.ex
  2. +10
    -1
      test/pleroma/web/metadata/providers/twitter_card_test.exs

+ 6
- 7
lib/pleroma/web/metadata/providers/twitter_card.ex 查看文件

@@ -55,7 +55,9 @@ defmodule Pleroma.Web.Metadata.Providers.TwitterCard do
Enum.reduce(attachments, [], fn attachment, acc ->
rendered_tags =
Enum.reduce(attachment["url"], [], fn url, acc ->
# TODO: Add additional properties to objects when we have the data available.
height = url["height"] || 480
width = url["width"] || 480

case Utils.fetch_media_type(@media_types, url["mediaType"]) do
"audio" ->
[
@@ -73,16 +75,13 @@ defmodule Pleroma.Web.Metadata.Providers.TwitterCard do
[
property: "twitter:player",
content: Utils.attachment_url(url["href"])
], []}
], []},
{:meta, [property: "twitter:player:width", content: "#{width}"], []},
{:meta, [property: "twitter:player:height", content: "#{height}"], []}
| acc
]

# TODO: Need the true width and height values here or Twitter renders an iFrame with
# a bad aspect ratio
"video" ->
height = url["height"] || 480
width = url["width"] || 480

[
{:meta, [property: "twitter:card", content: "player"], []},
{:meta, [property: "twitter:player", content: player_url(id)], []},


+ 10
- 1
test/pleroma/web/metadata/providers/twitter_card_test.exs 查看文件

@@ -111,7 +111,14 @@ defmodule Pleroma.Web.Metadata.Providers.TwitterCardTest do
"content" => "pleroma in a nutshell",
"attachment" => [
%{
"url" => [%{"mediaType" => "image/png", "href" => "https://pleroma.gov/tenshi.png"}]
"url" => [
%{
"mediaType" => "image/png",
"href" => "https://pleroma.gov/tenshi.png",
"height" => 1024,
"width" => 1280
}
]
},
%{
"url" => [
@@ -142,6 +149,8 @@ defmodule Pleroma.Web.Metadata.Providers.TwitterCardTest do
{:meta, [property: "twitter:description", content: "pleroma in a nutshell"], []},
{:meta, [property: "twitter:card", content: "summary_large_image"], []},
{:meta, [property: "twitter:player", content: "https://pleroma.gov/tenshi.png"], []},
{:meta, [property: "twitter:player:width", content: "1280"], []},
{:meta, [property: "twitter:player:height", content: "1024"], []},
{:meta, [property: "twitter:card", content: "player"], []},
{:meta,
[


正在加载...
取消
保存