803
by dcoles
Setup: Modularised setup.py so it is now no longer over 1000 lines. This should |
1 |
# IVLE - Informatics Virtual Learning Environment
|
2 |
# Copyright (C) 2007-2008 The University of Melbourne
|
|
3 |
#
|
|
4 |
# This program is free software; you can redistribute it and/or modify
|
|
5 |
# it under the terms of the GNU General Public License as published by
|
|
6 |
# the Free Software Foundation; either version 2 of the License, or
|
|
7 |
# (at your option) any later version.
|
|
8 |
#
|
|
9 |
# This program is distributed in the hope that it will be useful,
|
|
10 |
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
11 |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
12 |
# GNU General Public License for more details.
|
|
13 |
#
|
|
14 |
# You should have received a copy of the GNU General Public License
|
|
15 |
# along with this program; if not, write to the Free Software
|
|
16 |
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
17 |
||
18 |
# Module: setup/config
|
|
19 |
# Author: Matt Giuca, Refactored by David Coles
|
|
20 |
# Date: 03/07/2008
|
|
21 |
||
22 |
# setup/config.py
|
|
23 |
# Configures IVLE with machine-specific details, most notably, various paths.
|
|
24 |
# Either prompts the administrator for these details or accepts them as
|
|
25 |
# command-line args.
|
|
26 |
# Creates lib/conf/conf.py and trampoline/conf.h.
|
|
27 |
||
28 |
import optparse |
|
29 |
import getopt |
|
30 |
import os |
|
819
by mattgiuca
setup/configure.py: Added "import sys". |
31 |
import sys |
803
by dcoles
Setup: Modularised setup.py so it is now no longer over 1000 lines. This should |
32 |
import hashlib |
33 |
import uuid |
|
34 |
from setup.setuputil import query_user |
|
35 |
||
36 |
class ConfigOption: |
|
37 |
"""A configuration option; one of the things written to conf.py."""
|
|
38 |
def __init__(self, option_name, default, prompt, comment): |
|
39 |
"""Creates a configuration option.
|
|
40 |
option_name: Name of the variable in conf.py. Also name of the
|
|
41 |
command-line argument to setup.py conf.
|
|
42 |
default: Default value for this variable.
|
|
43 |
prompt: (Short) string presented during the interactive prompt in
|
|
44 |
setup.py conf.
|
|
45 |
comment: (Long) comment string stored in conf.py. Each line of this
|
|
46 |
string should begin with a '#'.
|
|
47 |
"""
|
|
48 |
self.option_name = option_name |
|
49 |
self.default = default |
|
50 |
self.prompt = prompt |
|
51 |
self.comment = comment |
|
52 |
||
53 |
# Configuration options, defaults and descriptions
|
|
54 |
config_options = [] |
|
55 |
config_options.append(ConfigOption("root_dir", "/", |
|
56 |
"""Root directory where IVLE is located (in URL space):""", |
|
57 |
"""
|
|
58 |
# In URL space, where in the site is IVLE located. (All URLs will be prefixed
|
|
59 |
# with this).
|
|
60 |
# eg. "/" or "/ivle".""")) |
|
61 |
config_options.append(ConfigOption("ivle_install_dir", "/opt/ivle", |
|
62 |
'Root directory where IVLE will be installed (on the local file '
|
|
63 |
'system):', |
|
64 |
"""
|
|
65 |
# In the local file system, where IVLE is actually installed.
|
|
66 |
# This directory should contain the "www" and "bin" directories.""")) |
|
67 |
config_options.append(ConfigOption("jail_base", "/home/informatics/jails", |
|
813
by William Grant
Merge jails-redux branch. We now use aufs rather than hardlinking tens |
68 |
"""Location of jail mountpoints
|
69 |
============================
|
|
70 |
Root directory where the user jails will be mounted, and the non-user
|
|
71 |
components of the jails will be stored (on the local file system):""", |
|
72 |
"""
|
|
73 |
# In the local file system, where the student/user jails will be mounted.
|
|
74 |
# Only a single copy of the jail's system components will be stored here -
|
|
75 |
# all user jails will be virtually mounted here.""")) |
|
76 |
config_options.append(ConfigOption("jail_system", "/home/informatics/jails/__base__", |
|
77 |
"""Location of system jail components
|
|
78 |
==================================
|
|
79 |
Directory where the template system jail will be stored.""", |
|
80 |
"""
|
|
81 |
# In the local file system, where the template system jail will be stored.""")) |
|
82 |
config_options.append(ConfigOption("jail_src_base", "/home/informatics/jailssrc", |
|
83 |
"""Location of user jail components
|
|
84 |
================================
|
|
85 |
Root directory where the user components of the jails will be stored (on the
|
|
86 |
local file system):""", |
|
803
by dcoles
Setup: Modularised setup.py so it is now no longer over 1000 lines. This should |
87 |
"""
|
88 |
# In the local file system, where are the student/user file spaces located.
|
|
89 |
# The user jails are expected to be located immediately in subdirectories of
|
|
813
by William Grant
Merge jails-redux branch. We now use aufs rather than hardlinking tens |
90 |
# this location. Note that no complete jails reside here - only user
|
91 |
# modifications.""")) |
|
803
by dcoles
Setup: Modularised setup.py so it is now no longer over 1000 lines. This should |
92 |
config_options.append(ConfigOption("subjects_base", |
93 |
"/home/informatics/subjects", |
|
94 |
"""Root directory where the subject directories (containing worksheets
|
|
95 |
and other per-subject files) are stored (on the local file system):""", |
|
96 |
"""
|
|
97 |
# In the local file system, where are the per-subject file spaces located.
|
|
98 |
# The individual subject directories are expected to be located immediately
|
|
99 |
# in subdirectories of this location.""")) |
|
100 |
config_options.append(ConfigOption("exercises_base", |
|
101 |
"/home/informatics/exercises", |
|
102 |
"""Root directory where the exercise directories (containing
|
|
103 |
subject-independent exercise sheets) are stored (on the local file
|
|
104 |
system):""", |
|
105 |
"""
|
|
106 |
# In the local file system, where are the subject-independent exercise sheet
|
|
107 |
# file spaces located.""")) |
|
108 |
config_options.append(ConfigOption("tos_path", |
|
109 |
"/home/informatics/tos.html", |
|
110 |
"""Location where the Terms of Service document is stored (on the local
|
|
111 |
file system):""", |
|
112 |
"""
|
|
113 |
# In the local file system, where is the Terms of Service document located.""")) |
|
114 |
config_options.append(ConfigOption("motd_path", |
|
115 |
"/home/informatics/motd.html", |
|
116 |
"""Location where the Message of the Day document is stored (on the local
|
|
117 |
file system):""", |
|
118 |
"""
|
|
119 |
# In the local file system, where is the Message of the Day document
|
|
120 |
# located. This is an HTML file (just the body fragment), which will
|
|
121 |
# be displayed on the login page. It is optional.""")) |
|
893
by dcoles
Dispatch: Now attempts to log unhandled exceptions to a log directory specified |
122 |
config_options.append(ConfigOption("log_path", |
123 |
"/home/informatics/logs/", |
|
124 |
"""Directory where IVLE log files are stored (on the local
|
|
125 |
file system). Note - this must be writable by the user the IVLE server
|
|
126 |
process runs as (usually www-data).:""", |
|
127 |
"""
|
|
128 |
# In the local file system, where is the Terms of Service document located.""")) |
|
803
by dcoles
Setup: Modularised setup.py so it is now no longer over 1000 lines. This should |
129 |
config_options.append(ConfigOption("public_host", "public.localhost", |
130 |
"""Hostname which will cause the server to go into "public mode",
|
|
131 |
providing login-free access to student's published work:""", |
|
132 |
"""
|
|
133 |
# The server goes into "public mode" if the browser sends a request with this
|
|
134 |
# host. This is for security reasons - we only serve public student files on a
|
|
135 |
# separate domain to the main IVLE site.
|
|
136 |
# Public mode does not use cookies, and serves only public content.
|
|
137 |
# Private mode (normal mode) requires login, and only serves files relevant to
|
|
138 |
# the logged-in user.""")) |
|
139 |
config_options.append(ConfigOption("allowed_uids", "33", |
|
140 |
"""UID of the web server process which will run IVLE.
|
|
141 |
Only this user may execute the trampoline. May specify multiple users as
|
|
142 |
a comma-separated list.
|
|
143 |
(eg. "1002,78")""", |
|
144 |
"""
|
|
145 |
# The User-ID of the web server process which will run IVLE, and any other
|
|
146 |
# users who are allowed to run the trampoline. This is stores as a string of
|
|
147 |
# comma-separated integers, simply because it is not used within Python, only
|
|
148 |
# used by the setup program to write to conf.h (see setup.py config).""")) |
|
149 |
config_options.append(ConfigOption("db_host", "localhost", |
|
150 |
"""PostgreSQL Database config
|
|
151 |
==========================
|
|
152 |
Hostname of the DB server:""", |
|
153 |
"""
|
|
154 |
### PostgreSQL Database config ###
|
|
155 |
# Database server hostname""")) |
|
156 |
config_options.append(ConfigOption("db_port", "5432", |
|
157 |
"""Port of the DB server:""", |
|
158 |
"""
|
|
159 |
# Database server port""")) |
|
160 |
config_options.append(ConfigOption("db_dbname", "ivle", |
|
161 |
"""Database name:""", |
|
162 |
"""
|
|
163 |
# Database name""")) |
|
164 |
config_options.append(ConfigOption("db_forumdbname", "ivle_forum", |
|
165 |
"""Forum Database name:""", |
|
166 |
"""
|
|
167 |
# Forum Database name""")) |
|
168 |
config_options.append(ConfigOption("db_user", "postgres", |
|
169 |
"""Username for DB server login:""", |
|
170 |
"""
|
|
171 |
# Database username""")) |
|
172 |
config_options.append(ConfigOption("db_password", "", |
|
173 |
"""Password for DB server login:
|
|
174 |
(Caution: This password is stored in plaintext in lib/conf/conf.py)""", |
|
175 |
"""
|
|
176 |
# Database password""")) |
|
177 |
config_options.append(ConfigOption("auth_modules", "ldap_auth", |
|
178 |
"""Authentication config
|
|
179 |
=====================
|
|
180 |
Comma-separated list of authentication modules. Only "ldap" is available
|
|
181 |
by default.""", |
|
182 |
"""
|
|
183 |
# Comma-separated list of authentication modules.
|
|
184 |
# These refer to importable Python modules in the www/auth directory.
|
|
185 |
# Modules "ldap" and "guest" are available in the source tree, but
|
|
186 |
# other modules may be plugged in to auth against organisation-specific
|
|
187 |
# auth backends.""")) |
|
188 |
config_options.append(ConfigOption("ldap_url", "ldaps://www.example.com", |
|
189 |
"""(LDAP options are only relevant if "ldap" is included in the list of
|
|
190 |
auth modules).
|
|
191 |
URL for LDAP authentication server:""", |
|
192 |
"""
|
|
193 |
# URL for LDAP authentication server""")) |
|
194 |
config_options.append(ConfigOption("ldap_format_string", |
|
195 |
"uid=%s,ou=users,o=example", |
|
196 |
"""Format string for LDAP auth request:
|
|
197 |
(Must contain a single "%s" for the user's login name)""", |
|
198 |
"""
|
|
199 |
# Format string for LDAP auth request
|
|
200 |
# (Must contain a single "%s" for the user's login name)""")) |
|
819
by mattgiuca
setup/configure.py: Added "import sys". |
201 |
config_options.append(ConfigOption("subject_pulldown_modules", "", |
202 |
"""Comma-separated list of subject pulldown modules.
|
|
203 |
Add proprietary modules to automatically enrol students in subjects.""", |
|
204 |
"""
|
|
205 |
# Comma-separated list of subject pulldown modules.
|
|
206 |
# These refer to importable Python modules in the lib/pulldown_subj directory.
|
|
820
by mattgiuca
lib: Added new package pulldown_subj, a collection of modules designed to |
207 |
# Only "dummy_subj" is available in the source tree (an example), but
|
819
by mattgiuca
setup/configure.py: Added "import sys". |
208 |
# other modules may be plugged in to pulldown against organisation-specific
|
209 |
# pulldown backends.""")) |
|
803
by dcoles
Setup: Modularised setup.py so it is now no longer over 1000 lines. This should |
210 |
config_options.append(ConfigOption("svn_addr", "http://svn.localhost/", |
211 |
"""Subversion config
|
|
212 |
=================
|
|
213 |
The base url for accessing subversion repositories:""", |
|
214 |
"""
|
|
215 |
# The base url for accessing subversion repositories.""")) |
|
216 |
config_options.append(ConfigOption("svn_conf", "/opt/ivle/svn/svn.conf", |
|
217 |
"""The location of the subversion configuration file used by apache
|
|
218 |
to host the user repositories:""", |
|
219 |
"""
|
|
220 |
# The location of the subversion configuration file used by
|
|
221 |
# apache to host the user repositories.""")) |
|
222 |
config_options.append(ConfigOption("svn_repo_path", "/home/informatics/repositories", |
|
223 |
"""The root directory for the subversion repositories:""", |
|
224 |
"""
|
|
225 |
# The root directory for the subversion repositories.""")) |
|
226 |
config_options.append(ConfigOption("svn_auth_ivle", "/opt/ivle/svn/ivle.auth", |
|
227 |
"""The location of the password file used to authenticate users
|
|
228 |
of the subversion repository from the ivle server:""", |
|
229 |
"""
|
|
230 |
# The location of the password file used to authenticate users
|
|
231 |
# of the subversion repository from the ivle server.""")) |
|
232 |
config_options.append(ConfigOption("svn_auth_local", "/opt/ivle/svn/local.auth", |
|
233 |
"""The location of the password file used to authenticate local users
|
|
234 |
of the subversion repository:""", |
|
235 |
"""
|
|
236 |
# The location of the password file used to authenticate local users
|
|
237 |
# of the subversion repository.""")) |
|
238 |
config_options.append(ConfigOption("usrmgt_host", "localhost", |
|
239 |
"""User Management Server config
|
|
240 |
============================
|
|
241 |
The hostname where the usrmgt-server runs:""", |
|
242 |
"""
|
|
243 |
# The hostname where the usrmgt-server runs.""")) |
|
244 |
config_options.append(ConfigOption("usrmgt_port", "2178", |
|
245 |
"""The port where the usrmgt-server runs:""", |
|
246 |
"""
|
|
247 |
# The port where the usrmgt-server runs.""")) |
|
248 |
config_options.append(ConfigOption("usrmgt_magic", "", |
|
249 |
"""The password for the usrmgt-server:""", |
|
250 |
"""
|
|
251 |
# The password for the usrmgt-server.""")) |
|
252 |
||
253 |
def configure(args): |
|
254 |
usage = """usage: %prog build [options] |
|
255 |
(requires root)
|
|
256 |
Compiles all files and sets up a jail template in the source directory.
|
|
257 |
-O is recommended to cause compilation to be optimised.
|
|
258 |
Details:
|
|
259 |
Compiles (GCC) trampoline/trampoline.c to trampoline/trampoline.
|
|
260 |
Creates jail with system and student packages installed from MIRROR.
|
|
261 |
Copies console/ to a location within the jail.
|
|
262 |
Copies OS programs and files to corresponding locations within the jail
|
|
263 |
(eg. python and Python libs, ld.so, etc).
|
|
264 |
Generates .pyc or .pyo files for all the IVLE .py files."""
|
|
265 |
||
266 |
# Parse arguments
|
|
267 |
parser = optparse.OptionParser(usage) |
|
268 |
(options, args) = parser.parse_args(args) |
|
269 |
||
270 |
# Call the real function
|
|
271 |
__configure(args) |
|
272 |
||
273 |
def __configure(args): |
|
274 |
global db_port, usrmgt_port |
|
275 |
||
276 |
# Try importing existing conf, but if we can't just set up defaults
|
|
277 |
# The reason for this is that these settings are used by other phases
|
|
278 |
# of setup besides conf, so we need to know them.
|
|
279 |
# Also this allows you to hit Return to accept the existing value.
|
|
280 |
try: |
|
281 |
confmodule = __import__("lib/conf/conf") |
|
282 |
for opt in config_options: |
|
283 |
try: |
|
284 |
globals()[opt.option_name] = \ |
|
285 |
confmodule.__dict__[opt.option_name] |
|
286 |
except: |
|
287 |
globals()[opt.option_name] = opt.default |
|
288 |
except ImportError: |
|
289 |
# Just set reasonable defaults
|
|
290 |
for opt in config_options: |
|
291 |
globals()[opt.option_name] = opt.default |
|
292 |
||
293 |
# Set up some variables
|
|
294 |
cwd = os.getcwd() |
|
295 |
||
296 |
# the files that will be created/overwritten
|
|
297 |
conffile = os.path.join(cwd, "lib/conf/conf.py") |
|
298 |
jailconffile = os.path.join(cwd, "lib/conf/jailconf.py") |
|
299 |
conf_hfile = os.path.join(cwd, "trampoline/conf.h") |
|
300 |
phpBBconffile = os.path.join(cwd, "www/php/phpBB3/config.php") |
|
301 |
usrmgtserver_initdfile = os.path.join(cwd, "doc/setup/usrmgt-server.init") |
|
302 |
||
303 |
# Get command-line arguments to avoid asking questions.
|
|
304 |
||
305 |
optnames = [] |
|
306 |
for opt in config_options: |
|
307 |
optnames.append(opt.option_name + "=") |
|
308 |
(opts, args) = getopt.gnu_getopt(args, "", optnames) |
|
309 |
||
310 |
if args != []: |
|
311 |
print >>sys.stderr, "Invalid arguments:", string.join(args, ' ') |
|
312 |
return 2 |
|
313 |
||
314 |
if opts == []: |
|
315 |
# Interactive mode. Prompt the user for all the values.
|
|
316 |
||
317 |
print """This tool will create the following files: |
|
318 |
%s |
|
319 |
%s |
|
320 |
%s |
|
321 |
%s |
|
322 |
%s |
|
323 |
prompting you for details about your configuration. The file will be
|
|
324 |
overwritten if it already exists. It will *not* install or deploy IVLE.
|
|
325 |
||
326 |
Please hit Ctrl+C now if you do not wish to do this.
|
|
327 |
""" % (conffile, jailconffile, conf_hfile, phpBBconffile, usrmgtserver_initdfile) |
|
328 |
||
329 |
# Get information from the administrator
|
|
330 |
# If EOF is encountered at any time during the questioning, just exit
|
|
331 |
# silently
|
|
332 |
||
333 |
for opt in config_options: |
|
334 |
globals()[opt.option_name] = \ |
|
335 |
query_user(globals()[opt.option_name], opt.prompt) |
|
336 |
else: |
|
337 |
opts = dict(opts) |
|
338 |
# Non-interactive mode. Parse the options.
|
|
339 |
for opt in config_options: |
|
340 |
if '--' + opt.option_name in opts: |
|
341 |
globals()[opt.option_name] = opts['--' + opt.option_name] |
|
342 |
||
343 |
# Error handling on input values
|
|
344 |
try: |
|
345 |
allowed_uids_list = map(int, allowed_uids.split(',')) |
|
346 |
except ValueError: |
|
347 |
print >>sys.stderr, ( |
|
348 |
"Invalid UID list (%s).\n" |
|
349 |
"Must be a comma-separated list of integers." % allowed_uids) |
|
350 |
return 1 |
|
351 |
try: |
|
352 |
db_port = int(db_port) |
|
353 |
if db_port < 0 or db_port >= 65536: raise ValueError() |
|
354 |
except ValueError: |
|
355 |
print >>sys.stderr, ( |
|
356 |
"Invalid DB port (%s).\n" |
|
357 |
"Must be an integer between 0 and 65535." % repr(db_port)) |
|
358 |
return 1 |
|
359 |
try: |
|
360 |
usrmgt_port = int(usrmgt_port) |
|
361 |
if usrmgt_port < 0 or usrmgt_port >= 65536: raise ValueError() |
|
362 |
except ValueError: |
|
363 |
print >>sys.stderr, ( |
|
364 |
"Invalid user management port (%s).\n" |
|
365 |
"Must be an integer between 0 and 65535." % repr(usrmgt_port)) |
|
366 |
return 1 |
|
367 |
||
368 |
# Generate the forum secret
|
|
369 |
forum_secret = hashlib.md5(uuid.uuid4().bytes).hexdigest() |
|
370 |
||
371 |
# Write lib/conf/conf.py
|
|
372 |
||
373 |
try: |
|
374 |
conf = open(conffile, "w") |
|
375 |
||
376 |
conf.write("""# IVLE Configuration File |
|
377 |
# conf.py
|
|
378 |
# Miscellaneous application settings
|
|
379 |
||
380 |
""") |
|
381 |
for opt in config_options: |
|
382 |
conf.write('%s\n%s = %s\n' % (opt.comment, opt.option_name, |
|
383 |
repr(globals()[opt.option_name]))) |
|
384 |
||
385 |
# Add the forum secret to the config file (regenerated each config)
|
|
386 |
conf.write('forum_secret = "%s"\n' % (forum_secret)) |
|
387 |
||
388 |
conf.close() |
|
389 |
except IOError, (errno, strerror): |
|
390 |
print "IO error(%s): %s" % (errno, strerror) |
|
391 |
sys.exit(1) |
|
392 |
||
393 |
print "Successfully wrote lib/conf/conf.py" |
|
394 |
||
395 |
# Write conf/jailconf.py
|
|
396 |
||
397 |
try: |
|
398 |
conf = open(jailconffile, "w") |
|
399 |
||
400 |
# In the "in-jail" version of conf, we don't need MOST of the details
|
|
401 |
# (it would be a security risk to have them here).
|
|
402 |
# So we just write root_dir, and jail_base is "/".
|
|
403 |
# (jail_base being "/" means "jail-relative" paths are relative to "/"
|
|
404 |
# when inside the jail.)
|
|
405 |
conf.write("""# IVLE Configuration File |
|
406 |
# conf.py
|
|
407 |
# Miscellaneous application settings
|
|
408 |
# (User jail version)
|
|
409 |
||
410 |
||
411 |
# In URL space, where in the site is IVLE located. (All URLs will be prefixed
|
|
412 |
# with this).
|
|
413 |
# eg. "/" or "/ivle".
|
|
414 |
root_dir = %s |
|
415 |
||
416 |
# In the local file system, where are the student/user file spaces located.
|
|
417 |
# The user jails are expected to be located immediately in subdirectories of
|
|
418 |
# this location.
|
|
419 |
jail_base = '/'
|
|
420 |
||
421 |
# The hostname for serving publicly accessible pages
|
|
422 |
public_host = %s |
|
423 |
""" % (repr(root_dir),repr(public_host))) |
|
424 |
||
425 |
conf.close() |
|
426 |
except IOError, (errno, strerror): |
|
427 |
print "IO error(%s): %s" % (errno, strerror) |
|
428 |
sys.exit(1) |
|
429 |
||
430 |
print "Successfully wrote lib/conf/jailconf.py" |
|
431 |
||
432 |
# Write trampoline/conf.h
|
|
433 |
||
434 |
try: |
|
435 |
conf = open(conf_hfile, "w") |
|
436 |
||
437 |
conf.write("""/* IVLE Configuration File |
|
438 |
* conf.h
|
|
439 |
* Administrator settings required by trampoline.
|
|
440 |
* Note: trampoline will have to be rebuilt in order for changes to this file
|
|
441 |
* to take effect.
|
|
442 |
*/
|
|
443 |
||
813
by William Grant
Merge jails-redux branch. We now use aufs rather than hardlinking tens |
444 |
#define IVLE_AUFS_JAILS
|
445 |
||
803
by dcoles
Setup: Modularised setup.py so it is now no longer over 1000 lines. This should |
446 |
/* In the local file system, where are the jails located.
|
447 |
* The trampoline does not allow the creation of a jail anywhere besides
|
|
448 |
* jail_base or a subdirectory of jail_base.
|
|
449 |
*/
|
|
450 |
static const char* jail_base = "%s"; |
|
813
by William Grant
Merge jails-redux branch. We now use aufs rather than hardlinking tens |
451 |
static const char* jail_src_base = "%s"; |
452 |
static const char* jail_system = "%s"; |
|
803
by dcoles
Setup: Modularised setup.py so it is now no longer over 1000 lines. This should |
453 |
|
454 |
/* Which user IDs are allowed to run the trampoline.
|
|
455 |
* This list should be limited to the web server user.
|
|
456 |
* (Note that root is an implicit member of this list).
|
|
457 |
*/
|
|
458 |
static const int allowed_uids[] = { %s }; |
|
813
by William Grant
Merge jails-redux branch. We now use aufs rather than hardlinking tens |
459 |
""" % (repr(jail_base)[1:-1], repr(jail_src_base)[1:-1], |
460 |
repr(jail_system)[1:-1], repr(allowed_uids_list)[1:-1])) |
|
803
by dcoles
Setup: Modularised setup.py so it is now no longer over 1000 lines. This should |
461 |
# Note: The above uses PYTHON reprs, not C reprs
|
462 |
# However they should be the same with the exception of the outer
|
|
463 |
# characters, which are stripped off and replaced
|
|
464 |
||
465 |
conf.close() |
|
466 |
except IOError, (errno, strerror): |
|
467 |
print "IO error(%s): %s" % (errno, strerror) |
|
468 |
sys.exit(1) |
|
469 |
||
470 |
print "Successfully wrote trampoline/conf.h" |
|
471 |
||
472 |
# Write www/php/phpBB3/config.php
|
|
473 |
||
474 |
try: |
|
475 |
conf = open(phpBBconffile, "w") |
|
476 |
||
477 |
# php-pg work around
|
|
478 |
if db_host == 'localhost': |
|
479 |
forumdb_host = '127.0.0.1' |
|
480 |
else: |
|
481 |
forumdb_host = db_host |
|
482 |
||
483 |
conf.write( """<?php |
|
484 |
// phpBB 3.0.x auto-generated configuration file
|
|
485 |
// Do not change anything in this file!
|
|
486 |
$dbms = 'postgres';
|
|
487 |
$dbhost = '""" + forumdb_host + """'; |
|
488 |
$dbport = '""" + str(db_port) + """'; |
|
489 |
$dbname = '""" + db_forumdbname + """'; |
|
490 |
$dbuser = '""" + db_user + """'; |
|
491 |
$dbpasswd = '""" + db_password + """'; |
|
492 |
||
493 |
$table_prefix = 'phpbb_';
|
|
494 |
$acm_type = 'file';
|
|
495 |
$load_extensions = '';
|
|
496 |
@define('PHPBB_INSTALLED', true);
|
|
497 |
// @define('DEBUG', true);
|
|
498 |
//@define('DEBUG_EXTRA', true);
|
|
499 |
||
500 |
$forum_secret = '""" + forum_secret +"""'; |
|
501 |
?>""" ) |
|
502 |
||
503 |
conf.close() |
|
504 |
except IOError, (errno, strerror): |
|
505 |
print "IO error(%s): %s" % (errno, strerror) |
|
506 |
sys.exit(1) |
|
507 |
||
508 |
print "Successfully wrote www/php/phpBB3/config.php" |
|
509 |
||
510 |
# Write lib/conf/usrmgt-server.init
|
|
511 |
||
512 |
try: |
|
513 |
conf = open(usrmgtserver_initdfile, "w") |
|
514 |
||
515 |
conf.write( '''#! /bin/sh |
|
516 |
||
517 |
# Works for Ubuntu. Check before using on other distributions
|
|
518 |
||
519 |
### BEGIN INIT INFO
|
|
520 |
# Provides: usrmgt-server
|
|
521 |
# Required-Start: $syslog $networking $urandom
|
|
522 |
# Required-Stop: $syslog
|
|
523 |
# Default-Start: 2 3 4 5
|
|
524 |
# Default-Stop: 1
|
|
525 |
# Short-Description: IVLE user management server
|
|
526 |
# Description: Daemon connecting to the IVLE user management database.
|
|
527 |
### END INIT INFO
|
|
528 |
||
529 |
PATH=/sbin:/bin:/usr/sbin:/usr/bin
|
|
530 |
DESC="IVLE user management server"
|
|
531 |
NAME=usrmgt-server
|
|
532 |
DAEMON=/opt/ivle/scripts/$NAME
|
|
533 |
DAEMON_ARGS="''' + str(usrmgt_port) + ''' ''' + usrmgt_magic + '''" |
|
534 |
PIDFILE=/var/run/$NAME.pid
|
|
535 |
SCRIPTNAME=/etc/init.d/usrmgt-server
|
|
536 |
||
537 |
# Exit if the daemon does not exist
|
|
538 |
test -f $DAEMON || exit 0
|
|
539 |
||
540 |
# Load the VERBOSE setting and other rcS variables
|
|
541 |
[ -f /etc/default/rcS ] && . /etc/default/rcS
|
|
542 |
||
543 |
# Define LSB log_* functions.
|
|
544 |
# Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
|
|
545 |
. /lib/lsb/init-functions
|
|
546 |
||
547 |
#
|
|
548 |
# Function that starts the daemon/service
|
|
549 |
#
|
|
550 |
do_start()
|
|
551 |
{
|
|
552 |
# Return
|
|
553 |
# 0 if daemon has been started
|
|
554 |
# 1 if daemon was already running
|
|
555 |
# 2 if daemon could not be started
|
|
556 |
start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON --test > /dev/null \ |
|
557 |
|| return 1
|
|
558 |
start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON -- \ |
|
559 |
$DAEMON_ARGS \ |
|
560 |
|| return 2
|
|
561 |
# Add code here, if necessary, that waits for the process to be ready
|
|
562 |
# to handle requests from services started subsequently which depend
|
|
563 |
# on this one. As a last resort, sleep for some time.
|
|
564 |
}
|
|
565 |
||
566 |
#
|
|
567 |
# Function that stops the daemon/service
|
|
568 |
#
|
|
569 |
do_stop()
|
|
570 |
{
|
|
571 |
# Return
|
|
572 |
# 0 if daemon has been stopped
|
|
573 |
# 1 if daemon was already stopped
|
|
574 |
# 2 if daemon could not be stopped
|
|
575 |
# other if a failure occurred
|
|
576 |
start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $NAME
|
|
577 |
RETVAL="$?"
|
|
578 |
[ "$RETVAL" = 2 ] && return 2
|
|
579 |
# Wait for children to finish too if this is a daemon that forks
|
|
580 |
# and if the daemon is only ever run from this initscript.
|
|
581 |
# If the above conditions are not satisfied then add some other code
|
|
582 |
# that waits for the process to drop all resources that could be
|
|
583 |
# needed by services started subsequently. A last resort is to
|
|
584 |
# sleep for some time.
|
|
585 |
start-stop-daemon --stop --quiet --oknodo --retry=0/30/KILL/5 --exec $DAEMON
|
|
586 |
[ "$?" = 2 ] && return 2
|
|
587 |
# Many daemons don't delete their pidfiles when they exit.
|
|
588 |
rm -f $PIDFILE
|
|
589 |
return "$RETVAL"
|
|
590 |
}
|
|
591 |
||
592 |
#
|
|
593 |
# Function that sends a SIGHUP to the daemon/service
|
|
594 |
#
|
|
595 |
do_reload() {
|
|
596 |
#
|
|
597 |
# If the daemon can reload its configuration without
|
|
598 |
# restarting (for example, when it is sent a SIGHUP),
|
|
599 |
# then implement that here.
|
|
600 |
#
|
|
601 |
start-stop-daemon --stop --signal 1 --quiet --pidfile $PIDFILE --name $NAME
|
|
602 |
return 0
|
|
603 |
}
|
|
604 |
||
605 |
case "$1" in
|
|
606 |
start)
|
|
607 |
[ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
|
|
608 |
do_start
|
|
609 |
case "$?" in
|
|
610 |
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
|
|
611 |
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
|
|
612 |
esac
|
|
613 |
;;
|
|
614 |
stop)
|
|
615 |
[ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
|
|
616 |
do_stop
|
|
617 |
case "$?" in
|
|
618 |
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
|
|
619 |
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
|
|
620 |
esac
|
|
621 |
;;
|
|
622 |
#reload|force-reload)
|
|
623 |
#
|
|
624 |
# If do_reload() is not implemented then leave this commented out
|
|
625 |
# and leave 'force-reload' as an alias for 'restart'.
|
|
626 |
#
|
|
627 |
#log_daemon_msg "Reloading $DESC" "$NAME"
|
|
628 |
#do_reload
|
|
629 |
#log_end_msg $?
|
|
630 |
#;;
|
|
631 |
restart|force-reload)
|
|
632 |
#
|
|
633 |
# If the "reload" option is implemented then remove the
|
|
634 |
# 'force-reload' alias
|
|
635 |
#
|
|
636 |
log_daemon_msg "Restarting $DESC" "$NAME"
|
|
637 |
do_stop
|
|
638 |
case "$?" in
|
|
639 |
0|1)
|
|
640 |
do_start
|
|
641 |
case "$?" in
|
|
642 |
0) log_end_msg 0 ;;
|
|
643 |
1) log_end_msg 1 ;; # Old process is still running
|
|
644 |
*) log_end_msg 1 ;; # Failed to start
|
|
645 |
esac
|
|
646 |
;;
|
|
647 |
*)
|
|
648 |
# Failed to stop
|
|
649 |
log_end_msg 1
|
|
650 |
;;
|
|
651 |
esac
|
|
652 |
;;
|
|
653 |
*)
|
|
654 |
#echo "Usage: $SCRIPTNAME {start|stop|restart|reload|force-reload}" >&2
|
|
655 |
echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload}" >&2
|
|
656 |
exit 3
|
|
657 |
;;
|
|
658 |
esac
|
|
659 |
||
660 |
:
|
|
661 |
''') |
|
662 |
||
663 |
conf.close() |
|
664 |
except IOError, (errno, strerror): |
|
665 |
print "IO error(%s): %s" % (errno, strerror) |
|
666 |
sys.exit(1) |
|
667 |
||
668 |
# fix permissions as the file contains the database password
|
|
669 |
try: |
|
670 |
os.chmod('doc/setup/usrmgt-server.init', 0600) |
|
671 |
except OSError, (errno, strerror): |
|
672 |
print "WARNING: Couldn't chmod doc/setup/usrmgt-server.init:" |
|
673 |
print "OS error(%s): %s" % (errno, strerror) |
|
674 |
||
675 |
print "Successfully wrote lib/conf/usrmgt-server.init" |
|
676 |
||
677 |
print
|
|
678 |
print "You may modify the configuration at any time by editing" |
|
679 |
print conffile |
|
680 |
print jailconffile |
|
681 |
print conf_hfile |
|
682 |
print phpBBconffile |
|
683 |
print usrmgtserver_initdfile |
|
684 |
print
|
|
685 |
||
686 |
return 0 |