diff options
| author | Egor <egor@kislitsyn.com> | 2019-04-12 19:25:53 +0000 | 
|---|---|---|
| committer | Haelwenn <contact+git.pleroma.social@hacktivis.me> | 2019-04-12 19:25:53 +0000 | 
| commit | f9af90c5aa42169b929f4ac6b352730b4d3416c7 (patch) | |
| tree | 69bcbc3e76b891cb3f702ff3a7ade7b451f09083 /lib | |
| parent | 184ae60b217f4e3a79aad538717d1cf35f10291a (diff) | |
| download | pleroma-f9af90c5aa42169b929f4ac6b352730b4d3416c7.tar.gz pleroma-f9af90c5aa42169b929f4ac6b352730b4d3416c7.zip | |
Revert "simplify mentions escape"
This reverts commit f3e06a1030636f24f7129dd93bb9780e67fb7de1.
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/pleroma/formatter.ex | 42 | ||||
| -rw-r--r-- | lib/pleroma/web/common_api/utils.ex | 5 | 
2 files changed, 35 insertions, 12 deletions
| diff --git a/lib/pleroma/formatter.ex b/lib/pleroma/formatter.ex index 8ea9dbd38..dab8910c1 100644 --- a/lib/pleroma/formatter.ex +++ b/lib/pleroma/formatter.ex @@ -9,20 +9,31 @@ defmodule Pleroma.Formatter do    alias Pleroma.Web.MediaProxy    @safe_mention_regex ~r/^(\s*(?<mentions>@.+?\s+)+)(?<rest>.*)/ +  @link_regex ~r"((?:http(s)?:\/\/)?[\w.-]+(?:\.[\w\.-]+)+[\w\-\._~%:/?#[\]@!\$&'\(\)\*\+,;=.]+)|[0-9a-z+\-\.]+:[0-9a-z$-_.+!*'(),]+"ui    @markdown_characters_regex ~r/(`|\*|_|{|}|[|]|\(|\)|#|\+|-|\.|!)/ -  @link_regex ~r{((?:http(s)?:\/\/)?[\w.-]+(?:\.[\w\.-]+)+[\w\-\._~%:/?#[\]@!\$&'\(\)\*\+,;=.]+)|[0-9a-z+\-\.]+:[0-9a-z$-_.+!*'(),]+}ui -  # credo:disable-for-previous-line Credo.Check.Readability.MaxLineLength    @auto_linker_config hashtag: true,                        hashtag_handler: &Pleroma.Formatter.hashtag_handler/4,                        mention: true,                        mention_handler: &Pleroma.Formatter.mention_handler/4 +  def escape_mention_handler("@" <> nickname = mention, buffer, _, _) do +    case User.get_cached_by_nickname(nickname) do +      %User{} -> +        # escape markdown characters with `\\` +        # (we don't want something like @user__name to be parsed by markdown) +        String.replace(mention, @markdown_characters_regex, "\\\\\\1") + +      _ -> +        buffer +    end +  end +    def mention_handler("@" <> nickname, buffer, opts, acc) do      case User.get_cached_by_nickname(nickname) do        %User{id: id} = user ->          ap_id = get_ap_id(user) -        nickname_text = get_nickname_text(nickname, opts) |> maybe_escape(opts) +        nickname_text = get_nickname_text(nickname, opts)          link =            "<span class='h-card'><a data-user='#{id}' class='u-url mention' href='#{ap_id}'>@<span>#{ @@ -70,6 +81,25 @@ defmodule Pleroma.Formatter do      end    end +  @doc """ +  Escapes a special characters in mention names. +  """ +  def mentions_escape(text, options \\ []) do +    options = +      Keyword.merge(options, +        mention: true, +        url: false, +        mention_handler: &Pleroma.Formatter.escape_mention_handler/4 +      ) + +    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) +    else +      AutoLinker.link(text, options) +    end +  end +    def emojify(text) do      emojify(text, Emoji.get_all())    end @@ -140,10 +170,4 @@ defmodule Pleroma.Formatter do    defp get_nickname_text(nickname, %{mentions_format: :full}), do: User.full_nickname(nickname)    defp get_nickname_text(nickname, _), do: User.local_nickname(nickname) - -  defp maybe_escape(str, %{mentions_escape: true}) do -    String.replace(str, @markdown_characters_regex, "\\\\\\1") -  end - -  defp maybe_escape(str, _), do: str  end diff --git a/lib/pleroma/web/common_api/utils.ex b/lib/pleroma/web/common_api/utils.ex index 7b9f0ea06..58a561a40 100644 --- a/lib/pleroma/web/common_api/utils.ex +++ b/lib/pleroma/web/common_api/utils.ex @@ -195,11 +195,10 @@ defmodule Pleroma.Web.CommonAPI.Utils do    Formatting text to markdown.    """    def format_input(text, "text/markdown", options) do -    options = Keyword.put(options, :mentions_escape, true) -      text +    |> Formatter.mentions_escape(options) +    |> Earmark.as_html!()      |> Formatter.linkify(options) -    |> (fn {text, mentions, tags} -> {Earmark.as_html!(text), mentions, tags} end).()      |> Formatter.html_escape("text/html")    end | 
