Browse Source

Use ILIKE to search users

tags/v1.1.4
Maxim Filippov 5 years ago
parent
commit
ed8a2935f5
2 changed files with 24 additions and 15 deletions
  1. +7
    -15
      lib/pleroma/user.ex
  2. +17
    -0
      test/user_test.exs

+ 7
- 15
lib/pleroma/user.ex View File

@@ -788,34 +788,26 @@ defmodule Pleroma.User do

@spec search_for_admin(%{
query: binary(),
admin: Pleroma.User.t(),
local: boolean(),
page: number(),
page_size: number()
}) :: {:ok, [Pleroma.User.t()], number()}
def search_for_admin(%{
query: term,
admin: admin,
local: local,
page: page,
page_size: page_size
}) do
term = String.trim_leading(term, "@")
maybe_local_query = User |> maybe_local_user_query(local)

local_paginated_query =
User
|> maybe_local_user_query(local)
search_query = from(u in maybe_local_query, where: ilike(u.nickname, ^"%#{term}%"))
count = search_query |> Repo.aggregate(:count, :id)
results =
search_query
|> paginate(page, page_size)
|> Repo.all()

search_query = fts_search_subquery(term, local_paginated_query)

count =
term
|> fts_search_subquery()
|> maybe_local_user_query(local)
|> Repo.aggregate(:count, :id)

{:ok, do_search(search_query, admin), count}
{:ok, results, count}
end

def search(query, resolve \\ false, for_user \\ nil) do


+ 17
- 0
test/user_test.exs View File

@@ -1098,4 +1098,21 @@ defmodule Pleroma.UserTest do
assert {:ok, user_state3} = User.bookmark(user, id2)
assert user_state3.bookmarks == [id2]
end

describe "search for admin" do
test "it ignores case" do
insert(:user, nickname: "papercoach")
insert(:user, nickname: "CanadaPaperCoach")

{:ok, _results, count} =
User.search_for_admin(%{
query: "paper",
local: false,
page: 1,
page_size: 50
})

assert count == 2
end
end
end

Loading…
Cancel
Save