# Pleroma: A lightweight social networking server # Copyright © 2017-2021 Pleroma Authors # SPDX-License-Identifier: AGPL-3.0-only defmodule Mix.Tasks.Pleroma.Search.Meilisearch do require Logger import Mix.Pleroma import Ecto.Query 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(id)", "typo", "words", "proximity", "attribute", "wordsPosition", "exactness" ]) ) Pleroma.Repo.chunk_stream( from(Pleroma.Object, where: fragment("data->>'type' = 'Note'") and fragment("LENGTH(data->>'source') > 0") ), 200, :batches ) |> Stream.map(fn objects -> Enum.map(objects, fn object -> data = object.data %{id: object.id, source: data["source"], ap: data["id"]} end) end) |> Stream.each(fn objects -> {:ok, _} = Pleroma.HTTP.post( "#{endpoint}/indexes/objects/documents", Jason.encode!(objects) ) IO.puts("Indexed #{Enum.count(objects)} entries") end) |> Stream.run() end end