Add remote user fetching to search.
authorRoger Braun <roger@rogerbraun.net>
Sat, 16 Sep 2017 09:26:20 +0000 (11:26 +0200)
committerRoger Braun <roger@rogerbraun.net>
Sat, 16 Sep 2017 09:26:20 +0000 (11:26 +0200)
lib/pleroma/web/mastodon_api/mastodon_api_controller.ex
test/web/mastodon_api/mastodon_api_controller_test.exs

index fcc87d414543d7e42ca895ac2a6755965388da95..c231ff7f829e6b270a3a7677f30d38cd15cc01e9 100644 (file)
@@ -287,7 +287,11 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIController do
     end
   end
 
-  def search(%{assigns: %{user: user}} = conn, %{"q" => query}) do
+  def search(%{assigns: %{user: user}} = conn, %{"q" => query} = params) do
+    if params["resolve"] == "true" do
+      User.get_or_fetch_by_nickname(query)
+    end
+
     q = from u in User,
       where: fragment("(to_tsvector('english', ?) || to_tsvector('english', ?)) @@ plainto_tsquery('english', ?)", u.nickname, u.name, ^query),
       limit: 20
index 1bef1a1fdc902462f0e60093e2529569cb6c5eb2..4261ac6b16fa9b4dd124bb7c3adf8d1eaca196c8 100644 (file)
@@ -332,4 +332,13 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do
     [status] = results["statuses"]
     assert status["id"] == activity.id
   end
+
+  test "search fetches remote accounts", %{conn: conn} do
+    conn = conn
+    |> get("/api/v1/search", %{"q" => "shp@social.heldscal.la", "resolve" => "true"})
+
+    assert results = json_response(conn, 200)
+    [account] = results["accounts"]
+    assert account["acct"] == "shp@social.heldscal.la"
+  end
 end