12
11
# While other install guides in this package are generic, this one is very
13
12
# specific to our intended configuration. It will be very helpful if trying to
14
# 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.
15
14
# This refers to ivle.conf, also included.
17
16
# Author: Matt Giuca
20
sudo vim /etc/apt/sources.list
22
# 7.10 (Gutsy) specific #
24
# Gutsy by default had the CD-ROM packages selected, and the Internet packages
25
# commented out. (A comment in the apt sources list said it was because it
26
# failed to verify - IMPORTANT?? Probably not.)
27
# Comment out line 4 (deb cdrom:...)
29
# End 7.10 (Gutsy) specific #
31
# Uncomment ALL the lines for main, restricted and universe
32
# (deb http:...gutsy main restricted, deb-src ... main restricted
33
# deb http:...gutsy universe)
34
# Universe is important for pysvn (python-svn) later on
19
##########################################################################
40
sudo apt-get install subversion
41
sudo apt-get install gcc libc6 libc6-dev
43
sudo apt-get install python2.4-dev
45
sudo apt-get install python2.5-dev
47
# Python packages needed by IVLE or student code
48
# See trunk/doc/dependencies.txt
49
wget 'http://pypi.python.org/packages/source/p/python-cjson/python-cjson-1.0.5.tar.gz'
51
tar -zxvf python-cjson-1.0.5.tar.gz
55
sudo ./setup.py install
58
# 6.06 (Dapper) specific
59
wget 'http://webpy.org/static/web.py-0.22.tar.gz'
60
tar -zxvf web.py-0.22.tar.gz
62
python ./setup.py build
63
sudo python ./setup.py install
66
sudo apt-get install python-svn python-webpy python2.4-gtk2 python-matplotlib
67
# End 6.06 (Dapper) specific
69
# 7.10 (Gutsy) specific
70
sudo apt-get install python-svn python-webpy python-numpy python-matplotlib
71
# Note: I had a lot of trouble with the python-svn package.
72
# After playing around a bit it started working.
73
# python -c 'import pysvn'
74
# to test if it worked.
75
# Do Not install python-svn-dbg.
76
# End 7.10 (Gutsy) specific
21
##########################################################################
22
sudo apt-get install rsync subversion build-essential debootstrap \
23
apache2 libapache2-mod-python libapache2-svn \
24
python2.5-dev python-svn python-webpy python-cjson \
25
postgresql python-pygresql php5 php5-pgsql \
26
python-docutils python-epydoc python-ldap
28
##########################################################################
30
##########################################################################
32
# Set the postgres user's postgres password
33
# At the prompt type (substituting <***password***> with a real one).
34
sudo -u postgres psql -c "ALTER USER postgres WITH ENCRYPTED PASSWORD '<***password***>'"
36
##########################################################################
38
##########################################################################
78
40
# Check out the IVLE trunk
79
42
svn co https://ivle.svn.sourceforge.net/svnroot/ivle/trunk ivle_svn
80
# Says the SourceForge certificate authority is not trusted.
81
# I chose "Accept (p)ermanently" - Problem??
83
# NOTE: From this point onwards it is 7.10 (Gutsy) specific. This is because I
84
# never was able to get IVLE to build with all dependencies on Dapper.
45
# Create a postgres database
46
# (only need the first line if it was previously created and is now changed)
47
sudo -u postgres dropdb ivle
48
sudo -u postgres createdb ivle
49
sudo -u postgres createlang plpgsql ivle
50
sudo -u postgres psql -d ivle < userdb/users.sql
88
53
./setup.py listmake
91
# "Root directory" - type "/"
56
# "Root directory" - type "/" or "/ivle" (without the quotes)
92
57
# "UID of web server process" - 1000 at this stage (informatics)
93
58
# Leave others default.
94
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}
97
65
sudo ./setup.py install
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
72
# Make the "repositories", "sessions" and "logs" directories in the home.
73
# Make sure they are owned by www-data.
100
sudo ./makeuser.py <username>
102
# Set up the Apache HTTP server
103
sudo apt-get install apache2 libapache2-mod-python
105
# DO: Copy the file "ivle.conf" from this package to
106
# /etc/apache2/sites-available.
76
sudo ./makeuser.py [OPTIONS] <login> 'Firstname Lastname' <rolenm> -p <password>
77
# role = guest/student/tutor/lecturer/admin
79
# Configure the Apache HTTP server
80
sudo cp doc/setup/ivle-both.conf /etc/apache2/sites-available/ivle
107
81
# MODIFY the first few lines so it is specific to your server.
109
# Replace the existing config link with the ivle one
110
cd /etc/apache2/sites-enabled/
111
sudo ln -fs /etc/apache2/sites-available/ivle.conf 000-default
114
sudo apache2ctl -k restart
117
# Installing postgres
118
# ===============================
120
# Some of these instructions follow
121
# https://help.ubuntu.com/community/PostgreSQL
122
# 1. install the base packages
124
sudo apt-get install postgresql
125
sudo apt-get install python-pygresql
127
# Set the postgres user's postgres password
128
sudo -u postgres psql template1
129
# At the prompt type (substituting <***password***> with a real one.
130
ALTER USER postgres WITH ENCRYPTED PASSWORD '<***password***>';
134
cd <<ivle source directory>>/userdb
135
sudo -u postgres createdb ivle
136
sudo -u postgres psql -d ivle < users.sql
82
# * Change ServerAdmin and ServerName (for error reporting).
83
# * Inside the first VirtualHost block, there are two ServerNames
84
# (localhost and public.localhost). You must change these to the domains
85
# for regular IVLE and published-browsing IVLE respectively.
86
# * Inside the second VirtualHost block, there is one ServerName
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.
90
sudo vim /etc/apache2/sites-available/ivle
92
# Replace the default with the IVLE site.
93
sudo a2dissite default
97
sudo /etc/init.d/apache2 restart
99
# Make sure the 3 domains given in Apache conf all lookup to your server.
100
# (By default these are localhost, public.localhost and svn.localhost).
101
# For testing purposes, this can be done by editing /etc/hosts, for example:
102
# 127.0.0.1 svn.localhost public.localhost
105
##########################################################################
106
# User management server: usrmgt-server
107
##########################################################################
109
sudo cp doc/setup/usrmgt-server.init /etc/init.d/usrmgt-server
110
sudo chown root:root /etc/init.d/usrmgt-server
111
sudo chmod +x /etc/init.d/usrmgt-server
114
sudo /etc/init.d/usrmgt-server start
116
# To run it at boot time:
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
##########################################################################
140
143
sudo apt-get install pound
142
145
# edit /etc/default/pound so that the line reading