diff options
Diffstat (limited to 'lib')
10 files changed, 91 insertions, 26 deletions
| diff --git a/lib/pleroma/emoji/pack.ex b/lib/pleroma/emoji/pack.ex index 14a5185be..787ff8141 100644 --- a/lib/pleroma/emoji/pack.ex +++ b/lib/pleroma/emoji/pack.ex @@ -1,6 +1,7 @@  defmodule Pleroma.Emoji.Pack do -  @derive {Jason.Encoder, only: [:files, :pack]} +  @derive {Jason.Encoder, only: [:files, :pack, :files_count]}    defstruct files: %{}, +            files_count: 0,              pack_file: nil,              path: nil,              pack: %{}, @@ -8,6 +9,7 @@ defmodule Pleroma.Emoji.Pack do    @type t() :: %__MODULE__{            files: %{String.t() => Path.t()}, +          files_count: non_neg_integer(),            pack_file: Path.t(),            path: Path.t(),            pack: map(), @@ -16,7 +18,7 @@ defmodule Pleroma.Emoji.Pack do    alias Pleroma.Emoji -  @spec create(String.t()) :: :ok | {:error, File.posix()} | {:error, :empty_values} +  @spec create(String.t()) :: {:ok, t()} | {:error, File.posix()} | {:error, :empty_values}    def create(name) do      with :ok <- validate_not_empty([name]),           dir <- Path.join(emoji_path(), name), @@ -26,10 +28,27 @@ defmodule Pleroma.Emoji.Pack do      end    end -  @spec show(String.t()) :: {:ok, t()} | {:error, atom()} -  def show(name) do +  defp paginate(entities, 1, page_size), do: Enum.take(entities, page_size) + +  defp paginate(entities, page, page_size) do +    entities +    |> Enum.chunk_every(page_size) +    |> Enum.at(page - 1) +  end + +  @spec show(keyword()) :: {:ok, t()} | {:error, atom()} +  def show(opts) do +    name = opts[:name] +      with :ok <- validate_not_empty([name]),           {:ok, pack} <- load_pack(name) do +      shortcodes = +        pack.files +        |> Map.keys() +        |> paginate(opts[:page], opts[:page_size]) + +      pack = Map.put(pack, :files, Map.take(pack.files, shortcodes)) +        {:ok, validate_pack(pack)}      end    end @@ -120,10 +139,10 @@ defmodule Pleroma.Emoji.Pack do      end    end -  @spec list_local() :: {:ok, map()} -  def list_local do +  @spec list_local(keyword()) :: {:ok, map(), non_neg_integer()} +  def list_local(opts) do      with {:ok, results} <- list_packs_dir() do -      packs = +      all_packs =          results          |> Enum.map(fn name ->            case load_pack(name) do @@ -132,9 +151,13 @@ defmodule Pleroma.Emoji.Pack do            end          end)          |> Enum.reject(&is_nil/1) + +      packs = +        all_packs +        |> paginate(opts[:page], opts[:page_size])          |> Map.new(fn pack -> {pack.name, validate_pack(pack)} end) -      {:ok, packs} +      {:ok, packs, length(all_packs)}      end    end @@ -146,7 +169,7 @@ defmodule Pleroma.Emoji.Pack do      end    end -  @spec download(String.t(), String.t(), String.t()) :: :ok | {:error, atom()} +  @spec download(String.t(), String.t(), String.t()) :: {:ok, t()} | {:error, atom()}    def download(name, url, as) do      uri = url |> String.trim() |> URI.parse() @@ -197,7 +220,12 @@ defmodule Pleroma.Emoji.Pack do          |> Map.put(:path, Path.dirname(pack_file))          |> Map.put(:name, name) -      {:ok, pack} +      files_count = +        pack.files +        |> Map.keys() +        |> length() + +      {:ok, Map.put(pack, :files_count, files_count)}      else        {:error, :not_found}      end @@ -296,7 +324,9 @@ defmodule Pleroma.Emoji.Pack do      # Otherwise, they'd have to download it from external-src      pack.pack["share-files"] &&        Enum.all?(pack.files, fn {_, file} -> -        File.exists?(Path.join(pack.path, file)) +        pack.path +        |> Path.join(file) +        |> File.exists?()        end)    end @@ -440,7 +470,7 @@ defmodule Pleroma.Emoji.Pack do      # with the API so it should be sufficient      with {:create_dir, :ok} <- {:create_dir, File.mkdir_p(emoji_path)},           {:ls, {:ok, results}} <- {:ls, File.ls(emoji_path)} do -      {:ok, results} +      {:ok, Enum.sort(results)}      else        {:create_dir, {:error, e}} -> {:error, :create_dir, e}        {:ls, {:error, e}} -> {:error, :ls, e} diff --git a/lib/pleroma/user.ex b/lib/pleroma/user.ex index f0ccc7c79..ae4f96aac 100644 --- a/lib/pleroma/user.ex +++ b/lib/pleroma/user.ex @@ -465,6 +465,7 @@ defmodule Pleroma.User do      |> validate_format(:nickname, local_nickname_regex())      |> validate_length(:bio, max: bio_limit)      |> validate_length(:name, min: 1, max: name_limit) +    |> validate_inclusion(:actor_type, ["Person", "Service"])      |> put_fields()      |> put_emoji()      |> put_change_if_present(:bio, &{:ok, parse_bio(&1, struct)}) diff --git a/lib/pleroma/web/activity_pub/activity_pub.ex b/lib/pleroma/web/activity_pub/activity_pub.ex index 3e4f3ad30..3e4d0a2be 100644 --- a/lib/pleroma/web/activity_pub/activity_pub.ex +++ b/lib/pleroma/web/activity_pub/activity_pub.ex @@ -834,7 +834,8 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do    defp restrict_media(query, %{only_media: true}) do      from( -      [_activity, object] in query, +      [activity, object] in query, +      where: fragment("(?)->>'type' = ?", activity.data, "Create"),        where: fragment("not (?)->'attachment' = (?)", object.data, ^[])      )    end diff --git a/lib/pleroma/web/activity_pub/mrf/hellthread_policy.ex b/lib/pleroma/web/activity_pub/mrf/hellthread_policy.ex index 1764bc789..f6b2c4415 100644 --- a/lib/pleroma/web/activity_pub/mrf/hellthread_policy.ex +++ b/lib/pleroma/web/activity_pub/mrf/hellthread_policy.ex @@ -13,8 +13,10 @@ defmodule Pleroma.Web.ActivityPub.MRF.HellthreadPolicy do    defp delist_message(message, threshold) when threshold > 0 do      follower_collection = User.get_cached_by_ap_id(message["actor"]).follower_address +    to = message["to"] || [] +    cc = message["cc"] || [] -    follower_collection? = Enum.member?(message["to"] ++ message["cc"], follower_collection) +    follower_collection? = Enum.member?(to ++ cc, follower_collection)      message =        case get_recipient_count(message) do @@ -71,7 +73,8 @@ defmodule Pleroma.Web.ActivityPub.MRF.HellthreadPolicy do    end    @impl true -  def filter(%{"type" => "Create"} = message) do +  def filter(%{"type" => "Create", "object" => %{"type" => object_type}} = message) +      when object_type in ~w{Note Article} do      reject_threshold =        Pleroma.Config.get(          [:mrf_hellthread, :reject_threshold], diff --git a/lib/pleroma/web/activity_pub/object_validators/note_validator.ex b/lib/pleroma/web/activity_pub/object_validators/note_validator.ex index a10728ac6..56b93dde8 100644 --- a/lib/pleroma/web/activity_pub/object_validators/note_validator.ex +++ b/lib/pleroma/web/activity_pub/object_validators/note_validator.ex @@ -41,7 +41,6 @@ defmodule Pleroma.Web.ActivityPub.ObjectValidators.NoteValidator do      field(:announcements, {:array, :string}, default: [])      # see if needed -    field(:conversation, :string)      field(:context_id, :string)    end diff --git a/lib/pleroma/web/activity_pub/transmogrifier.ex b/lib/pleroma/web/activity_pub/transmogrifier.ex index 851f474b8..1c60ef8f5 100644 --- a/lib/pleroma/web/activity_pub/transmogrifier.ex +++ b/lib/pleroma/web/activity_pub/transmogrifier.ex @@ -172,8 +172,8 @@ defmodule Pleroma.Web.ActivityPub.Transmogrifier do          object          |> Map.put("inReplyTo", replied_object.data["id"])          |> Map.put("inReplyToAtomUri", object["inReplyToAtomUri"] || in_reply_to_id) -        |> Map.put("conversation", replied_object.data["context"] || object["conversation"])          |> Map.put("context", replied_object.data["context"] || object["conversation"]) +        |> Map.drop(["conversation"])        else          e ->            Logger.error("Couldn't fetch #{inspect(in_reply_to_id)}, error: #{inspect(e)}") @@ -207,7 +207,7 @@ defmodule Pleroma.Web.ActivityPub.Transmogrifier do      object      |> Map.put("context", context) -    |> Map.put("conversation", context) +    |> Map.drop(["conversation"])    end    def fix_attachments(%{"attachment" => attachment} = object) when is_list(attachment) do @@ -458,7 +458,7 @@ defmodule Pleroma.Web.ActivityPub.Transmogrifier do          to: data["to"],          object: object,          actor: user, -        context: object["conversation"], +        context: object["context"],          local: false,          published: data["published"],          additional: diff --git a/lib/pleroma/web/api_spec/operations/pleroma_emoji_pack_operation.ex b/lib/pleroma/web/api_spec/operations/pleroma_emoji_pack_operation.ex index 567688ff5..b2b4f8713 100644 --- a/lib/pleroma/web/api_spec/operations/pleroma_emoji_pack_operation.ex +++ b/lib/pleroma/web/api_spec/operations/pleroma_emoji_pack_operation.ex @@ -33,6 +33,20 @@ defmodule Pleroma.Web.ApiSpec.PleromaEmojiPackOperation do        tags: ["Emoji Packs"],        summary: "Lists local custom emoji packs",        operationId: "PleromaAPI.EmojiPackController.index", +      parameters: [ +        Operation.parameter( +          :page, +          :query, +          %Schema{type: :integer, default: 1}, +          "Page" +        ), +        Operation.parameter( +          :page_size, +          :query, +          %Schema{type: :integer, default: 50}, +          "Number of emoji packs to return" +        ) +      ],        responses: %{          200 => emoji_packs_response()        } @@ -44,7 +58,21 @@ defmodule Pleroma.Web.ApiSpec.PleromaEmojiPackOperation do        tags: ["Emoji Packs"],        summary: "Show emoji pack",        operationId: "PleromaAPI.EmojiPackController.show", -      parameters: [name_param()], +      parameters: [ +        name_param(), +        Operation.parameter( +          :page, +          :query, +          %Schema{type: :integer, default: 1}, +          "Page" +        ), +        Operation.parameter( +          :page_size, +          :query, +          %Schema{type: :integer, default: 30}, +          "Number of emoji to return" +        ) +      ],        responses: %{          200 => Operation.response("Emoji Pack", "application/json", emoji_pack()),          400 => Operation.response("Bad Request", "application/json", ApiError), diff --git a/lib/pleroma/web/mastodon_api/controllers/account_controller.ex b/lib/pleroma/web/mastodon_api/controllers/account_controller.ex index c38c2b895..adbbac624 100644 --- a/lib/pleroma/web/mastodon_api/controllers/account_controller.ex +++ b/lib/pleroma/web/mastodon_api/controllers/account_controller.ex @@ -177,6 +177,9 @@ defmodule Pleroma.Web.MastodonAPI.AccountController do        |> Maps.put_if_present(:pleroma_settings_store, params[:pleroma_settings_store])        |> Maps.put_if_present(:default_scope, params[:default_scope])        |> Maps.put_if_present(:default_scope, params["source"]["privacy"]) +      |> Maps.put_if_present(:actor_type, params[:bot], fn bot -> +        if bot, do: {:ok, "Service"}, else: {:ok, "Person"} +      end)        |> Maps.put_if_present(:actor_type, params[:actor_type])      changeset = User.update_changeset(user, user_params) diff --git a/lib/pleroma/web/mastodon_api/views/account_view.ex b/lib/pleroma/web/mastodon_api/views/account_view.ex index 68beb69b8..6c40b8ccd 100644 --- a/lib/pleroma/web/mastodon_api/views/account_view.ex +++ b/lib/pleroma/web/mastodon_api/views/account_view.ex @@ -179,7 +179,7 @@ defmodule Pleroma.Web.MastodonAPI.AccountView do          0        end -    bot = user.actor_type in ["Application", "Service"] +    bot = user.actor_type == "Service"      emojis =        Enum.map(user.emoji, fn {shortcode, raw_url} -> diff --git a/lib/pleroma/web/pleroma_api/controllers/emoji_pack_controller.ex b/lib/pleroma/web/pleroma_api/controllers/emoji_pack_controller.ex index d1efdeb5d..33ecd1f70 100644 --- a/lib/pleroma/web/pleroma_api/controllers/emoji_pack_controller.ex +++ b/lib/pleroma/web/pleroma_api/controllers/emoji_pack_controller.ex @@ -37,14 +37,14 @@ defmodule Pleroma.Web.PleromaAPI.EmojiPackController do      end    end -  def index(conn, _params) do +  def index(conn, params) do      emoji_path =        [:instance, :static_dir]        |> Pleroma.Config.get!()        |> Path.join("emoji") -    with {:ok, packs} <- Pack.list_local() do -      json(conn, packs) +    with {:ok, packs, count} <- Pack.list_local(page: params.page, page_size: params.page_size) do +      json(conn, %{packs: packs, count: count})      else        {:error, :create_dir, e} ->          conn @@ -60,10 +60,10 @@ defmodule Pleroma.Web.PleromaAPI.EmojiPackController do      end    end -  def show(conn, %{name: name}) do +  def show(conn, %{name: name, page: page, page_size: page_size}) do      name = String.trim(name) -    with {:ok, pack} <- Pack.show(name) do +    with {:ok, pack} <- Pack.show(name: name, page: page, page_size: page_size) do        json(conn, pack)      else        {:error, :not_found} -> | 
