# .i;;;;i. # iYcviii;vXY: # .YXi .i1c. # .YC. . in7. # .vc. ...... ;1c. # i7, .. .;1; # i7, .. ... .Y1i # ,7v .6MMM@; .YX, # .7;. ..IMMMMMM1 :t7. # .;Y. ;$MMMMMM9. :tc. # vY. .. .nMMM@MMU. ;1v. # i7i ... .#MM@M@C. .....:71i # it: .... $MMM@9;.,i;;;i,;tti # :t7. ..... 0MMMWv.,iii:::,,;St. # .nC. ..... IMMMQ..,::::::,.,czX. # .ct: ....... .ZMMMI..,:::::::,,:76Y. # c2: ......,i..Y$M@t..:::::::,,..inZY # vov ......:ii..c$MBc..,,,,,,,,,,..iI9i # i9Y ......iii:..7@MA,..,,,,,,,,,....;AA: # iIS. ......:ii::..;@MI....,............;Ez. # .I9. ......:i::::...8M1..................C0z. # .z9; ......:i::::,.. .i:...................zWX. # vbv ......,i::::,,. ................. :AQY # c6Y. .,...,::::,,..:t0@@QY. ................ :8bi # :6S. ..,,...,:::,,,..EMMMMMMI. ............... .;bZ, # :6o, .,,,,..:::,,,..i#MMMMMM#v................. YW2. # .n8i ..,,,,,,,::,,,,.. tMMMMM@C:.................. .1Wn # 7Uc. .:::,,,,,::,,,,.. i1t;,..................... .UEi # 7C...::::::::::::,,,,.. .................... vSi. # ;1;...,,::::::,......... .................. Yz: # v97,......... .voC. # izAotX7777777777777777777777777777777777777777Y7n92: # .;CoIIIIIUAA666666699999ZZZZZZZZZZZZZZZZZZZZ6ov. # # !!! ATTENTION !!! # DO NOT EDIT THIS FILE! THIS FILE CONTAINS THE DEFAULT VALUES FOR THE CON- # FIGURATION! EDIT YOUR SECRET FILE (either prod.secret.exs, dev.secret.exs). # # This file is responsible for configuring your application # and its dependencies with the aid of the Mix.Config module. # # This configuration file is loaded before any dependency and # is restricted to this project. use Mix.Config # General application configuration config :pleroma, ecto_repos: [Pleroma.Repo] config :pleroma, Pleroma.Repo, types: Pleroma.PostgresTypes, telemetry_event: [Pleroma.Repo.Instrumenter], migration_lock: nil config :pleroma, Pleroma.Captcha, enabled: true, seconds_valid: 300, method: Pleroma.Captcha.Native config :pleroma, Pleroma.Captcha.Kocaptcha, endpoint: "https://captcha.kotobank.ch" # Upload configuration config :pleroma, Pleroma.Upload, uploader: Pleroma.Uploaders.Local, filters: [Pleroma.Upload.Filter.Dedupe], link_name: false, proxy_remote: false, proxy_opts: [ redirect_on_failure: false, max_body_length: 25 * 1_048_576, http: [ follow_redirect: true, pool: :upload ] ], filename_display_max_length: 30, default_description: nil config :pleroma, Pleroma.Uploaders.Local, uploads: "uploads" config :pleroma, Pleroma.Uploaders.S3, bucket: nil, streaming_enabled: true, public_endpoint: "https://s3.amazonaws.com" config :pleroma, :emoji, shortcode_globs: ["/emoji/custom/**/*.png"], pack_extensions: [".png", ".gif"], groups: [ Custom: ["/emoji/*.png", "/emoji/**/*.png"] ], default_manifest: "https://git.pleroma.social/pleroma/emoji-index/raw/master/index.json", shared_pack_cache_seconds_per_file: 60 config :pleroma, :uri_schemes, valid_schemes: [ "https", "http", "dat", "dweb", "gopher", "hyper", "ipfs", "ipns", "irc", "ircs", "magnet", "mailto", "mumble", "ssb", "xmpp" ] websocket_config = [ path: "/websocket", serializer: [ {Phoenix.Socket.V1.JSONSerializer, "~> 1.0.0"}, {Phoenix.Socket.V2.JSONSerializer, "~> 2.0.0"} ], timeout: 60_000, transport_log: false, compress: false ] # Configures the endpoint config :pleroma, Pleroma.Web.Endpoint, url: [host: "localhost"], http: [ ip: {127, 0, 0, 1}, dispatch: [ {:_, [ {"/api/fedsocket/v1", Pleroma.Web.FedSockets.IncomingHandler, []}, {"/api/v1/streaming", Pleroma.Web.MastodonAPI.WebsocketHandler, []}, {"/websocket", Phoenix.Endpoint.CowboyWebSocket, {Phoenix.Transports.WebSocket, {Pleroma.Web.Endpoint, Pleroma.Web.UserSocket, websocket_config}}}, {:_, Phoenix.Endpoint.Cowboy2Handler, {Pleroma.Web.Endpoint, []}} ]} ] ], protocol: "https", secret_key_base: "aK4Abxf29xU9TTDKre9coZPUgevcVCFQJe/5xP/7Lt4BEif6idBIbjupVbOrbKxl", signing_salt: "CqaoopA2", render_errors: [view: Pleroma.Web.ErrorView, accepts: ~w(json)], pubsub_server: Pleroma.PubSub, secure_cookie_flag: true, extra_cookie_attrs: [ "SameSite=Lax" ] config :pleroma, :fed_sockets, enabled: false, connection_duration: :timer.hours(8), rejection_duration: :timer.minutes(15), fed_socket_fetches: [ default: 12_000, interval: 3_000, lazy: false ] # Configures Elixir's Logger config :logger, :console, level: :debug, format: "\n$time $metadata[$level] $message\n", metadata: [:request_id] config :logger, :ex_syslogger, level: :debug, ident: "pleroma", format: "$metadata[$level] $message", metadata: [:request_id] config :quack, level: :warn, meta: [:all], webhook_url: "https://hooks.slack.com/services/YOUR-KEY-HERE" config :mime, :types, %{ "application/xml" => ["xml"], "application/xrd+xml" => ["xrd+xml"], "application/jrd+json" => ["jrd+json"], "application/activity+json" => ["activity+json"], "application/ld+json" => ["activity+json"] } config :tesla, adapter: Tesla.Adapter.Hackney # Configures http settings, upstream proxy etc. config :pleroma, :http, proxy_url: nil, send_user_agent: true, user_agent: :default, adapter: [] config :pleroma, :instance, name: "Pleroma", email: "example@example.com", notify_email: "noreply@example.com", description: "Pleroma: An efficient and flexible fediverse server", background_image: "/images/city.jpg", instance_thumbnail: "/instance/thumbnail.jpeg", limit: 5_000, description_limit: 5_000, chat_limit: 5_000, remote_limit: 100_000, upload_limit: 16_000_000, avatar_upload_limit: 2_000_000, background_upload_limit: 4_000_000, banner_upload_limit: 4_000_000, poll_limits: %{ max_options: 20, max_option_chars: 200, min_expiration: 0, max_expiration: 365 * 24 * 60 * 60 }, registrations_open: true, invites_enabled: false, account_activation_required: false, account_approval_required: false, federating: true, federation_incoming_replies_max_depth: 100, federation_reachability_timeout_days: 7, federation_publisher_modules: [ Pleroma.Web.ActivityPub.Publisher ], allow_relay: true, public: true, quarantined_instances: [], static_dir: "instance/static/", allowed_post_formats: [ "text/plain", "text/html", "text/markdown", "text/bbcode" ], mrf_transparency: true, mrf_transparency_exclusions: [], staff_transparency: [], autofollowed_nicknames: [], autofollowing_nicknames: [], max_pinned_statuses: 1, attachment_links: false, max_report_comment_size: 1000, safe_dm_mentions: false, healthcheck: false, remote_post_retention_days: 90, skip_thread_containment: true, limit_to_local_content: :unauthenticated, user_bio_length: 5000, user_name_length: 100, max_account_fields: 10, max_remote_account_fields: 20, account_field_name_length: 512, account_field_value_length: 2048, registration_reason_length: 500, external_user_synchronization: true, extended_nickname_format: true, cleanup_attachments: false, multi_factor_authentication: [ totp: [ # digits 6 or 8 digits: 6, period: 30 ], backup_codes: [ number: 5, length: 16 ] ], show_reactions: true config :pleroma, :welcome, direct_message: [ enabled: false, sender_nickname: nil, message: nil ], chat_message: [ enabled: false, sender_nickname: nil, message: nil ], email: [ enabled: false, sender: nil, subject: "Welcome to <%= instance_name %>", html: "Welcome to <%= instance_name %>", text: "Welcome to <%= instance_name %>" ] config :pleroma, :feed, post_title: %{ max_length: 100, omission: "..." } config :pleroma, :markup, # XXX - unfortunately, inline images must be enabled by default right now, because # of custom emoji. Issue #275 discusses defanging that somehow. allow_inline_images: true, allow_headings: false, allow_tables: false, allow_fonts: false, scrub_policy: [ Pleroma.HTML.Scrubber.Default, Pleroma.HTML.Transform.MediaProxy ] config :pleroma, :frontend_configurations, pleroma_fe: %{ alwaysShowSubjectInput: true, background: "/images/city.jpg", collapseMessageWithSubject: false, disableChat: false, greentext: false, hideFilteredStatuses: false, hideMutedPosts: false, hidePostStats: false, hideSitename: false, hideUserStats: false, loginMethod: "password", logo: "/static/logo.png", logoMargin: ".1em", logoMask: true, minimalScopesMode: false, noAttachmentLinks: false, nsfwCensorImage: "", postContentType: "text/plain", redirectRootLogin: "/main/friends", redirectRootNoLogin: "/main/all", scopeCopy: true, sidebarRight: false, showFeaturesPanel: true, showInstanceSpecificPanel: false, subjectLineBehavior: "email", theme: "pleroma-dark", webPushNotifications: false }, masto_fe: %{ showInstanceSpecificPanel: true } config :pleroma, :assets, mascots: [ pleroma_fox_tan: %{ url: "/images/pleroma-fox-tan-smol.png", mime_type: "image/png" }, pleroma_fox_tan_shy: %{ url: "/images/pleroma-fox-tan-shy.png", mime_type: "image/png" } ], default_mascot: :pleroma_fox_tan config :pleroma, :manifest, icons: [ %{ src: "/static/logo.png", type: "image/png" } ], theme_color: "#282c37", background_color: "#191b22" config :pleroma, :activitypub, unfollow_blocked: true, outgoing_blocks: true, follow_handshake_timeout: 500, note_replies_output_limit: 5, sign_object_fetches: true, authorized_fetch_mode: false config :pleroma, :streamer, workers: 3, overflow_workers: 2 config :pleroma, :user, deny_follow_blocked: true config :pleroma, :mrf_normalize_markup, scrub_policy: Pleroma.HTML.Scrubber.Default config :pleroma, :mrf_rejectnonpublic, allow_followersonly: false, allow_direct: false config :pleroma, :mrf_hellthread, delist_threshold: 10, reject_threshold: 20 config :pleroma, :mrf_simple, media_removal: [], media_nsfw: [], federated_timeline_removal: [], report_removal: [], reject: [], followers_only: [], accept: [], avatar_removal: [], banner_removal: [], reject_deletes: [] config :pleroma, :mrf_keyword, reject: [], federated_timeline_removal: [], replace: [] config :pleroma, :mrf_subchain, match_actor: %{} config :pleroma, :mrf_activity_expiration, days: 365 config :pleroma, :mrf_vocabulary, accept: [], reject: [] # threshold of 7 days config :pleroma, :mrf_object_age, threshold: 604_800, actions: [:delist, :strip_followers] config :pleroma, :rich_media, enabled: true, ignore_hosts: [], ignore_tld: ["local", "localdomain", "lan"], parsers: [ Pleroma.Web.RichMedia.Parsers.TwitterCard, Pleroma.Web.RichMedia.Parsers.OEmbed ], failure_backoff: 60_000, ttl_setters: [Pleroma.Web.RichMedia.Parser.TTL.AwsSignedUrl] config :pleroma, :media_proxy, enabled: false, invalidation: [ enabled: false, provider: Pleroma.Web.MediaProxy.Invalidation.Script ], proxy_opts: [ redirect_on_failure: false, max_body_length: 25 * 1_048_576, # Note: max_read_duration defaults to Pleroma.ReverseProxy.max_read_duration_default/1 max_read_duration: 30_000, http: [ follow_redirect: true, pool: :media ] ], whitelist: [] config :pleroma, Pleroma.Web.MediaProxy.Invalidation.Http, method: :purge, headers: [], options: [] config :pleroma, Pleroma.Web.MediaProxy.Invalidation.Script, script_path: nil # Note: media preview proxy depends on media proxy to be enabled config :pleroma, :media_preview_proxy, enabled: false, thumbnail_max_width: 600, thumbnail_max_height: 600, image_quality: 85, min_content_length: 100 * 1024 config :pleroma, :chat, enabled: true config :phoenix, :format_encoders, json: Jason config :phoenix, :json_library, Jason config :phoenix, :filter_parameters, ["password", "confirm"] config :pleroma, :gopher, enabled: false, ip: {0, 0, 0, 0}, port: 9999 config :pleroma, Pleroma.Web.Metadata, providers: [ Pleroma.Web.Metadata.Providers.OpenGraph, Pleroma.Web.Metadata.Providers.TwitterCard ], unfurl_nsfw: false config :pleroma, Pleroma.Web.Preload, providers: [ Pleroma.Web.Preload.Providers.Instance ] config :pleroma, :http_security, enabled: true, sts: false, sts_max_age: 31_536_000, ct_max_age: 2_592_000, referrer_policy: "same-origin" config :cors_plug, max_age: 86_400, methods: ["POST", "PUT", "DELETE", "GET", "PATCH", "OPTIONS"], expose: [ "Link", "X-RateLimit-Reset", "X-RateLimit-Limit", "X-RateLimit-Remaining", "X-Request-Id", "Idempotency-Key" ], credentials: true, headers: ["Authorization", "Content-Type", "Idempotency-Key"] config :pleroma, Pleroma.User, restricted_nicknames: [ ".well-known", "~", "about", "activities", "api", "auth", "check_password", "dev", "friend-requests", "inbox", "internal", "main", "media", "nodeinfo", "notice", "oauth", "objects", "ostatus_subscribe", "pleroma", "proxy", "push", "registration", "relay", "settings", "status", "tag", "user-search", "user_exists", "users", "web", "verify_credentials", "update_credentials", "relationships", "search", "confirmation_resend", "mfa" ], email_blacklist: [] config :pleroma, Oban, repo: Pleroma.Repo, log: false, queues: [ activity_expiration: 10, token_expiration: 5, backup: 1, federator_incoming: 50, federator_outgoing: 50, ingestion_queue: 50, web_push: 50, mailer: 10, transmogrifier: 20, scheduled_activities: 10, background: 5, remote_fetcher: 2, attachments_cleanup: 5, new_users_digest: 1 ], plugins: [Oban.Plugins.Pruner], crontab: [ {"0 0 * * 0", Pleroma.Workers.Cron.DigestEmailsWorker}, {"0 0 * * *", Pleroma.Workers.Cron.NewUsersDigestWorker} ] config :pleroma, :workers, retries: [ federator_incoming: 5, federator_outgoing: 5 ] config :pleroma, Pleroma.Formatter, class: false, rel: "ugc", new_window: false, truncate: false, strip_prefix: false, extra: true, validate_tld: :no_scheme config :pleroma, :ldap, enabled: System.get_env("LDAP_ENABLED") == "true", host: System.get_env("LDAP_HOST") || "localhost", port: String.to_integer(System.get_env("LDAP_PORT") || "389"), ssl: System.get_env("LDAP_SSL") == "true", sslopts: [], tls: System.get_env("LDAP_TLS") == "true", tlsopts: [], base: System.get_env("LDAP_BASE") || "dc=example,dc=com", uid: System.get_env("LDAP_UID") || "cn" config :esshd, enabled: false oauth_consumer_strategies = System.get_env("OAUTH_CONSUMER_STRATEGIES") |> to_string() |> String.split() |> Enum.map(&hd(String.split(&1, ":"))) ueberauth_providers = for strategy <- oauth_consumer_strategies do strategy_module_name = "Elixir.Ueberauth.Strategy.#{String.capitalize(strategy)}" strategy_module = String.to_atom(strategy_module_name) {String.to_atom(strategy), {strategy_module, [callback_params: ["state"]]}} end config :ueberauth, Ueberauth, base_path: "/oauth", providers: ueberauth_providers config :pleroma, :auth, enforce_oauth_admin_scope_usage: true, oauth_consumer_strategies: oauth_consumer_strategies config :pleroma, Pleroma.Emails.Mailer, adapter: Swoosh.Adapters.Sendmail, enabled: false config :pleroma, Pleroma.Emails.UserEmail, logo: nil, styling: %{ link_color: "#d8a070", background_color: "#2C3645", content_background_color: "#1B2635", header_color: "#d8a070", text_color: "#b9b9ba", text_muted_color: "#b9b9ba" } config :pleroma, Pleroma.Emails.NewUsersDigestEmail, enabled: false config :prometheus, Pleroma.Web.Endpoint.MetricsExporter, enabled: false, auth: false, ip_whitelist: [], path: "/api/pleroma/app_metrics", format: :text config :pleroma, Pleroma.ScheduledActivity, daily_user_limit: 25, total_user_limit: 300, enabled: true config :pleroma, :email_notifications, digest: %{ active: false, interval: 7, inactivity_threshold: 7 } config :pleroma, :oauth2, token_expires_in: 600, issue_new_refresh_token: true, clean_expired_tokens: false config :pleroma, :database, rum_enabled: false config :pleroma, :env, Mix.env() config :http_signatures, adapter: Pleroma.Signature config :pleroma, :rate_limit, authentication: {60_000, 15}, timeline: {500, 3}, search: [{1000, 10}, {1000, 30}], app_account_creation: {1_800_000, 25}, relations_actions: {10_000, 10}, relation_id_action: {60_000, 2}, statuses_actions: {10_000, 15}, status_id_action: {60_000, 3}, password_reset: {1_800_000, 5}, account_confirmation_resend: {8_640_000, 5}, ap_routes: {60_000, 15} config :pleroma, Pleroma.Workers.PurgeExpiredActivity, enabled: true, min_lifetime: 600 config :pleroma, Pleroma.Web.Plugs.RemoteIp, enabled: true, headers: ["x-forwarded-for"], proxies: [], reserved: [ "127.0.0.0/8", "::1/128", "fc00::/7", "10.0.0.0/8", "172.16.0.0/12", "192.168.0.0/16" ] config :pleroma, :static_fe, enabled: false # Example of frontend configuration # This example will make us serve the primary frontend from the # frontends directory within your `:pleroma, :instance, static_dir`. # e.g., instance/static/frontends/pleroma/develop/ # # With no frontend configuration, the bundled files from the `static` directory will # be used. # # config :pleroma, :frontends, # primary: %{"name" => "pleroma-fe", "ref" => "develop"}, # admin: %{"name" => "admin-fe", "ref" => "stable"}, # available: %{...} config :pleroma, :frontends, available: %{ "kenoma" => %{ "name" => "kenoma", "git" => "https://git.pleroma.social/lambadalambda/kenoma", "build_url" => "https://git.pleroma.social/lambadalambda/kenoma/-/jobs/artifacts/${ref}/download?job=build", "ref" => "master" }, "pleroma-fe" => %{ "name" => "pleroma-fe", "git" => "https://git.pleroma.social/pleroma/pleroma-fe", "build_url" => "https://git.pleroma.social/pleroma/pleroma-fe/-/jobs/artifacts/${ref}/download?job=build", "ref" => "develop" }, "fedi-fe" => %{ "name" => "fedi-fe", "git" => "https://git.pleroma.social/pleroma/fedi-fe", "build_url" => "https://git.pleroma.social/pleroma/fedi-fe/-/jobs/artifacts/${ref}/download?job=build", "ref" => "master" }, "admin-fe" => %{ "name" => "admin-fe", "git" => "https://git.pleroma.social/pleroma/admin-fe", "build_url" => "https://git.pleroma.social/pleroma/admin-fe/-/jobs/artifacts/${ref}/download?job=build", "ref" => "develop" }, "soapbox-fe" => %{ "name" => "soapbox-fe", "git" => "https://gitlab.com/soapbox-pub/soapbox-fe", "build_url" => "https://gitlab.com/soapbox-pub/soapbox-fe/-/jobs/artifacts/${ref}/download?job=build-production", "ref" => "v1.0.0", "build_dir" => "static" } } config :pleroma, :web_cache_ttl, activity_pub: nil, activity_pub_question: 30_000 config :pleroma, :modules, runtime_dir: "instance/modules" config :pleroma, configurable_from_database: false config :pleroma, Pleroma.Repo, parameters: [gin_fuzzy_search_limit: "500"], prepare: :unnamed config :pleroma, :connections_pool, reclaim_multiplier: 0.1, connection_acquisition_wait: 250, connection_acquisition_retries: 5, max_connections: 250, max_idle_time: 30_000, retry: 0, connect_timeout: 5_000 config :pleroma, :pools, federation: [ size: 50, max_waiting: 10, recv_timeout: 10_000 ], media: [ size: 50, max_waiting: 20, recv_timeout: 15_000 ], upload: [ size: 25, max_waiting: 5, recv_timeout: 15_000 ], default: [ size: 10, max_waiting: 2, recv_timeout: 5_000 ] config :pleroma, :hackney_pools, federation: [ max_connections: 50, timeout: 150_000 ], media: [ max_connections: 50, timeout: 150_000 ], upload: [ max_connections: 25, timeout: 300_000 ] config :pleroma, :majic_pool, size: 2 private_instance? = :if_instance_is_private config :pleroma, :restrict_unauthenticated, timelines: %{local: private_instance?, federated: private_instance?}, profiles: %{local: private_instance?, remote: private_instance?}, activities: %{local: private_instance?, remote: private_instance?} config :pleroma, Pleroma.Web.ApiSpec.CastAndValidate, strict: false config :pleroma, :mrf, policies: Pleroma.Web.ActivityPub.MRF.ObjectAgePolicy, transparency: true, transparency_exclusions: [] config :tzdata, :http_client, Pleroma.HTTP.Tzdata config :ex_aws, http_client: Pleroma.HTTP.ExAws config :web_push_encryption, http_client: Pleroma.HTTP.WebPush config :pleroma, :instances_favicons, enabled: false config :floki, :html_parser, Floki.HTMLParser.FastHtml config :pleroma, Pleroma.Web.Auth.Authenticator, Pleroma.Web.Auth.PleromaAuthenticator config :pleroma, Pleroma.User.Backup, purge_after_days: 30, limit_days: 7, dir: nil # Import environment specific config. This must remain at the bottom # of this file so it overrides the configuration defined above. import_config "#{Mix.env()}.exs"