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:
32 # izAotX7777777777777777777777777777777777777777Y7n92:
33 # .;CoIIIIIUAA666666699999ZZZZZZZZZZZZZZZZZZZZ6ov.
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).
39 # This file is responsible for configuring your application
40 # and its dependencies with the aid of the Mix.Config module.
42 # This configuration file is loaded before any dependency and
43 # is restricted to this project.
46 # General application configuration
47 config :pleroma, ecto_repos: [Pleroma.Repo]
49 config :pleroma, Pleroma.Repo,
50 types: Pleroma.PostgresTypes,
51 telemetry_event: [Pleroma.Repo.Instrumenter],
55 with digest_config <- Application.get_env(:pleroma, :email_notifications)[:digest],
56 true <- digest_config[:active] do
57 [{digest_config[:schedule], {Pleroma.Daemons.DigestEmailDaemon, :perform, []}}]
64 [{"0 */6 * * * *", {Pleroma.Web.Websub, :refresh_subscriptions, []}}]
66 config :pleroma, Pleroma.Scheduler,
72 config :pleroma, Pleroma.Captcha,
75 method: Pleroma.Captcha.Kocaptcha
77 config :pleroma, :hackney_pools,
91 config :pleroma, Pleroma.Captcha.Kocaptcha, endpoint: "https://captcha.kotobank.ch"
93 # Upload configuration
94 config :pleroma, Pleroma.Upload,
95 uploader: Pleroma.Uploaders.Local,
96 filters: [Pleroma.Upload.Filter.Dedupe],
100 redirect_on_failure: false,
101 max_body_length: 25 * 1_048_576,
103 follow_redirect: true,
108 config :pleroma, Pleroma.Uploaders.Local, uploads: "uploads"
110 config :pleroma, Pleroma.Uploaders.S3,
112 streaming_enabled: true,
113 public_endpoint: "https://s3.amazonaws.com"
115 config :pleroma, Pleroma.Uploaders.MDII,
116 cgi: "https://mdii.sakura.ne.jp/mdii-post.cgi",
117 files: "https://mdii.sakura.ne.jp"
119 config :pleroma, :emoji,
120 shortcode_globs: ["/emoji/custom/**/*.png"],
121 pack_extensions: [".png", ".gif"],
123 # Put groups that have higher priority than defaults here. Example in `docs/config/custom_emoji.md`
124 Custom: ["/emoji/*.png", "/emoji/**/*.png"]
126 default_manifest: "https://git.pleroma.social/pleroma/emoji-index/raw/master/index.json",
127 shared_pack_cache_seconds_per_file: 60
129 config :pleroma, :uri_schemes,
150 {Phoenix.Socket.V1.JSONSerializer, "~> 1.0.0"},
151 {Phoenix.Socket.V2.JSONSerializer, "~> 2.0.0"}
154 transport_log: false,
158 # Configures the endpoint
159 config :pleroma, Pleroma.Web.Endpoint,
160 instrumenters: [Pleroma.Web.Endpoint.Instrumenter],
161 url: [host: "localhost"],
167 {"/api/v1/streaming", Pleroma.Web.MastodonAPI.WebsocketHandler, []},
168 {"/websocket", Phoenix.Endpoint.CowboyWebSocket,
169 {Phoenix.Transports.WebSocket,
170 {Pleroma.Web.Endpoint, Pleroma.Web.UserSocket, websocket_config}}},
171 {:_, Phoenix.Endpoint.Cowboy2Handler, {Pleroma.Web.Endpoint, []}}
176 secret_key_base: "aK4Abxf29xU9TTDKre9coZPUgevcVCFQJe/5xP/7Lt4BEif6idBIbjupVbOrbKxl",
177 signing_salt: "CqaoopA2",
178 render_errors: [view: Pleroma.Web.ErrorView, accepts: ~w(json)],
179 pubsub: [name: Pleroma.PubSub, adapter: Phoenix.PubSub.PG2],
180 secure_cookie_flag: true,
181 extra_cookie_attrs: [
185 # Configures Elixir's Logger
186 config :logger, :console,
187 format: "$time $metadata[$level] $message\n",
188 metadata: [:request_id]
190 config :logger, :ex_syslogger,
193 format: "$metadata[$level] $message",
194 metadata: [:request_id]
199 webhook_url: "https://hooks.slack.com/services/YOUR-KEY-HERE"
201 config :mime, :types, %{
202 "application/xml" => ["xml"],
203 "application/xrd+xml" => ["xrd+xml"],
204 "application/jrd+json" => ["jrd+json"],
205 "application/activity+json" => ["activity+json"],
206 "application/ld+json" => ["activity+json"]
209 config :tesla, adapter: Tesla.Adapter.Hackney
211 # Configures http settings, upstream proxy etc.
212 config :pleroma, :http,
214 send_user_agent: true,
217 # Workaround for remote server certificate chain issues
218 partial_chain: &:hackney_connect.partial_chain/1,
219 # We don't support TLS v1.3 yet
220 versions: [:tlsv1, :"tlsv1.1", :"tlsv1.2"]
224 config :pleroma, :instance,
226 email: "example@example.com",
227 notify_email: "noreply@example.com",
228 description: "A Pleroma instance, an alternative fediverse server",
230 remote_limit: 100_000,
231 upload_limit: 16_000_000,
232 avatar_upload_limit: 2_000_000,
233 background_upload_limit: 4_000_000,
234 banner_upload_limit: 4_000_000,
237 max_option_chars: 200,
239 max_expiration: 365 * 24 * 60 * 60
241 registrations_open: true,
243 federation_incoming_replies_max_depth: 100,
244 federation_reachability_timeout_days: 7,
245 federation_publisher_modules: [
246 Pleroma.Web.ActivityPub.Publisher,
251 rewrite_policy: Pleroma.Web.ActivityPub.MRF.NoOpPolicy,
253 quarantined_instances: [],
254 managed_config: true,
255 static_dir: "instance/static/",
256 allowed_post_formats: [
262 mrf_transparency: true,
263 mrf_transparency_exclusions: [],
264 autofollowed_nicknames: [],
265 max_pinned_statuses: 1,
266 no_attachment_links: false,
267 welcome_user_nickname: nil,
268 welcome_message: nil,
269 max_report_comment_size: 1000,
270 safe_dm_mentions: false,
272 remote_post_retention_days: 90,
273 skip_thread_containment: true,
274 limit_to_local_content: :unauthenticated,
275 dynamic_configuration: false,
276 user_bio_length: 5000,
277 user_name_length: 100,
278 max_account_fields: 10,
279 max_remote_account_fields: 20,
280 account_field_name_length: 512,
281 account_field_value_length: 2048,
282 external_user_synchronization: true,
283 extended_nickname_format: false
285 config :pleroma, :markup,
286 # XXX - unfortunately, inline images must be enabled by default right now, because
287 # of custom emoji. Issue #275 discusses defanging that somehow.
288 allow_inline_images: true,
289 allow_headings: false,
293 Pleroma.HTML.Transform.MediaProxy,
294 Pleroma.HTML.Scrubber.Default
297 config :pleroma, :frontend_configurations,
299 theme: "pleroma-dark",
300 logo: "/static/logo.png",
301 background: "/images/city.jpg",
302 redirectRootNoLogin: "/main/all",
303 redirectRootLogin: "/main/friends",
304 showInstanceSpecificPanel: true,
305 scopeOptionsEnabled: false,
306 formattingOptionsEnabled: false,
307 collapseMessageWithSubject: false,
308 hidePostStats: false,
309 hideUserStats: false,
311 subjectLineBehavior: "email",
312 alwaysShowSubjectInput: true
315 showInstanceSpecificPanel: true
318 config :pleroma, :assets,
321 url: "/images/pleroma-fox-tan-smol.png",
322 mime_type: "image/png"
324 pleroma_fox_tan_shy: %{
325 url: "/images/pleroma-fox-tan-shy.png",
326 mime_type: "image/png"
329 default_mascot: :pleroma_fox_tan
331 config :pleroma, :activitypub,
332 unfollow_blocked: true,
333 outgoing_blocks: true,
334 follow_handshake_timeout: 500,
335 sign_object_fetches: true
337 config :pleroma, :streamer,
341 config :pleroma, :user, deny_follow_blocked: true
343 config :pleroma, :mrf_normalize_markup, scrub_policy: Pleroma.HTML.Scrubber.Default
345 config :pleroma, :mrf_rejectnonpublic,
346 allow_followersonly: false,
349 config :pleroma, :mrf_hellthread,
350 delist_threshold: 10,
353 config :pleroma, :mrf_simple,
356 federated_timeline_removal: [],
363 config :pleroma, :mrf_keyword,
365 federated_timeline_removal: [],
368 config :pleroma, :mrf_subchain, match_actor: %{}
370 config :pleroma, :mrf_vocabulary,
374 config :pleroma, :rich_media,
377 ignore_tld: ["local", "localdomain", "lan"],
379 Pleroma.Web.RichMedia.Parsers.TwitterCard,
380 Pleroma.Web.RichMedia.Parsers.OGP,
381 Pleroma.Web.RichMedia.Parsers.OEmbed
383 ttl_setters: [Pleroma.Web.RichMedia.Parser.TTL.AwsSignedUrl]
385 config :pleroma, :media_proxy,
388 redirect_on_failure: false,
389 max_body_length: 25 * 1_048_576,
391 follow_redirect: true,
397 config :pleroma, :chat, enabled: true
399 config :phoenix, :format_encoders, json: Jason
401 config :phoenix, :json_library, Jason
403 config :pleroma, :gopher,
408 config :pleroma, Pleroma.Web.Metadata,
410 Pleroma.Web.Metadata.Providers.OpenGraph,
411 Pleroma.Web.Metadata.Providers.TwitterCard,
412 Pleroma.Web.Metadata.Providers.RelMe,
413 Pleroma.Web.Metadata.Providers.Feed
417 config :pleroma, :suggestions,
420 "http://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-suggestions-api.cgi?{{host}}+{{user}}",
423 web: "https://vinayaka.distsn.org"
425 config :pleroma, :http_security,
428 sts_max_age: 31_536_000,
429 ct_max_age: 2_592_000,
430 referrer_policy: "same-origin"
434 methods: ["POST", "PUT", "DELETE", "GET", "PATCH", "OPTIONS"],
439 "X-RateLimit-Remaining",
444 headers: ["Authorization", "Content-Type", "Idempotency-Key"]
446 config :pleroma, Pleroma.User,
447 restricted_nicknames: [
480 config :pleroma, Oban,
483 prune: {:maxlen, 1500},
485 activity_expiration: 10,
486 federator_incoming: 50,
487 federator_outgoing: 50,
491 scheduled_activities: 10,
495 config :pleroma, :workers,
497 federator_incoming: 5,
498 federator_outgoing: 5
501 config :pleroma, :fetch_initial_posts,
509 # TODO: Set to :no_scheme when it works properly
517 config :pleroma, :ldap,
518 enabled: System.get_env("LDAP_ENABLED") == "true",
519 host: System.get_env("LDAP_HOST") || "localhost",
520 port: String.to_integer(System.get_env("LDAP_PORT") || "389"),
521 ssl: System.get_env("LDAP_SSL") == "true",
523 tls: System.get_env("LDAP_TLS") == "true",
525 base: System.get_env("LDAP_BASE") || "dc=example,dc=com",
526 uid: System.get_env("LDAP_UID") || "cn"
531 oauth_consumer_strategies =
532 System.get_env("OAUTH_CONSUMER_STRATEGIES")
535 |> Enum.map(&hd(String.split(&1, ":")))
537 ueberauth_providers =
538 for strategy <- oauth_consumer_strategies do
539 strategy_module_name = "Elixir.Ueberauth.Strategy.#{String.capitalize(strategy)}"
540 strategy_module = String.to_atom(strategy_module_name)
541 {String.to_atom(strategy), {strategy_module, [callback_params: ["state"]]}}
547 providers: ueberauth_providers
549 config :pleroma, :auth, oauth_consumer_strategies: oauth_consumer_strategies
551 config :pleroma, Pleroma.Emails.Mailer, adapter: Swoosh.Adapters.Sendmail, enabled: false
553 config :pleroma, Pleroma.Emails.UserEmail,
556 link_color: "#d8a070",
557 background_color: "#2C3645",
558 content_background_color: "#1B2635",
559 header_color: "#d8a070",
560 text_color: "#b9b9ba",
561 text_muted_color: "#b9b9ba"
564 config :prometheus, Pleroma.Web.Endpoint.MetricsExporter, path: "/api/pleroma/app_metrics"
566 config :pleroma, Pleroma.ScheduledActivity,
567 daily_user_limit: 25,
568 total_user_limit: 300,
571 config :pleroma, :email_notifications,
574 schedule: "0 0 * * 0",
576 inactivity_threshold: 7
579 config :pleroma, :oauth2,
580 token_expires_in: 600,
581 issue_new_refresh_token: true,
582 clean_expired_tokens: false,
583 clean_expired_tokens_interval: 86_400_000
585 config :pleroma, :database, rum_enabled: false
587 config :pleroma, :env, Mix.env()
589 config :http_signatures,
590 adapter: Pleroma.Signature
592 config :pleroma, :rate_limit, authentication: {60_000, 15}
594 config :pleroma, Pleroma.ActivityExpiration, enabled: true
596 config :pleroma, Pleroma.Plugs.RemoteIp, enabled: false
598 config :pleroma, :web_cache_ttl,
600 activity_pub_question: 30_000
602 # Import environment specific config. This must remain at the bottom
603 # of this file so it overrides the configuration defined above.
604 import_config "#{Mix.env()}.exs"