diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/mix/pleroma.ex | 1 | ||||
| -rw-r--r-- | lib/pleroma/application.ex | 2 | ||||
| -rw-r--r-- | lib/pleroma/user.ex | 6 | ||||
| -rw-r--r-- | lib/pleroma/web/activity_pub/activity_pub.ex | 13 | ||||
| -rw-r--r-- | lib/pleroma/web/activity_pub/utils.ex | 96 | ||||
| -rw-r--r-- | lib/pleroma/web/admin_api/admin_api_controller.ex | 8 | ||||
| -rw-r--r-- | lib/pleroma/web/admin_api/views/report_view.ex | 28 | ||||
| -rw-r--r-- | lib/pleroma/web/mastodon_api/views/account_view.ex | 4 | ||||
| -rw-r--r-- | lib/pleroma/web/metadata.ex | 7 | ||||
| -rw-r--r-- | lib/pleroma/web/metadata/opengraph.ex | 2 | ||||
| -rw-r--r-- | lib/pleroma/web/metadata/restrict_indexing.ex | 25 | ||||
| -rw-r--r-- | lib/pleroma/web/router.ex | 1 | ||||
| -rw-r--r-- | lib/pleroma/web/templates/static_fe/static_fe/_user_card.html.eex | 2 | ||||
| -rw-r--r-- | lib/pleroma/web/templates/static_fe/static_fe/profile.html.eex | 2 | 
14 files changed, 53 insertions, 144 deletions
| diff --git a/lib/mix/pleroma.ex b/lib/mix/pleroma.ex index 3ad6edbfb..4dfcc32e7 100644 --- a/lib/mix/pleroma.ex +++ b/lib/mix/pleroma.ex @@ -5,6 +5,7 @@  defmodule Mix.Pleroma do    @doc "Common functions to be reused in mix tasks"    def start_pleroma do +    Mix.Task.run("app.start")      Application.put_env(:phoenix, :serve_endpoints, false, persistent: true)      if Pleroma.Config.get(:env) != :test do diff --git a/lib/pleroma/application.ex b/lib/pleroma/application.ex index 719114671..a00938c04 100644 --- a/lib/pleroma/application.ex +++ b/lib/pleroma/application.ex @@ -171,7 +171,7 @@ defmodule Pleroma.Application do    defp chat_enabled?, do: Config.get([:chat, :enabled]) -  defp streamer_child(:test), do: [] +  defp streamer_child(env) when env in [:test, :benchmark], do: []    defp streamer_child(_) do      [Pleroma.Web.Streamer.supervisor()] diff --git a/lib/pleroma/user.ex b/lib/pleroma/user.ex index d9aa54057..ff828aa17 100644 --- a/lib/pleroma/user.ex +++ b/lib/pleroma/user.ex @@ -305,16 +305,12 @@ defmodule Pleroma.User do      end    end -  def profile_url(%User{source_data: %{"url" => url}}), do: url -  def profile_url(%User{ap_id: ap_id}), do: ap_id -  def profile_url(_), do: nil -    def ap_id(%User{nickname: nickname}), do: "#{Web.base_url()}/users/#{nickname}"    def ap_followers(%User{follower_address: fa}) when is_binary(fa), do: fa    def ap_followers(%User{} = user), do: "#{ap_id(user)}/followers" -  @spec ap_following(User.t()) :: Sring.t() +  @spec ap_following(User.t()) :: String.t()    def ap_following(%User{following_address: fa}) when is_binary(fa), do: fa    def ap_following(%User{} = user), do: "#{ap_id(user)}/following" diff --git a/lib/pleroma/web/activity_pub/activity_pub.ex b/lib/pleroma/web/activity_pub/activity_pub.ex index 9c0f5d771..53b6ad654 100644 --- a/lib/pleroma/web/activity_pub/activity_pub.ex +++ b/lib/pleroma/web/activity_pub/activity_pub.ex @@ -1379,6 +1379,18 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do      end    end +  @spec get_actor_url(any()) :: binary() | nil +  defp get_actor_url(url) when is_binary(url), do: url +  defp get_actor_url(%{"href" => href}) when is_binary(href), do: href + +  defp get_actor_url(url) when is_list(url) do +    url +    |> List.first() +    |> get_actor_url() +  end + +  defp get_actor_url(_url), do: nil +    defp object_to_user_data(data) do      avatar =        data["icon"]["url"] && @@ -1408,6 +1420,7 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do      user_data = %{        ap_id: data["id"], +      uri: get_actor_url(data["url"]),        ap_enabled: true,        source_data: data,        banner: banner, diff --git a/lib/pleroma/web/activity_pub/utils.ex b/lib/pleroma/web/activity_pub/utils.ex index c65bbed67..2d685ecc0 100644 --- a/lib/pleroma/web/activity_pub/utils.ex +++ b/lib/pleroma/web/activity_pub/utils.ex @@ -795,102 +795,6 @@ defmodule Pleroma.Web.ActivityPub.Utils do      ActivityPub.fetch_activities([], params, :offset)    end -  def parse_report_group(activity) do -    reports = get_reports_by_status_id(activity["id"]) -    max_date = Enum.max_by(reports, &NaiveDateTime.from_iso8601!(&1.data["published"])) -    actors = Enum.map(reports, & &1.user_actor) -    [%{data: %{"object" => [account_id | _]}} | _] = reports - -    account = -      AccountView.render("show.json", %{ -        user: User.get_by_ap_id(account_id) -      }) - -    status = get_status_data(activity) - -    %{ -      date: max_date.data["published"], -      account: account, -      status: status, -      actors: Enum.uniq(actors), -      reports: reports -    } -  end - -  defp get_status_data(status) do -    case status["deleted"] do -      true -> -        %{ -          "id" => status["id"], -          "deleted" => true -        } - -      _ -> -        Activity.get_by_ap_id(status["id"]) -    end -  end - -  def get_reports_by_status_id(ap_id) do -    from(a in Activity, -      where: fragment("(?)->>'type' = 'Flag'", a.data), -      where: fragment("(?)->'object' @> ?", a.data, ^[%{id: ap_id}]), -      or_where: fragment("(?)->'object' @> ?", a.data, ^[ap_id]) -    ) -    |> Activity.with_preloaded_user_actor() -    |> Repo.all() -  end - -  @spec get_reports_grouped_by_status([String.t()]) :: %{ -          required(:groups) => [ -            %{ -              required(:date) => String.t(), -              required(:account) => %{}, -              required(:status) => %{}, -              required(:actors) => [%User{}], -              required(:reports) => [%Activity{}] -            } -          ] -        } -  def get_reports_grouped_by_status(activity_ids) do -    parsed_groups = -      activity_ids -      |> Enum.map(fn id -> -        id -        |> build_flag_object() -        |> parse_report_group() -      end) - -    %{ -      groups: parsed_groups -    } -  end - -  @spec get_reported_activities() :: [ -          %{ -            required(:activity) => String.t(), -            required(:date) => String.t() -          } -        ] -  def get_reported_activities do -    reported_activities_query = -      from(a in Activity, -        where: fragment("(?)->>'type' = 'Flag'", a.data), -        select: %{ -          activity: fragment("jsonb_array_elements((? #- '{object,0}')->'object')", a.data) -        }, -        group_by: fragment("activity") -      ) - -    from(a in subquery(reported_activities_query), -      distinct: true, -      select: %{ -        id: fragment("COALESCE(?->>'id'::text, ? #>> '{}')", a.activity, a.activity) -      } -    ) -    |> Repo.all() -    |> Enum.map(& &1.id) -  end -    def update_report_state(%Activity{} = activity, state)        when state in @strip_status_report_states do      {:ok, stripped_activity} = strip_report_status_data(activity) diff --git a/lib/pleroma/web/admin_api/admin_api_controller.ex b/lib/pleroma/web/admin_api/admin_api_controller.ex index 0368df1e9..ca5439920 100644 --- a/lib/pleroma/web/admin_api/admin_api_controller.ex +++ b/lib/pleroma/web/admin_api/admin_api_controller.ex @@ -715,14 +715,6 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIController do      |> render("index.json", %{reports: reports})    end -  def list_grouped_reports(conn, _params) do -    statuses = Utils.get_reported_activities() - -    conn -    |> put_view(ReportView) -    |> render("index_grouped.json", Utils.get_reports_grouped_by_status(statuses)) -  end -    def report_show(conn, %{"id" => id}) do      with %Activity{} = report <- Activity.get_by_id(id) do        conn diff --git a/lib/pleroma/web/admin_api/views/report_view.ex b/lib/pleroma/web/admin_api/views/report_view.ex index fc8733ce8..ca0bcebc7 100644 --- a/lib/pleroma/web/admin_api/views/report_view.ex +++ b/lib/pleroma/web/admin_api/views/report_view.ex @@ -4,7 +4,7 @@  defmodule Pleroma.Web.AdminAPI.ReportView do    use Pleroma.Web, :view -  alias Pleroma.Activity +    alias Pleroma.HTML    alias Pleroma.User    alias Pleroma.Web.AdminAPI.Report @@ -44,32 +44,6 @@ defmodule Pleroma.Web.AdminAPI.ReportView do      }    end -  def render("index_grouped.json", %{groups: groups}) do -    reports = -      Enum.map(groups, fn group -> -        status = -          case group.status do -            %Activity{} = activity -> StatusView.render("show.json", %{activity: activity}) -            _ -> group.status -          end - -        %{ -          date: group[:date], -          account: group[:account], -          status: Map.put_new(status, "deleted", false), -          actors: Enum.map(group[:actors], &merge_account_views/1), -          reports: -            group[:reports] -            |> Enum.map(&Report.extract_report_info(&1)) -            |> Enum.map(&render(__MODULE__, "show.json", &1)) -        } -      end) - -    %{ -      reports: reports -    } -  end -    def render("index_notes.json", %{notes: notes}) when is_list(notes) do      Enum.map(notes, &render(__MODULE__, "show_note.json", &1))    end diff --git a/lib/pleroma/web/mastodon_api/views/account_view.ex b/lib/pleroma/web/mastodon_api/views/account_view.ex index 0efcabc01..c482bba64 100644 --- a/lib/pleroma/web/mastodon_api/views/account_view.ex +++ b/lib/pleroma/web/mastodon_api/views/account_view.ex @@ -43,7 +43,7 @@ defmodule Pleroma.Web.MastodonAPI.AccountView do        id: to_string(user.id),        acct: user.nickname,        username: username_from_nickname(user.nickname), -      url: User.profile_url(user) +      url: user.uri || user.ap_id      }    end @@ -207,7 +207,7 @@ defmodule Pleroma.Web.MastodonAPI.AccountView do        following_count: following_count,        statuses_count: user.note_count,        note: user.bio || "", -      url: User.profile_url(user), +      url: user.uri || user.ap_id,        avatar: image,        avatar_static: image,        header: header, diff --git a/lib/pleroma/web/metadata.ex b/lib/pleroma/web/metadata.ex index c9aac27dc..a9f70c43e 100644 --- a/lib/pleroma/web/metadata.ex +++ b/lib/pleroma/web/metadata.ex @@ -6,7 +6,12 @@ defmodule Pleroma.Web.Metadata do    alias Phoenix.HTML    def build_tags(params) do -    Enum.reduce(Pleroma.Config.get([__MODULE__, :providers], []), "", fn parser, acc -> +    providers = [ +      Pleroma.Web.Metadata.Providers.RestrictIndexing +      | Pleroma.Config.get([__MODULE__, :providers], []) +    ] + +    Enum.reduce(providers, "", fn parser, acc ->        rendered_html =          params          |> parser.build_tags() diff --git a/lib/pleroma/web/metadata/opengraph.ex b/lib/pleroma/web/metadata/opengraph.ex index 21446ac77..68c871e71 100644 --- a/lib/pleroma/web/metadata/opengraph.ex +++ b/lib/pleroma/web/metadata/opengraph.ex @@ -68,7 +68,7 @@ defmodule Pleroma.Web.Metadata.Providers.OpenGraph do             property: "og:title",             content: Utils.user_name_string(user)           ], []}, -        {:meta, [property: "og:url", content: User.profile_url(user)], []}, +        {:meta, [property: "og:url", content: user.uri || user.ap_id], []},          {:meta, [property: "og:description", content: truncated_bio], []},          {:meta, [property: "og:type", content: "website"], []},          {:meta, [property: "og:image", content: Utils.attachment_url(User.avatar_url(user))], []}, diff --git a/lib/pleroma/web/metadata/restrict_indexing.ex b/lib/pleroma/web/metadata/restrict_indexing.ex new file mode 100644 index 000000000..f15607896 --- /dev/null +++ b/lib/pleroma/web/metadata/restrict_indexing.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.Metadata.Providers.RestrictIndexing do +  @behaviour Pleroma.Web.Metadata.Providers.Provider + +  @moduledoc """ +  Restricts indexing of remote users. +  """ + +  @impl true +  def build_tags(%{user: %{local: false}}) do +    [ +      {:meta, +       [ +         name: "robots", +         content: "noindex, noarchive" +       ], []} +    ] +  end + +  @impl true +  def build_tags(%{user: %{local: true}}), do: [] +end diff --git a/lib/pleroma/web/router.ex b/lib/pleroma/web/router.ex index a22f744c1..5a0902739 100644 --- a/lib/pleroma/web/router.ex +++ b/lib/pleroma/web/router.ex @@ -186,7 +186,6 @@ defmodule Pleroma.Web.Router do      patch("/users/resend_confirmation_email", AdminAPIController, :resend_confirmation_email)      get("/reports", AdminAPIController, :list_reports) -    get("/grouped_reports", AdminAPIController, :list_grouped_reports)      get("/reports/:id", AdminAPIController, :report_show)      patch("/reports", AdminAPIController, :reports_update)      post("/reports/:id/notes", AdminAPIController, :report_notes_create) diff --git a/lib/pleroma/web/templates/static_fe/static_fe/_user_card.html.eex b/lib/pleroma/web/templates/static_fe/static_fe/_user_card.html.eex index c7789f9ac..2a7582d45 100644 --- a/lib/pleroma/web/templates/static_fe/static_fe/_user_card.html.eex +++ b/lib/pleroma/web/templates/static_fe/static_fe/_user_card.html.eex @@ -1,5 +1,5 @@  <div class="p-author h-card"> -  <a class="u-url" rel="author noopener" href="<%= User.profile_url(@user) %>"> +  <a class="u-url" rel="author noopener" href="<%= (@user.uri || @user.ap_id) %>">      <div class="avatar">        <img src="<%= User.avatar_url(@user) |> MediaProxy.url %>" width="48" height="48" alt="">      </div> diff --git a/lib/pleroma/web/templates/static_fe/static_fe/profile.html.eex b/lib/pleroma/web/templates/static_fe/static_fe/profile.html.eex index 94063c92d..e7d2aecad 100644 --- a/lib/pleroma/web/templates/static_fe/static_fe/profile.html.eex +++ b/lib/pleroma/web/templates/static_fe/static_fe/profile.html.eex @@ -8,7 +8,7 @@        <button type="submit" class="collapse">Remote follow</button>      </form>      <%= raw Formatter.emojify(@user.name, emoji_for_user(@user)) %> | -    <%= link "@#{@user.nickname}@#{Endpoint.host()}", to: User.profile_url(@user) %> +    <%= link "@#{@user.nickname}@#{Endpoint.host()}", to: (@user.uri || @user.ap_id) %>    </h3>    <p><%= raw @user.bio %></p>  </header> | 
