2019-01-27 23:04:54 -07:00
|
|
|
# Pleroma: A lightweight social networking server
|
2020-03-03 15:44:49 -07:00
|
|
|
# Copyright _ 2017-2020 Pleroma Authors <https://pleroma.social/>
|
2019-01-27 23:04:54 -07:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
defmodule Pleroma.Web.RichMedia.Helpers do
|
2019-02-09 08:16:26 -07:00
|
|
|
alias Pleroma.Activity
|
2019-06-25 13:25:37 -06:00
|
|
|
alias Pleroma.Config
|
2019-02-09 08:16:26 -07:00
|
|
|
alias Pleroma.HTML
|
2019-03-04 19:52:23 -07:00
|
|
|
alias Pleroma.Object
|
2019-01-27 23:04:54 -07:00
|
|
|
alias Pleroma.Web.RichMedia.Parser
|
|
|
|
|
2019-06-25 13:25:37 -06:00
|
|
|
@spec validate_page_url(any()) :: :ok | :error
|
2019-03-04 11:38:23 -07:00
|
|
|
defp validate_page_url(page_url) when is_binary(page_url) do
|
2019-06-25 21:24:12 -06:00
|
|
|
validate_tld = Application.get_env(:auto_linker, :opts)[:validate_tld]
|
|
|
|
|
2019-06-25 13:25:37 -06:00
|
|
|
page_url
|
2019-06-25 21:24:12 -06:00
|
|
|
|> AutoLinker.Parser.url?(scheme: true, validate_tld: validate_tld)
|
2019-06-25 13:25:37 -06:00
|
|
|
|> parse_uri(page_url)
|
|
|
|
end
|
2019-06-18 07:08:18 -06:00
|
|
|
|
2019-06-25 13:25:37 -06:00
|
|
|
defp validate_page_url(%URI{host: host, scheme: scheme, authority: authority})
|
|
|
|
when scheme == "https" and not is_nil(authority) do
|
2019-06-25 06:52:53 -06:00
|
|
|
cond do
|
2019-06-25 13:25:37 -06:00
|
|
|
host in Config.get([:rich_media, :ignore_hosts], []) ->
|
2019-06-25 06:52:53 -06:00
|
|
|
:error
|
|
|
|
|
2019-06-25 13:25:37 -06:00
|
|
|
get_tld(host) in Config.get([:rich_media, :ignore_tld], []) ->
|
|
|
|
:error
|
2019-06-25 06:52:53 -06:00
|
|
|
|
|
|
|
true ->
|
2019-06-25 13:25:37 -06:00
|
|
|
:ok
|
2019-03-04 11:38:23 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
defp validate_page_url(_), do: :error
|
2019-02-24 12:13:46 -07:00
|
|
|
|
2019-06-25 13:25:37 -06:00
|
|
|
defp parse_uri(true, url) do
|
|
|
|
url
|
|
|
|
|> URI.parse()
|
|
|
|
|> validate_page_url
|
|
|
|
end
|
|
|
|
|
|
|
|
defp parse_uri(_, _), do: :error
|
|
|
|
|
|
|
|
defp get_tld(host) do
|
|
|
|
host
|
|
|
|
|> String.split(".")
|
|
|
|
|> Enum.reverse()
|
|
|
|
|> hd
|
|
|
|
end
|
|
|
|
|
2019-03-22 20:26:49 -06:00
|
|
|
def fetch_data_for_activity(%Activity{data: %{"type" => "Create"}} = activity) do
|
2019-06-25 13:25:37 -06:00
|
|
|
with true <- Config.get([:rich_media, :enabled]),
|
2019-03-22 18:22:57 -06:00
|
|
|
%Object{} = object <- Object.normalize(activity),
|
2019-05-17 12:49:43 -06:00
|
|
|
false <- object.data["sensitive"] || false,
|
2019-01-28 13:55:33 -07:00
|
|
|
{:ok, page_url} <- HTML.extract_first_external_url(object, object.data["content"]),
|
2019-02-24 12:13:46 -07:00
|
|
|
:ok <- validate_page_url(page_url),
|
2019-01-27 23:04:54 -07:00
|
|
|
{:ok, rich_media} <- Parser.parse(page_url) do
|
|
|
|
%{page_url: page_url, rich_media: rich_media}
|
|
|
|
else
|
|
|
|
_ -> %{}
|
|
|
|
end
|
|
|
|
end
|
2019-03-22 20:26:49 -06:00
|
|
|
|
|
|
|
def fetch_data_for_activity(_), do: %{}
|
2019-05-12 20:02:00 -06:00
|
|
|
|
|
|
|
def perform(:fetch, %Activity{} = activity), do: fetch_data_for_activity(activity)
|
2019-01-27 23:04:54 -07:00
|
|
|
end
|