diff options
| author | lain <lain@soykaf.club> | 2020-05-16 17:13:38 +0000 | 
|---|---|---|
| committer | lain <lain@soykaf.club> | 2020-05-16 17:13:38 +0000 | 
| commit | d96f8f17e82147c50b3413c3739f5023a5daa834 (patch) | |
| tree | 040005f22f4dd84b072111857cffd4752a24bcdb /lib | |
| parent | 3bc1138dd9beec03d2336fa1ad45dd23816f5285 (diff) | |
| parent | bb03dfdb03714027640087ad1bd6475a8bb1c2c3 (diff) | |
| download | pleroma-d96f8f17e82147c50b3413c3739f5023a5daa834.tar.gz pleroma-d96f8f17e82147c50b3413c3739f5023a5daa834.zip | |
Merge branch 'features/mastoapi_v2_media' into 'develop'
MastodonAPI: /api/v2/media endpoints
See merge request pleroma/pleroma!2439
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/pleroma/web/api_spec/operations/media_operation.ex | 132 | ||||
| -rw-r--r-- | lib/pleroma/web/api_spec/schemas/attachment.ex | 2 | ||||
| -rw-r--r-- | lib/pleroma/web/mastodon_api/controllers/media_controller.ex | 43 | ||||
| -rw-r--r-- | lib/pleroma/web/router.ex | 3 | 
4 files changed, 174 insertions, 6 deletions
| diff --git a/lib/pleroma/web/api_spec/operations/media_operation.ex b/lib/pleroma/web/api_spec/operations/media_operation.ex new file mode 100644 index 000000000..d9c3c42db --- /dev/null +++ b/lib/pleroma/web/api_spec/operations/media_operation.ex @@ -0,0 +1,132 @@ +# 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.MediaOperation do +  alias OpenApiSpex.Operation +  alias OpenApiSpex.Schema +  alias Pleroma.Web.ApiSpec.Helpers +  alias Pleroma.Web.ApiSpec.Schemas.ApiError +  alias Pleroma.Web.ApiSpec.Schemas.Attachment + +  def open_api_operation(action) do +    operation = String.to_existing_atom("#{action}_operation") +    apply(__MODULE__, operation, []) +  end + +  def create_operation do +    %Operation{ +      tags: ["media"], +      summary: "Upload media as attachment", +      description: "Creates an attachment to be used with a new status.", +      operationId: "MediaController.create", +      security: [%{"oAuth" => ["write:media"]}], +      requestBody: Helpers.request_body("Parameters", create_request()), +      responses: %{ +        200 => Operation.response("Media", "application/json", Attachment), +        401 => Operation.response("Media", "application/json", ApiError), +        422 => Operation.response("Media", "application/json", ApiError) +      } +    } +  end + +  defp create_request do +    %Schema{ +      title: "MediaCreateRequest", +      description: "POST body for creating an attachment", +      type: :object, +      required: [:file], +      properties: %{ +        file: %Schema{ +          type: :string, +          format: :binary, +          description: "The file to be attached, using multipart form data." +        }, +        description: %Schema{ +          type: :string, +          description: "A plain-text description of the media, for accessibility purposes." +        }, +        focus: %Schema{ +          type: :string, +          description: "Two floating points (x,y), comma-delimited, ranging from -1.0 to 1.0." +        } +      } +    } +  end + +  def update_operation do +    %Operation{ +      tags: ["media"], +      summary: "Upload media as attachment", +      description: "Creates an attachment to be used with a new status.", +      operationId: "MediaController.update", +      security: [%{"oAuth" => ["write:media"]}], +      parameters: [id_param()], +      requestBody: Helpers.request_body("Parameters", update_request()), +      responses: %{ +        200 => Operation.response("Media", "application/json", Attachment), +        400 => Operation.response("Media", "application/json", ApiError), +        401 => Operation.response("Media", "application/json", ApiError), +        422 => Operation.response("Media", "application/json", ApiError) +      } +    } +  end + +  defp update_request do +    %Schema{ +      title: "MediaUpdateRequest", +      description: "POST body for updating an attachment", +      type: :object, +      properties: %{ +        file: %Schema{ +          type: :string, +          format: :binary, +          description: "The file to be attached, using multipart form data." +        }, +        description: %Schema{ +          type: :string, +          description: "A plain-text description of the media, for accessibility purposes." +        }, +        focus: %Schema{ +          type: :string, +          description: "Two floating points (x,y), comma-delimited, ranging from -1.0 to 1.0." +        } +      } +    } +  end + +  def show_operation do +    %Operation{ +      tags: ["media"], +      summary: "Show Uploaded media attachment", +      operationId: "MediaController.show", +      parameters: [id_param()], +      security: [%{"oAuth" => ["read:media"]}], +      responses: %{ +        200 => Operation.response("Media", "application/json", Attachment), +        401 => Operation.response("Media", "application/json", ApiError), +        422 => Operation.response("Media", "application/json", ApiError) +      } +    } +  end + +  def create2_operation do +    %Operation{ +      tags: ["media"], +      summary: "Upload media as attachment", +      description: "Creates an attachment to be used with a new status.", +      operationId: "MediaController.create2", +      security: [%{"oAuth" => ["write:media"]}], +      requestBody: Helpers.request_body("Parameters", create_request()), +      responses: %{ +        202 => Operation.response("Media", "application/json", Attachment), +        422 => Operation.response("Media", "application/json", ApiError), +        500 => Operation.response("Media", "application/json", ApiError) +      } +    } +  end + +  defp id_param do +    Operation.parameter(:id, :path, :string, "The ID of the Attachment entity") +  end +end diff --git a/lib/pleroma/web/api_spec/schemas/attachment.ex b/lib/pleroma/web/api_spec/schemas/attachment.ex index c146c416e..c6edf6d36 100644 --- a/lib/pleroma/web/api_spec/schemas/attachment.ex +++ b/lib/pleroma/web/api_spec/schemas/attachment.ex @@ -13,7 +13,7 @@ defmodule Pleroma.Web.ApiSpec.Schemas.Attachment do      type: :object,      requried: [:id, :url, :preview_url],      properties: %{ -      id: %Schema{type: :string}, +      id: %Schema{type: :string, description: "The ID of the attachment in the database."},        url: %Schema{          type: :string,          format: :uri, diff --git a/lib/pleroma/web/mastodon_api/controllers/media_controller.ex b/lib/pleroma/web/mastodon_api/controllers/media_controller.ex index e36751220..a21233393 100644 --- a/lib/pleroma/web/mastodon_api/controllers/media_controller.ex +++ b/lib/pleroma/web/mastodon_api/controllers/media_controller.ex @@ -11,17 +11,20 @@ defmodule Pleroma.Web.MastodonAPI.MediaController do    alias Pleroma.Web.ActivityPub.ActivityPub    action_fallback(Pleroma.Web.MastodonAPI.FallbackController) +  plug(Pleroma.Web.ApiSpec.CastAndValidate)    plug(:put_view, Pleroma.Web.MastodonAPI.StatusView)    plug(OAuthScopesPlug, %{scopes: ["write:media"]}) +  defdelegate open_api_operation(action), to: Pleroma.Web.ApiSpec.MediaOperation +    @doc "POST /api/v1/media" -  def create(%{assigns: %{user: user}} = conn, %{"file" => file} = data) do +  def create(%{assigns: %{user: user}, body_params: %{file: file} = data} = conn, _) do      with {:ok, object} <-             ActivityPub.upload(               file,               actor: User.ap_id(user), -             description: Map.get(data, "description") +             description: Map.get(data, :description)             ) do        attachment_data = Map.put(object.data, "id", object.id) @@ -29,9 +32,28 @@ defmodule Pleroma.Web.MastodonAPI.MediaController do      end    end +  def create(_conn, _data), do: {:error, :bad_request} + +  @doc "POST /api/v2/media" +  def create2(%{assigns: %{user: user}, body_params: %{file: file} = data} = conn, _) do +    with {:ok, object} <- +           ActivityPub.upload( +             file, +             actor: User.ap_id(user), +             description: Map.get(data, :description) +           ) do +      attachment_data = Map.put(object.data, "id", object.id) + +      conn +      |> put_status(202) +      |> render("attachment.json", %{attachment: attachment_data}) +    end +  end + +  def create2(_conn, _data), do: {:error, :bad_request} +    @doc "PUT /api/v1/media/:id" -  def update(%{assigns: %{user: user}} = conn, %{"id" => id, "description" => description}) -      when is_binary(description) do +  def update(%{assigns: %{user: user}, body_params: %{description: description}} = conn, %{id: id}) do      with %Object{} = object <- Object.get_by_id(id),           true <- Object.authorize_mutation(object, user),           {:ok, %Object{data: data}} <- Object.update_data(object, %{"name" => description}) do @@ -41,5 +63,16 @@ defmodule Pleroma.Web.MastodonAPI.MediaController do      end    end -  def update(_conn, _data), do: {:error, :bad_request} +  def update(conn, data), do: show(conn, data) + +  @doc "GET /api/v1/media/:id" +  def show(conn, %{id: id}) do +    with %Object{data: data, id: object_id} <- Object.get_by_id(id) do +      attachment_data = Map.put(data, "id", object_id) + +      render(conn, "attachment.json", %{attachment: attachment_data}) +    end +  end + +  def get_media(_conn, _data), do: {:error, :bad_request}  end diff --git a/lib/pleroma/web/router.ex b/lib/pleroma/web/router.ex index 7a171f9fb..d77a61361 100644 --- a/lib/pleroma/web/router.ex +++ b/lib/pleroma/web/router.ex @@ -403,6 +403,7 @@ defmodule Pleroma.Web.Router do      post("/markers", MarkerController, :upsert)      post("/media", MediaController, :create) +    get("/media/:id", MediaController, :show)      put("/media/:id", MediaController, :update)      get("/notifications", NotificationController, :index) @@ -497,6 +498,8 @@ defmodule Pleroma.Web.Router do    scope "/api/v2", Pleroma.Web.MastodonAPI do      pipe_through(:api)      get("/search", SearchController, :search2) + +    post("/media", MediaController, :create2)    end    scope "/api", Pleroma.Web do | 
