fallback to the old behaviour
[akkoma] / config / config.exs
1 # This file is responsible for configuring your application
2 # and its dependencies with the aid of the Mix.Config module.
3 #
4 # This configuration file is loaded before any dependency and
5 # is restricted to this project.
6 use Mix.Config
7
8 # General application configuration
9 config :pleroma, ecto_repos: [Pleroma.Repo]
10
11 config :pleroma, Pleroma.Repo,
12 types: Pleroma.PostgresTypes,
13 telemetry_event: [Pleroma.Repo.Instrumenter]
14
15 config :pleroma, Pleroma.Captcha,
16 enabled: false,
17 seconds_valid: 60,
18 method: Pleroma.Captcha.Kocaptcha
19
20 config :pleroma, :hackney_pools,
21 federation: [
22 max_connections: 50,
23 timeout: 150_000
24 ],
25 media: [
26 max_connections: 50,
27 timeout: 150_000
28 ],
29 upload: [
30 max_connections: 25,
31 timeout: 300_000
32 ]
33
34 config :pleroma, Pleroma.Captcha.Kocaptcha, endpoint: "https://captcha.kotobank.ch"
35
36 # Upload configuration
37 config :pleroma, Pleroma.Upload,
38 uploader: Pleroma.Uploaders.Local,
39 filters: [Pleroma.Upload.Filter.Dedupe],
40 link_name: true,
41 proxy_remote: false,
42 proxy_opts: [
43 redirect_on_failure: false,
44 max_body_length: 25 * 1_048_576,
45 http: [
46 follow_redirect: true,
47 pool: :upload
48 ]
49 ]
50
51 config :pleroma, Pleroma.Uploaders.Local, uploads: "uploads"
52
53 config :pleroma, Pleroma.Uploaders.S3,
54 bucket: nil,
55 public_endpoint: "https://s3.amazonaws.com"
56
57 config :pleroma, Pleroma.Uploaders.MDII,
58 cgi: "https://mdii.sakura.ne.jp/mdii-post.cgi",
59 files: "https://mdii.sakura.ne.jp"
60
61 config :pleroma, :emoji,
62 shortcode_globs: ["/emoji/custom/**/*.png"],
63 groups: [
64 # Put groups that have higher priority than defaults here. Example in `docs/config/custom_emoji.md`
65 Finmoji: "/finmoji/128px/*-128.png",
66 Custom: ["/emoji/*.png", "/emoji/custom/*.png"]
67 ]
68
69 config :pleroma, :uri_schemes,
70 valid_schemes: [
71 "https",
72 "http",
73 "dat",
74 "dweb",
75 "gopher",
76 "ipfs",
77 "ipns",
78 "irc",
79 "ircs",
80 "magnet",
81 "mailto",
82 "mumble",
83 "ssb",
84 "xmpp"
85 ]
86
87 websocket_config = [
88 path: "/websocket",
89 serializer: [
90 {Phoenix.Socket.V1.JSONSerializer, "~> 1.0.0"},
91 {Phoenix.Socket.V2.JSONSerializer, "~> 2.0.0"}
92 ],
93 timeout: 60_000,
94 transport_log: false,
95 compress: false
96 ]
97
98 # Configures the endpoint
99 config :pleroma, Pleroma.Web.Endpoint,
100 instrumenters: [Pleroma.Web.Endpoint.Instrumenter],
101 url: [host: "localhost"],
102 http: [
103 dispatch: [
104 {:_,
105 [
106 {"/api/v1/streaming", Pleroma.Web.MastodonAPI.WebsocketHandler, []},
107 {"/websocket", Phoenix.Endpoint.CowboyWebSocket,
108 {Phoenix.Transports.WebSocket,
109 {Pleroma.Web.Endpoint, Pleroma.Web.UserSocket, websocket_config}}},
110 {:_, Phoenix.Endpoint.Cowboy2Handler, {Pleroma.Web.Endpoint, []}}
111 ]}
112 ]
113 ],
114 protocol: "https",
115 secret_key_base: "aK4Abxf29xU9TTDKre9coZPUgevcVCFQJe/5xP/7Lt4BEif6idBIbjupVbOrbKxl",
116 signing_salt: "CqaoopA2",
117 render_errors: [view: Pleroma.Web.ErrorView, accepts: ~w(json)],
118 pubsub: [name: Pleroma.PubSub, adapter: Phoenix.PubSub.PG2],
119 secure_cookie_flag: true
120
121 # Configures Elixir's Logger
122 config :logger, :console,
123 format: "$time $metadata[$level] $message\n",
124 metadata: [:request_id]
125
126 config :logger, :ex_syslogger,
127 level: :debug,
128 ident: "Pleroma",
129 format: "$metadata[$level] $message",
130 metadata: [:request_id]
131
132 config :quack,
133 level: :warn,
134 meta: [:all],
135 webhook_url: "https://hooks.slack.com/services/YOUR-KEY-HERE"
136
137 config :mime, :types, %{
138 "application/xml" => ["xml"],
139 "application/xrd+xml" => ["xrd+xml"],
140 "application/jrd+json" => ["jrd+json"],
141 "application/activity+json" => ["activity+json"],
142 "application/ld+json" => ["activity+json"]
143 }
144
145 config :pleroma, :websub, Pleroma.Web.Websub
146 config :pleroma, :ostatus, Pleroma.Web.OStatus
147 config :pleroma, :httpoison, Pleroma.HTTP
148 config :tesla, adapter: Tesla.Adapter.Hackney
149
150 # Configures http settings, upstream proxy etc.
151 config :pleroma, :http,
152 proxy_url: nil,
153 adapter: [
154 ssl_options: [
155 # We don't support TLS v1.3 yet
156 versions: [:tlsv1, :"tlsv1.1", :"tlsv1.2"]
157 ]
158 ]
159
160 config :pleroma, :instance,
161 name: "Pleroma",
162 email: "example@example.com",
163 notify_email: "noreply@example.com",
164 description: "A Pleroma instance, an alternative fediverse server",
165 limit: 5_000,
166 remote_limit: 100_000,
167 upload_limit: 16_000_000,
168 avatar_upload_limit: 2_000_000,
169 background_upload_limit: 4_000_000,
170 banner_upload_limit: 4_000_000,
171 registrations_open: true,
172 federating: true,
173 federation_reachability_timeout_days: 7,
174 allow_relay: true,
175 rewrite_policy: Pleroma.Web.ActivityPub.MRF.NoOpPolicy,
176 public: true,
177 quarantined_instances: [],
178 managed_config: true,
179 static_dir: "instance/static/",
180 allowed_post_formats: [
181 "text/plain",
182 "text/html",
183 "text/markdown"
184 ],
185 finmoji_enabled: true,
186 mrf_transparency: true,
187 autofollowed_nicknames: [],
188 max_pinned_statuses: 1,
189 no_attachment_links: false,
190 welcome_user_nickname: nil,
191 welcome_message: nil,
192 max_report_comment_size: 1000,
193 safe_dm_mentions: false
194
195 config :pleroma, :markup,
196 # XXX - unfortunately, inline images must be enabled by default right now, because
197 # of custom emoji. Issue #275 discusses defanging that somehow.
198 allow_inline_images: true,
199 allow_headings: false,
200 allow_tables: false,
201 allow_fonts: false,
202 scrub_policy: [
203 Pleroma.HTML.Transform.MediaProxy,
204 Pleroma.HTML.Scrubber.Default
205 ]
206
207 # Deprecated, will be gone in 1.0
208 config :pleroma, :fe,
209 theme: "pleroma-dark",
210 logo: "/static/logo.png",
211 logo_mask: true,
212 logo_margin: "0.1em",
213 background: "/static/aurora_borealis.jpg",
214 redirect_root_no_login: "/main/all",
215 redirect_root_login: "/main/friends",
216 show_instance_panel: true,
217 scope_options_enabled: false,
218 formatting_options_enabled: false,
219 collapse_message_with_subject: false,
220 hide_post_stats: false,
221 hide_user_stats: false,
222 scope_copy: true,
223 subject_line_behavior: "email",
224 always_show_subject_input: true
225
226 config :pleroma, :frontend_configurations,
227 pleroma_fe: %{
228 theme: "pleroma-dark",
229 logo: "/static/logo.png",
230 background: "/images/city.jpg",
231 redirectRootNoLogin: "/main/all",
232 redirectRootLogin: "/main/friends",
233 showInstanceSpecificPanel: true,
234 scopeOptionsEnabled: false,
235 formattingOptionsEnabled: false,
236 collapseMessageWithSubject: false,
237 hidePostStats: false,
238 hideUserStats: false,
239 scopeCopy: true,
240 subjectLineBehavior: "email",
241 alwaysShowSubjectInput: true
242 },
243 masto_fe: %{
244 showInstanceSpecificPanel: true
245 }
246
247 config :pleroma, :activitypub,
248 accept_blocks: true,
249 unfollow_blocked: true,
250 outgoing_blocks: true,
251 follow_handshake_timeout: 500
252
253 config :pleroma, :user, deny_follow_blocked: true
254
255 config :pleroma, :mrf_normalize_markup, scrub_policy: Pleroma.HTML.Scrubber.Default
256
257 config :pleroma, :mrf_rejectnonpublic,
258 allow_followersonly: false,
259 allow_direct: false
260
261 config :pleroma, :mrf_hellthread,
262 delist_threshold: 10,
263 reject_threshold: 20
264
265 config :pleroma, :mrf_simple,
266 media_removal: [],
267 media_nsfw: [],
268 federated_timeline_removal: [],
269 reject: [],
270 accept: []
271
272 config :pleroma, :mrf_keyword,
273 reject: [],
274 federated_timeline_removal: [],
275 replace: []
276
277 config :pleroma, :rich_media, enabled: true
278
279 config :pleroma, :media_proxy,
280 enabled: false,
281 proxy_opts: [
282 redirect_on_failure: false,
283 max_body_length: 25 * 1_048_576,
284 http: [
285 follow_redirect: true,
286 pool: :media
287 ]
288 ]
289
290 config :pleroma, :chat, enabled: true
291
292 config :phoenix, :format_encoders, json: Jason
293
294 config :pleroma, :gopher,
295 enabled: false,
296 ip: {0, 0, 0, 0},
297 port: 9999
298
299 config :pleroma, Pleroma.Web.Metadata, providers: [], unfurl_nsfw: false
300
301 config :pleroma, :suggestions,
302 enabled: false,
303 third_party_engine:
304 "http://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-suggestions-api.cgi?{{host}}+{{user}}",
305 timeout: 300_000,
306 limit: 23,
307 web: "https://vinayaka.distsn.org/?{{host}}+{{user}}"
308
309 config :pleroma, :http_security,
310 enabled: true,
311 sts: false,
312 sts_max_age: 31_536_000,
313 ct_max_age: 2_592_000,
314 referrer_policy: "same-origin"
315
316 config :cors_plug,
317 max_age: 86_400,
318 methods: ["POST", "PUT", "DELETE", "GET", "PATCH", "OPTIONS"],
319 expose: [
320 "Link",
321 "X-RateLimit-Reset",
322 "X-RateLimit-Limit",
323 "X-RateLimit-Remaining",
324 "X-Request-Id",
325 "Idempotency-Key"
326 ],
327 credentials: true,
328 headers: ["Authorization", "Content-Type", "Idempotency-Key"]
329
330 config :pleroma, Pleroma.User,
331 restricted_nicknames: [
332 ".well-known",
333 "~",
334 "about",
335 "activities",
336 "api",
337 "auth",
338 "dev",
339 "friend-requests",
340 "inbox",
341 "internal",
342 "main",
343 "media",
344 "nodeinfo",
345 "notice",
346 "oauth",
347 "objects",
348 "ostatus_subscribe",
349 "pleroma",
350 "proxy",
351 "push",
352 "registration",
353 "relay",
354 "settings",
355 "status",
356 "tag",
357 "user-search",
358 "users",
359 "web"
360 ]
361
362 config :pleroma, Pleroma.Web.Federator.RetryQueue,
363 enabled: false,
364 max_jobs: 20,
365 initial_timeout: 30,
366 max_retries: 5
367
368 config :pleroma_job_queue, :queues,
369 federator_incoming: 50,
370 federator_outgoing: 50,
371 web_push: 50,
372 mailer: 10,
373 transmogrifier: 20,
374 scheduled_activities: 10
375
376 config :pleroma, :fetch_initial_posts,
377 enabled: false,
378 pages: 5
379
380 config :auto_linker,
381 opts: [
382 scheme: true,
383 extra: true,
384 class: false,
385 strip_prefix: false,
386 new_window: false,
387 rel: false
388 ]
389
390 config :pleroma, :ldap,
391 enabled: System.get_env("LDAP_ENABLED") == "true",
392 host: System.get_env("LDAP_HOST") || "localhost",
393 port: String.to_integer(System.get_env("LDAP_PORT") || "389"),
394 ssl: System.get_env("LDAP_SSL") == "true",
395 sslopts: [],
396 tls: System.get_env("LDAP_TLS") == "true",
397 tlsopts: [],
398 base: System.get_env("LDAP_BASE") || "dc=example,dc=com",
399 uid: System.get_env("LDAP_UID") || "cn"
400
401 oauth_consumer_strategies = String.split(System.get_env("OAUTH_CONSUMER_STRATEGIES") || "")
402
403 ueberauth_providers =
404 for strategy <- oauth_consumer_strategies do
405 strategy_module_name = "Elixir.Ueberauth.Strategy.#{String.capitalize(strategy)}"
406 strategy_module = String.to_atom(strategy_module_name)
407 {String.to_atom(strategy), {strategy_module, [callback_params: ["state"]]}}
408 end
409
410 config :ueberauth,
411 Ueberauth,
412 base_path: "/oauth",
413 providers: ueberauth_providers
414
415 config :pleroma, :auth, oauth_consumer_strategies: oauth_consumer_strategies
416
417 config :pleroma, Pleroma.Mailer, adapter: Swoosh.Adapters.Sendmail
418
419 config :prometheus, Pleroma.Web.Endpoint.MetricsExporter, path: "/api/pleroma/app_metrics"
420
421 config :pleroma, Pleroma.ScheduledActivity,
422 daily_user_limit: 25,
423 total_user_limit: 300,
424 enabled: true
425
426 # Import environment specific config. This must remain at the bottom
427 # of this file so it overrides the configuration defined above.
428 import_config "#{Mix.env()}.exs"