rev |
line source |
bsw@730
|
1 -- ========================================================================
|
bsw@813
|
2 -- MANDATORY (MUST BE CAREFULLY CHECKED AND PROPERLY SET!)
|
bsw@730
|
3 -- ========================================================================
|
bsw@525
|
4
|
bsw@813
|
5 -- Name of this instance, defaults to name of config file
|
bsw@813
|
6 -- ------------------------------------------------------------------------
|
bsw@813
|
7 config.instance_name = "Instance name"
|
bsw@813
|
8
|
bsw@813
|
9
|
bsw@731
|
10 -- Information about service provider (HTML)
|
bsw@730
|
11 -- ------------------------------------------------------------------------
|
bsw/jbe@0
|
12 config.app_service_provider = "Snake Oil<br/>10000 Berlin<br/>Germany"
|
bsw/jbe@0
|
13
|
bsw@813
|
14
|
bsw@1045
|
15 -- A HTML formatted text the user has to accept while registering
|
bsw@730
|
16 -- ------------------------------------------------------------------------
|
bsw@1045
|
17 config.use_terms = "<h1>Terms of Use</h1><p>Insert terms here</p>"
|
bsw@88
|
18
|
bsw@813
|
19
|
bsw@729
|
20 -- Checkbox(es) the user has to accept while registering
|
bsw@730
|
21 -- ------------------------------------------------------------------------
|
bsw@1222
|
22 --[[
|
bsw@79
|
23 config.use_terms_checkboxes = {
|
bsw@79
|
24 {
|
jbe@232
|
25 name = "terms_of_use_v1",
|
jbe@232
|
26 html = "I accept the terms of use.",
|
jbe@232
|
27 not_accepted_error = "You have to accept the terms of use to be able to register."
|
bsw@734
|
28 },
|
bsw@1222
|
29 {
|
bsw@1222
|
30 name = "extra_terms_of_use_v1",
|
bsw@1222
|
31 html = "I accept the extra terms of use.",
|
bsw@1222
|
32 not_accepted_error = "You have to accept the extra terms of use to be able to register."
|
bsw@1222
|
33 }
|
bsw@79
|
34 }
|
bsw@1222
|
35 --]]
|
bsw@735
|
36
|
bsw@813
|
37 -- Absolute base url of application
|
bsw@813
|
38 -- ------------------------------------------------------------------------
|
bsw@813
|
39 config.absolute_base_url = "http://example.com/"
|
bsw@1222
|
40 config.localhost = false
|
bsw@813
|
41
|
bsw@813
|
42
|
bsw@813
|
43 -- Connection information for the LiquidFeedback database
|
bsw@813
|
44 -- ------------------------------------------------------------------------
|
bsw@813
|
45 config.database = { engine='postgresql', dbname='liquid_feedback' }
|
bsw@813
|
46
|
bsw@813
|
47
|
bsw@735
|
48 -- Location of the rocketwiki binaries
|
bsw@735
|
49 -- ------------------------------------------------------------------------
|
bsw@1045
|
50 config.enforce_formatting_engine = "markdown2"
|
bsw@1045
|
51 config.formatting_engines = {
|
bsw@1045
|
52 { id = "markdown2",
|
bsw@1045
|
53 name = "python-markdown2",
|
bsw@1045
|
54 executable = "markdown2",
|
bsw@1052
|
55 args = {'-s', 'escape', '-x', 'nofollow,wiki-tables'},
|
bsw@1045
|
56 remove_images = true
|
bsw@1045
|
57 },
|
bsw@1170
|
58 -- { id = "markdown_py",
|
bsw@1170
|
59 -- name = "Python Markdown",
|
bsw@1170
|
60 -- executable = "markdown_py",
|
bsw@1170
|
61 -- args = {'-s', 'escape', '-x', 'extra', '-x', 'nl2br', '-x', 'sane_lists'},
|
bsw@1170
|
62 -- remove_images = true
|
bsw@1170
|
63 -- },
|
bsw@1170
|
64 -- { id = "rocketwiki",
|
bsw@1170
|
65 -- name = "RocketWiki",
|
bsw@1170
|
66 -- executable = "/opt/rocketwiki-lqfb/rocketwiki-lqfb"
|
bsw@1170
|
67 -- },
|
bsw@1170
|
68 -- { id = "compat",
|
bsw@1170
|
69 -- name = "Traditional WIKI syntax",
|
bsw@1170
|
70 -- executable = "/opt/rocketwiki-lqfb/rocketwiki-lqfb-compat"
|
bsw@1170
|
71 -- },
|
bsw@735
|
72 }
|
bsw@79
|
73
|
bsw/jbe@6
|
74
|
bsw@813
|
75 -- Public access level
|
bsw@734
|
76 -- ------------------------------------------------------------------------
|
bsw@813
|
77 -- Available options:
|
bsw@813
|
78 -- "none"
|
bsw@813
|
79 -- -> Closed user group, no public access at all
|
bsw@813
|
80 -- (except login/registration/password reset)
|
bsw@813
|
81 -- "anonymous"
|
bsw@813
|
82 -- -> Shows only initiative/suggestions texts and aggregated
|
bsw@813
|
83 -- supporter/voter counts
|
bsw@813
|
84 -- "authors_pseudonymous"
|
bsw@813
|
85 -- -> Like anonymous, but shows screen names of authors
|
bsw@813
|
86 -- "all_pseudonymous"
|
bsw@813
|
87 -- -> Show everything a member can see, except profile pages
|
bsw@813
|
88 -- "everything"
|
bsw@813
|
89 -- -> Show everything a member can see, including profile pages
|
bsw@813
|
90 -- ------------------------------------------------------------------------
|
bsw/jbe@1309
|
91 config.public_access = "authors_pseudonymous"
|
bsw@734
|
92
|
bsw@737
|
93
|
bsw@732
|
94
|
bsw@737
|
95 -- ========================================================================
|
bsw@737
|
96 -- OPTIONAL
|
bsw@737
|
97 -- Remove leading -- to use a option
|
bsw@737
|
98 -- ========================================================================
|
bsw@731
|
99
|
bsw@1071
|
100 -- Disable registration
|
bsw@1071
|
101 -- ------------------------------------------------------------------------
|
bsw@1071
|
102 -- Available options:
|
bsw@1071
|
103 -- false: registration is enabled (default)
|
bsw@1071
|
104 -- true: registration is disabled
|
bsw@1071
|
105 -- ------------------------------------------------------------------------
|
bsw@1071
|
106 -- config.disable_registration = true
|
bsw@1071
|
107
|
bsw@1170
|
108
|
bsw@729
|
109 -- List of enabled languages, defaults to available languages
|
bsw@730
|
110 -- ------------------------------------------------------------------------
|
bsw@1129
|
111 -- config.enabled_languages = { 'en', 'de', 'eo', 'el', 'hu', 'it', 'ka', 'nl', 'zh-Hans', 'zh-TW' }
|
bsw@2
|
112
|
bsw@1170
|
113
|
bsw@729
|
114 -- Default language, defaults to "en"
|
bsw@730
|
115 -- ------------------------------------------------------------------------
|
bsw@729
|
116 -- config.default_lang = "en"
|
poelzi@163
|
117
|
bsw@1170
|
118
|
bsw@734
|
119 -- after how long is a user considered inactive and the trustee will see warning,
|
bsw@734
|
120 -- notation is according to postgresql intervals, default: no warning at all
|
bsw@730
|
121 -- ------------------------------------------------------------------------
|
bsw@729
|
122 -- config.delegation_warning_time = '6 months'
|
bsw/jbe@6
|
123
|
bsw@1170
|
124
|
bsw@988
|
125 -- after which time a user is advised (_soft) or forced (_hard) to check
|
bsw@988
|
126 -- unit and area delegations. default: no check at all
|
bsw@988
|
127 -- ------------------------------------------------------------------------
|
bsw@988
|
128 -- config.check_delegations_interval_hard = "6 months"
|
bsw@988
|
129 -- config.check_delegations_interval_soft = "3 months"
|
bsw@988
|
130
|
bsw@1170
|
131
|
bsw@988
|
132 -- default option when checking delegations
|
bsw@988
|
133 -- available options: "confirm", "revoke" and "none", default: "confirm"
|
bsw@988
|
134 -- ------------------------------------------------------------------------
|
bsw@988
|
135 -- config.check_delegations_default = "confirm"
|
bsw@988
|
136
|
bsw@1170
|
137
|
bsw@734
|
138 -- Prefix of all automatic mails, defaults to "[Liquid Feedback] "
|
bsw@730
|
139 -- ------------------------------------------------------------------------
|
bsw@729
|
140 -- config.mail_subject_prefix = "[LiquidFeedback] "
|
bsw@734
|
141
|
bsw@1170
|
142
|
bsw@734
|
143 -- Sender of all automatic mails, defaults to system defaults
|
bsw@734
|
144 -- ------------------------------------------------------------------------
|
bsw@839
|
145 -- config.mail_envelope_from = "liquidfeedback@example.com"
|
bsw@839
|
146 -- config.mail_from = { name = "LiquidFeedback", address = "liquidfeedback@example.com" }
|
bsw@839
|
147 -- config.mail_reply_to = { name = "Support", address = "support@example.com" }
|
bsw/jbe@6
|
148
|
bsw@1170
|
149
|
bsw@1250
|
150 -- Template for digest emails
|
bsw@1250
|
151 -- #{name} will be replaced by member screen name
|
bsw@1250
|
152 -- #{digest} will be replaced with the digest content
|
bsw@1250
|
153 -- ------------------------------------------------------------------------
|
bsw@1250
|
154 -- config.notification_digest_template = [[
|
bsw@1250
|
155 -- Hello #{name},
|
bsw@1250
|
156 --
|
bsw@1250
|
157 -- this is your personal digest.
|
bsw@1250
|
158 --
|
bsw@1250
|
159 -- #{digest}
|
bsw@1250
|
160 -- ]]
|
bsw@1250
|
161
|
bsw@1250
|
162
|
bsw@905
|
163 -- Configuration of password hashing algorithm (defaults to "crypt_sha512")
|
bsw@905
|
164 -- ------------------------------------------------------------------------
|
bsw@905
|
165 -- config.password_hash_algorithm = "crypt_sha512"
|
bsw@1206
|
166 -- config.password_hash_algorithm = "crypt_sha256"
|
bsw@905
|
167 -- config.password_hash_algorithm = "crypt_md5"
|
bsw@905
|
168
|
bsw@1170
|
169
|
bsw@905
|
170 -- Number of rounds for crypt_sha* algorithms, minimum and maximum
|
bsw@905
|
171 -- (defaults to minimum 10000 and maximum 20000)
|
bsw@905
|
172 -- ------------------------------------------------------------------------
|
bsw@905
|
173 -- config.password_hash_min_rounds = 10000
|
bsw@905
|
174 -- config.password_hash_max_rounds = 20000
|
bsw@905
|
175
|
bsw@905
|
176
|
bsw@729
|
177 -- Supply custom url for avatar/photo delivery
|
bsw@730
|
178 -- ------------------------------------------------------------------------
|
bsw@729
|
179 -- config.fastpath_url_func = nil
|
bsw@51
|
180
|
bsw@1170
|
181
|
bsw@729
|
182 -- Local directory for database dumps offered for download
|
bsw@730
|
183 -- ------------------------------------------------------------------------
|
bsw@729
|
184 -- config.download_dir = nil
|
bsw@51
|
185
|
bsw@1170
|
186
|
bsw@729
|
187 -- Special use terms for database dump download
|
bsw@730
|
188 -- ------------------------------------------------------------------------
|
bsw@729
|
189 -- config.download_use_terms = "=== Download use terms ===\n"
|
bsw/jbe@52
|
190
|
bsw@1170
|
191
|
bsw@734
|
192 -- Use custom image conversion, defaults to ImageMagick's convert
|
bsw@730
|
193 -- ------------------------------------------------------------------------
|
bsw@729
|
194 --config.member_image_content_type = "image/jpeg"
|
bsw@729
|
195 --config.member_image_convert_func = {
|
bsw@729
|
196 -- avatar = function(data) return extos.pfilter(data, "convert", "jpeg:-", "-thumbnail", "48x48", "jpeg:-") end,
|
bsw@729
|
197 -- photo = function(data) return extos.pfilter(data, "convert", "jpeg:-", "-thumbnail", "240x240", "jpeg:-") end
|
bsw@729
|
198 --}
|
bsw@51
|
199
|
bsw@1170
|
200
|
bsw@1045
|
201 -- Display a html formatted public message of the day
|
bsw@837
|
202 -- ------------------------------------------------------------------------
|
bsw@1045
|
203 -- config.motd_public = "<h1>Message of the day (public)</h1><p>The MOTD is formatted with HTML</p>"
|
bsw@1045
|
204
|
bsw@1170
|
205
|
bsw@1045
|
206 -- Display a html formatted internal message of the day
|
bsw@1045
|
207 -- ------------------------------------------------------------------------
|
bsw@1045
|
208 -- config.motd_intern = "<h1>Message of the day (intern)</h1><p>The MOTD is formatted with HTML</p>"
|
bsw@837
|
209
|
bsw@1170
|
210
|
bsw@734
|
211 -- Integration of Etherpad, disabled by default
|
bsw@730
|
212 -- ------------------------------------------------------------------------
|
bsw@729
|
213 --config.etherpad = {
|
bsw@729
|
214 -- base_url = "http://example.com:9001/",
|
bsw@729
|
215 -- api_base = "http://localhost:9001/",
|
bsw@729
|
216 -- api_key = "mysecretapikey",
|
bsw@729
|
217 -- group_id = "mygroupname",
|
bsw@729
|
218 -- cookie_path = "/"
|
bsw@729
|
219 --}
|
bsw@51
|
220
|
bsw@1170
|
221
|
bsw@961
|
222 -- Free timings
|
bsw@961
|
223 -- ------------------------------------------------------------------------
|
bsw@961
|
224 -- This example expects a date string entered in the free timing field
|
bsw@961
|
225 -- by the user creating a poll, interpreting it as target date for then
|
bsw@961
|
226 -- poll and splits the remaining time at the ratio of 4:1:2
|
bsw@961
|
227 -- Please note, polling policies never have an admission phase
|
bsw@961
|
228 -- The available_func is optional, if not set any target date is allowed
|
bsw@961
|
229
|
bsw@1222
|
230 --[[
|
bsw@961
|
231 config.free_timing = {
|
bsw@961
|
232 calculate_func = function(policy, timing_string)
|
bsw@1166
|
233 local function interval_by_seconds(secs)
|
bsw@961
|
234 local secs_per_day = 60 * 60 * 24
|
bsw@961
|
235 local days
|
bsw@961
|
236 days = math.floor(secs / secs_per_day)
|
bsw@961
|
237 secs = secs - days * secs_per_day
|
bsw@961
|
238 return days .. " days " .. secs .. " seconds"
|
bsw@961
|
239 end
|
bsw@961
|
240 local target_date = parse.date(timing_string, atom.date)
|
bsw@961
|
241 if not target_date then
|
bsw@961
|
242 return false
|
bsw@961
|
243 end
|
bsw@961
|
244 local target_timestamp = target_date.midday
|
bsw@961
|
245 local now = atom.timestamp:get_current()
|
bsw@961
|
246 trace.debug(target_timestamp, now)
|
bsw@961
|
247 local duration = target_timestamp - now
|
bsw@961
|
248 if duration < 0 then
|
bsw@961
|
249 return false
|
bsw@961
|
250 end
|
bsw@961
|
251 return {
|
bsw@961
|
252 discussion = interval_by_seconds(duration / 7 * 4),
|
bsw@961
|
253 verification = interval_by_seconds(duration / 7 * 1),
|
bsw@961
|
254 voting = interval_by_seconds(duration / 7 * 2)
|
bsw@961
|
255 }
|
bsw@961
|
256 end,
|
bsw@961
|
257 available_func = function(policy)
|
bsw@961
|
258 return {
|
bsw@961
|
259 { name = "End of 2013", id = '2013-12-31' },
|
bsw@961
|
260 { name = "End of 2014", id = '2014-12-31' },
|
bsw@961
|
261 { name = "End of 2015", id = '2015-12-31' }
|
bsw@961
|
262 }
|
bsw@961
|
263 end
|
bsw@961
|
264 }
|
bsw@1222
|
265 --]]
|
bsw@1170
|
266
|
bsw@1219
|
267 -- Configuration of lf4rcs
|
bsw@1219
|
268 -- ------------------------------------------------------------------------
|
bsw@1222
|
269 -- config.lf4rc = {}
|
bsw@1219
|
270
|
bsw@1219
|
271 -- Example configuration for controlling a Git repository
|
bsw@1222
|
272 --[[
|
bsw@1219
|
273 config.lf4rcs.git = {
|
bsw@1219
|
274
|
bsw@1219
|
275 render_draft_reference = function(url, draft)
|
bsw@1219
|
276 if not draft.external_reference then return end
|
bsw@1219
|
277 ui.tag{ content = _"Changeset:" }
|
bsw@1219
|
278 slot.put(" ")
|
bsw@1219
|
279 ui.link{
|
bsw@1219
|
280 text = draft.external_reference,
|
bsw@1219
|
281 external = url .. ";a=commit;h=" .. draft.external_reference
|
bsw@1219
|
282 }
|
bsw@1219
|
283 end,
|
bsw@1219
|
284
|
bsw@1219
|
285 get_remote_user = function()
|
bsw@1219
|
286 return os.getenv("REMOTE_USER")
|
bsw@1219
|
287 end,
|
bsw@1219
|
288
|
bsw@1219
|
289 get_branches = function(path, exec)
|
bsw@1219
|
290 local branches = {}
|
bsw@1219
|
291 for line in io.lines() do
|
bsw@1219
|
292 local oldrev, newrev, branch = string.match(line, "([^ ]+) ([^ ]+) refs/heads/(.+)")
|
bsw@1219
|
293 if not branch then
|
bsw@1219
|
294 return nil, "unexpected format from git hook environment"
|
bsw@1219
|
295 end
|
bsw@1219
|
296 branches[branch] = { newrev }
|
bsw@1219
|
297 end
|
bsw@1219
|
298 return branches
|
bsw@1219
|
299 end,
|
bsw@1219
|
300
|
bsw@1219
|
301 commit = function(path, exec, branch, target_node_id, close_message, merge_message)
|
bsw@1219
|
302 if merge_message then
|
jbe@1221
|
303 exec("git", "-C", path, "checkout", "-f", "master")
|
bsw@1219
|
304 exec("git", "-C", path, "merge", target_node_id, "-m", merge_message)
|
bsw@1219
|
305 exec("git", "-C", path, "push", "origin", "master")
|
bsw@1219
|
306 end
|
bsw@1219
|
307 end
|
bsw@1219
|
308
|
bsw@1219
|
309 }
|
bsw@1219
|
310
|
bsw@1219
|
311 -- Example configuration for controlling a Mercurial repository
|
bsw@1219
|
312 config.lf4rcs.hg = {
|
bsw@1219
|
313
|
bsw@1219
|
314 working_branch_name = "work",
|
bsw@1219
|
315
|
bsw@1219
|
316 render_draft_reference = function(url, draft)
|
bsw@1219
|
317 if not draft.external_reference then return end
|
bsw@1219
|
318 ui.tag{ content = _"Changeset graph:" }
|
bsw@1219
|
319 slot.put(" ")
|
bsw@1219
|
320 ui.link{
|
bsw@1219
|
321 text = draft.external_reference,
|
bsw@1219
|
322 external = url .. "/graph/" .. draft.external_reference
|
bsw@1219
|
323 }
|
bsw@1219
|
324 end,
|
bsw@1219
|
325
|
bsw@1219
|
326 get_remote_user = function()
|
bsw@1219
|
327 return os.getenv("REMOTE_USER")
|
bsw@1219
|
328 end,
|
bsw@1219
|
329
|
bsw@1219
|
330 get_branches = function(path, exec)
|
bsw@1219
|
331 local first_node_id = os.getenv("HG_NODE")
|
bsw@1219
|
332 if not first_node_id then
|
bsw@1219
|
333 return nil, "internal error, no first node ID available"
|
bsw@1219
|
334 end
|
bsw@1219
|
335 local hg_log = exec(
|
bsw@1219
|
336 "hg", "log", "-R", path, "-r", first_node_id .. ":", "--template", "{branches}\n"
|
bsw@1219
|
337 )
|
bsw@1219
|
338 local branches = {}
|
bsw@1219
|
339 for branch in hg_log:gmatch("(.-)\n") do
|
bsw@1219
|
340 if branch == "" then branch = "default" end
|
bsw@1219
|
341 if not branches[branch] then
|
bsw@1219
|
342 branches[branch] = {}
|
bsw@1219
|
343 local head_lines = exec(
|
bsw@1219
|
344 "hg", "heads", "-R", path, "--template", "{node}\n", branch
|
bsw@1219
|
345 )
|
bsw@1219
|
346 for node_id in string.gmatch(head_lines, "[^\n]+") do
|
bsw@1219
|
347 table.insert(branches[branch], node_id)
|
bsw@1219
|
348 end
|
bsw@1219
|
349 end
|
bsw@1219
|
350 end
|
bsw@1219
|
351 return branches
|
bsw@1219
|
352 end,
|
bsw@1219
|
353
|
bsw@1219
|
354 extra_checks = function(path, exec)
|
bsw@1219
|
355 local result = exec("hg", "heads", "-t", "-c")
|
bsw@1219
|
356 for branch in string.gmatch(result, "[^\n]+") do
|
bsw@1219
|
357 if branch == lf4rcs.config.hg.working_branch_name then
|
bsw@1219
|
358 return nil, "open head found for branch " .. lf4rcs.config.hg.working_branch_name
|
bsw@1219
|
359 end
|
bsw@1219
|
360 end
|
bsw@1219
|
361 return true
|
bsw@1219
|
362 end,
|
bsw@1219
|
363
|
bsw@1219
|
364 commit = function(path, exec, branch, target_node_id, close_message, merge_message)
|
bsw@1219
|
365 exec("hg", "up", "-R", path, "-C", "-r", target_node_id)
|
bsw@1219
|
366 exec("hg", "commit", "-R", path, "--close-branch", "-m", close_message)
|
bsw@1219
|
367 if merge_message then
|
bsw@1219
|
368 exec("hg", "up", "-R", path, "-C", "-r", "default")
|
bsw@1219
|
369 exec("hg", "merge", "-R", path, "-r", "tip")
|
bsw@1219
|
370 exec("hg", "commit", "-R", path, "-m", merge_message)
|
bsw@1219
|
371 end
|
bsw@1219
|
372 end
|
bsw@1219
|
373
|
bsw@1219
|
374 }
|
bsw@1219
|
375
|
bsw@1235
|
376 -- Grace period after creating an initiative for pushing changes during verification phase
|
bsw@1235
|
377 -- disabled by default (nil), use PostgreSQL interval notation
|
bsw@1235
|
378 -- config.lf4rcs.push_grace_period = nil
|
bsw@1235
|
379
|
bsw@1219
|
380 lf4rcs.init()
|
bsw@1222
|
381 --]]
|
bsw@1219
|
382
|
bsw@1209
|
383 -- External references
|
bsw@1209
|
384 -- ------------------------------------------------------------------------
|
bsw@1209
|
385 -- Rendering of external references
|
bsw@1209
|
386
|
bsw@1209
|
387 --[[
|
bsw@1209
|
388 config.render_external_reference = {
|
bsw@1209
|
389 draft = function(draft, wrapper)
|
bsw@1209
|
390 wrapper(function()
|
bsw@1209
|
391 ui.tag{ content = draft.external_reference)
|
bsw@1209
|
392 end)
|
bsw@1209
|
393 end,
|
bsw@1209
|
394 initiative = function(initiative, wrapper)
|
bsw@1209
|
395 wrapper(function()
|
bsw@1209
|
396 ui.tag{ content = initiative.external_reference)
|
bsw@1209
|
397 end)
|
bsw@1209
|
398 end
|
bsw@1209
|
399 end
|
bsw@1209
|
400 --]]
|
bsw@1209
|
401
|
bsw@1106
|
402 -- Admin logger
|
bsw@1106
|
403 -- ------------------------------------------------------------------------
|
bsw@1106
|
404 -- Logging administrative activities
|
bsw@1106
|
405 -- disabled by default
|
bsw@1106
|
406
|
bsw@1106
|
407 --[[
|
bsw@1106
|
408 config.admin_logger = function(params)
|
bsw@1106
|
409
|
bsw@1106
|
410 local adminid = app.session.member_id
|
bsw@1106
|
411 local adminname = app.session.member.name
|
bsw@1107
|
412 local url = params._webmcp_path
|
bsw@1106
|
413
|
bsw@1106
|
414 -- do something (e.g. calling 'logger' via extos.pfilter)
|
bsw@1106
|
415
|
bsw@1106
|
416 end
|
bsw@1106
|
417 --]]
|
bsw@1106
|
418
|
bsw@1106
|
419
|
bsw@1170
|
420 -- Network interface to bind to
|
bsw@1170
|
421 -- ------------------------------------------------------------------------
|
bsw@1170
|
422 -- Available options:
|
bsw@1170
|
423 -- true: bind to localhost (default)
|
bsw@1170
|
424 -- false: bind to all interface
|
bsw@1170
|
425 -- ------------------------------------------------------------------------
|
bsw@1170
|
426 -- config.localhost = true
|
bsw@1170
|
427
|
bsw@1170
|
428
|
bsw@1170
|
429 -- Network port to bind to
|
bsw@1170
|
430 -- ------------------------------------------------------------------------
|
bsw@1170
|
431 -- config.port = 8080
|
bsw@1170
|
432
|
bsw@1170
|
433
|
bsw@1170
|
434 -- Serving content via IPV6
|
bsw@1170
|
435 -- ------------------------------------------------------------------------
|
bsw@1170
|
436 -- Available options:
|
bsw@1170
|
437 -- nil or false: do not serve via IPv6 (default)
|
bsw@1170
|
438 -- true: serve via IPv6
|
bsw@1170
|
439 -- ------------------------------------------------------------------------
|
bsw@1170
|
440 -- config.ipv6 = false
|
bsw@1170
|
441
|
bsw@1170
|
442
|
bsw@1170
|
443 -- Application server fork configuration
|
bsw@1170
|
444 -- ------------------------------------------------------------------------
|
bsw@1170
|
445 -- config.fork = {
|
bsw@1170
|
446 -- pre = 2, -- desired number of spare (idle) processes
|
bsw@1170
|
447 -- min = 4, -- minimum number of processes
|
bsw@1170
|
448 -- max = 128, -- maximum number of processes (hard limit)
|
bsw@1170
|
449 -- delay = 0.125, -- delay (seconds) between creation of spare processes
|
bsw@1170
|
450 -- error_delay = 2, -- delay (seconds) before retry of failed process creation
|
bsw@1170
|
451 -- exit_delay = 2, -- delay (seconds) between destruction of excessive spare processes
|
bsw@1170
|
452 -- idle_timeout = 900, -- idle time (seconds) after a fork gets terminated (0 for no timeout)
|
bsw@1170
|
453 -- memory_limit = 0, -- maximum memory consumption (bytes) before process gets terminated
|
bsw@1170
|
454 -- min_requests = 50, -- minimum count of requests handled before fork is terminated
|
bsw@1170
|
455 -- max_requests = 100 -- maximum count of requests handled before fork is terminated
|
bsw@1170
|
456 -- }
|
bsw@1170
|
457
|
bsw@1170
|
458
|
bsw@1170
|
459 -- HTTP server options
|
bsw@1170
|
460 -- ------------------------------------------------------------------------
|
bsw@1170
|
461 -- http_options = {
|
bsw@1170
|
462 -- static_headers = {} -- string or table of static headers to be returned with every request
|
bsw@1170
|
463 -- request_header_size_limit = 1024*1024, -- maximum size of request body sent by client
|
bsw@1170
|
464 -- request_body_size_limit = 64*1024*1024, -- maximum size of request body sent by client
|
jbe@1198
|
465 -- idle_timeout = 65, -- maximum time until receiving the first byte of the request headera
|
jbe@1198
|
466 -- stall_timeout = 60, -- maximum time a client connection may be stalled
|
jbe@1198
|
467 -- request_header_timeout = 120, -- maximum time until receiving the remaining bytes of the request header
|
jbe@1198
|
468 -- response_timeout = 3600, -- time in which request body and response must be sent
|
bsw@1170
|
469 -- maximum_input_chunk_size = 16384 -- tweaks behavior of request-body parser
|
bsw@1170
|
470 -- minimum_output_chunk_size = 1024 -- chunk size for chunked-transfer-encoding
|
bsw@1170
|
471 -- }
|
bsw@1170
|
472
|
bsw@1170
|
473
|
bsw@729
|
474 -- WebMCP accelerator
|
jbe@1223
|
475 -- ------------------------------------------------------------------------
|
jbe@1223
|
476 -- uncomment the following line to use C implementations of chosen
|
jbe@1223
|
477 -- functions:
|
bsw@730
|
478 -- ------------------------------------------------------------------------
|
bsw@729
|
479 -- require 'webmcp_accelerator'
|
jbe@1223
|
480
|
bsw/jbe@0
|
481
|
bsw@868
|
482 -- Trace debug
|
bsw@1222
|
483 -- ------------------------------------------------------------------------
|
bsw@868
|
484 -- uncomment the following line to enable debug trace
|
jbe@1223
|
485 -- ------------------------------------------------------------------------
|
bsw/jbe@1309
|
486 config.enable_debug_trace = true
|
bsw/jbe@1309
|
487
|
bsw/jbe@1309
|
488
|
bsw/jbe@1309
|
489 config.fork = {
|
bsw/jbe@1309
|
490 pre =1, min = 1, max = 1, max_requests = 1, min_requests = 1
|
bsw/jbe@1309
|
491 }
|
bsw/jbe@1309
|
492
|
bsw/jbe@1309
|
493 config.localhost = true
|
bsw/jbe@0
|
494
|
bsw/jbe@1309
|
495 config.oauth2 = {
|
bsw/jbe@1309
|
496 available_scopes = {
|
bsw/jbe@1309
|
497 { scope = "read", name = { de = "Lesen", en = "Read data" } },
|
bsw/jbe@1309
|
498 { scope = "write", name = { de = "Schreiben", en = "Write data" } },
|
bsw/jbe@1309
|
499 { scope = "privA", name = { de = "Beispielprivileg A", en = "Example privilege A" } },
|
bsw/jbe@1309
|
500 { scope = "privB", name = { de = "Beispielprivileg B", en = "Example privilege B" } }
|
bsw/jbe@1309
|
501 },
|
bsw/jbe@1309
|
502 authorization_code_lifetime = 5 * 60,
|
bsw/jbe@1309
|
503 refresh_token_lifetime = 60 * 60 * 24 * 30 * 3,
|
bsw/jbe@1309
|
504 refresh_pause = 60,
|
bsw/jbe@1309
|
505 refresh_grace_period = 60,
|
bsw/jbe@1309
|
506 access_token_lifetime = 60 * 60,
|
bsw/jbe@1309
|
507 -- NOTE for init.lua : check for refresh_pause >= refresh_grace_period
|
bsw/jbe@1309
|
508 endpoint_magic = "liquidfeedback_client_redirection_endpoint"
|
bsw/jbe@1309
|
509 }
|
bsw/jbe@1309
|
510
|