1
0
Fork 0
mirror of https://akkoma.dev/AkkomaGang/akkoma.git synced 2025-01-25 15:09:34 +00:00
akkoma/lib/mix/pleroma.ex

152 lines
3.7 KiB
Elixir
Raw Normal View History

2018-12-23 20:05:55 +00:00
# Pleroma: A lightweight social networking server
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
2018-12-23 20:05:55 +00:00
# SPDX-License-Identifier: AGPL-3.0-only
defmodule Mix.Pleroma do
2020-07-09 19:13:16 +03:00
@apps [
:restarter,
:ecto,
:ecto_sql,
:postgrex,
:db_connection,
:cachex,
:flake_id,
:swoosh,
:timex,
:fast_html,
:oban
2020-07-09 19:13:16 +03:00
]
@cachex_children ["object", "user", "scrubber", "web_resp", "http_backoff"]
2018-12-09 12:12:48 +03:00
@doc "Common functions to be reused in mix tasks"
2018-12-07 06:12:39 +01:00
def start_pleroma do
2020-07-09 11:17:43 +03:00
Pleroma.Config.Holder.save_default()
Pleroma.Config.Oban.warn()
2020-11-20 11:37:01 +03:00
Pleroma.Application.limiters_setup()
Application.put_env(:phoenix, :serve_endpoints, false, persistent: true)
proxy_url = Pleroma.Config.get([:http, :proxy_url])
proxy = Pleroma.HTTP.AdapterHelper.format_proxy(proxy_url)
finch_config =
[:http, :adapter]
|> Pleroma.Config.get([])
|> Pleroma.HTTP.AdapterHelper.maybe_add_proxy_pool(proxy)
|> Keyword.put(:name, MyFinch)
unless System.get_env("DEBUG") do
Logger.remove_backend(:console)
end
Enum.each(@apps, &Application.ensure_all_started/1)
2020-07-03 19:18:08 +03:00
oban_config = [
crontab: [],
repo: Pleroma.Repo,
log: false,
queues: [],
plugins: []
]
children =
[
Pleroma.Repo,
Pleroma.Emoji,
{Pleroma.Config.TransferTask, false},
Pleroma.Web.Endpoint,
{Finch, finch_config},
{Oban, oban_config},
{Majic.Pool,
[name: Pleroma.MajicPool, pool_size: Pleroma.Config.get([:majic_pool, :size], 2)]}
] ++
elasticsearch_children()
2020-07-03 19:18:08 +03:00
2020-07-09 19:13:16 +03:00
cachex_children = Enum.map(@cachex_children, &Pleroma.Application.build_cachex(&1, []))
2020-07-03 19:18:08 +03:00
2020-07-09 19:13:16 +03:00
Supervisor.start_link(children ++ cachex_children,
2020-07-03 19:18:08 +03:00
strategy: :one_for_one,
name: Pleroma.Supervisor
)
if Pleroma.Config.get(:env) not in [:test, :benchmark] do
pleroma_rebooted?()
end
end
defp pleroma_rebooted? do
if Restarter.Pleroma.rebooted?() do
:ok
else
Process.sleep(10)
pleroma_rebooted?()
end
2018-12-07 06:12:39 +01:00
end
def load_pleroma do
Application.load(:pleroma)
end
2018-12-07 09:46:13 +03:00
def get_option(options, opt, prompt, defval \\ nil, defname \\ nil) do
2019-06-08 17:40:40 +03:00
Keyword.get(options, opt) || shell_prompt(prompt, defval, defname)
2018-12-07 06:12:39 +01:00
end
2019-06-08 17:40:40 +03:00
def shell_prompt(prompt, defval \\ nil, defname \\ nil) do
prompt_message = "#{prompt} [#{defname || defval}] "
2019-06-08 17:40:40 +03:00
input =
if mix_shell?(),
do: Mix.shell().prompt(prompt_message),
else: :io.get_line(prompt_message)
case input do
"\n" ->
case defval do
nil ->
shell_prompt(prompt, defval, defname)
defval ->
defval
end
input ->
String.trim(input)
end
end
def shell_info(message) when is_binary(message) or is_list(message) do
2019-06-08 17:40:40 +03:00
if mix_shell?(),
do: Mix.shell().info(message),
else: IO.puts(message)
end
def shell_info(message) do
shell_info("#{inspect(message)}")
end
def shell_error(message) when is_binary(message) or is_list(message) do
2019-06-08 17:40:40 +03:00
if mix_shell?(),
do: Mix.shell().error(message),
else: IO.puts(:stderr, message)
end
def shell_error(message) do
shell_error("#{inspect(message)}")
end
2019-06-08 17:40:40 +03:00
@doc "Performs a safe check whether `Mix.shell/0` is available (does not raise if Mix is not loaded)"
def mix_shell?, do: :erlang.function_exported(Mix, :shell, 0)
2018-12-07 06:12:39 +01:00
def escape_sh_path(path) do
~S(') <> String.replace(path, ~S('), ~S(\')) <> ~S(')
end
def elasticsearch_children do
config = Pleroma.Config.get([Pleroma.Search, :module])
if config == Pleroma.Search.Elasticsearch do
[Pleroma.Search.Elasticsearch.Cluster]
else
[]
end
end
2018-12-07 06:12:39 +01:00
end