19
19
##########################################################################
21
21
##########################################################################
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
23
sudo apt-get install subversion
24
sudo apt-get install gcc libc6 libc6-dev make debootstrap
25
sudo apt-get install apache2 libapache2-mod-python libapache2-svn
26
sudo apt-get install python2.5-dev python-svn python-webpy
27
sudo apt-get install postgresql python-pygresql python-ldap
28
sudo apt-get install php5 php5-pgsql
29
sudo apt-get install python-cjson
30
sudo apt-get install python-docutils python-epydoc
29
32
##########################################################################
30
33
# Configure postgres
31
34
##########################################################################
36
# Some of these instructions follow
37
# https://help.ubuntu.com/community/PostgreSQL
38
# 1. install the base packages
33
40
# Set the postgres user's postgres 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***>'"
41
sudo -u postgres psql template1
42
# At the prompt type (substituting <***password***> with a real one.
43
ALTER USER postgres WITH ENCRYPTED PASSWORD '<***password***>';
37
46
##########################################################################
39
48
##########################################################################
50
# Check out the IVLE trunk
52
export IVLE_SVN=ivle_svn
53
svn co https://ivle.svn.sourceforge.net/svnroot/ivle/trunk $IVLE_SVN
41
56
# Create a postgres database
42
57
# (only need the first line if it was previously created and is now changed)
43
58
sudo -u postgres dropdb ivle
44
59
sudo -u postgres createdb ivle
45
sudo -u postgres createlang plpgsql ivle
46
60
sudo -u postgres psql -d ivle < userdb/users.sql
66
# "Root directory" - type "/" or "/ivle" (without the quotes)
67
# "UID of web server process" - 1000 at this stage (informatics)
68
# Leave others default.
69
# Note: This will cause IVLE to get installed to /opt/ivle
50
72
sudo ./setup.py install
53
sudo ivle-createdatadirs
74
# Make the directory containing the svn auth.
75
# Make sure it is owned by www-data.
76
sudo mkdir /opt/ivle/svn
77
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
79
# Make the "repositories" and "sessions" directories in the home.
80
# Make sure they are owned by www-data.
82
sudo mkdir repositories sessions
83
sudo chown -R www-data:www-data repositories sessions
59
sudo ivle-makeuser [OPTIONS] <login> 'Firstname Lastname' <rolenm> -p <password>
86
sudo ./makeuser.py [OPTIONS] <login> 'Firstname Lastname' <rolenm> -p <password>
60
87
# role = guest/student/tutor/lecturer/admin
62
89
# Configure the Apache HTTP server
63
sudo cp doc/setup/ivle-both.conf /etc/apache2/sites-available/ivle
90
sudo cp doc/setup/ivle-both.conf /etc/apache2/sites-available/ivle.conf
64
91
# MODIFY the first few lines so it is specific to your server.
65
92
# * Change ServerAdmin and ServerName (for error reporting).
66
# * Inside the first VirtualHost block, there is a ServerName and ServerAlias
93
# * Inside the first VirtualHost block, there are two ServerNames
67
94
# (localhost and public.localhost). You must change these to the domains
68
95
# for regular IVLE and published-browsing IVLE respectively.
69
96
# * Inside the second VirtualHost block, there is one ServerName
70
97
# (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
98
# * Change all paths beginning with /opt/ivle or /home/informatics to the
99
# locations you have installed things in.
100
vim /etc/apache2/sites-available/ivle.conf
102
# Replace the existing config link with the ivle one
103
cd /etc/apache2/sites-enabled/
104
sudo ln -fs /etc/apache2/sites-available/ivle.conf 000-default
80
106
# Make sure the 3 domains given in Apache conf all lookup to your server.
81
107
# (By default these are localhost, public.localhost and svn.localhost).
82
108
# For testing purposes, this can be done by editing /etc/hosts, for example:
83
# 127.0.0.1 svn.localhost public.localhost
109
127.0.0.1 public.localhost
110
127.0.0.1 svn.localhost
113
sudo apache2ctl -k restart
86
115
##########################################################################
87
116
# User management server: usrmgt-server
88
117
##########################################################################
118
# To start the user management server:
120
sudo ./usrmgt-server <port> <usrmgt-password>
121
# usrmgt-password is the password entered in setup.py config (usrmgt_magic)
122
# Note that the port number and usrmgt password are recorded in
123
# the automatically created init.d script: doc/setup/usrmgt-server.init
125
# To run it at boot time:
90
126
sudo cp doc/setup/usrmgt-server.init /etc/init.d/usrmgt-server
91
127
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:
128
sudo chmod 700 /etc/init.d/usrmgt-server # so world can't read database magic
98
129
sudo update-rc.d usrmgt-server defaults 99 # create symlinks in /etc/rc*.d
131
##########################################################################
132
# Setting up phpBB Forum in IVLE
133
##########################################################################
134
# This should all be run from the SVN directory
136
# Create a postgres database
137
# (only need the first line if it was previously created and is now changed)
138
sudo -u postgres dropdb ivle_forum
139
sudo -u postgres createdb ivle_forum
140
sudo -u postgres psql -d ivle_forum < userdb/forum_schema.sql
141
sudo -u postgres psql -d ivle_forum < userdb/forum_data.sql
143
#Change to the installed IVLE directory
145
# Fix permissions for install
147
# At very minimum you apache user must be able to write to
148
# cache/ files/ store/ images/avatars/upload config.php
149
sudo chown -R www-data:www-data .
151
##########################################################################
152
# Installing Pound reverse proxy (optional)
153
##########################################################################
155
sudo apt-get install pound
157
# edit /etc/default/pound so that the line reading
162
# copy pound.cfg to /etc/pound/pound.cfg
163
# edit IP addresses in pound.cfg