103
101
# Needed by python
104
102
'/usr/bin/python%s' % PYTHON_VERSION,
105
# Needed by fileservice
106
'/lib/libcom_err.so.2',
107
'/lib/libcrypt.so.1',
108
'/lib/libkeyutils.so.1',
109
'/lib/libresolv.so.2',
112
'/usr/lib/libapr-1.so.0',
113
'/usr/lib/libaprutil-1.so.0',
114
'/usr/lib/libdb-4.4.so',
115
'/usr/lib/libexpat.so.1',
116
'/usr/lib/libgcrypt.so.11',
117
'/usr/lib/libgnutls.so.13',
118
'/usr/lib/libgpg-error.so.0',
119
'/usr/lib/libgssapi_krb5.so.2',
120
'/usr/lib/libk5crypto.so.3',
121
'/usr/lib/libkrb5.so.3',
122
'/usr/lib/libkrb5support.so.0',
123
'/usr/lib/liblber.so.2',
124
'/usr/lib/libldap_r.so.2',
125
'/usr/lib/libneon.so.26',
126
'/usr/lib/libpq.so.5',
127
'/usr/lib/libsasl2.so.2',
128
'/usr/lib/libsqlite3.so.0',
129
'/usr/lib/libsvn_client-1.so.1',
130
'/usr/lib/libsvn_delta-1.so.1',
131
'/usr/lib/libsvn_diff-1.so.1',
132
'/usr/lib/libsvn_fs-1.so.1',
133
'/usr/lib/libsvn_fs_base-1.so.1',
134
'/usr/lib/libsvn_fs_fs-1.so.1',
135
'/usr/lib/libsvn_ra-1.so.1',
136
'/usr/lib/libsvn_ra_dav-1.so.1',
137
'/usr/lib/libsvn_ra_local-1.so.1',
138
'/usr/lib/libsvn_ra_svn-1.so.1',
139
'/usr/lib/libsvn_repos-1.so.1',
140
'/usr/lib/libsvn_subr-1.so.1',
141
'/usr/lib/libsvn_wc-1.so.1',
142
'/usr/lib/libtasn1.so.3',
143
'/usr/lib/libxml2.so.2',
144
103
# Needed by matplotlib
145
104
'/usr/lib/i686/cmov/libssl.so.0.9.8',
146
105
'/usr/lib/i686/cmov/libcrypto.so.0.9.8',
232
179
# In the local file system, where are the per-subject file spaces located.
233
180
# The individual subject directories are expected to be located immediately
234
181
# in subdirectories of this location."""))
235
config_options.append(ConfigOption("exercises_base",
236
"/home/informatics/exercises",
237
"""Root directory where the exercise directories (containing
238
subject-independent exercise sheets) are stored (on the local file
182
config_options.append(ConfigOption("problems_base",
183
"/home/informatics/problems",
184
"""Root directory where the problem directories (containing
185
subject-independent problem sheets) are stored (on the local file
241
# In the local file system, where are the subject-independent exercise sheet
188
# In the local file system, where are the subject-independent problem sheet
242
189
# file spaces located."""))
243
config_options.append(ConfigOption("tos_path",
244
"/home/informatics/tos.html",
245
"""Location where the Terms of Service document is stored (on the local
248
# In the local file system, where is the Terms of Service document located."""))
249
config_options.append(ConfigOption("motd_path",
250
"/home/informatics/motd.html",
251
"""Location where the Message of the Day document is stored (on the local
254
# In the local file system, where is the Message of the Day document
255
# located. This is an HTML file (just the body fragment), which will
256
# be displayed on the login page. It is optional."""))
257
190
config_options.append(ConfigOption("public_host", "public.localhost",
258
191
"""Hostname which will cause the server to go into "public mode",
259
192
providing login-free access to student's published work:""",
302
231
(Caution: This password is stored in plaintext in lib/conf/conf.py)""",
304
233
# Database password"""))
305
config_options.append(ConfigOption("auth_modules", "ldap_auth",
306
"""Authentication config
307
=====================
308
Comma-separated list of authentication modules. Only "ldap" is available
311
# Comma-separated list of authentication modules.
312
# These refer to importable Python modules in the www/auth directory.
313
# Modules "ldap" and "guest" are available in the source tree, but
314
# other modules may be plugged in to auth against organisation-specific
315
# auth backends."""))
316
config_options.append(ConfigOption("ldap_url", "ldaps://www.example.com",
317
"""(LDAP options are only relevant if "ldap" is included in the list of
319
URL for LDAP authentication server:""",
321
# URL for LDAP authentication server"""))
322
config_options.append(ConfigOption("ldap_format_string",
323
"uid=%s,ou=users,o=example",
324
"""Format string for LDAP auth request:
325
(Must contain a single "%s" for the user's login name)""",
327
# Format string for LDAP auth request
328
# (Must contain a single "%s" for the user's login name)"""))
329
config_options.append(ConfigOption("svn_addr", "http://svn.localhost/",
332
The base url for accessing subversion repositories:""",
334
# The base url for accessing subversion repositories."""))
335
config_options.append(ConfigOption("svn_conf", "/opt/ivle/svn/svn.conf",
336
"""The location of the subversion configuration file used by apache
337
to host the user repositories:""",
339
# The location of the subversion configuration file used by
340
# apache to host the user repositories."""))
341
config_options.append(ConfigOption("svn_repo_path", "/home/informatics/repositories",
342
"""The root directory for the subversion repositories:""",
344
# The root directory for the subversion repositories."""))
345
config_options.append(ConfigOption("svn_auth_ivle", "/opt/ivle/svn/ivle.auth",
346
"""The location of the password file used to authenticate users
347
of the subversion repository from the ivle server:""",
349
# The location of the password file used to authenticate users
350
# of the subversion repository from the ivle server."""))
351
config_options.append(ConfigOption("svn_auth_local", "/opt/ivle/svn/local.auth",
352
"""The location of the password file used to authenticate local users
353
of the subversion repository:""",
355
# The location of the password file used to authenticate local users
356
# of the subversion repository."""))
357
config_options.append(ConfigOption("usrmgt_host", "localhost",
358
"""User Management Server config
359
============================
360
The hostname where the usrmgt-server runs:""",
362
# The hostname where the usrmgt-server runs."""))
363
config_options.append(ConfigOption("usrmgt_port", "2178",
364
"""The port where the usrmgt-server runs:""",
366
# The port where the usrmgt-server runs."""))
367
config_options.append(ConfigOption("usrmgt_magic", "",
368
"""The password for the usrmgt-server:""",
370
# The password for the usrmgt-server."""))
372
235
# Try importing existing conf, but if we can't just set up defaults
373
236
# The reason for this is that these settings are used by other phases
540
403
# We build two separate lists, by walking www and console
541
404
list_www = build_list_py_files('www')
542
405
list_lib = build_list_py_files('lib')
406
list_console = build_list_py_files('console')
543
407
list_subjects = build_list_py_files('subjects', no_top_level=True)
544
list_exercises = build_list_py_files('exercises', no_top_level=True)
546
"scripts/python-console",
547
"scripts/fileservice",
548
"scripts/serveservice",
549
"scripts/usrmgt-server",
550
"scripts/diffservice",
408
list_problems = build_list_py_files('problems', no_top_level=True)
552
409
# Make sure that the files generated by conf are in the list
553
410
# (since listmake is typically run before conf)
554
411
if "lib/conf/conf.py" not in list_lib:
555
list_lib.append("lib/conf/conf.py")
412
list_www.append("lib/conf/conf.py")
413
# Make sure that console/python-console is in the list
414
if "console/python-console" not in list_console:
415
list_console.append("console/python-console")
556
416
# Write these out to a file
557
417
cwd = os.getcwd()
558
418
# the files that will be created/overwritten
738
578
print "Successfully wrote lib/conf/conf.py"
740
# Write conf/jailconf.py
743
conf = open(jailconffile, "w")
745
# In the "in-jail" version of conf, we don't need MOST of the details
746
# (it would be a security risk to have them here).
747
# So we just write root_dir, and jail_base is "/".
748
# (jail_base being "/" means "jail-relative" paths are relative to "/"
749
# when inside the jail.)
750
conf.write("""# IVLE Configuration File
752
# Miscellaneous application settings
753
# (User jail version)
756
# In URL space, where in the site is IVLE located. (All URLs will be prefixed
758
# eg. "/" or "/ivle".
761
# In the local file system, where are the student/user file spaces located.
762
# The user jails are expected to be located immediately in subdirectories of
766
# The hostname for serving publicly accessible pages
768
""" % (repr(root_dir),repr(public_host)))
771
except IOError, (errno, strerror):
772
print "IO error(%s): %s" % (errno, strerror)
775
print "Successfully wrote lib/conf/jailconf.py"
777
580
# Write trampoline/conf.h
810
610
print "Successfully wrote trampoline/conf.h"
812
# Write www/php/phpBB3/config.php
815
conf = open(phpBBconffile, "w")
818
if db_host == 'localhost':
819
forumdb_host = '127.0.0.1'
821
forumdb_host = db_host
824
// phpBB 3.0.x auto-generated configuration file
825
// Do not change anything in this file!
827
$dbhost = '""" + forumdb_host + """';
828
$dbport = '""" + str(db_port) + """';
829
$dbname = '""" + db_forumdbname + """';
830
$dbuser = '""" + db_user + """';
831
$dbpasswd = '""" + db_password + """';
833
$table_prefix = 'phpbb_';
835
$load_extensions = '';
836
@define('PHPBB_INSTALLED', true);
837
// @define('DEBUG', true);
838
//@define('DEBUG_EXTRA', true);
840
$forum_secret = '""" + forum_secret +"""';
844
except IOError, (errno, strerror):
845
print "IO error(%s): %s" % (errno, strerror)
848
print "Successfully wrote www/php/phpBB3/config.php"
850
# Write lib/conf/usrmgt-server.init
853
conf = open(usrmgtserver_initdfile, "w")
855
conf.write( '''#! /bin/sh
857
# Works for Ubuntu. Check before using on other distributions
860
# Provides: usrmgt-server
861
# Required-Start: $syslog $networking $urandom
862
# Required-Stop: $syslog
863
# Default-Start: 2 3 4 5
865
# Short-Description: IVLE user management server
866
# Description: Daemon connecting to the IVLE user management database.
869
PATH=/sbin:/bin:/usr/sbin:/usr/bin
870
DESC="IVLE user management server"
872
DAEMON=/opt/ivle/scripts/$NAME
873
DAEMON_ARGS="''' + str(usrmgt_port) + ''' ''' + usrmgt_magic + '''"
874
PIDFILE=/var/run/$NAME.pid
875
SCRIPTNAME=/etc/init.d/usrmgt-server
877
# Exit if the daemon does not exist
878
test -f $DAEMON || exit 0
880
# Load the VERBOSE setting and other rcS variables
881
[ -f /etc/default/rcS ] && . /etc/default/rcS
883
# Define LSB log_* functions.
884
# Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
885
. /lib/lsb/init-functions
888
# Function that starts the daemon/service
893
# 0 if daemon has been started
894
# 1 if daemon was already running
895
# 2 if daemon could not be started
896
start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON --test > /dev/null \
898
start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON -- \
901
# Add code here, if necessary, that waits for the process to be ready
902
# to handle requests from services started subsequently which depend
903
# on this one. As a last resort, sleep for some time.
907
# Function that stops the daemon/service
912
# 0 if daemon has been stopped
913
# 1 if daemon was already stopped
914
# 2 if daemon could not be stopped
915
# other if a failure occurred
916
start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $NAME
918
[ "$RETVAL" = 2 ] && return 2
919
# Wait for children to finish too if this is a daemon that forks
920
# and if the daemon is only ever run from this initscript.
921
# If the above conditions are not satisfied then add some other code
922
# that waits for the process to drop all resources that could be
923
# needed by services started subsequently. A last resort is to
924
# sleep for some time.
925
start-stop-daemon --stop --quiet --oknodo --retry=0/30/KILL/5 --exec $DAEMON
926
[ "$?" = 2 ] && return 2
927
# Many daemons don't delete their pidfiles when they exit.
933
# Function that sends a SIGHUP to the daemon/service
937
# If the daemon can reload its configuration without
938
# restarting (for example, when it is sent a SIGHUP),
939
# then implement that here.
941
start-stop-daemon --stop --signal 1 --quiet --pidfile $PIDFILE --name $NAME
947
[ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
950
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
951
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
955
[ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
958
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
959
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
962
#reload|force-reload)
964
# If do_reload() is not implemented then leave this commented out
965
# and leave 'force-reload' as an alias for 'restart'.
967
#log_daemon_msg "Reloading $DESC" "$NAME"
971
restart|force-reload)
973
# If the "reload" option is implemented then remove the
974
# 'force-reload' alias
976
log_daemon_msg "Restarting $DESC" "$NAME"
983
1) log_end_msg 1 ;; # Old process is still running
984
*) log_end_msg 1 ;; # Failed to start
994
#echo "Usage: $SCRIPTNAME {start|stop|restart|reload|force-reload}" >&2
995
echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload}" >&2
1004
except IOError, (errno, strerror):
1005
print "IO error(%s): %s" % (errno, strerror)
1008
# fix permissions as the file contains the database password
1010
os.chmod('doc/setup/usrmgt-server.init', 0600)
1011
except OSError, (errno, strerror):
1012
print "WARNING: Couldn't chmod doc/setup/usrmgt-server.init:"
1013
print "OS error(%s): %s" % (errno, strerror)
1015
print "Successfully wrote lib/conf/usrmgt-server.init"
1018
613
print "You may modify the configuration at any time by editing"
1021
615
print conf_hfile
1023
print usrmgtserver_initdfile
1045
637
action_mkdir('jail/home', dry)
1046
638
action_mkdir('jail/tmp', dry)
1048
# Chmod the tmp directory to world writable
1049
action_chmod_w('jail/tmp', dry)
1051
640
# Copy all console and operating system files into the jail
1052
action_copylist(install_list.list_scripts, 'jail/opt/ivle', dry)
641
action_copylist(install_list.list_console, 'jail/opt/ivle', dry)
1053
642
copy_os_files_jail(dry)
1054
643
# Chmod the python console
1055
action_chmod_x('jail/opt/ivle/scripts/python-console', dry)
1056
action_chmod_x('jail/opt/ivle/scripts/fileservice', dry)
1057
action_chmod_x('jail/opt/ivle/scripts/serveservice', dry)
644
action_chmod_x('jail/opt/ivle/console/python-console', dry)
1059
# Also copy the IVLE lib directory into the jail
1060
# This is necessary for running certain scripts
1061
action_copylist(install_list.list_lib, 'jail/opt/ivle', dry)
1062
# IMPORTANT: The file jail/opt/ivle/lib/conf/conf.py contains details
1063
# which could compromise security if left in the jail (such as the DB
1065
# The "safe" version is in jailconf.py. Delete conf.py and replace it with
1067
action_copyfile('lib/conf/jailconf.py',
1068
'jail/opt/ivle/lib/conf/conf.py', dry)
1070
647
# Compile .py files into .pyc or .pyo files
1071
648
compileall.compile_dir('www', quiet=True)
1072
compileall.compile_dir('lib', quiet=True)
1073
compileall.compile_dir('scripts', quiet=True)
1074
compileall.compile_dir('jail/opt/ivle/lib', quiet=True)
1076
# Set up ivle.pth inside the jail
1077
# Need to set /opt/ivle/lib to be on the import path
1079
"jail/usr/lib/python%s/site-packages/ivle.pth" % PYTHON_VERSION
1080
f = open(ivle_pth, 'w')
1081
f.write('/opt/ivle/lib\n')
649
compileall.compile_dir('console', quiet=True)
1127
694
# chown trampoline to root and set setuid bit
1128
695
action_chown_setuid(tramppath, dry)
1130
# Create a scripts directory to put the usrmgt-server in.
1131
action_mkdir(os.path.join(ivle_install_dir, 'scripts'), dry)
1132
usrmgtpath = os.path.join(ivle_install_dir, 'scripts/usrmgt-server')
1133
action_copyfile('scripts/usrmgt-server', usrmgtpath, dry)
1134
action_chmod_x(usrmgtpath, dry)
1136
697
# Copy the www and lib directories using the list
1137
698
action_copylist(install_list.list_www, ivle_install_dir, dry)
1138
699
action_copylist(install_list.list_lib, ivle_install_dir, dry)
1140
# Copy the php directory
1141
forum_dir = "www/php/phpBB3"
1142
forum_path = os.path.join(ivle_install_dir, forum_dir)
1143
action_copytree(forum_dir, forum_path, dry)
1144
print "chown -R www-data:www-data %s" % forum_path
1146
os.system("chown -R www-data:www-data %s" % forum_path)
1149
702
# Copy the local jail directory built by the build action