diff options
| author | marcin mikołajczak <git@mkljczk.pl> | 2023-12-22 13:29:56 +0100 | 
|---|---|---|
| committer | marcin mikołajczak <git@mkljczk.pl> | 2023-12-22 13:29:56 +0100 | 
| commit | 28e5e65676ea08ae9e329d51648baf06dcf950c0 (patch) | |
| tree | fd0b04e34a2f3df53b35ed5c3eb8301ad242ede6 /lib/mix/tasks | |
| parent | 39d3df86c8e2ee05d409865ebc866c543a604ad9 (diff) | |
| parent | 5f1d70736711275ac9f0c95e5ada4cb2f1a96e11 (diff) | |
| download | pleroma-28e5e65676ea08ae9e329d51648baf06dcf950c0.tar.gz pleroma-28e5e65676ea08ae9e329d51648baf06dcf950c0.zip | |
Merge remote-tracking branch 'origin/develop' into webfinger-fix
Signed-off-by: marcin mikołajczak <git@mkljczk.pl>
Diffstat (limited to 'lib/mix/tasks')
| -rw-r--r-- | lib/mix/tasks/pleroma/benchmark.ex | 113 | ||||
| -rw-r--r-- | lib/mix/tasks/pleroma/search/meilisearch.ex | 145 | 
2 files changed, 145 insertions, 113 deletions
| diff --git a/lib/mix/tasks/pleroma/benchmark.ex b/lib/mix/tasks/pleroma/benchmark.ex deleted file mode 100644 index f32492169..000000000 --- a/lib/mix/tasks/pleroma/benchmark.ex +++ /dev/null @@ -1,113 +0,0 @@ -# Pleroma: A lightweight social networking server -# Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/> -# SPDX-License-Identifier: AGPL-3.0-only - -defmodule Mix.Tasks.Pleroma.Benchmark do -  import Mix.Pleroma -  use Mix.Task - -  def run(["search"]) do -    start_pleroma() - -    Benchee.run(%{ -      "search" => fn -> -        Pleroma.Activity.search(nil, "cofe") -      end -    }) -  end - -  def run(["tag"]) do -    start_pleroma() - -    Benchee.run(%{ -      "tag" => fn -> -        %{"type" => "Create", "tag" => "cofe"} -        |> Pleroma.Web.ActivityPub.ActivityPub.fetch_public_activities() -      end -    }) -  end - -  def run(["render_timeline", nickname | _] = args) do -    start_pleroma() -    user = Pleroma.User.get_by_nickname(nickname) - -    activities = -      %{} -      |> Map.put("type", ["Create", "Announce"]) -      |> Map.put("blocking_user", user) -      |> Map.put("muting_user", user) -      |> Map.put("user", user) -      |> Map.put("limit", 4096) -      |> Pleroma.Web.ActivityPub.ActivityPub.fetch_public_activities() -      |> Enum.reverse() - -    inputs = %{ -      "1 activity" => Enum.take_random(activities, 1), -      "10 activities" => Enum.take_random(activities, 10), -      "20 activities" => Enum.take_random(activities, 20), -      "40 activities" => Enum.take_random(activities, 40), -      "80 activities" => Enum.take_random(activities, 80) -    } - -    inputs = -      if Enum.at(args, 2) == "extended" do -        Map.merge(inputs, %{ -          "200 activities" => Enum.take_random(activities, 200), -          "500 activities" => Enum.take_random(activities, 500), -          "2000 activities" => Enum.take_random(activities, 2000), -          "4096 activities" => Enum.take_random(activities, 4096) -        }) -      else -        inputs -      end - -    Benchee.run( -      %{ -        "Standart rendering" => fn activities -> -          Pleroma.Web.MastodonAPI.StatusView.render("index.json", %{ -            activities: activities, -            for: user, -            as: :activity -          }) -        end -      }, -      inputs: inputs -    ) -  end - -  def run(["adapters"]) do -    start_pleroma() - -    :ok = -      Pleroma.Gun.Conn.open( -        "https://httpbin.org/stream-bytes/1500", -        :gun_connections -      ) - -    Process.sleep(1_500) - -    Benchee.run( -      %{ -        "Without conn and without pool" => fn -> -          {:ok, %Tesla.Env{}} = -            Pleroma.HTTP.get("https://httpbin.org/stream-bytes/1500", [], -              pool: :no_pool, -              receive_conn: false -            ) -        end, -        "Without conn and with pool" => fn -> -          {:ok, %Tesla.Env{}} = -            Pleroma.HTTP.get("https://httpbin.org/stream-bytes/1500", [], receive_conn: false) -        end, -        "With reused conn and without pool" => fn -> -          {:ok, %Tesla.Env{}} = -            Pleroma.HTTP.get("https://httpbin.org/stream-bytes/1500", [], pool: :no_pool) -        end, -        "With reused conn and with pool" => fn -> -          {:ok, %Tesla.Env{}} = Pleroma.HTTP.get("https://httpbin.org/stream-bytes/1500") -        end -      }, -      parallel: 10 -    ) -  end -end diff --git a/lib/mix/tasks/pleroma/search/meilisearch.ex b/lib/mix/tasks/pleroma/search/meilisearch.ex new file mode 100644 index 000000000..8379a0c25 --- /dev/null +++ b/lib/mix/tasks/pleroma/search/meilisearch.ex @@ -0,0 +1,145 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Mix.Tasks.Pleroma.Search.Meilisearch do +  require Pleroma.Constants + +  import Mix.Pleroma +  import Ecto.Query + +  import Pleroma.Search.Meilisearch, +    only: [meili_post: 2, meili_put: 2, meili_get: 1, meili_delete: 1] + +  def run(["index"]) do +    start_pleroma() +    Pleroma.HTML.compile_scrubbers() + +    meili_version = +      ( +        {:ok, result} = meili_get("/version") + +        result["pkgVersion"] +      ) + +    # The ranking rule syntax was changed but nothing about that is mentioned in the changelog +    if not Version.match?(meili_version, ">= 0.25.0") do +      raise "Meilisearch <0.24.0 not supported" +    end + +    {:ok, _} = +      meili_post( +        "/indexes/objects/settings/ranking-rules", +        [ +          "published:desc", +          "words", +          "exactness", +          "proximity", +          "typo", +          "attribute", +          "sort" +        ] +      ) + +    {:ok, _} = +      meili_post( +        "/indexes/objects/settings/searchable-attributes", +        [ +          "content" +        ] +      ) + +    IO.puts("Created indices. Starting to insert posts.") + +    chunk_size = Pleroma.Config.get([Pleroma.Search.Meilisearch, :initial_indexing_chunk_size]) + +    Pleroma.Repo.transaction( +      fn -> +        query = +          from(Pleroma.Object, +            # Only index public and unlisted posts which are notes and have some text +            where: +              fragment("data->>'type' = 'Note'") and +                (fragment("data->'to' \\? ?", ^Pleroma.Constants.as_public()) or +                   fragment("data->'cc' \\? ?", ^Pleroma.Constants.as_public())), +            order_by: [desc: fragment("data->'published'")] +          ) + +        count = query |> Pleroma.Repo.aggregate(:count, :data) +        IO.puts("Entries to index: #{count}") + +        Pleroma.Repo.stream( +          query, +          timeout: :infinity +        ) +        |> Stream.map(&Pleroma.Search.Meilisearch.object_to_search_data/1) +        |> Stream.filter(fn o -> not is_nil(o) end) +        |> Stream.chunk_every(chunk_size) +        |> Stream.transform(0, fn objects, acc -> +          new_acc = acc + Enum.count(objects) + +          # Reset to the beginning of the line and rewrite it +          IO.write("\r") +          IO.write("Indexed #{new_acc} entries") + +          {[objects], new_acc} +        end) +        |> Stream.each(fn objects -> +          result = +            meili_put( +              "/indexes/objects/documents", +              objects +            ) + +          with {:ok, res} <- result do +            if not Map.has_key?(res, "uid") do +              IO.puts("\nFailed to index: #{inspect(result)}") +            end +          else +            e -> IO.puts("\nFailed to index due to network error: #{inspect(e)}") +          end +        end) +        |> Stream.run() +      end, +      timeout: :infinity +    ) + +    IO.write("\n") +  end + +  def run(["clear"]) do +    start_pleroma() + +    meili_delete("/indexes/objects/documents") +  end + +  def run(["show-keys", master_key]) do +    start_pleroma() + +    endpoint = Pleroma.Config.get([Pleroma.Search.Meilisearch, :url]) + +    {:ok, result} = +      Pleroma.HTTP.get( +        Path.join(endpoint, "/keys"), +        [{"Authorization", "Bearer #{master_key}"}] +      ) + +    decoded = Jason.decode!(result.body) + +    if decoded["results"] do +      Enum.each(decoded["results"], fn %{"description" => desc, "key" => key} -> +        IO.puts("#{desc}: #{key}") +      end) +    else +      IO.puts("Error fetching the keys, check the master key is correct: #{inspect(decoded)}") +    end +  end + +  def run(["stats"]) do +    start_pleroma() + +    {:ok, result} = meili_get("/indexes/objects/stats") +    IO.puts("Number of entries: #{result["numberOfDocuments"]}") +    IO.puts("Indexing? #{result["isIndexing"]}") +  end +end | 
