summaryrefslogtreecommitdiff
path: root/lib/mix
diff options
context:
space:
mode:
authorEkaterina Vaartis <vaartis@kotobank.ch>2021-08-23 19:35:21 +0300
committerEkaterina Vaartis <vaartis@kotobank.ch>2022-10-10 20:19:09 +0300
commit2c7d973af7797ae860829c1764ade521a17e7263 (patch)
tree009d8c4e155a8c51f87248c489183f01b970960d /lib/mix
parent410c8cb765bbec1014cb2bbdbcc44d3a25f834e1 (diff)
downloadpleroma-2c7d973af7797ae860829c1764ade521a17e7263.tar.gz
pleroma-2c7d973af7797ae860829c1764ade521a17e7263.zip
Implement meilisearch auth
Diffstat (limited to 'lib/mix')
-rw-r--r--lib/mix/tasks/pleroma/search/meilisearch.ex75
1 files changed, 44 insertions, 31 deletions
diff --git a/lib/mix/tasks/pleroma/search/meilisearch.ex b/lib/mix/tasks/pleroma/search/meilisearch.ex
index 2485a441d..230be5aa1 100644
--- a/lib/mix/tasks/pleroma/search/meilisearch.ex
+++ b/lib/mix/tasks/pleroma/search/meilisearch.ex
@@ -9,32 +9,30 @@ defmodule Mix.Tasks.Pleroma.Search.Meilisearch do
import Mix.Pleroma
import Ecto.Query
+ import Pleroma.Search.Meilisearch, only: [meili_post!: 2, meili_delete!: 1]
+
def run(["index"]) do
start_pleroma()
- endpoint = Pleroma.Config.get([Pleroma.Search.Meilisearch, :url])
-
- {:ok, _} =
- Pleroma.HTTP.post(
- "#{endpoint}/indexes/objects/settings/ranking-rules",
- Jason.encode!([
- "desc(published)",
- "typo",
- "words",
- "proximity",
- "attribute",
- "wordsPosition",
- "exactness"
- ])
- )
+ meili_post!(
+ "/indexes/objects/settings/ranking-rules",
+ [
+ "desc(published)",
+ "typo",
+ "words",
+ "proximity",
+ "attribute",
+ "wordsPosition",
+ "exactness"
+ ]
+ )
- {:ok, _} =
- Pleroma.HTTP.post(
- "#{endpoint}/indexes/objects/settings/searchable-attributes",
- Jason.encode!([
- "content"
- ])
- )
+ meili_post!(
+ "/indexes/objects/settings/searchable-attributes",
+ [
+ "content"
+ ]
+ )
chunk_size = 10_000
@@ -64,14 +62,14 @@ defmodule Mix.Tasks.Pleroma.Search.Meilisearch do
{[objects], new_acc}
end)
|> Stream.each(fn objects ->
- {:ok, result} =
- Pleroma.HTTP.post(
- "#{endpoint}/indexes/objects/documents",
- Jason.encode!(objects)
+ result =
+ meili_post!(
+ "/indexes/objects/documents",
+ objects
)
- if not Map.has_key?(Jason.decode!(result.body), "updateId") do
- IO.puts("Failed to index: #{result}")
+ if not Map.has_key?(result, "updateId") do
+ IO.puts("Failed to index: #{inspect(result)}")
end
end)
|> Stream.run()
@@ -85,11 +83,26 @@ defmodule Mix.Tasks.Pleroma.Search.Meilisearch do
def run(["clear"]) do
start_pleroma()
+ meili_delete!("/indexes/objects/documents")
+ end
+
+ def run(["show-private-key", master_key]) do
+ start_pleroma()
+
endpoint = Pleroma.Config.get([Pleroma.Search.Meilisearch, :url])
- {:ok, _} =
- Pleroma.HTTP.request(:delete, "#{endpoint}/indexes/objects/documents", "", [],
- timeout: :infinity
+ {:ok, result} =
+ Pleroma.HTTP.get(
+ Path.join(endpoint, "/keys"),
+ [{"X-Meili-API-Key", master_key}]
)
+
+ decoded = Jason.decode!(result.body)
+
+ if decoded["private"] do
+ IO.puts(decoded["private"])
+ else
+ IO.puts("Error fetching the key, check the master key is correct: #{inspect(decoded)}")
+ end
end
end