logo

pleroma

My custom branche(s) on git.pleroma.social/pleroma/pleroma git clone https://hacktivis.me/git/pleroma.git

directory_controller.ex (2220B)


  1. # Pleroma: A lightweight social networking server
  2. # Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/>
  3. # SPDX-License-Identifier: AGPL-3.0-only
  4. defmodule Pleroma.Web.MastodonAPI.DirectoryController do
  5. use Pleroma.Web, :controller
  6. import Ecto.Query
  7. alias Pleroma.Pagination
  8. alias Pleroma.User
  9. alias Pleroma.UserRelationship
  10. alias Pleroma.Web.MastodonAPI.AccountView
  11. require Logger
  12. plug(Pleroma.Web.ApiSpec.CastAndValidate)
  13. plug(:skip_auth when action == :index)
  14. defdelegate open_api_operation(action), to: Pleroma.Web.ApiSpec.DirectoryOperation
  15. @doc "GET /api/v1/directory"
  16. def index(%{assigns: %{user: user}} = conn, params) do
  17. with true <- Pleroma.Config.get([:instance, :profile_directory]) do
  18. limit = Map.get(params, :limit, 20) |> min(80)
  19. users =
  20. User.Query.build(%{is_discoverable: true, invisible: false, limit: limit})
  21. |> order_by_creation_date(params)
  22. |> exclude_remote(params)
  23. |> exclude_user(user)
  24. |> exclude_relationships(user, [:block, :mute])
  25. |> Pagination.fetch_paginated(params, :offset)
  26. conn
  27. |> put_view(AccountView)
  28. |> render("index.json", for: user, users: users, as: :user)
  29. else
  30. _ -> json(conn, [])
  31. end
  32. end
  33. defp order_by_creation_date(query, %{order: "new"}) do
  34. query
  35. end
  36. defp order_by_creation_date(query, _params) do
  37. query
  38. |> order_by([u], desc_nulls_last: u.last_status_at)
  39. end
  40. defp exclude_remote(query, %{local: true}) do
  41. where(query, [u], u.local == true)
  42. end
  43. defp exclude_remote(query, _params) do
  44. query
  45. end
  46. defp exclude_user(query, %User{id: user_id}) do
  47. where(query, [u], u.id != ^user_id)
  48. end
  49. defp exclude_user(query, _user) do
  50. query
  51. end
  52. defp exclude_relationships(query, %User{id: user_id}, relationship_types) do
  53. query
  54. |> join(:left, [u], r in UserRelationship,
  55. as: :user_relationships,
  56. on:
  57. r.target_id == u.id and r.source_id == ^user_id and
  58. r.relationship_type in ^relationship_types
  59. )
  60. |> where([user_relationships: r], is_nil(r.target_id))
  61. end
  62. defp exclude_relationships(query, _user, _relationship_types) do
  63. query
  64. end
  65. end