Add captcha documentation to config.md
[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, types: Pleroma.PostgresTypes
12
13 config :pleroma, Pleroma.Captcha,
14 enabled: false,
15 method: Pleroma.Captcha.Kocaptcha
16
17 config :pleroma, Pleroma.Captcha.Kocaptcha, endpoint: "http://localhost:9093"
18
19 # Upload configuration
20 config :pleroma, Pleroma.Upload,
21 uploader: Pleroma.Uploaders.Local,
22 filters: [],
23 proxy_remote: false,
24 proxy_opts: []
25
26 config :pleroma, Pleroma.Uploaders.Local, uploads: "uploads"
27
28 config :pleroma, Pleroma.Uploaders.S3,
29 bucket: nil,
30 public_endpoint: "https://s3.amazonaws.com"
31
32 config :pleroma, Pleroma.Uploaders.MDII,
33 cgi: "https://mdii.sakura.ne.jp/mdii-post.cgi",
34 files: "https://mdii.sakura.ne.jp"
35
36 config :pleroma, :emoji, shortcode_globs: ["/emoji/custom/**/*.png"]
37
38 config :pleroma, :uri_schemes,
39 valid_schemes: [
40 "https",
41 "http",
42 "dat",
43 "dweb",
44 "gopher",
45 "ipfs",
46 "ipns",
47 "irc",
48 "ircs",
49 "magnet",
50 "mailto",
51 "mumble",
52 "ssb",
53 "xmpp"
54 ]
55
56 # Configures the endpoint
57 config :pleroma, Pleroma.Web.Endpoint,
58 url: [host: "localhost"],
59 protocol: "https",
60 secret_key_base: "aK4Abxf29xU9TTDKre9coZPUgevcVCFQJe/5xP/7Lt4BEif6idBIbjupVbOrbKxl",
61 signing_salt: "CqaoopA2",
62 render_errors: [view: Pleroma.Web.ErrorView, accepts: ~w(json)],
63 pubsub: [name: Pleroma.PubSub, adapter: Phoenix.PubSub.PG2],
64 secure_cookie_flag: true
65
66 # Configures Elixir's Logger
67 config :logger, :console,
68 format: "$time $metadata[$level] $message\n",
69 metadata: [:request_id]
70
71 config :mime, :types, %{
72 "application/xml" => ["xml"],
73 "application/xrd+xml" => ["xrd+xml"],
74 "application/activity+json" => ["activity+json"],
75 "application/ld+json" => ["activity+json"]
76 }
77
78 config :pleroma, :websub, Pleroma.Web.Websub
79 config :pleroma, :ostatus, Pleroma.Web.OStatus
80 config :pleroma, :httpoison, Pleroma.HTTP
81 config :tesla, adapter: Tesla.Adapter.Hackney
82
83 # Configures http settings, upstream proxy etc.
84 config :pleroma, :http, proxy_url: nil
85
86 config :pleroma, :instance,
87 name: "Pleroma",
88 email: "example@example.com",
89 description: "A Pleroma instance, an alternative fediverse server",
90 limit: 5000,
91 upload_limit: 16_000_000,
92 avatar_upload_limit: 2_000_000,
93 background_upload_limit: 4_000_000,
94 banner_upload_limit: 4_000_000,
95 registrations_open: true,
96 federating: true,
97 allow_relay: true,
98 rewrite_policy: Pleroma.Web.ActivityPub.MRF.NoOpPolicy,
99 public: true,
100 quarantined_instances: [],
101 managed_config: true,
102 allowed_post_formats: [
103 "text/plain",
104 "text/html",
105 "text/markdown"
106 ],
107 finmoji_enabled: true,
108 mrf_transparency: true
109
110 config :pleroma, :markup,
111 # XXX - unfortunately, inline images must be enabled by default right now, because
112 # of custom emoji. Issue #275 discusses defanging that somehow.
113 allow_inline_images: true,
114 allow_headings: false,
115 allow_tables: false,
116 allow_fonts: false,
117 scrub_policy: [
118 Pleroma.HTML.Transform.MediaProxy,
119 Pleroma.HTML.Scrubber.Default
120 ]
121
122 config :pleroma, :fe,
123 theme: "pleroma-dark",
124 logo: "/static/logo.png",
125 logo_mask: true,
126 logo_margin: "0.1em",
127 background: "/static/aurora_borealis.jpg",
128 redirect_root_no_login: "/main/all",
129 redirect_root_login: "/main/friends",
130 show_instance_panel: true,
131 scope_options_enabled: false,
132 formatting_options_enabled: false,
133 collapse_message_with_subject: false,
134 hide_post_stats: false,
135 hide_user_stats: false,
136 scope_copy: true,
137 subject_line_behavior: "email",
138 always_show_subject_input: true
139
140 config :pleroma, :activitypub,
141 accept_blocks: true,
142 unfollow_blocked: true,
143 outgoing_blocks: true,
144 follow_handshake_timeout: 500
145
146 config :pleroma, :user, deny_follow_blocked: true
147
148 config :pleroma, :mrf_normalize_markup, scrub_policy: Pleroma.HTML.Scrubber.Default
149
150 config :pleroma, :mrf_rejectnonpublic,
151 allow_followersonly: false,
152 allow_direct: false
153
154 config :pleroma, :mrf_simple,
155 media_removal: [],
156 media_nsfw: [],
157 federated_timeline_removal: [],
158 reject: [],
159 accept: []
160
161 config :pleroma, :media_proxy,
162 enabled: false,
163 # base_url: "https://cache.pleroma.social",
164 proxy_opts: [
165 # inline_content_types: [] | false | true,
166 # http: [:insecure]
167 ]
168
169 config :pleroma, :chat, enabled: true
170
171 config :ecto, json_library: Jason
172
173 config :phoenix, :format_encoders, json: Jason
174
175 config :pleroma, :gopher,
176 enabled: false,
177 ip: {0, 0, 0, 0},
178 port: 9999
179
180 config :pleroma, :suggestions,
181 enabled: false,
182 third_party_engine:
183 "http://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-suggestions-api.cgi?{{host}}+{{user}}",
184 timeout: 300_000,
185 limit: 23,
186 web: "https://vinayaka.distsn.org/?{{host}}+{{user}}"
187
188 config :pleroma, :http_security,
189 enabled: true,
190 sts: false,
191 sts_max_age: 31_536_000,
192 ct_max_age: 2_592_000,
193 referrer_policy: "same-origin"
194
195 config :cors_plug,
196 max_age: 86_400,
197 methods: ["POST", "PUT", "DELETE", "GET", "PATCH", "OPTIONS"],
198 expose: [
199 "Link",
200 "X-RateLimit-Reset",
201 "X-RateLimit-Limit",
202 "X-RateLimit-Remaining",
203 "X-Request-Id",
204 "Idempotency-Key"
205 ],
206 credentials: true,
207 headers: ["Authorization", "Content-Type", "Idempotency-Key"]
208
209 # Import environment specific config. This must remain at the bottom
210 # of this file so it overrides the configuration defined above.
211 import_config "#{Mix.env()}.exs"