diff options
Diffstat (limited to 'lib/mix/tasks')
| -rw-r--r-- | lib/mix/tasks/pleroma/database.ex | 23 | ||||
| -rw-r--r-- | lib/mix/tasks/pleroma/emoji.ex | 38 | 
2 files changed, 30 insertions, 31 deletions
| diff --git a/lib/mix/tasks/pleroma/database.ex b/lib/mix/tasks/pleroma/database.ex index 778de162f..82e2abdcb 100644 --- a/lib/mix/tasks/pleroma/database.ex +++ b/lib/mix/tasks/pleroma/database.ex @@ -4,6 +4,7 @@  defmodule Mix.Tasks.Pleroma.Database do    alias Pleroma.Conversation +  alias Pleroma.Maintenance    alias Pleroma.Object    alias Pleroma.Repo    alias Pleroma.User @@ -34,13 +35,7 @@ defmodule Mix.Tasks.Pleroma.Database do      )      if Keyword.get(options, :vacuum) do -      Logger.info("Runnning VACUUM FULL") - -      Repo.query!( -        "vacuum full;", -        [], -        timeout: :infinity -      ) +      Maintenance.vacuum("full")      end    end @@ -94,13 +89,7 @@ defmodule Mix.Tasks.Pleroma.Database do      |> Repo.delete_all(timeout: :infinity)      if Keyword.get(options, :vacuum) do -      Logger.info("Runnning VACUUM FULL") - -      Repo.query!( -        "vacuum full;", -        [], -        timeout: :infinity -      ) +      Maintenance.vacuum("full")      end    end @@ -135,4 +124,10 @@ defmodule Mix.Tasks.Pleroma.Database do      end)      |> Stream.run()    end + +  def run(["vacuum", args]) do +    start_pleroma() + +    Maintenance.vacuum(args) +  end  end diff --git a/lib/mix/tasks/pleroma/emoji.ex b/lib/mix/tasks/pleroma/emoji.ex index cdffa88b2..29a5fa99c 100644 --- a/lib/mix/tasks/pleroma/emoji.ex +++ b/lib/mix/tasks/pleroma/emoji.ex @@ -15,7 +15,7 @@ defmodule Mix.Tasks.Pleroma.Emoji do      {options, [], []} = parse_global_opts(args)      url_or_path = options[:manifest] || default_manifest() -    manifest = fetch_manifest(url_or_path) +    manifest = fetch_and_decode(url_or_path)      Enum.each(manifest, fn {name, info} ->        to_print = [ @@ -42,12 +42,12 @@ defmodule Mix.Tasks.Pleroma.Emoji do      url_or_path = options[:manifest] || default_manifest() -    manifest = fetch_manifest(url_or_path) +    manifest = fetch_and_decode(url_or_path)      for pack_name <- pack_names do        if Map.has_key?(manifest, pack_name) do          pack = manifest[pack_name] -        src_url = pack["src"] +        src = pack["src"]          IO.puts(            IO.ANSI.format([ @@ -57,11 +57,11 @@ defmodule Mix.Tasks.Pleroma.Emoji do              :normal,              " from ",              :underline, -            src_url +            src            ])          ) -        binary_archive = Tesla.get!(client(), src_url).body +        {:ok, binary_archive} = fetch(src)          archive_sha = :crypto.hash(:sha256, binary_archive) |> Base.encode16()          sha_status_text = ["SHA256 of ", :bright, pack_name, :normal, " source file is ", :bright] @@ -74,8 +74,8 @@ defmodule Mix.Tasks.Pleroma.Emoji do            raise "Bad SHA256 for #{pack_name}"          end -        # The url specified in files should be in the same directory -        files_url = +        # The location specified in files should be in the same directory +        files_loc =            url_or_path            |> Path.dirname()            |> Path.join(pack["files"]) @@ -88,11 +88,11 @@ defmodule Mix.Tasks.Pleroma.Emoji do              :normal,              " from ",              :underline, -            files_url +            files_loc            ])          ) -        files = Tesla.get!(client(), files_url).body |> Jason.decode!() +        files = fetch_and_decode(files_loc)          IO.puts(IO.ANSI.format(["Unpacking ", :bright, pack_name])) @@ -237,16 +237,20 @@ defmodule Mix.Tasks.Pleroma.Emoji do      end    end -  defp fetch_manifest(from) do -    Jason.decode!( -      if String.starts_with?(from, "http") do -        Tesla.get!(client(), from).body -      else -        File.read!(from) -      end -    ) +  defp fetch_and_decode(from) do +    with {:ok, json} <- fetch(from) do +      Jason.decode!(json) +    end    end +  defp fetch("http" <> _ = from) do +    with {:ok, %{body: body}} <- Tesla.get(client(), from) do +      {:ok, body} +    end +  end + +  defp fetch(path), do: File.read(path) +    defp parse_global_opts(args) do      OptionParser.parse(        args, | 
