diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/pleroma/formatter.ex | 23 | ||||
| -rw-r--r-- | lib/pleroma/web/activity_pub/transmogrifier.ex | 23 | ||||
| -rw-r--r-- | lib/pleroma/web/activity_pub/utils.ex | 2 | ||||
| -rw-r--r-- | lib/pleroma/web/activity_pub/views/user_view.ex | 2 | ||||
| -rw-r--r-- | lib/pleroma/web/mastodon_api/mastodon_api_controller.ex | 5 | ||||
| -rw-r--r-- | lib/pleroma/web/mastodon_api/views/status_view.ex | 22 | ||||
| -rw-r--r-- | lib/pleroma/web/twitter_api/representers/activity_representer.ex | 14 | ||||
| -rw-r--r-- | lib/pleroma/web/twitter_api/twitter_api_controller.ex | 13 | ||||
| -rw-r--r-- | lib/pleroma/web/twitter_api/views/activity_view.ex | 46 | ||||
| -rw-r--r-- | lib/pleroma/web/twitter_api/views/user_view.ex | 3 | 
10 files changed, 122 insertions, 31 deletions
| diff --git a/lib/pleroma/formatter.ex b/lib/pleroma/formatter.ex index df7ffbc41..0aaf21538 100644 --- a/lib/pleroma/formatter.ex +++ b/lib/pleroma/formatter.ex @@ -116,7 +116,28 @@ defmodule Pleroma.Formatter do                        _ -> []                      end) -  @emoji @finmoji_with_filenames ++ @emoji_from_file +  @emoji_from_globs ( +                      static_path = Path.join(:code.priv_dir(:pleroma), "static") + +                      globs = +                        Application.get_env(:pleroma, :emoji, []) +                        |> Keyword.get(:shortcode_globs, []) + +                      paths = +                        Enum.map(globs, fn glob -> +                          Path.join(static_path, glob) +                          |> Path.wildcard() +                        end) +                        |> Enum.concat() + +                      Enum.map(paths, fn path -> +                        shortcode = Path.basename(path, Path.extname(path)) +                        external_path = Path.join("/", Path.relative_to(path, static_path)) +                        {shortcode, external_path} +                      end) +                    ) + +  @emoji @finmoji_with_filenames ++ @emoji_from_globs ++ @emoji_from_file    def emojify(text, emoji \\ @emoji)    def emojify(text, nil), do: text diff --git a/lib/pleroma/web/activity_pub/transmogrifier.ex b/lib/pleroma/web/activity_pub/transmogrifier.ex index 30cd70fb6..3dd3df553 100644 --- a/lib/pleroma/web/activity_pub/transmogrifier.ex +++ b/lib/pleroma/web/activity_pub/transmogrifier.ex @@ -18,7 +18,7 @@ defmodule Pleroma.Web.ActivityPub.Transmogrifier do    """    def fix_object(object) do      object -    |> Map.put("actor", object["attributedTo"]) +    |> fix_actor      |> fix_attachments      |> fix_context      |> fix_in_reply_to @@ -27,6 +27,19 @@ defmodule Pleroma.Web.ActivityPub.Transmogrifier do      |> fix_content_map    end +  def fix_actor(%{"attributedTo" => actor} = object) do +    # attributedTo can be a list in the case of peertube or plume +    actor = +      if is_list(actor) do +        Enum.at(actor, 0) +      else +        actor +      end + +    object +    |> Map.put("actor", actor) +  end +    def fix_in_reply_to(%{"inReplyTo" => in_reply_to_id} = object)        when not is_nil(in_reply_to_id) do      case ActivityPub.fetch_object_from_id(in_reply_to_id) do @@ -122,10 +135,14 @@ defmodule Pleroma.Web.ActivityPub.Transmogrifier do    # TODO: validate those with a Ecto scheme    # - tags    # - emoji -  def handle_incoming(%{"type" => "Create", "object" => %{"type" => "Note"} = object} = data) do +  def handle_incoming(%{"type" => "Create", "object" => %{"type" => objtype} = object} = data) +      when objtype in ["Article", "Note"] do      with nil <- Activity.get_create_activity_by_object_ap_id(object["id"]),           %User{} = user <- User.get_or_fetch_by_ap_id(data["actor"]) do -      object = fix_object(data["object"]) +      # prefer the activity's actor instead of attributedTo +      object = +        fix_object(data["object"]) +        |> Map.put("actor", data["actor"])        params = %{          to: data["to"], diff --git a/lib/pleroma/web/activity_pub/utils.ex b/lib/pleroma/web/activity_pub/utils.ex index 64329b710..8b41a3bec 100644 --- a/lib/pleroma/web/activity_pub/utils.ex +++ b/lib/pleroma/web/activity_pub/utils.ex @@ -128,7 +128,7 @@ defmodule Pleroma.Web.ActivityPub.Utils do    Inserts a full object if it is contained in an activity.    """    def insert_full_object(%{"object" => %{"type" => type} = object_data}) -      when is_map(object_data) and type in ["Note"] do +      when is_map(object_data) and type in ["Article", "Note"] do      with {:ok, _} <- Object.create(object_data) do        :ok      end diff --git a/lib/pleroma/web/activity_pub/views/user_view.ex b/lib/pleroma/web/activity_pub/views/user_view.ex index f4b2e0610..41bfe5048 100644 --- a/lib/pleroma/web/activity_pub/views/user_view.ex +++ b/lib/pleroma/web/activity_pub/views/user_view.ex @@ -12,7 +12,7 @@ defmodule Pleroma.Web.ActivityPub.UserView do    def render("user.json", %{user: user}) do      {:ok, user} = WebFinger.ensure_keys_present(user)      {:ok, _, public_key} = Salmon.keys_from_pem(user.info["keys"]) -    public_key = :public_key.pem_entry_encode(:RSAPublicKey, public_key) +    public_key = :public_key.pem_entry_encode(:SubjectPublicKeyInfo, public_key)      public_key = :public_key.pem_encode([public_key])      %{ diff --git a/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex b/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex index dab255ee2..09e6b0b59 100644 --- a/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex +++ b/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex @@ -868,9 +868,12 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIController do              reduce_motion: false,              max_toot_chars: Keyword.get(@instance, :limit)            }, +          rights: %{ +            delete_others_notice: !!user.info["is_moderator"] +          },            compose: %{              me: "#{user.id}", -            default_privacy: "public", +            default_privacy: user.info["default_scope"] || "public",              default_sensitive: false            },            media_attachments: %{ diff --git a/lib/pleroma/web/mastodon_api/views/status_view.ex b/lib/pleroma/web/mastodon_api/views/status_view.ex index 59898457b..4c20581d6 100644 --- a/lib/pleroma/web/mastodon_api/views/status_view.ex +++ b/lib/pleroma/web/mastodon_api/views/status_view.ex @@ -54,8 +54,7 @@ defmodule Pleroma.Web.MastodonAPI.StatusView do      %{        id: to_string(activity.id),        uri: object, -      # TODO: This might be wrong, check with mastodon. -      url: nil, +      url: object,        account: AccountView.render("account.json", %{user: user}),        in_reply_to_id: nil,        in_reply_to_account_id: nil, @@ -128,7 +127,7 @@ defmodule Pleroma.Web.MastodonAPI.StatusView do        in_reply_to_id: reply_to && to_string(reply_to.id),        in_reply_to_account_id: reply_to_user && to_string(reply_to_user.id),        reblog: nil, -      content: HtmlSanitizeEx.basic_html(object["content"]), +      content: render_content(object),        created_at: created_at,        reblogs_count: announcement_count,        favourites_count: like_count, @@ -207,4 +206,21 @@ defmodule Pleroma.Web.MastodonAPI.StatusView do          "direct"      end    end + +  def render_content(%{"type" => "Article"} = object) do +    summary = object["name"] + +    content = +      if !!summary and summary != "" do +        "<p><a href=\"#{object["url"]}\">#{summary}</a></p>#{object["content"]}" +      else +        object["content"] +      end + +    HtmlSanitizeEx.basic_html(content) +  end + +  def render_content(object) do +    HtmlSanitizeEx.basic_html(object["content"]) +  end  end diff --git a/lib/pleroma/web/twitter_api/representers/activity_representer.ex b/lib/pleroma/web/twitter_api/representers/activity_representer.ex index 57837205e..26bfb79af 100644 --- a/lib/pleroma/web/twitter_api/representers/activity_representer.ex +++ b/lib/pleroma/web/twitter_api/representers/activity_representer.ex @@ -4,7 +4,7 @@ defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenter do    use Pleroma.Web.TwitterAPI.Representers.BaseRepresenter    alias Pleroma.Web.TwitterAPI.Representers.ObjectRepresenter    alias Pleroma.{Activity, User} -  alias Pleroma.Web.TwitterAPI.{TwitterAPI, UserView} +  alias Pleroma.Web.TwitterAPI.{TwitterAPI, UserView, ActivityView}    alias Pleroma.Web.CommonAPI.Utils    alias Pleroma.Formatter @@ -164,14 +164,7 @@ defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenter do      tags = if possibly_sensitive, do: Enum.uniq(["nsfw" | tags]), else: tags -    summary = activity.data["object"]["summary"] - -    content = -      if !!summary and summary != "" do -        "<span>#{activity.data["object"]["summary"]}</span><br />#{content}</span>" -      else -        content -      end +    {summary, content} = ActivityView.render_content(object)      html =        HtmlSanitizeEx.basic_html(content) @@ -198,7 +191,8 @@ defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenter do        "tags" => tags,        "activity_type" => "post",        "possibly_sensitive" => possibly_sensitive, -      "visibility" => Pleroma.Web.MastodonAPI.StatusView.get_visibility(object) +      "visibility" => Pleroma.Web.MastodonAPI.StatusView.get_visibility(object), +      "summary" => object["summary"]      }    end diff --git a/lib/pleroma/web/twitter_api/twitter_api_controller.ex b/lib/pleroma/web/twitter_api/twitter_api_controller.ex index 8f5b3c786..65e67396b 100644 --- a/lib/pleroma/web/twitter_api/twitter_api_controller.ex +++ b/lib/pleroma/web/twitter_api/twitter_api_controller.ex @@ -431,6 +431,19 @@ defmodule Pleroma.Web.TwitterAPI.Controller do          user        end +    user = +      if default_scope = params["default_scope"] do +        with new_info <- Map.put(user.info, "default_scope", default_scope), +             change <- User.info_changeset(user, %{info: new_info}), +             {:ok, user} <- User.update_and_set_cache(change) do +          user +        else +          _e -> user +        end +      else +        user +      end +      with changeset <- User.update_changeset(user, params),           {:ok, user} <- User.update_and_set_cache(changeset) do        CommonAPI.update(user) diff --git a/lib/pleroma/web/twitter_api/views/activity_view.ex b/lib/pleroma/web/twitter_api/views/activity_view.ex index 62ce3b7b5..55b5287f5 100644 --- a/lib/pleroma/web/twitter_api/views/activity_view.ex +++ b/lib/pleroma/web/twitter_api/views/activity_view.ex @@ -228,15 +228,7 @@ defmodule Pleroma.Web.TwitterAPI.ActivityView do      tags = if possibly_sensitive, do: Enum.uniq(["nsfw" | tags]), else: tags -    summary = activity.data["object"]["summary"] -    content = object["content"] - -    content = -      if !!summary and summary != "" do -        "<span>#{activity.data["object"]["summary"]}</span><br />#{content}</span>" -      else -        content -      end +    {summary, content} = render_content(object)      html =        HtmlSanitizeEx.basic_html(content) @@ -263,7 +255,41 @@ defmodule Pleroma.Web.TwitterAPI.ActivityView do        "tags" => tags,        "activity_type" => "post",        "possibly_sensitive" => possibly_sensitive, -      "visibility" => Pleroma.Web.MastodonAPI.StatusView.get_visibility(object) +      "visibility" => Pleroma.Web.MastodonAPI.StatusView.get_visibility(object), +      "summary" => summary      }    end + +  def render_content(%{"type" => "Note"} = object) do +    summary = object["summary"] + +    content = +      if !!summary and summary != "" do +        "<p>#{summary}</p>#{object["content"]}" +      else +        object["content"] +      end + +    {summary, content} +  end + +  def render_content(%{"type" => "Article"} = object) do +    summary = object["name"] || object["summary"] + +    content = +      if !!summary and summary != "" do +        "<p><a href=\"#{object["url"]}\">#{summary}</a></p>#{object["content"]}" +      else +        object["content"] +      end + +    {summary, content} +  end + +  def render_content(object) do +    summary = object["summary"] || "Unhandled activity type: #{object["type"]}" +    content = "<p>#{summary}</p>#{object["content"]}" + +    {summary, content} +  end  end diff --git a/lib/pleroma/web/twitter_api/views/user_view.ex b/lib/pleroma/web/twitter_api/views/user_view.ex index 711008973..9c8460378 100644 --- a/lib/pleroma/web/twitter_api/views/user_view.ex +++ b/lib/pleroma/web/twitter_api/views/user_view.ex @@ -52,7 +52,8 @@ defmodule Pleroma.Web.TwitterAPI.UserView do        "cover_photo" => User.banner_url(user) |> MediaProxy.url(),        "background_image" => image_url(user.info["background"]) |> MediaProxy.url(),        "is_local" => user.local, -      "locked" => !!user.info["locked"] +      "locked" => !!user.info["locked"], +      "default_scope" => user.info["default_scope"] || "public"      }      if assigns[:token] do | 
