1
# Installation Procedure for IVLE
2
# ===============================
4
# Target Platform: Ubuntu 7.10
6
# IMPORTANT: This is NOT a shell script. It has interactive sections and
7
# things that need to be customized.
8
# It is written like a shell script so it can be mostly cut-and-pasted into
9
# the shell, but it can't simply be executed.
11
# While other install guides in this package are generic, this one is very
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.
14
# This refers to ivle.conf, also included.
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
##########################################################################
34
##########################################################################
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
##########################################################################
66
##########################################################################
68
# Some of these instructions follow
69
# https://help.ubuntu.com/community/PostgreSQL
70
# 1. install the base packages
72
# Set the postgres user's postgres password
73
sudo -u postgres psql template1
74
# At the prompt type (substituting <***password***> with a real one.
75
ALTER USER postgres WITH ENCRYPTED PASSWORD '<***password***>';
78
##########################################################################
80
##########################################################################
82
# Check out the IVLE trunk
84
export IVLE_SVN=ivle_svn
85
svn co https://ivle.svn.sourceforge.net/svnroot/ivle/trunk $IVLE_SVN
88
# Create a postgres database
89
# (only need the first line if it was previously created and is now changed)
90
sudo -u postgres dropdb ivle
91
sudo -u postgres createdb ivle
92
sudo -u postgres psql -d ivle < userdb/users.sql
98
# "Root directory" - type "/" or "/ivle" (without the quotes)
99
# "UID of web server process" - 1000 at this stage (informatics)
100
# Leave others default.
101
# Note: This will cause IVLE to get installed to /opt/ivle
104
sudo ./setup.py install
107
sudo ./makeuser.py [OPTIONS] <login> 'Firstname Lastname' <rolenm> -p <password>
108
# role = guest/student/tutor/lecturer/admin
110
# Configure the Apache HTTP server
111
sudo cp doc/setup/ivle.conf /etc/apache2/sites-available
112
# MODIFY the first few lines so it is specific to your server.
113
vim /etc/apache2/sites-available/ivle.conf
115
# Replace the existing config link with the ivle one
116
cd /etc/apache2/sites-enabled/
117
sudo ln -fs /etc/apache2/sites-available/ivle.conf 000-default
119
# Make the directory corresponding to the directory for saved session
120
# objects in the apache config ivle.conf. Make sure it is owned by www-data,
121
# or at least readable and writable by it.
123
sudo mkdir /home/informatics/sessions
124
sudo chown www-data:www-data /home/informatics/sessions
127
sudo apache2ctl -k restart
129
##########################################################################
130
# Setting up phpBB Forum in IVLE
131
##########################################################################
133
# Change to the installed IVLE directory
135
# Fix permissions for install
138
chmod 777 cache/ files/ store/ images/avatars/upload config.php
140
# Add database to Postgres server
141
sudo -u postgres createdb forum
143
# Log on to IVLE and open the Forum Application (/forum)
144
# Click 'INSTALL' tab, 'Proceed to next step'
145
# Check that requirements are OK
146
# Click 'Start install'
147
# Fill in Database configuration
148
# Database type: PostgreSQL 7.x/8.x
149
# # localhost doesn't work, but localhost.csse.unimelb.edu.au does?
150
# Database server hostname: 127.0.0.1
151
# Database name: forum
152
# Database username: postgres
153
# Database password: ##Same as password for ivle db##
154
# Complete the rest of the wizard with site settings
156
# Remove the Install directory to enable access
159
# Disable Registration...
161
##########################################################################
162
# Installing Pound reverse proxy (optional)
163
##########################################################################
165
sudo apt-get install pound
167
# edit /etc/default/pound so that the line reading
172
# copy pound.cfg to /etc/pound/pound.cfg
173
# edit IP addresses in pound.cfg