diff options
author | Maksim Pechnikov <parallel588@gmail.com> | 2019-12-21 20:37:29 +0300 |
---|---|---|
committer | Maksim Pechnikov <parallel588@gmail.com> | 2019-12-21 20:38:59 +0300 |
commit | 54c9db38c8035ecc115e136a09a3d991e426959a (patch) | |
tree | 496afddf614e826c2c76c7d69e3968a3c118e717 /lib/pleroma/application.ex | |
parent | 67cb46e15dd5fa16da257a9b0e5166266d10c694 (diff) | |
parent | c51e93978ea2aa0f2d5bcc43bf7c925b2590eece (diff) | |
download | pleroma-54c9db38c8035ecc115e136a09a3d991e426959a.tar.gz |
Merge branch 'develop' into issue/1383
Diffstat (limited to 'lib/pleroma/application.ex')
-rw-r--r-- | lib/pleroma/application.ex | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/lib/pleroma/application.ex b/lib/pleroma/application.ex index ab7f6d502..98d7a6e86 100644 --- a/lib/pleroma/application.ex +++ b/lib/pleroma/application.ex @@ -5,6 +5,7 @@ defmodule Pleroma.Application do import Cachex.Spec use Application + require Logger @name Mix.Project.config()[:name] @version Mix.Project.config()[:version] @@ -33,6 +34,7 @@ defmodule Pleroma.Application do Pleroma.HTML.compile_scrubbers() Pleroma.Config.DeprecationWarnings.warn() setup_instrumenters() + load_custom_modules() # Define workers and child supervisors to be supervised children = @@ -64,6 +66,28 @@ defmodule Pleroma.Application do Supervisor.start_link(children, opts) end + def load_custom_modules do + dir = Pleroma.Config.get([:modules, :runtime_dir]) + + if dir && File.exists?(dir) do + dir + |> Pleroma.Utils.compile_dir() + |> case do + {:error, _errors, _warnings} -> + raise "Invalid custom modules" + + {:ok, modules, _warnings} -> + if @env != :test do + Enum.each(modules, fn mod -> + Logger.info("Custom module loaded: #{inspect(mod)}") + end) + end + + :ok + end + end + end + defp setup_instrumenters do require Prometheus.Registry |