Merge branch 'develop' of https://git.pleroma.social/pleroma/pleroma into develop
[akkoma] / config / config.exs
1 # .i;;;;i.
2 # iYcviii;vXY:
3 # .YXi .i1c.
4 # .YC. . in7.
5 # .vc. ...... ;1c.
6 # i7, .. .;1;
7 # i7, .. ... .Y1i
8 # ,7v .6MMM@; .YX,
9 # .7;. ..IMMMMMM1 :t7.
10 # .;Y. ;$MMMMMM9. :tc.
11 # vY. .. .nMMM@MMU. ;1v.
12 # i7i ... .#MM@M@C. .....:71i
13 # it: .... $MMM@9;.,i;;;i,;tti
14 # :t7. ..... 0MMMWv.,iii:::,,;St.
15 # .nC. ..... IMMMQ..,::::::,.,czX.
16 # .ct: ....... .ZMMMI..,:::::::,,:76Y.
17 # c2: ......,i..Y$M@t..:::::::,,..inZY
18 # vov ......:ii..c$MBc..,,,,,,,,,,..iI9i
19 # i9Y ......iii:..7@MA,..,,,,,,,,,....;AA:
20 # iIS. ......:ii::..;@MI....,............;Ez.
21 # .I9. ......:i::::...8M1..................C0z.
22 # .z9; ......:i::::,.. .i:...................zWX.
23 # vbv ......,i::::,,. ................. :AQY
24 # c6Y. .,...,::::,,..:t0@@QY. ................ :8bi
25 # :6S. ..,,...,:::,,,..EMMMMMMI. ............... .;bZ,
26 # :6o, .,,,,..:::,,,..i#MMMMMM#v................. YW2.
27 # .n8i ..,,,,,,,::,,,,.. tMMMMM@C:.................. .1Wn
28 # 7Uc. .:::,,,,,::,,,,.. i1t;,..................... .UEi
29 # 7C...::::::::::::,,,,.. .................... vSi.
30 # ;1;...,,::::::,......... .................. Yz:
31 # v97,......... .voC.
32 # izAotX7777777777777777777777777777777777777777Y7n92:
33 # .;CoIIIIIUAA666666699999ZZZZZZZZZZZZZZZZZZZZ6ov.
34 #
35 # !!! ATTENTION !!!
36 # DO NOT EDIT THIS FILE! THIS FILE CONTAINS THE DEFAULT VALUES FOR THE CON-
37 # FIGURATION! EDIT YOUR SECRET FILE (either prod.secret.exs, dev.secret.exs).
38 #
39 # This file is responsible for configuring your application
40 # and its dependencies with the aid of the Mix.Config module.
41 #
42 # This configuration file is loaded before any dependency and
43 # is restricted to this project.
44 use Mix.Config
45
46 # General application configuration
47 config :pleroma, ecto_repos: [Pleroma.Repo]
48
49 config :pleroma, Pleroma.Repo,
50 types: Pleroma.PostgresTypes,
51 telemetry_event: [Pleroma.Repo.Instrumenter],
52 migration_lock: nil
53
54 config :pleroma, Pleroma.Captcha,
55 enabled: true,
56 seconds_valid: 300,
57 method: Pleroma.Captcha.Native
58
59 config :pleroma, Pleroma.Captcha.Kocaptcha, endpoint: "https://captcha.kotobank.ch"
60
61 # Upload configuration
62 config :pleroma, Pleroma.Upload,
63 uploader: Pleroma.Uploaders.Local,
64 filters: [Pleroma.Upload.Filter.Dedupe],
65 link_name: false,
66 proxy_remote: false,
67 proxy_opts: [
68 redirect_on_failure: false,
69 max_body_length: 25 * 1_048_576,
70 http: [
71 follow_redirect: true,
72 pool: :upload
73 ]
74 ],
75 filename_display_max_length: 30
76
77 config :pleroma, Pleroma.Uploaders.Local, uploads: "uploads"
78
79 config :pleroma, Pleroma.Uploaders.S3,
80 bucket: nil,
81 streaming_enabled: true,
82 public_endpoint: "https://s3.amazonaws.com"
83
84 config :pleroma, :emoji,
85 shortcode_globs: ["/emoji/custom/**/*.png"],
86 pack_extensions: [".png", ".gif"],
87 groups: [
88 Custom: ["/emoji/*.png", "/emoji/**/*.png"]
89 ],
90 default_manifest: "https://git.pleroma.social/pleroma/emoji-index/raw/master/index.json",
91 shared_pack_cache_seconds_per_file: 60
92
93 config :pleroma, :uri_schemes,
94 valid_schemes: [
95 "https",
96 "http",
97 "dat",
98 "dweb",
99 "gopher",
100 "hyper",
101 "ipfs",
102 "ipns",
103 "irc",
104 "ircs",
105 "magnet",
106 "mailto",
107 "mumble",
108 "ssb",
109 "xmpp"
110 ]
111
112 websocket_config = [
113 path: "/websocket",
114 serializer: [
115 {Phoenix.Socket.V1.JSONSerializer, "~> 1.0.0"},
116 {Phoenix.Socket.V2.JSONSerializer, "~> 2.0.0"}
117 ],
118 timeout: 60_000,
119 transport_log: false,
120 compress: false
121 ]
122
123 # Configures the endpoint
124 config :pleroma, Pleroma.Web.Endpoint,
125 instrumenters: [Pleroma.Web.Endpoint.Instrumenter],
126 url: [host: "localhost"],
127 http: [
128 ip: {127, 0, 0, 1},
129 dispatch: [
130 {:_,
131 [
132 {"/api/v1/streaming", Pleroma.Web.MastodonAPI.WebsocketHandler, []},
133 {"/websocket", Phoenix.Endpoint.CowboyWebSocket,
134 {Phoenix.Transports.WebSocket,
135 {Pleroma.Web.Endpoint, Pleroma.Web.UserSocket, websocket_config}}},
136 {:_, Phoenix.Endpoint.Cowboy2Handler, {Pleroma.Web.Endpoint, []}}
137 ]}
138 ]
139 ],
140 protocol: "https",
141 secret_key_base: "aK4Abxf29xU9TTDKre9coZPUgevcVCFQJe/5xP/7Lt4BEif6idBIbjupVbOrbKxl",
142 signing_salt: "CqaoopA2",
143 render_errors: [view: Pleroma.Web.ErrorView, accepts: ~w(json)],
144 pubsub: [name: Pleroma.PubSub, adapter: Phoenix.PubSub.PG2],
145 secure_cookie_flag: true,
146 extra_cookie_attrs: [
147 "SameSite=Lax"
148 ]
149
150 # Configures Elixir's Logger
151 config :logger, :console,
152 level: :debug,
153 format: "\n$time $metadata[$level] $message\n",
154 metadata: [:request_id]
155
156 config :logger, :ex_syslogger,
157 level: :debug,
158 ident: "pleroma",
159 format: "$metadata[$level] $message",
160 metadata: [:request_id]
161
162 config :quack,
163 level: :warn,
164 meta: [:all],
165 webhook_url: "https://hooks.slack.com/services/YOUR-KEY-HERE"
166
167 config :mime, :types, %{
168 "application/xml" => ["xml"],
169 "application/xrd+xml" => ["xrd+xml"],
170 "application/jrd+json" => ["jrd+json"],
171 "application/activity+json" => ["activity+json"],
172 "application/ld+json" => ["activity+json"]
173 }
174
175 config :tesla, adapter: Tesla.Adapter.Hackney
176
177 # Configures http settings, upstream proxy etc.
178 config :pleroma, :http,
179 proxy_url: nil,
180 send_user_agent: true,
181 user_agent: :default,
182 adapter: []
183
184 config :pleroma, :instance,
185 name: "Pleroma",
186 email: "example@example.com",
187 notify_email: "noreply@example.com",
188 description: "Pleroma: An efficient and flexible fediverse server",
189 background_image: "/images/city.jpg",
190 instance_thumbnail: "/instance/thumbnail.jpeg",
191 limit: 5_000,
192 description_limit: 5_000,
193 chat_limit: 5_000,
194 remote_limit: 100_000,
195 upload_limit: 16_000_000,
196 avatar_upload_limit: 2_000_000,
197 background_upload_limit: 4_000_000,
198 banner_upload_limit: 4_000_000,
199 poll_limits: %{
200 max_options: 20,
201 max_option_chars: 200,
202 min_expiration: 0,
203 max_expiration: 365 * 24 * 60 * 60
204 },
205 registrations_open: true,
206 invites_enabled: false,
207 account_activation_required: false,
208 federating: true,
209 federation_incoming_replies_max_depth: 100,
210 federation_reachability_timeout_days: 7,
211 federation_publisher_modules: [
212 Pleroma.Web.ActivityPub.Publisher
213 ],
214 allow_relay: true,
215 public: true,
216 quarantined_instances: [],
217 managed_config: true,
218 static_dir: "instance/static/",
219 allowed_post_formats: [
220 "text/plain",
221 "text/html",
222 "text/markdown",
223 "text/bbcode"
224 ],
225 mrf_transparency: true,
226 mrf_transparency_exclusions: [],
227 staff_transparency: [],
228 autofollowed_nicknames: [],
229 max_pinned_statuses: 1,
230 attachment_links: false,
231 welcome_user_nickname: nil,
232 welcome_message: nil,
233 max_report_comment_size: 1000,
234 safe_dm_mentions: false,
235 healthcheck: false,
236 remote_post_retention_days: 90,
237 skip_thread_containment: true,
238 limit_to_local_content: :unauthenticated,
239 user_bio_length: 5000,
240 user_name_length: 100,
241 max_account_fields: 10,
242 max_remote_account_fields: 20,
243 account_field_name_length: 512,
244 account_field_value_length: 2048,
245 external_user_synchronization: true,
246 extended_nickname_format: true,
247 cleanup_attachments: false,
248 multi_factor_authentication: [
249 totp: [
250 # digits 6 or 8
251 digits: 6,
252 period: 30
253 ],
254 backup_codes: [
255 number: 5,
256 length: 16
257 ]
258 ]
259
260 config :pleroma, :feed,
261 post_title: %{
262 max_length: 100,
263 omission: "..."
264 }
265
266 config :pleroma, :markup,
267 # XXX - unfortunately, inline images must be enabled by default right now, because
268 # of custom emoji. Issue #275 discusses defanging that somehow.
269 allow_inline_images: true,
270 allow_headings: false,
271 allow_tables: false,
272 allow_fonts: false,
273 scrub_policy: [
274 Pleroma.HTML.Scrubber.Default,
275 Pleroma.HTML.Transform.MediaProxy
276 ]
277
278 config :pleroma, :frontend_configurations,
279 pleroma_fe: %{
280 alwaysShowSubjectInput: true,
281 background: "/images/city.jpg",
282 collapseMessageWithSubject: false,
283 disableChat: false,
284 greentext: false,
285 hideFilteredStatuses: false,
286 hideMutedPosts: false,
287 hidePostStats: false,
288 hideSitename: false,
289 hideUserStats: false,
290 loginMethod: "password",
291 logo: "/static/logo.png",
292 logoMargin: ".1em",
293 logoMask: true,
294 minimalScopesMode: false,
295 noAttachmentLinks: false,
296 nsfwCensorImage: "",
297 postContentType: "text/plain",
298 redirectRootLogin: "/main/friends",
299 redirectRootNoLogin: "/main/all",
300 scopeCopy: true,
301 sidebarRight: false,
302 showFeaturesPanel: true,
303 showInstanceSpecificPanel: false,
304 subjectLineBehavior: "email",
305 theme: "pleroma-dark",
306 webPushNotifications: false
307 },
308 masto_fe: %{
309 showInstanceSpecificPanel: true
310 }
311
312 config :pleroma, :assets,
313 mascots: [
314 pleroma_fox_tan: %{
315 url: "/images/pleroma-fox-tan-smol.png",
316 mime_type: "image/png"
317 },
318 pleroma_fox_tan_shy: %{
319 url: "/images/pleroma-fox-tan-shy.png",
320 mime_type: "image/png"
321 }
322 ],
323 default_mascot: :pleroma_fox_tan
324
325 config :pleroma, :manifest,
326 icons: [
327 %{
328 src: "/static/logo.png",
329 type: "image/png"
330 }
331 ],
332 theme_color: "#282c37",
333 background_color: "#191b22"
334
335 config :pleroma, :activitypub,
336 unfollow_blocked: true,
337 outgoing_blocks: true,
338 follow_handshake_timeout: 500,
339 note_replies_output_limit: 5,
340 sign_object_fetches: true,
341 authorized_fetch_mode: false
342
343 config :pleroma, :streamer,
344 workers: 3,
345 overflow_workers: 2
346
347 config :pleroma, :user, deny_follow_blocked: true
348
349 config :pleroma, :mrf_normalize_markup, scrub_policy: Pleroma.HTML.Scrubber.Default
350
351 config :pleroma, :mrf_rejectnonpublic,
352 allow_followersonly: false,
353 allow_direct: false
354
355 config :pleroma, :mrf_hellthread,
356 delist_threshold: 10,
357 reject_threshold: 20
358
359 config :pleroma, :mrf_simple,
360 media_removal: [],
361 media_nsfw: [],
362 federated_timeline_removal: [],
363 report_removal: [],
364 reject: [],
365 accept: [],
366 avatar_removal: [],
367 banner_removal: [],
368 reject_deletes: []
369
370 config :pleroma, :mrf_keyword,
371 reject: [],
372 federated_timeline_removal: [],
373 replace: []
374
375 config :pleroma, :mrf_subchain, match_actor: %{}
376
377 config :pleroma, :mrf_activity_expiration, days: 365
378
379 config :pleroma, :mrf_vocabulary,
380 accept: [],
381 reject: []
382
383 config :pleroma, :mrf_object_age,
384 threshold: 172_800,
385 actions: [:delist, :strip_followers]
386
387 config :pleroma, :rich_media,
388 enabled: true,
389 ignore_hosts: [],
390 ignore_tld: ["local", "localdomain", "lan"],
391 parsers: [
392 Pleroma.Web.RichMedia.Parsers.TwitterCard,
393 Pleroma.Web.RichMedia.Parsers.OEmbed
394 ],
395 ttl_setters: [Pleroma.Web.RichMedia.Parser.TTL.AwsSignedUrl]
396
397 config :pleroma, :media_proxy,
398 enabled: false,
399 invalidation: [
400 enabled: false,
401 provider: Pleroma.Web.MediaProxy.Invalidation.Script
402 ],
403 proxy_opts: [
404 redirect_on_failure: false,
405 max_body_length: 25 * 1_048_576,
406 http: [
407 follow_redirect: true,
408 pool: :media
409 ]
410 ],
411 whitelist: []
412
413 config :pleroma, Pleroma.Web.MediaProxy.Invalidation.Http,
414 method: :purge,
415 headers: [],
416 options: []
417
418 config :pleroma, Pleroma.Web.MediaProxy.Invalidation.Script, script_path: nil
419
420 config :pleroma, :chat, enabled: true
421
422 config :phoenix, :format_encoders, json: Jason
423
424 config :phoenix, :json_library, Jason
425
426 config :phoenix, :filter_parameters, ["password", "confirm"]
427
428 config :pleroma, :gopher,
429 enabled: false,
430 ip: {0, 0, 0, 0},
431 port: 9999
432
433 config :pleroma, Pleroma.Web.Metadata,
434 providers: [
435 Pleroma.Web.Metadata.Providers.OpenGraph,
436 Pleroma.Web.Metadata.Providers.TwitterCard,
437 Pleroma.Web.Metadata.Providers.RelMe,
438 Pleroma.Web.Metadata.Providers.Feed
439 ],
440 unfurl_nsfw: false
441
442 config :pleroma, Pleroma.Web.Preload,
443 providers: [
444 Pleroma.Web.Preload.Providers.Instance
445 ]
446
447 config :pleroma, :http_security,
448 enabled: true,
449 sts: false,
450 sts_max_age: 31_536_000,
451 ct_max_age: 2_592_000,
452 referrer_policy: "same-origin"
453
454 config :cors_plug,
455 max_age: 86_400,
456 methods: ["POST", "PUT", "DELETE", "GET", "PATCH", "OPTIONS"],
457 expose: [
458 "Link",
459 "X-RateLimit-Reset",
460 "X-RateLimit-Limit",
461 "X-RateLimit-Remaining",
462 "X-Request-Id",
463 "Idempotency-Key"
464 ],
465 credentials: true,
466 headers: ["Authorization", "Content-Type", "Idempotency-Key"]
467
468 config :pleroma, Pleroma.User,
469 restricted_nicknames: [
470 ".well-known",
471 "~",
472 "about",
473 "activities",
474 "api",
475 "auth",
476 "check_password",
477 "dev",
478 "friend-requests",
479 "inbox",
480 "internal",
481 "main",
482 "media",
483 "nodeinfo",
484 "notice",
485 "oauth",
486 "objects",
487 "ostatus_subscribe",
488 "pleroma",
489 "proxy",
490 "push",
491 "registration",
492 "relay",
493 "settings",
494 "status",
495 "tag",
496 "user-search",
497 "user_exists",
498 "users",
499 "web"
500 ]
501
502 config :pleroma, Oban,
503 repo: Pleroma.Repo,
504 verbose: false,
505 prune: {:maxlen, 1500},
506 queues: [
507 activity_expiration: 10,
508 federator_incoming: 50,
509 federator_outgoing: 50,
510 web_push: 50,
511 mailer: 10,
512 transmogrifier: 20,
513 scheduled_activities: 10,
514 background: 5,
515 remote_fetcher: 2,
516 attachments_cleanup: 5,
517 new_users_digest: 1
518 ],
519 crontab: [
520 {"0 0 * * *", Pleroma.Workers.Cron.ClearOauthTokenWorker},
521 {"0 * * * *", Pleroma.Workers.Cron.StatsWorker},
522 {"* * * * *", Pleroma.Workers.Cron.PurgeExpiredActivitiesWorker},
523 {"0 0 * * 0", Pleroma.Workers.Cron.DigestEmailsWorker},
524 {"0 0 * * *", Pleroma.Workers.Cron.NewUsersDigestWorker}
525 ]
526
527 config :pleroma, :workers,
528 retries: [
529 federator_incoming: 5,
530 federator_outgoing: 5
531 ]
532
533 config :auto_linker,
534 opts: [
535 extra: true,
536 # TODO: Set to :no_scheme when it works properly
537 validate_tld: true,
538 class: false,
539 strip_prefix: false,
540 new_window: false,
541 rel: "ugc"
542 ]
543
544 config :pleroma, :ldap,
545 enabled: System.get_env("LDAP_ENABLED") == "true",
546 host: System.get_env("LDAP_HOST") || "localhost",
547 port: String.to_integer(System.get_env("LDAP_PORT") || "389"),
548 ssl: System.get_env("LDAP_SSL") == "true",
549 sslopts: [],
550 tls: System.get_env("LDAP_TLS") == "true",
551 tlsopts: [],
552 base: System.get_env("LDAP_BASE") || "dc=example,dc=com",
553 uid: System.get_env("LDAP_UID") || "cn"
554
555 config :esshd,
556 enabled: false
557
558 oauth_consumer_strategies =
559 System.get_env("OAUTH_CONSUMER_STRATEGIES")
560 |> to_string()
561 |> String.split()
562 |> Enum.map(&hd(String.split(&1, ":")))
563
564 ueberauth_providers =
565 for strategy <- oauth_consumer_strategies do
566 strategy_module_name = "Elixir.Ueberauth.Strategy.#{String.capitalize(strategy)}"
567 strategy_module = String.to_atom(strategy_module_name)
568 {String.to_atom(strategy), {strategy_module, [callback_params: ["state"]]}}
569 end
570
571 config :ueberauth,
572 Ueberauth,
573 base_path: "/oauth",
574 providers: ueberauth_providers
575
576 config :pleroma,
577 :auth,
578 enforce_oauth_admin_scope_usage: true,
579 oauth_consumer_strategies: oauth_consumer_strategies
580
581 config :pleroma, Pleroma.Emails.Mailer, adapter: Swoosh.Adapters.Sendmail, enabled: false
582
583 config :pleroma, Pleroma.Emails.UserEmail,
584 logo: nil,
585 styling: %{
586 link_color: "#d8a070",
587 background_color: "#2C3645",
588 content_background_color: "#1B2635",
589 header_color: "#d8a070",
590 text_color: "#b9b9ba",
591 text_muted_color: "#b9b9ba"
592 }
593
594 config :pleroma, Pleroma.Emails.NewUsersDigestEmail, enabled: false
595
596 config :prometheus, Pleroma.Web.Endpoint.MetricsExporter, path: "/api/pleroma/app_metrics"
597
598 config :pleroma, Pleroma.ScheduledActivity,
599 daily_user_limit: 25,
600 total_user_limit: 300,
601 enabled: true
602
603 config :pleroma, :email_notifications,
604 digest: %{
605 active: false,
606 interval: 7,
607 inactivity_threshold: 7
608 }
609
610 config :pleroma, :oauth2,
611 token_expires_in: 600,
612 issue_new_refresh_token: true,
613 clean_expired_tokens: false
614
615 config :pleroma, :database, rum_enabled: false
616
617 config :pleroma, :env, Mix.env()
618
619 config :http_signatures,
620 adapter: Pleroma.Signature
621
622 config :pleroma, :rate_limit,
623 authentication: {60_000, 15},
624 timeline: {500, 3},
625 search: [{1000, 10}, {1000, 30}],
626 app_account_creation: {1_800_000, 25},
627 relations_actions: {10_000, 10},
628 relation_id_action: {60_000, 2},
629 statuses_actions: {10_000, 15},
630 status_id_action: {60_000, 3},
631 password_reset: {1_800_000, 5},
632 account_confirmation_resend: {8_640_000, 5},
633 ap_routes: {60_000, 15}
634
635 config :pleroma, Pleroma.ActivityExpiration, enabled: true
636
637 config :pleroma, Pleroma.Plugs.RemoteIp, enabled: true
638
639 config :pleroma, :static_fe, enabled: false
640
641 config :pleroma, :web_cache_ttl,
642 activity_pub: nil,
643 activity_pub_question: 30_000
644
645 config :pleroma, :modules, runtime_dir: "instance/modules"
646
647 config :pleroma, configurable_from_database: false
648
649 config :pleroma, Pleroma.Repo,
650 parameters: [gin_fuzzy_search_limit: "500"],
651 prepare: :unnamed
652
653 config :pleroma, :connections_pool,
654 checkin_timeout: 250,
655 max_connections: 250,
656 retry: 1,
657 retry_timeout: 1000,
658 await_up_timeout: 5_000
659
660 config :pleroma, :pools,
661 federation: [
662 size: 50,
663 max_overflow: 10,
664 timeout: 150_000
665 ],
666 media: [
667 size: 50,
668 max_overflow: 10,
669 timeout: 150_000
670 ],
671 upload: [
672 size: 25,
673 max_overflow: 5,
674 timeout: 300_000
675 ],
676 default: [
677 size: 10,
678 max_overflow: 2,
679 timeout: 10_000
680 ]
681
682 config :pleroma, :hackney_pools,
683 federation: [
684 max_connections: 50,
685 timeout: 150_000
686 ],
687 media: [
688 max_connections: 50,
689 timeout: 150_000
690 ],
691 upload: [
692 max_connections: 25,
693 timeout: 300_000
694 ]
695
696 config :pleroma, :restrict_unauthenticated,
697 timelines: %{local: false, federated: false},
698 profiles: %{local: false, remote: false},
699 activities: %{local: false, remote: false}
700
701 config :pleroma, Pleroma.Web.ApiSpec.CastAndValidate, strict: false
702
703 config :pleroma, :mrf,
704 policies: Pleroma.Web.ActivityPub.MRF.NoOpPolicy,
705 transparency: true,
706 transparency_exclusions: []
707
708 config :tzdata, :http_client, Pleroma.HTTP.Tzdata
709
710 config :ex_aws, http_client: Pleroma.HTTP.ExAws
711
712 config :pleroma, :instances_favicons, enabled: false
713
714 # Import environment specific config. This must remain at the bottom
715 # of this file so it overrides the configuration defined above.
716 import_config "#{Mix.env()}.exs"