17f6b9c8038a8558de6c65bba6353fd04ec7e163
[akkoma] / lib / pleroma / application.ex
1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
4
5 defmodule Pleroma.Application do
6 import Cachex.Spec
7 use Application
8
9 @name Mix.Project.config()[:name]
10 @version Mix.Project.config()[:version]
11 @repository Mix.Project.config()[:source_url]
12 @env Mix.env()
13
14 def name, do: @name
15 def version, do: @version
16 def named_version, do: @name <> " " <> @version
17 def repository, do: @repository
18
19 def user_agent do
20 case Pleroma.Config.get([:http, :user_agent], :default) do
21 :default ->
22 info = "#{Pleroma.Web.base_url()} <#{Pleroma.Config.get([:instance, :email], "")}>"
23 named_version() <> "; " <> info
24
25 custom ->
26 custom
27 end
28 end
29
30 # See http://elixir-lang.org/docs/stable/elixir/Application.html
31 # for more information on OTP Applications
32 def start(_type, _args) do
33 Pleroma.Config.DeprecationWarnings.warn()
34 setup_instrumenters()
35 load_custom_modules()
36
37 # Define workers and child supervisors to be supervised
38 children =
39 [
40 Pleroma.Repo,
41 Pleroma.Scheduler,
42 Pleroma.Config.TransferTask,
43 Pleroma.Emoji,
44 Pleroma.Captcha,
45 Pleroma.Daemons.ScheduledActivityDaemon,
46 Pleroma.Daemons.ActivityExpirationDaemon,
47 Pleroma.Plugs.RateLimiter.Supervisor
48 ] ++
49 cachex_children() ++
50 hackney_pool_children() ++
51 [
52 Pleroma.Stats,
53 Pleroma.JobQueueMonitor,
54 {Oban, Pleroma.Config.get(Oban)}
55 ] ++
56 task_children(@env) ++
57 oauth_cleanup_child(oauth_cleanup_enabled?()) ++
58 streamer_child(@env) ++
59 chat_child(@env, chat_enabled?()) ++
60 [
61 Pleroma.Web.Endpoint,
62 Pleroma.Gopher.Server
63 ]
64
65 # See http://elixir-lang.org/docs/stable/elixir/Supervisor.html
66 # for other strategies and supported options
67 opts = [strategy: :one_for_one, name: Pleroma.Supervisor]
68 Supervisor.start_link(children, opts)
69 end
70
71 def load_custom_modules do
72 dir = Pleroma.Config.get([:modules, :runtime_dir])
73
74 if dir && File.exists?(dir) do
75 dir
76 |> File.ls!()
77 |> Enum.map(&Path.join(dir, &1))
78 |> Kernel.ParallelCompiler.compile()
79 |> case do
80 {:error, _errors, _warnings} ->
81 raise "Invalid custom modules"
82
83 {:ok, modules, _warnings} ->
84 Enum.each(modules, fn mod ->
85 IO.puts("Custom module loaded: #{inspect(mod)}")
86 end)
87
88 :ok
89 end
90 end
91 end
92
93 defp setup_instrumenters do
94 require Prometheus.Registry
95
96 if Application.get_env(:prometheus, Pleroma.Repo.Instrumenter) do
97 :ok =
98 :telemetry.attach(
99 "prometheus-ecto",
100 [:pleroma, :repo, :query],
101 &Pleroma.Repo.Instrumenter.handle_event/4,
102 %{}
103 )
104
105 Pleroma.Repo.Instrumenter.setup()
106 end
107
108 Pleroma.Web.Endpoint.MetricsExporter.setup()
109 Pleroma.Web.Endpoint.PipelineInstrumenter.setup()
110 Pleroma.Web.Endpoint.Instrumenter.setup()
111 end
112
113 def enabled_hackney_pools do
114 [:media] ++
115 if Application.get_env(:tesla, :adapter) == Tesla.Adapter.Hackney do
116 [:federation]
117 else
118 []
119 end ++
120 if Pleroma.Config.get([Pleroma.Upload, :proxy_remote]) do
121 [:upload]
122 else
123 []
124 end
125 end
126
127 defp cachex_children do
128 [
129 build_cachex("used_captcha", ttl_interval: seconds_valid_interval()),
130 build_cachex("user", default_ttl: 25_000, ttl_interval: 1000, limit: 2500),
131 build_cachex("object", default_ttl: 25_000, ttl_interval: 1000, limit: 2500),
132 build_cachex("rich_media", default_ttl: :timer.minutes(120), limit: 5000),
133 build_cachex("scrubber", limit: 2500),
134 build_cachex("idempotency", expiration: idempotency_expiration(), limit: 2500),
135 build_cachex("web_resp", limit: 2500),
136 build_cachex("emoji_packs", expiration: emoji_packs_expiration(), limit: 10),
137 build_cachex("failed_proxy_url", limit: 2500)
138 ]
139 end
140
141 defp emoji_packs_expiration,
142 do: expiration(default: :timer.seconds(5 * 60), interval: :timer.seconds(60))
143
144 defp idempotency_expiration,
145 do: expiration(default: :timer.seconds(6 * 60 * 60), interval: :timer.seconds(60))
146
147 defp seconds_valid_interval,
148 do: :timer.seconds(Pleroma.Config.get!([Pleroma.Captcha, :seconds_valid]))
149
150 defp build_cachex(type, opts),
151 do: %{
152 id: String.to_atom("cachex_" <> type),
153 start: {Cachex, :start_link, [String.to_atom(type <> "_cache"), opts]},
154 type: :worker
155 }
156
157 defp chat_enabled?, do: Pleroma.Config.get([:chat, :enabled])
158
159 defp oauth_cleanup_enabled?,
160 do: Pleroma.Config.get([:oauth2, :clean_expired_tokens], false)
161
162 defp streamer_child(:test), do: []
163
164 defp streamer_child(_) do
165 [Pleroma.Web.Streamer.supervisor()]
166 end
167
168 defp oauth_cleanup_child(true),
169 do: [Pleroma.Web.OAuth.Token.CleanWorker]
170
171 defp oauth_cleanup_child(_), do: []
172
173 defp chat_child(:test, _), do: []
174
175 defp chat_child(_env, true) do
176 [Pleroma.Web.ChatChannel.ChatChannelState]
177 end
178
179 defp chat_child(_, _), do: []
180
181 defp hackney_pool_children do
182 for pool <- enabled_hackney_pools() do
183 options = Pleroma.Config.get([:hackney_pools, pool])
184 :hackney_pool.child_spec(pool, options)
185 end
186 end
187
188 defp task_children(:test) do
189 [
190 %{
191 id: :web_push_init,
192 start: {Task, :start_link, [&Pleroma.Web.Push.init/0]},
193 restart: :temporary
194 }
195 ]
196 end
197
198 defp task_children(_) do
199 [
200 %{
201 id: :web_push_init,
202 start: {Task, :start_link, [&Pleroma.Web.Push.init/0]},
203 restart: :temporary
204 },
205 %{
206 id: :internal_fetch_init,
207 start: {Task, :start_link, [&Pleroma.Web.ActivityPub.InternalFetchActor.init/0]},
208 restart: :temporary
209 }
210 ]
211 end
212 end