11
11
# While other install guides in this package are generic, this one is very
12
12
# specific to our intended configuration. It will be very helpful if trying to
13
# set up IVLE on Ubuntu 7.06 or higher; less helpful for other platforms.
13
# set up IVLE on Ubuntu 8.04 or higher; less helpful for other platforms.
14
14
# This refers to ivle.conf, also included.
16
16
# Author: Matt Giuca
19
sudo vim /etc/apt/sources.list
21
# Gutsy by default had the CD-ROM packages selected, and the Internet packages
22
# commented out. (A comment in the apt sources list said it was because it
23
# failed to verify - IMPORTANT?? Probably not.)
24
# Comment out line 4 (deb cdrom:...)
26
# Uncomment ALL the lines for main, restricted and universe
27
# (deb http:...gutsy main restricted, deb-src ... main restricted
28
# deb http:...gutsy universe)
29
# Universe is important for pysvn (python-svn) later on
32
19
##########################################################################
34
21
##########################################################################
37
sudo apt-get install subversion
38
sudo apt-get install gcc libc6 libc6-dev make
39
sudo apt-get install apache2 libapache2-mod-python
40
sudo apt-get install python2.5-dev python-svn python-webpy python-numpy python-matplotlib
41
sudo apt-get install postgresql python-pygresql
43
# Note: I had a lot of trouble with the python-svn package.
44
# After playing around a bit it started working.
45
# python -c 'import pysvn'
46
# to test if it worked.
47
# Do Not install python-svn-dbg.
49
##########################################################################
50
# Python packages needed by IVLE or student code
51
##########################################################################
53
# See trunk/doc/dependencies.txt
55
wget 'http://pypi.python.org/packages/source/p/python-cjson/python-cjson-1.0.5.tar.gz'
56
tar -zxvf python-cjson-1.0.5.tar.gz
60
sudo ./setup.py install
22
sudo apt-get install rsync subversion build-essential debootstrap \
23
apache2 libapache2-mod-python libapache2-svn \
24
python-svn python-cjson python-genshi \
25
python-configobj postgresql python-routes \
26
python-docutils python-epydoc \
27
python-storm python-psycopg2
63
29
##########################################################################
64
30
# Configure postgres
65
31
##########################################################################
67
# Some of these instructions follow
68
# https://help.ubuntu.com/community/PostgreSQL
69
# 1. install the base packages
71
33
# Set the postgres user's postgres password
72
sudo -u postgres psql template1
73
# At the prompt type (substituting <***password***> with a real one.
74
ALTER USER postgres WITH ENCRYPTED PASSWORD '<***password***>';
34
# At the prompt type (substituting <***password***> with a real one).
35
sudo -u postgres psql -c "ALTER USER postgres WITH ENCRYPTED PASSWORD '<***password***>'"
77
37
##########################################################################
79
39
##########################################################################
81
# Check out the IVLE trunk
83
export IVLE_SVN=ivle_svn
84
svn co https://ivle.svn.sourceforge.net/svnroot/ivle/trunk $IVLE_SVN
87
41
# Create a postgres database
88
sudo -u postgres dropdb ivle # if it was previously created and now changed
42
# (only need the first line if it was previously created and is now changed)
43
sudo -u postgres dropdb ivle
89
44
sudo -u postgres createdb ivle
45
sudo -u postgres createlang plpgsql ivle
90
46
sudo -u postgres psql -d ivle < userdb/users.sql
96
# "Root directory" - type "/" or "/ivle"
97
# "UID of web server process" - 1000 at this stage (informatics)
98
# Leave others default.
99
# Note: This will cause IVLE to get installed to /opt/ivle
102
50
sudo ./setup.py install
53
sudo ivle-createdatadirs
55
# Create the jail. The mirror option is optional.
56
sudo ivle-buildjail -r -m http://url.to.archive/mirror
105
sudo ./makeuser.py [OPTIONS] <login> 'Firstname Lastname' <rolenm> -p <password>
59
sudo ivle-makeuser [OPTIONS] <login> 'Firstname Lastname' <rolenm> -p <password>
106
60
# role = guest/student/tutor/lecturer/admin
108
62
# Configure the Apache HTTP server
109
sudo cp setup/ivle.conf /etc/apache2/sites-available
63
sudo cp doc/setup/ivle-both.conf /etc/apache2/sites-available/ivle
110
64
# MODIFY the first few lines so it is specific to your server.
111
vim /etc/apache2/sites-available/ivle.conf
113
# Replace the existing config link with the ivle one
114
cd /etc/apache2/sites-enabled/
115
sudo ln -fs /etc/apache2/sites-available/ivle.conf 000-default
117
# Make the directory corresponding to the directory for saved session
118
# objects in the apache config ivle.conf. Make sure it is owned by www-data,
119
# or at least readable and writable by it.
121
sudo mkdir /home/informatics/sessions
122
sudo chown www-data:www-data /home/informatics/sessions
125
sudo apache2ctl -k restart
128
##########################################################################
129
# Installing Pound reverse proxy (optional)
130
##########################################################################
132
sudo apt-get install pound
134
# edit /etc/default/pound so that the line reading
139
# copy pound.cfg to /etc/pound/pound.cfg
140
# edit IP addresses in pound.cfg
65
# * Change ServerAdmin and ServerName (for error reporting).
66
# * Inside the first VirtualHost block, there is a ServerName and ServerAlias
67
# (localhost and public.localhost). You must change these to the domains
68
# for regular IVLE and published-browsing IVLE respectively.
69
# * Inside the second VirtualHost block, there is one ServerName
70
# (svn.localhost). You must change this to the domain for svn access.
71
sudo vim /etc/apache2/sites-available/ivle
73
# Replace the default with the IVLE site.
74
sudo a2dissite default
78
sudo /etc/init.d/apache2 restart
80
# Make sure the 3 domains given in Apache conf all lookup to your server.
81
# (By default these are localhost, public.localhost and svn.localhost).
82
# For testing purposes, this can be done by editing /etc/hosts, for example:
83
# 127.0.0.1 svn.localhost public.localhost
86
##########################################################################
87
# User management server: usrmgt-server
88
##########################################################################
90
sudo cp doc/setup/usrmgt-server.init /etc/init.d/usrmgt-server
91
sudo chown root:root /etc/init.d/usrmgt-server
92
sudo chmod +x /etc/init.d/usrmgt-server
95
sudo /etc/init.d/usrmgt-server start
97
# To run it at boot time:
98
sudo update-rc.d usrmgt-server defaults 99 # create symlinks in /etc/rc*.d