diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/pleroma/activity.ex | 12 | ||||
| -rw-r--r-- | lib/pleroma/application.ex | 19 | ||||
| -rw-r--r-- | lib/pleroma/formatter.ex | 2 | ||||
| -rw-r--r-- | lib/pleroma/http/connection.ex | 2 | ||||
| -rw-r--r-- | lib/pleroma/user.ex | 20 | ||||
| -rw-r--r-- | lib/pleroma/user/info.ex | 9 | ||||
| -rw-r--r-- | lib/pleroma/web/activity_pub/activity_pub.ex | 8 | ||||
| -rw-r--r-- | lib/pleroma/web/mastodon_api/mastodon_api_controller.ex | 37 | ||||
| -rw-r--r-- | lib/pleroma/web/mastodon_api/views/status_view.ex | 8 | ||||
| -rw-r--r-- | lib/pleroma/web/mongooseim/mongoose_im_controller.ex | 41 | ||||
| -rw-r--r-- | lib/pleroma/web/router.ex | 15 | ||||
| -rw-r--r-- | lib/pleroma/web/twitter_api/views/activity_view.ex | 8 | 
12 files changed, 168 insertions, 13 deletions
| diff --git a/lib/pleroma/activity.ex b/lib/pleroma/activity.ex index 4e54b15ba..99589590c 100644 --- a/lib/pleroma/activity.ex +++ b/lib/pleroma/activity.ex @@ -10,6 +10,7 @@ defmodule Pleroma.Activity do    alias Pleroma.Notification    alias Pleroma.Object    alias Pleroma.Repo +  alias Pleroma.ThreadMute    alias Pleroma.User    import Ecto.Changeset @@ -37,6 +38,7 @@ defmodule Pleroma.Activity do      field(:local, :boolean, default: true)      field(:actor, :string)      field(:recipients, {:array, :string}, default: []) +    field(:thread_muted?, :boolean, virtual: true)      # This is a fake relation, do not use outside of with_preloaded_bookmark/get_bookmark      has_one(:bookmark, Bookmark)      has_many(:notifications, Notification, on_delete: :delete_all) @@ -90,6 +92,16 @@ defmodule Pleroma.Activity do    def with_preloaded_bookmark(query, _), do: query +  def with_set_thread_muted_field(query, %User{} = user) do +    from([a] in query, +      left_join: tm in ThreadMute, +      on: tm.user_id == ^user.id and tm.context == fragment("?->>'context'", a.data), +      select: %Activity{a | thread_muted?: not is_nil(tm.id)} +    ) +  end + +  def with_set_thread_muted_field(query, _), do: query +    def get_by_ap_id(ap_id) do      Repo.one(        from( diff --git a/lib/pleroma/application.ex b/lib/pleroma/application.ex index eeb415084..dab45a0b2 100644 --- a/lib/pleroma/application.ex +++ b/lib/pleroma/application.ex @@ -131,19 +131,22 @@ defmodule Pleroma.Application do    defp setup_instrumenters do      require Prometheus.Registry -    :ok = -      :telemetry.attach( -        "prometheus-ecto", -        [:pleroma, :repo, :query], -        &Pleroma.Repo.Instrumenter.handle_event/4, -        %{} -      ) +    if Application.get_env(:prometheus, Pleroma.Repo.Instrumenter) do +      :ok = +        :telemetry.attach( +          "prometheus-ecto", +          [:pleroma, :repo, :query], +          &Pleroma.Repo.Instrumenter.handle_event/4, +          %{} +        ) + +      Pleroma.Repo.Instrumenter.setup() +    end      Prometheus.Registry.register_collector(:prometheus_process_collector)      Pleroma.Web.Endpoint.MetricsExporter.setup()      Pleroma.Web.Endpoint.PipelineInstrumenter.setup()      Pleroma.Web.Endpoint.Instrumenter.setup() -    Pleroma.Repo.Instrumenter.setup()    end    def enabled_hackney_pools do diff --git a/lib/pleroma/formatter.ex b/lib/pleroma/formatter.ex index 3d7c36d21..3e3b9fe97 100644 --- a/lib/pleroma/formatter.ex +++ b/lib/pleroma/formatter.ex @@ -8,7 +8,7 @@ defmodule Pleroma.Formatter do    alias Pleroma.User    alias Pleroma.Web.MediaProxy -  @safe_mention_regex ~r/^(\s*(?<mentions>@.+?\s+)+)(?<rest>.*)/ +  @safe_mention_regex ~r/^(\s*(?<mentions>@.+?\s+)+)(?<rest>.*)/s    @link_regex ~r"((?:http(s)?:\/\/)?[\w.-]+(?:\.[\w\.-]+)+[\w\-\._~%:/?#[\]@!\$&'\(\)\*\+,;=.]+)|[0-9a-z+\-\.]+:[0-9a-z$-_.+!*'(),]+"ui    @markdown_characters_regex ~r/(`|\*|_|{|}|[|]|\(|\)|#|\+|-|\.|!)/ diff --git a/lib/pleroma/http/connection.ex b/lib/pleroma/http/connection.ex index c0173465a..558005c19 100644 --- a/lib/pleroma/http/connection.ex +++ b/lib/pleroma/http/connection.ex @@ -8,7 +8,7 @@ defmodule Pleroma.HTTP.Connection do    """    @hackney_options [ -    connect_timeout: 2_000, +    connect_timeout: 10_000,      recv_timeout: 20_000,      follow_redirect: true,      pool: :federation diff --git a/lib/pleroma/user.ex b/lib/pleroma/user.ex index 28da310ee..05fe58f7c 100644 --- a/lib/pleroma/user.ex +++ b/lib/pleroma/user.ex @@ -1402,4 +1402,24 @@ defmodule Pleroma.User do      |> put_embed(:info, info_changeset)      |> update_and_set_cache()    end + +  def get_mascot(%{info: %{mascot: %{} = mascot}}) when not is_nil(mascot) do +    mascot +  end + +  def get_mascot(%{info: %{mascot: mascot}}) when is_nil(mascot) do +    # use instance-default +    config = Pleroma.Config.get([:assets, :mascots]) +    default_mascot = Pleroma.Config.get([:assets, :default_mascot]) +    mascot = Keyword.get(config, default_mascot) + +    %{ +      "id" => "default-mascot", +      "url" => mascot[:url], +      "preview_url" => mascot[:url], +      "pleroma" => %{ +        "mime_type" => mascot[:mime_type] +      } +    } +  end  end diff --git a/lib/pleroma/user/info.ex b/lib/pleroma/user/info.ex index 5f0cefc00..6397e2737 100644 --- a/lib/pleroma/user/info.ex +++ b/lib/pleroma/user/info.ex @@ -43,6 +43,7 @@ defmodule Pleroma.User.Info do      field(:hide_favorites, :boolean, default: true)      field(:pinned_activities, {:array, :string}, default: [])      field(:flavour, :string, default: nil) +    field(:mascot, :map, default: nil)      field(:emoji, {:array, :map}, default: [])      field(:notification_settings, :map, @@ -248,6 +249,14 @@ defmodule Pleroma.User.Info do      |> validate_required([:flavour])    end +  def mascot_update(info, url) do +    params = %{mascot: url} + +    info +    |> cast(params, [:mascot]) +    |> validate_required([:mascot]) +  end +    def set_source_data(info, source_data) do      params = %{source_data: source_data} diff --git a/lib/pleroma/web/activity_pub/activity_pub.ex b/lib/pleroma/web/activity_pub/activity_pub.ex index 5c3156978..3d9679ec0 100644 --- a/lib/pleroma/web/activity_pub/activity_pub.ex +++ b/lib/pleroma/web/activity_pub/activity_pub.ex @@ -834,6 +834,13 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do      |> Activity.with_preloaded_bookmark(opts["user"])    end +  defp maybe_set_thread_muted_field(query, %{"skip_preload" => true}), do: query + +  defp maybe_set_thread_muted_field(query, opts) do +    query +    |> Activity.with_set_thread_muted_field(opts["user"]) +  end +    defp maybe_order(query, %{order: :desc}) do      query      |> order_by(desc: :id) @@ -852,6 +859,7 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do      base_query      |> maybe_preload_objects(opts)      |> maybe_preload_bookmarks(opts) +    |> maybe_set_thread_muted_field(opts)      |> maybe_order(opts)      |> restrict_recipients(recipients, opts["user"])      |> restrict_tag(opts) diff --git a/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex b/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex index 1051861ff..1ec0f30a1 100644 --- a/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex +++ b/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex @@ -707,6 +707,41 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIController do      end    end +  def set_mascot(%{assigns: %{user: user}} = conn, %{"file" => file}) do +    with {:ok, object} <- ActivityPub.upload(file, actor: User.ap_id(user)), +         %{} = attachment_data <- Map.put(object.data, "id", object.id), +         %{type: type} = rendered <- +           StatusView.render("attachment.json", %{attachment: attachment_data}) do +      # Reject if not an image +      if type == "image" do +        # Sure! +        # Save to the user's info +        info_changeset = User.Info.mascot_update(user.info, rendered) + +        user_changeset = +          user +          |> Ecto.Changeset.change() +          |> Ecto.Changeset.put_embed(:info, info_changeset) + +        {:ok, _user} = User.update_and_set_cache(user_changeset) + +        conn +        |> json(rendered) +      else +        conn +        |> put_resp_content_type("application/json") +        |> send_resp(415, Jason.encode!(%{"error" => "mascots can only be images"})) +      end +    end +  end + +  def get_mascot(%{assigns: %{user: user}} = conn, _params) do +    mascot = User.get_mascot(user) + +    conn +    |> json(mascot) +  end +    def favourited_by(%{assigns: %{user: user}} = conn, %{"id" => id}) do      with %Activity{data: %{"object" => object}} <- Repo.get(Activity, id),           %Object{data: %{"likes" => likes}} <- Object.normalize(object) do @@ -1329,7 +1364,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIController do              display_sensitive_media: false,              reduce_motion: false,              max_toot_chars: limit, -            mascot: "/images/pleroma-fox-tan-smol.png" +            mascot: User.get_mascot(user)["url"]            },            rights: %{              delete_others_notice: present?(user.info.is_moderator), diff --git a/lib/pleroma/web/mastodon_api/views/status_view.ex b/lib/pleroma/web/mastodon_api/views/status_view.ex index c93d915e5..e55f9b96e 100644 --- a/lib/pleroma/web/mastodon_api/views/status_view.ex +++ b/lib/pleroma/web/mastodon_api/views/status_view.ex @@ -157,6 +157,12 @@ defmodule Pleroma.Web.MastodonAPI.StatusView do      bookmarked = Activity.get_bookmark(activity, opts[:for]) != nil +    thread_muted? = +      case activity.thread_muted? do +        thread_muted? when is_boolean(thread_muted?) -> thread_muted? +        nil -> CommonAPI.thread_muted?(user, activity) +      end +      attachment_data = object.data["attachment"] || []      attachments = render_many(attachment_data, StatusView, "attachment.json", as: :attachment) @@ -228,7 +234,7 @@ defmodule Pleroma.Web.MastodonAPI.StatusView do        reblogged: reblogged?(activity, opts[:for]),        favourited: present?(favorited),        bookmarked: present?(bookmarked), -      muted: CommonAPI.thread_muted?(user, activity) || User.mutes?(opts[:for], user), +      muted: thread_muted? || User.mutes?(opts[:for], user),        pinned: pinned?(activity, user),        sensitive: sensitive,        spoiler_text: summary_html, diff --git a/lib/pleroma/web/mongooseim/mongoose_im_controller.ex b/lib/pleroma/web/mongooseim/mongoose_im_controller.ex new file mode 100644 index 000000000..489d5d3a5 --- /dev/null +++ b/lib/pleroma/web/mongooseim/mongoose_im_controller.ex @@ -0,0 +1,41 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.MongooseIM.MongooseIMController do +  use Pleroma.Web, :controller +  alias Comeonin.Pbkdf2 +  alias Pleroma.Repo +  alias Pleroma.User + +  def user_exists(conn, %{"user" => username}) do +    with %User{} <- Repo.get_by(User, nickname: username, local: true) do +      conn +      |> json(true) +    else +      _ -> +        conn +        |> put_status(:not_found) +        |> json(false) +    end +  end + +  def check_password(conn, %{"user" => username, "pass" => password}) do +    with %User{password_hash: password_hash} <- +           Repo.get_by(User, nickname: username, local: true), +         true <- Pbkdf2.checkpw(password, password_hash) do +      conn +      |> json(true) +    else +      false -> +        conn +        |> put_status(403) +        |> json(false) + +      _ -> +        conn +        |> put_status(:not_found) +        |> json(false) +    end +  end +end diff --git a/lib/pleroma/web/router.ex b/lib/pleroma/web/router.ex index 6a4e4a1d4..352268b96 100644 --- a/lib/pleroma/web/router.ex +++ b/lib/pleroma/web/router.ex @@ -352,6 +352,9 @@ defmodule Pleroma.Web.Router do        post("/pleroma/flavour/:flavour", MastodonAPIController, :set_flavour) +      get("/pleroma/mascot", MastodonAPIController, :get_mascot) +      put("/pleroma/mascot", MastodonAPIController, :set_mascot) +        post("/reports", MastodonAPIController, :reports)      end @@ -704,9 +707,15 @@ defmodule Pleroma.Web.Router do      end    end +  scope "/", Pleroma.Web.MongooseIM do +    get("/user_exists", MongooseIMController, :user_exists) +    get("/check_password", MongooseIMController, :check_password) +  end +    scope "/", Fallback do      get("/registration/:token", RedirectController, :registration_page)      get("/:maybe_nickname_or_id", RedirectController, :redirector_with_meta) +    get("/api*path", RedirectController, :api_not_implemented)      get("/*path", RedirectController, :redirector)      options("/*path", RedirectController, :empty) @@ -718,6 +727,12 @@ defmodule Fallback.RedirectController do    alias Pleroma.User    alias Pleroma.Web.Metadata +  def api_not_implemented(conn, _params) do +    conn +    |> put_status(404) +    |> json(%{error: "Not implemented"}) +  end +    def redirector(conn, _params, code \\ 200) do      conn      |> put_resp_content_type("text/html") diff --git a/lib/pleroma/web/twitter_api/views/activity_view.ex b/lib/pleroma/web/twitter_api/views/activity_view.ex index 44bcafe0e..e84af84dc 100644 --- a/lib/pleroma/web/twitter_api/views/activity_view.ex +++ b/lib/pleroma/web/twitter_api/views/activity_view.ex @@ -284,6 +284,12 @@ defmodule Pleroma.Web.TwitterAPI.ActivityView do          Pleroma.Web.RichMedia.Helpers.fetch_data_for_activity(activity)        ) +    thread_muted? = +      case activity.thread_muted? do +        thread_muted? when is_boolean(thread_muted?) -> thread_muted? +        nil -> CommonAPI.thread_muted?(user, activity) +      end +      %{        "id" => activity.id,        "uri" => object.data["id"], @@ -314,7 +320,7 @@ defmodule Pleroma.Web.TwitterAPI.ActivityView do        "summary" => summary,        "summary_html" => summary |> Formatter.emojify(object.data["emoji"]),        "card" => card, -      "muted" => CommonAPI.thread_muted?(user, activity) || User.mutes?(opts[:for], user) +      "muted" => thread_muted? || User.mutes?(opts[:for], user)      }    end | 
