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 python-ldap
42
sudo apt-get install php5 php5-pgsql
44
# Note: I had a lot of trouble with the python-svn package.
45
# After playing around a bit it started working.
46
# python -c 'import pysvn'
47
# to test if it worked.
48
# Do Not install python-svn-dbg.
50
##########################################################################
51
# Python packages needed by IVLE or student code
52
##########################################################################
54
# See trunk/doc/dependencies.txt
56
wget 'http://pypi.python.org/packages/source/p/python-cjson/python-cjson-1.0.5.tar.gz'
57
tar -zxvf python-cjson-1.0.5.tar.gz
61
sudo ./setup.py install
64
# Documentation packages needed for tutorial system: Docutils, Epydoc
65
# wget each of these, untar them, and then do: sudo python ./setup.py install
67
http://docutils.sourceforge.net/docutils-snapshot.tgz
68
http://downloads.sourceforge.net/epydoc/epydoc-3.0.1.tar.gz?use_mirror=optusnet
71
# (Note: epydoc doesn't work on Fiesty using apt-get)
73
sudo apt-get install python-docutils python-epydoc
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
75
28
##########################################################################
76
29
# Configure postgres
77
30
##########################################################################
79
# Some of these instructions follow
80
# https://help.ubuntu.com/community/PostgreSQL
81
# 1. install the base packages
83
32
# Set the postgres user's postgres password
84
sudo -u postgres psql template1
85
# At the prompt type (substituting <***password***> with a real one.
86
ALTER USER postgres WITH ENCRYPTED PASSWORD '<***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***>'"
89
36
##########################################################################
93
40
# Check out the IVLE trunk
95
export IVLE_SVN=ivle_svn
96
svn co https://ivle.svn.sourceforge.net/svnroot/ivle/trunk $IVLE_SVN
42
svn co https://ivle.svn.sourceforge.net/svnroot/ivle/trunk ivle_svn
99
45
# Create a postgres database
100
46
# (only need the first line if it was previously created and is now changed)
101
47
sudo -u postgres dropdb ivle
102
48
sudo -u postgres createdb ivle
49
sudo -u postgres createlang plpgsql ivle
103
50
sudo -u postgres psql -d ivle < userdb/users.sql
109
# "Root directory" - type "/" or "/ivle" (without the quotes)
110
# "UID of web server process" - 1000 at this stage (informatics)
111
# Leave others default.
112
# Note: This will cause IVLE to get installed to /opt/ivle
55
# -j is required to rebuild all jails, not just do an update
56
sudo ./setup.py build -j
115
57
sudo ./setup.py install
118
sudo ./makeuser.py [OPTIONS] <login> 'Firstname Lastname' <rolenm> -p <password>
60
sudo ivle-makeuser [OPTIONS] <login> 'Firstname Lastname' <rolenm> -p <password>
119
61
# role = guest/student/tutor/lecturer/admin
121
63
# Configure the Apache HTTP server
122
sudo cp doc/setup/ivle.conf /etc/apache2/sites-available
64
sudo cp doc/setup/ivle-both.conf /etc/apache2/sites-available/ivle
123
65
# MODIFY the first few lines so it is specific to your server.
124
vim /etc/apache2/sites-available/ivle.conf
126
# Replace the existing config link with the ivle one
127
cd /etc/apache2/sites-enabled/
128
sudo ln -fs /etc/apache2/sites-available/ivle.conf 000-default
130
# Make the directory corresponding to the directory for saved session
131
# objects in the apache config ivle.conf. Make sure it is owned by www-data,
132
# or at least readable and writable by it.
134
sudo mkdir /home/informatics/sessions
135
sudo chown www-data:www-data /home/informatics/sessions
138
sudo apache2ctl -k restart
66
# * Change ServerAdmin and ServerName (for error reporting).
67
# * Inside the first VirtualHost block, there are two ServerNames
68
# (localhost and public.localhost). You must change these to the domains
69
# for regular IVLE and published-browsing IVLE respectively.
70
# * Inside the second VirtualHost block, there is one ServerName
71
# (svn.localhost). You must change this to the domain for svn access.
72
# * Change all paths beginning with /opt/ivle or /home/informatics to the
73
# locations you have installed things in.
74
# * Update all of the paths to where you installed IVLE, if required.
75
sudo vim /etc/apache2/sites-available/ivle
77
# Replace the default with the IVLE site.
78
sudo a2dissite default
82
sudo /etc/init.d/apache2 restart
84
# Make sure the 3 domains given in Apache conf all lookup to your server.
85
# (By default these are localhost, public.localhost and svn.localhost).
86
# For testing purposes, this can be done by editing /etc/hosts, for example:
87
# 127.0.0.1 svn.localhost public.localhost
90
##########################################################################
91
# User management server: usrmgt-server
92
##########################################################################
94
sudo cp doc/setup/usrmgt-server.init /etc/init.d/usrmgt-server
95
sudo chown root:root /etc/init.d/usrmgt-server
96
sudo chmod +x /etc/init.d/usrmgt-server
99
sudo /etc/init.d/usrmgt-server start
101
# To run it at boot time:
102
sudo update-rc.d usrmgt-server defaults 99 # create symlinks in /etc/rc*.d
140
104
##########################################################################
141
105
# Setting up phpBB Forum in IVLE
142
106
##########################################################################
144
# Change to the installed IVLE directory
146
# Fix permissions for install
149
chmod 777 cache/ files/ store/ images/avatars/upload config.php
151
# Add database to Postgres server
152
sudo -u postgres createdb forum
154
# Log on to IVLE and open the Forum Application (/forum)
155
# Click 'INSTALL' tab, 'Proceed to next step'
156
# Check that requirements are OK
157
# Click 'Start install'
158
# Fill in Database configuration
159
# Database type: PostgreSQL 7.x/8.x
160
# # localhost doesn't work, but localhost.csse.unimelb.edu.au does?
161
# Database server hostname: 127.0.0.1
162
# Database name: forum
163
# Database username: postgres
164
# Database password: ##Same as password for ivle db##
165
# Complete the rest of the wizard with site settings
167
# Remove the Install directory to enable access
170
# Disable Registration...
172
##########################################################################
173
# Installing Pound reverse proxy (optional)
174
##########################################################################
176
sudo apt-get install pound
178
# edit /etc/default/pound so that the line reading
183
# copy pound.cfg to /etc/pound/pound.cfg
184
# edit IP addresses in pound.cfg
107
# This should all be run from the SVN directory
109
# Create a postgres database
110
# (only need the first line if it was previously created and is now changed)
111
sudo -u postgres dropdb ivle_forum
112
sudo -u postgres createdb ivle_forum
113
sudo -u postgres psql -d ivle_forum < userdb/forum_schema.sql
114
sudo -u postgres psql -d ivle_forum < userdb/forum_data.sql