diff options
| author | lain <lain@soykaf.club> | 2019-09-30 13:58:14 +0200 | 
|---|---|---|
| committer | lain <lain@soykaf.club> | 2019-09-30 13:58:14 +0200 | 
| commit | a7f22c6e93308710f45fa6a8c2ecadff1a748d90 (patch) | |
| tree | 3686be67abf9656afb47f8e00967cd74482ef912 /lib | |
| parent | b923842e96e821afeb7bbfa0d098b9c5698281c5 (diff) | |
| parent | 3f0e276ac94589d860c7e4c95d3661fa494f4361 (diff) | |
| download | pleroma-a7f22c6e93308710f45fa6a8c2ecadff1a748d90.tar.gz pleroma-a7f22c6e93308710f45fa6a8c2ecadff1a748d90.zip | |
Merge remote-tracking branch 'origin/develop' into reactions
Diffstat (limited to 'lib')
6 files changed, 49 insertions, 18 deletions
| diff --git a/lib/pleroma/web/activity_pub/activity_pub_controller.ex b/lib/pleroma/web/activity_pub/activity_pub_controller.ex index 8112f6642..7cd13b4b8 100644 --- a/lib/pleroma/web/activity_pub/activity_pub_controller.ex +++ b/lib/pleroma/web/activity_pub/activity_pub_controller.ex @@ -334,6 +334,7 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubController do      |> represent_service_actor(conn)    end +  @doc "Returns the authenticated user's ActivityPub User object or a 404 Not Found if non-authenticated"    def whoami(%{assigns: %{user: %User{} = user}} = conn, _params) do      conn      |> put_resp_content_type("application/activity+json") @@ -509,4 +510,31 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubController do      {new_user, for_user}    end + +  # TODO: Add support for "object" field +  @doc """ +  Endpoint based on <https://www.w3.org/wiki/SocialCG/ActivityPub/MediaUpload> + +  Parameters: +  - (required) `file`: data of the media +  - (optionnal) `description`: description of the media, intended for accessibility + +  Response: +  - HTTP Code: 201 Created +  - HTTP Body: ActivityPub object to be inserted into another's `attachment` field +  """ +  def upload_media(%{assigns: %{user: user}} = conn, %{"file" => file} = data) do +    with {:ok, object} <- +           ActivityPub.upload( +             file, +             actor: User.ap_id(user), +             description: Map.get(data, "description") +           ) do +      Logger.debug(inspect(object)) + +      conn +      |> put_status(:created) +      |> json(object.data) +    end +  end  end diff --git a/lib/pleroma/web/activity_pub/views/user_view.ex b/lib/pleroma/web/activity_pub/views/user_view.ex index 993307287..c94c5a225 100644 --- a/lib/pleroma/web/activity_pub/views/user_view.ex +++ b/lib/pleroma/web/activity_pub/views/user_view.ex @@ -24,7 +24,8 @@ defmodule Pleroma.Web.ActivityPub.UserView do        "oauthAuthorizationEndpoint" => Helpers.o_auth_url(Endpoint, :authorize),        "oauthRegistrationEndpoint" => Helpers.mastodon_api_url(Endpoint, :create_app),        "oauthTokenEndpoint" => Helpers.o_auth_url(Endpoint, :token_exchange), -      "sharedInbox" => Helpers.activity_pub_url(Endpoint, :inbox) +      "sharedInbox" => Helpers.activity_pub_url(Endpoint, :inbox), +      "uploadMedia" => Helpers.activity_pub_url(Endpoint, :upload_media)      }    end diff --git a/lib/pleroma/web/mastodon_api/controllers/mastodon_api_controller.ex b/lib/pleroma/web/mastodon_api/controllers/mastodon_api_controller.ex index 650fb74cd..3bdcea0f7 100644 --- a/lib/pleroma/web/mastodon_api/controllers/mastodon_api_controller.ex +++ b/lib/pleroma/web/mastodon_api/controllers/mastodon_api_controller.ex @@ -29,7 +29,6 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIController do    alias Pleroma.Web.MastodonAPI.ListView    alias Pleroma.Web.MastodonAPI.MastodonAPI    alias Pleroma.Web.MastodonAPI.MastodonView -  alias Pleroma.Web.MastodonAPI.ReportView    alias Pleroma.Web.MastodonAPI.StatusView    alias Pleroma.Web.MediaProxy    alias Pleroma.Web.OAuth.App @@ -944,20 +943,6 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIController do      end    end -  def reports(%{assigns: %{user: user}} = conn, params) do -    case CommonAPI.report(user, params) do -      {:ok, activity} -> -        conn -        |> put_view(ReportView) -        |> try_render("report.json", %{activity: activity}) - -      {:error, err} -> -        conn -        |> put_status(:bad_request) -        |> json(%{error: err}) -    end -  end -    def account_register(          %{assigns: %{app: app}} = conn,          %{"username" => nickname, "email" => _, "password" => _, "agreement" => true} = params diff --git a/lib/pleroma/web/mastodon_api/controllers/report_controller.ex b/lib/pleroma/web/mastodon_api/controllers/report_controller.ex new file mode 100644 index 000000000..1c084b740 --- /dev/null +++ b/lib/pleroma/web/mastodon_api/controllers/report_controller.ex @@ -0,0 +1,16 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.MastodonAPI.ReportController do +  use Pleroma.Web, :controller + +  action_fallback(Pleroma.Web.MastodonAPI.FallbackController) + +  @doc "POST /api/v1/reports" +  def create(%{assigns: %{user: user}} = conn, params) do +    with {:ok, activity} <- Pleroma.Web.CommonAPI.report(user, params) do +      render(conn, "show.json", activity: activity) +    end +  end +end diff --git a/lib/pleroma/web/mastodon_api/views/report_view.ex b/lib/pleroma/web/mastodon_api/views/report_view.ex index a16e7ff10..9da2dd740 100644 --- a/lib/pleroma/web/mastodon_api/views/report_view.ex +++ b/lib/pleroma/web/mastodon_api/views/report_view.ex @@ -5,7 +5,7 @@  defmodule Pleroma.Web.MastodonAPI.ReportView do    use Pleroma.Web, :view -  def render("report.json", %{activity: activity}) do +  def render("show.json", %{activity: activity}) do      %{        id: to_string(activity.id),        action_taken: false diff --git a/lib/pleroma/web/router.ex b/lib/pleroma/web/router.ex index 0b13990cb..09cbca766 100644 --- a/lib/pleroma/web/router.ex +++ b/lib/pleroma/web/router.ex @@ -414,7 +414,7 @@ defmodule Pleroma.Web.Router do        get("/pleroma/mascot", MastodonAPIController, :get_mascot)        put("/pleroma/mascot", MastodonAPIController, :set_mascot) -      post("/reports", MastodonAPIController, :reports) +      post("/reports", ReportController, :create)      end      scope [] do @@ -615,6 +615,7 @@ defmodule Pleroma.Web.Router do      scope [] do        pipe_through(:oauth_write)        post("/users/:nickname/outbox", ActivityPubController, :update_outbox) +      post("/api/ap/upload_media", ActivityPubController, :upload_media)      end      scope [] do | 
