X-Git-Url: http://git.squeep.com/?a=blobdiff_plain;f=lib%2Fpleroma%2Fweb%2Fmetadata.ex;h=48801b5884da2761885e996221589bec7cfe5b3d;hb=a079ec3a3cdfd42d2cbd51c7698c2c87828e5778;hp=a5a706b8fabfe2b8628d99a6bbced03d57c7d0d6;hpb=70b2bb6eded5597bd768d7dc8754c2c994561aee;p=akkoma diff --git a/lib/pleroma/web/metadata.ex b/lib/pleroma/web/metadata.ex index a5a706b8f..48801b588 100644 --- a/lib/pleroma/web/metadata.ex +++ b/lib/pleroma/web/metadata.ex @@ -1,19 +1,36 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2021 Pleroma Authors +# SPDX-License-Identifier: AGPL-3.0-only + defmodule Pleroma.Web.Metadata do alias Phoenix.HTML - @parsers Pleroma.Config.get([:metadata, :providers], []) + def build_static_tags(params) do + providers = [ + Pleroma.Web.Metadata.Providers.Theme + ] - def get_cached_tags(params) do - # I am unsure how well ETS works with big keys - key = :erlang.term_to_binary(params) + Enum.reduce(providers, "", fn parser, acc -> + rendered_html = + params + |> parser.build_tags() + |> Enum.map(&to_tag/1) + |> Enum.map(&HTML.safe_to_string/1) + |> Enum.join() - Cachex.fetch!(:metadata_cache, key, fn _key -> - {:commit, build_tags(params)} + acc <> rendered_html end) end def build_tags(params) do - Enum.reduce(@parsers, "", fn parser, acc -> + providers = [ + Pleroma.Web.Metadata.Providers.RelMe, + Pleroma.Web.Metadata.Providers.RestrictIndexing, + Pleroma.Web.Metadata.Providers.Theme + | activated_providers() + ] + + Enum.reduce(providers, "", fn parser, acc -> rendered_html = params |> parser.build_tags() @@ -36,4 +53,20 @@ defmodule Pleroma.Web.Metadata do raise ArgumentError, message: "make_tag invalid args" end end + + def activity_nsfw?(%{data: %{"sensitive" => sensitive}}) do + Pleroma.Config.get([__MODULE__, :unfurl_nsfw], false) == false and sensitive + end + + def activity_nsfw?(_) do + false + end + + defp activated_providers do + unless Pleroma.Config.restrict_unauthenticated_access?(:activities, :local) do + [Pleroma.Web.Metadata.Providers.Feed | Pleroma.Config.get([__MODULE__, :providers], [])] + else + [] + end + end end