Cleanup and ensure we obey custom Repo timeout

This commit is contained in:
Mark Felder 2021-04-22 10:11:08 -05:00
parent 99fd9c5e38
commit 959dc6e6fc
1 changed files with 10 additions and 1 deletions

View File

@ -11,6 +11,8 @@ defmodule Pleroma.Utils do
eperm epipe erange erofs espipe esrch estale etxtbsy exdev eperm epipe erange erofs espipe esrch estale etxtbsy exdev
)a )a
@repo_timeout Pleroma.Config.get([Pleroma.Repo, :timeout], 15_000)
def compile_dir(dir) when is_binary(dir) do def compile_dir(dir) when is_binary(dir) do
dir dir
|> File.ls!() |> File.ls!()
@ -64,13 +66,20 @@ def posix_error_message(code) when code in @posix_error_codes do
def posix_error_message(_), do: "" def posix_error_message(_), do: ""
@doc """
Returns [timeout: integer] suitable for passing as an option to Repo functions.
This function detects if the execution was triggered from IEx shell, Mix task, or
./bin/pleroma_ctl and sets the timeout to :infinity, else returns the default timeout value.
"""
@spec query_timeout() :: [timeout: integer]
def query_timeout do def query_timeout do
{parent, _, _, _} = Process.info(self(), :current_stacktrace) |> elem(1) |> Enum.fetch!(2) {parent, _, _, _} = Process.info(self(), :current_stacktrace) |> elem(1) |> Enum.fetch!(2)
cond do cond do
parent |> to_string |> String.starts_with?("Elixir.Mix.Task") -> [timeout: :infinity] parent |> to_string |> String.starts_with?("Elixir.Mix.Task") -> [timeout: :infinity]
parent == :erl_eval -> [timeout: :infinity] parent == :erl_eval -> [timeout: :infinity]
true -> [timeout: 15_000] true -> [timeout: @repo_timeout]
end end
end end
end end