diff options
| author | Egor Kislitsyn <egor@kislitsyn.com> | 2020-04-13 21:21:04 +0400 | 
|---|---|---|
| committer | Egor Kislitsyn <egor@kislitsyn.com> | 2020-04-13 21:21:04 +0400 | 
| commit | c28aaf9d82a781508eba886bd455767a110d1b7c (patch) | |
| tree | a1137fc5c0d102de4fb6f84a536025b8f95fdccb /lib | |
| parent | 7ee35eb9a6a55ef610eb02a04a33f67e5921cff3 (diff) | |
| download | pleroma-c28aaf9d82a781508eba886bd455767a110d1b7c.tar.gz pleroma-c28aaf9d82a781508eba886bd455767a110d1b7c.zip | |
Add OpenAPI spec for CustomEmojiController
Diffstat (limited to 'lib')
4 files changed, 101 insertions, 0 deletions
| diff --git a/lib/pleroma/web/api_spec/operations/custom_emoji_operation.ex b/lib/pleroma/web/api_spec/operations/custom_emoji_operation.ex new file mode 100644 index 000000000..cf2215823 --- /dev/null +++ b/lib/pleroma/web/api_spec/operations/custom_emoji_operation.ex @@ -0,0 +1,25 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.ApiSpec.CustomEmojiOperation do +  alias OpenApiSpex.Operation +  alias Pleroma.Web.ApiSpec.Schemas.CustomEmojisResponse + +  def open_api_operation(action) do +    operation = String.to_existing_atom("#{action}_operation") +    apply(__MODULE__, operation, []) +  end + +  def index_operation do +    %Operation{ +      tags: ["custom_emojis"], +      summary: "List custom custom emojis", +      description: "Returns custom emojis that are available on the server.", +      operationId: "CustomEmojiController.index", +      responses: %{ +        200 => Operation.response("Custom Emojis", "application/json", CustomEmojisResponse) +      } +    } +  end +end diff --git a/lib/pleroma/web/api_spec/schemas/custom_emoji.ex b/lib/pleroma/web/api_spec/schemas/custom_emoji.ex new file mode 100644 index 000000000..5531b2081 --- /dev/null +++ b/lib/pleroma/web/api_spec/schemas/custom_emoji.ex @@ -0,0 +1,30 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.ApiSpec.Schemas.CustomEmoji do +  alias OpenApiSpex.Schema + +  require OpenApiSpex + +  OpenApiSpex.schema(%{ +    title: "CustomEmoji", +    description: "Response schema for an CustomEmoji", +    type: :object, +    properties: %{ +      shortcode: %Schema{type: :string}, +      url: %Schema{type: :string}, +      static_url: %Schema{type: :string}, +      visible_in_picker: %Schema{type: :boolean}, +      category: %Schema{type: :string}, +      tags: %Schema{type: :array} +    }, +    example: %{ +      "shortcode" => "aaaa", +      "url" => "https://files.mastodon.social/custom_emojis/images/000/007/118/original/aaaa.png", +      "static_url" => +        "https://files.mastodon.social/custom_emojis/images/000/007/118/static/aaaa.png", +      "visible_in_picker" => true +    } +  }) +end diff --git a/lib/pleroma/web/api_spec/schemas/custom_emojis_response.ex b/lib/pleroma/web/api_spec/schemas/custom_emojis_response.ex new file mode 100644 index 000000000..01582a63d --- /dev/null +++ b/lib/pleroma/web/api_spec/schemas/custom_emojis_response.ex @@ -0,0 +1,42 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.ApiSpec.Schemas.CustomEmojisResponse do +  alias Pleroma.Web.ApiSpec.Schemas.CustomEmoji + +  require OpenApiSpex + +  OpenApiSpex.schema(%{ +    title: "CustomEmojisResponse", +    description: "Response schema for custom emojis", +    type: :array, +    items: CustomEmoji, +    example: [ +      %{ +        "category" => "Fun", +        "shortcode" => "blank", +        "static_url" => "https://lain.com/emoji/blank.png", +        "tags" => ["Fun"], +        "url" => "https://lain.com/emoji/blank.png", +        "visible_in_picker" => true +      }, +      %{ +        "category" => "Gif,Fun", +        "shortcode" => "firefox", +        "static_url" => "https://lain.com/emoji/Firefox.gif", +        "tags" => ["Gif", "Fun"], +        "url" => "https://lain.com/emoji/Firefox.gif", +        "visible_in_picker" => true +      }, +      %{ +        "category" => "pack:mixed", +        "shortcode" => "sadcat", +        "static_url" => "https://lain.com/emoji/mixed/sadcat.png", +        "tags" => ["pack:mixed"], +        "url" => "https://lain.com/emoji/mixed/sadcat.png", +        "visible_in_picker" => true +      } +    ] +  }) +end diff --git a/lib/pleroma/web/mastodon_api/controllers/custom_emoji_controller.ex b/lib/pleroma/web/mastodon_api/controllers/custom_emoji_controller.ex index d82de1db5..3bfebef8b 100644 --- a/lib/pleroma/web/mastodon_api/controllers/custom_emoji_controller.ex +++ b/lib/pleroma/web/mastodon_api/controllers/custom_emoji_controller.ex @@ -5,6 +5,10 @@  defmodule Pleroma.Web.MastodonAPI.CustomEmojiController do    use Pleroma.Web, :controller +  plug(OpenApiSpex.Plug.CastAndValidate) + +  defdelegate open_api_operation(action), to: Pleroma.Web.ApiSpec.CustomEmojiOperation +    def index(conn, _params) do      render(conn, "index.json", custom_emojis: Pleroma.Emoji.get_all())    end | 
