diff options
author | rinpatch <rinpatch@sdf.org> | 2019-12-21 11:56:24 +0000 |
---|---|---|
committer | rinpatch <rinpatch@sdf.org> | 2019-12-21 11:56:24 +0000 |
commit | c51e93978ea2aa0f2d5bcc43bf7c925b2590eece (patch) | |
tree | a914a0129fcd6e42c2317254cec7411ec5045696 /lib/pleroma/application.ex | |
parent | 7447c80e33a7d54c3d9f03f5c0be3fb738f1318b (diff) | |
parent | b9a87b1baa0650bfb4b699054304daae585a0e9a (diff) | |
download | pleroma-c51e93978ea2aa0f2d5bcc43bf7c925b2590eece.tar.gz |
Merge branch 'feature/custom-runtime-modules' into 'develop'
Add support for custom modules at runtime
Closes #1448
See merge request pleroma/pleroma!2039
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 5b844aa41..2ae052069 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 = @@ -68,6 +70,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 |