1
1
# Installation Procedure for IVLE
2
2
# ===============================
4
# Target Platform: Ubuntu 8.04+
4
# Target Platform: Ubuntu 8.04
6
6
# IMPORTANT: This is NOT a shell script. It has interactive sections and
7
7
# things that need to be customized.
21
21
##########################################################################
22
22
sudo apt-get install rsync subversion build-essential debootstrap \
23
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
24
python2.5-dev python-svn python-webpy python-cjson \
25
postgresql python-pygresql php5 php5-pgsql \
26
python-docutils python-epydoc python-ldap
29
28
##########################################################################
30
29
# Configure postgres
37
36
##########################################################################
39
38
##########################################################################
40
# Check out the IVLE trunk
42
svn co https://ivle.svn.sourceforge.net/svnroot/ivle/trunk ivle_svn
41
45
# Create a postgres database
42
46
# (only need the first line if it was previously created and is now changed)
46
50
sudo -u postgres psql -d ivle < userdb/users.sql
56
# "Root directory" - type "/" or "/ivle" (without the quotes)
57
# "UID of web server process" - 1000 at this stage (informatics)
58
# Leave others default.
59
# Note: This will cause IVLE to get installed to /opt/ivle
61
sudo mkdir -p /home/informatics/{repositories/{users,groups},sessions,logs,jails,jailssrc}
62
sudo chown -R www-data:www-data /home/informatics/{repositories,sessions,logs}
50
65
sudo ./setup.py install
53
sudo ivle-createdatadirs
67
# Make the directory containing the svn auth.
68
# Make sure it is owned by www-data.
69
sudo mkdir /opt/ivle/svn
70
sudo chown -R www-data:www-data /opt/ivle/svn
55
# Create the jail. The mirror option is optional.
56
sudo ivle-buildjail -r -m http://url.to.archive/mirror
72
# Make the "repositories", "sessions" and "logs" directories in the home.
73
# Make sure they are owned by www-data.
59
sudo ivle-makeuser [OPTIONS] <login> 'Firstname Lastname' <rolenm> -p <password>
76
sudo ./makeuser.py [OPTIONS] <login> 'Firstname Lastname' <rolenm> -p <password>
60
77
# role = guest/student/tutor/lecturer/admin
62
79
# Configure the Apache HTTP server
63
80
sudo cp doc/setup/ivle-both.conf /etc/apache2/sites-available/ivle
64
81
# MODIFY the first few lines so it is specific to your server.
65
82
# * Change ServerAdmin and ServerName (for error reporting).
66
# * Inside the first VirtualHost block, there is a ServerName and ServerAlias
83
# * Inside the first VirtualHost block, there are two ServerNames
67
84
# (localhost and public.localhost). You must change these to the domains
68
85
# for regular IVLE and published-browsing IVLE respectively.
69
86
# * Inside the second VirtualHost block, there is one ServerName
70
87
# (svn.localhost). You must change this to the domain for svn access.
88
# * Change all paths beginning with /opt/ivle or /home/informatics to the
89
# locations you have installed things in.
71
90
sudo vim /etc/apache2/sites-available/ivle
73
92
# Replace the default with the IVLE site.
97
116
# To run it at boot time:
98
117
sudo update-rc.d usrmgt-server defaults 99 # create symlinks in /etc/rc*.d
119
##########################################################################
120
# Setting up phpBB Forum in IVLE
121
##########################################################################
122
# This should all be run from the SVN directory
124
# Create a postgres database
125
# (only need the first line if it was previously created and is now changed)
126
sudo -u postgres dropdb ivle_forum
127
sudo -u postgres createdb ivle_forum
128
sudo -u postgres psql -d ivle_forum < userdb/forum_schema.sql
129
sudo -u postgres psql -d ivle_forum < userdb/forum_data.sql
131
#Change to the installed IVLE directory
133
# Fix permissions for install
135
# At very minimum you apache user must be able to write to
136
# cache/ files/ store/ images/avatars/upload config.php
137
sudo chown -R www-data:www-data .
139
##########################################################################
140
# Installing Pound reverse proxy (optional)
141
##########################################################################
143
sudo apt-get install pound
145
# edit /etc/default/pound so that the line reading
150
# copy pound.cfg to /etc/pound/pound.cfg
151
# edit IP addresses in pound.cfg