diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/pleroma/application_requirements.ex | 19 | ||||
| -rw-r--r-- | lib/pleroma/config/config_db.ex | 1 | ||||
| -rw-r--r-- | lib/pleroma/formatter.ex | 26 | ||||
| -rw-r--r-- | lib/pleroma/object/fetcher.ex | 4 | ||||
| -rw-r--r-- | lib/pleroma/user.ex | 22 | ||||
| -rw-r--r-- | lib/pleroma/web/activity_pub/activity_pub.ex | 4 | ||||
| -rw-r--r-- | lib/pleroma/web/activity_pub/transmogrifier.ex | 2 | ||||
| -rw-r--r-- | lib/pleroma/web/admin_api/controllers/admin_api_controller.ex | 23 | ||||
| -rw-r--r-- | lib/pleroma/web/rich_media/helpers.ex | 4 | 
9 files changed, 67 insertions, 38 deletions
| diff --git a/lib/pleroma/application_requirements.ex b/lib/pleroma/application_requirements.ex index 88575a498..ee88c3346 100644 --- a/lib/pleroma/application_requirements.ex +++ b/lib/pleroma/application_requirements.ex @@ -16,6 +16,7 @@ defmodule Pleroma.ApplicationRequirements do    @spec verify!() :: :ok | VerifyError.t()    def verify! do      :ok +    |> check_confirmation_accounts!      |> check_migrations_applied!()      |> check_rum!()      |> handle_result() @@ -24,6 +25,24 @@ defmodule Pleroma.ApplicationRequirements do    defp handle_result(:ok), do: :ok    defp handle_result({:error, message}), do: raise(VerifyError, message: message) +  # Checks account confirmation email +  # +  def check_confirmation_accounts!(:ok) do +    if Pleroma.Config.get([:instance, :account_activation_required]) && +         not Pleroma.Config.get([Pleroma.Emails.Mailer, :enabled]) do +      Logger.error( +        "Account activation enabled, but no Mailer settings enabled.\nPlease set config :pleroma, :instance, account_activation_required: false\nOtherwise setup and enable Mailer." +      ) + +      {:error, +       "Account activation enabled, but Mailer is disabled. Cannot send confirmation emails."} +    else +      :ok +    end +  end + +  def check_confirmation_accounts!(result), do: result +    # Checks for pending migrations.    #    def check_migrations_applied!(:ok) do diff --git a/lib/pleroma/config/config_db.ex b/lib/pleroma/config/config_db.ex index 1a89d8895..e5b7811aa 100644 --- a/lib/pleroma/config/config_db.ex +++ b/lib/pleroma/config/config_db.ex @@ -156,7 +156,6 @@ defmodule Pleroma.ConfigDB do        {:quack, :meta},        {:mime, :types},        {:cors_plug, [:max_age, :methods, :expose, :headers]}, -      {:auto_linker, :opts},        {:swarm, :node_blacklist},        {:logger, :backends}      ] diff --git a/lib/pleroma/formatter.ex b/lib/pleroma/formatter.ex index 02a93a8dc..0c450eae4 100644 --- a/lib/pleroma/formatter.ex +++ b/lib/pleroma/formatter.ex @@ -10,11 +10,15 @@ defmodule Pleroma.Formatter do    @link_regex ~r"((?:http(s)?:\/\/)?[\w.-]+(?:\.[\w\.-]+)+[\w\-\._~%:/?#[\]@!\$&'\(\)\*\+,;=.]+)|[0-9a-z+\-\.]+:[0-9a-z$-_.+!*'(),]+"ui    @markdown_characters_regex ~r/(`|\*|_|{|}|[|]|\(|\)|#|\+|-|\.|!)/ -  @auto_linker_config hashtag: true, -                      hashtag_handler: &Pleroma.Formatter.hashtag_handler/4, -                      mention: true, -                      mention_handler: &Pleroma.Formatter.mention_handler/4, -                      scheme: true +  defp linkify_opts do +    Pleroma.Config.get(Pleroma.Formatter) ++ +      [ +        hashtag: true, +        hashtag_handler: &Pleroma.Formatter.hashtag_handler/4, +        mention: true, +        mention_handler: &Pleroma.Formatter.mention_handler/4 +      ] +  end    def escape_mention_handler("@" <> nickname = mention, buffer, _, _) do      case User.get_cached_by_nickname(nickname) do @@ -80,19 +84,19 @@ defmodule Pleroma.Formatter do    @spec linkify(String.t(), keyword()) ::            {String.t(), [{String.t(), User.t()}], [{String.t(), String.t()}]}    def linkify(text, options \\ []) do -    options = options ++ @auto_linker_config +    options = linkify_opts() ++ options      if options[:safe_mention] && Regex.named_captures(@safe_mention_regex, text) do        %{"mentions" => mentions, "rest" => rest} = Regex.named_captures(@safe_mention_regex, text)        acc = %{mentions: MapSet.new(), tags: MapSet.new()} -      {text_mentions, %{mentions: mentions}} = AutoLinker.link_map(mentions, acc, options) -      {text_rest, %{tags: tags}} = AutoLinker.link_map(rest, acc, options) +      {text_mentions, %{mentions: mentions}} = Linkify.link_map(mentions, acc, options) +      {text_rest, %{tags: tags}} = Linkify.link_map(rest, acc, options)        {text_mentions <> text_rest, MapSet.to_list(mentions), MapSet.to_list(tags)}      else        acc = %{mentions: MapSet.new(), tags: MapSet.new()} -      {text, %{mentions: mentions, tags: tags}} = AutoLinker.link_map(text, acc, options) +      {text, %{mentions: mentions, tags: tags}} = Linkify.link_map(text, acc, options)        {text, MapSet.to_list(mentions), MapSet.to_list(tags)}      end @@ -111,9 +115,9 @@ defmodule Pleroma.Formatter do      if options[:safe_mention] && Regex.named_captures(@safe_mention_regex, text) do        %{"mentions" => mentions, "rest" => rest} = Regex.named_captures(@safe_mention_regex, text) -      AutoLinker.link(mentions, options) <> AutoLinker.link(rest, options) +      Linkify.link(mentions, options) <> Linkify.link(rest, options)      else -      AutoLinker.link(text, options) +      Linkify.link(text, options)      end    end diff --git a/lib/pleroma/object/fetcher.ex b/lib/pleroma/object/fetcher.ex index 3e2949ee2..e74c87269 100644 --- a/lib/pleroma/object/fetcher.ex +++ b/lib/pleroma/object/fetcher.ex @@ -124,6 +124,10 @@ defmodule Pleroma.Object.Fetcher do        {:error, "Object has been deleted"} ->          nil +      {:reject, reason} -> +        Logger.info("Rejected #{id} while fetching: #{inspect(reason)}") +        nil +        e ->          Logger.error("Error while fetching #{id}: #{inspect(e)}")          nil diff --git a/lib/pleroma/user.ex b/lib/pleroma/user.ex index 9240e912d..714ec9a4b 100644 --- a/lib/pleroma/user.ex +++ b/lib/pleroma/user.ex @@ -719,21 +719,25 @@ defmodule Pleroma.User do      end    end -  def try_send_confirmation_email(%User{} = user) do -    if user.confirmation_pending && -         Config.get([:instance, :account_activation_required]) do -      user -      |> Pleroma.Emails.UserEmail.account_confirmation_email() -      |> Pleroma.Emails.Mailer.deliver_async() - +  @spec try_send_confirmation_email(User.t()) :: {:ok, :enqueued | :noop} +  def try_send_confirmation_email(%User{confirmation_pending: true} = user) do +    if Config.get([:instance, :account_activation_required]) do +      send_confirmation_email(user)        {:ok, :enqueued}      else        {:ok, :noop}      end    end -  def try_send_confirmation_email(users) do -    Enum.each(users, &try_send_confirmation_email/1) +  def try_send_confirmation_email(_), do: {:ok, :noop} + +  @spec send_confirmation_email(Uset.t()) :: User.t() +  def send_confirmation_email(%User{} = user) do +    user +    |> Pleroma.Emails.UserEmail.account_confirmation_email() +    |> Pleroma.Emails.Mailer.deliver_async() + +    user    end    def needs_update?(%User{local: true}), do: false diff --git a/lib/pleroma/web/activity_pub/activity_pub.ex b/lib/pleroma/web/activity_pub/activity_pub.ex index bc7b5d95a..a4db1d87c 100644 --- a/lib/pleroma/web/activity_pub/activity_pub.ex +++ b/lib/pleroma/web/activity_pub/activity_pub.ex @@ -1370,6 +1370,10 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do          Logger.debug("Could not decode user at fetch #{ap_id}, #{inspect(e)}")          {:error, e} +      {:error, {:reject, reason} = e} -> +        Logger.info("Rejected user #{ap_id}: #{inspect(reason)}") +        {:error, e} +        {:error, e} ->          Logger.error("Could not decode user at fetch #{ap_id}, #{inspect(e)}")          {:error, e} diff --git a/lib/pleroma/web/activity_pub/transmogrifier.ex b/lib/pleroma/web/activity_pub/transmogrifier.ex index f37bcab3e..35aa05eb5 100644 --- a/lib/pleroma/web/activity_pub/transmogrifier.ex +++ b/lib/pleroma/web/activity_pub/transmogrifier.ex @@ -178,7 +178,7 @@ defmodule Pleroma.Web.ActivityPub.Transmogrifier do          |> Map.drop(["conversation"])        else          e -> -          Logger.error("Couldn't fetch #{inspect(in_reply_to_id)}, error: #{inspect(e)}") +          Logger.warn("Couldn't fetch #{inspect(in_reply_to_id)}, error: #{inspect(e)}")            object        end      else diff --git a/lib/pleroma/web/admin_api/controllers/admin_api_controller.ex b/lib/pleroma/web/admin_api/controllers/admin_api_controller.ex index 225ceb1fd..5101e28d6 100644 --- a/lib/pleroma/web/admin_api/controllers/admin_api_controller.ex +++ b/lib/pleroma/web/admin_api/controllers/admin_api_controller.ex @@ -620,29 +620,24 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIController do    end    def confirm_email(%{assigns: %{user: admin}} = conn, %{"nicknames" => nicknames}) do -    users = nicknames |> Enum.map(&User.get_cached_by_nickname/1) +    users = Enum.map(nicknames, &User.get_cached_by_nickname/1)      User.toggle_confirmation(users) -    ModerationLog.insert_log(%{ -      actor: admin, -      subject: users, -      action: "confirm_email" -    }) +    ModerationLog.insert_log(%{actor: admin, subject: users, action: "confirm_email"})      json(conn, "")    end    def resend_confirmation_email(%{assigns: %{user: admin}} = conn, %{"nicknames" => nicknames}) do -    users = nicknames |> Enum.map(&User.get_cached_by_nickname/1) - -    User.try_send_confirmation_email(users) +    users = +      Enum.map(nicknames, fn nickname -> +        nickname +        |> User.get_cached_by_nickname() +        |> User.send_confirmation_email() +      end) -    ModerationLog.insert_log(%{ -      actor: admin, -      subject: users, -      action: "resend_confirmation_email" -    }) +    ModerationLog.insert_log(%{actor: admin, subject: users, action: "resend_confirmation_email"})      json(conn, "")    end diff --git a/lib/pleroma/web/rich_media/helpers.ex b/lib/pleroma/web/rich_media/helpers.ex index 1729141e9..747f2dc6b 100644 --- a/lib/pleroma/web/rich_media/helpers.ex +++ b/lib/pleroma/web/rich_media/helpers.ex @@ -11,10 +11,10 @@ defmodule Pleroma.Web.RichMedia.Helpers do    @spec validate_page_url(URI.t() | binary()) :: :ok | :error    defp validate_page_url(page_url) when is_binary(page_url) do -    validate_tld = Application.get_env(:auto_linker, :opts)[:validate_tld] +    validate_tld = Pleroma.Config.get([Pleroma.Formatter, :validate_tld])      page_url -    |> AutoLinker.Parser.url?(scheme: true, validate_tld: validate_tld) +    |> Linkify.Parser.url?(validate_tld: validate_tld)      |> parse_uri(page_url)    end | 
