~azzar1/unity/add-show-desktop-key

« back to all changes in this revision

Viewing changes to doc/setup/install_proc.txt

  • Committer: mattgiuca
  • Date: 2008-02-15 06:34:19 UTC
  • Revision ID: svn-v3-trunk0:2b9c9e99-6f39-0410-b283-7f802c844ae2:trunk:476
Added new module: common/caps.py. This is the Capabilities centre of IVLE.
    It provides a Role class which is a rich enumeration type for Roles.
    The Role class will replace what has previously been simple strings used
    for Roles within the program. It has comparison ability to see if a Role
    is greater than or equal to another.
    This module also provides a set of capability objects which roles can be
    checked against.
dispatch/login: Rather than setting 'rolenm' string in session, now sets
    'role', a Role object.
common/db: _escape allows Role objects, which get converted into strings.
    So the DB now accepts Role objects as values (though we don't make use of
    this currently).
www/apps/tos: svn:ignore

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
# Installation Procedure for IVLE
2
2
# ===============================
3
3
 
4
 
# Target Platform: Ubuntu 8.04
 
4
# Target Machine: Ubuntu (Versions 6.06 and 7.10 - differences between
 
5
# versions noted)
5
6
#
6
7
# IMPORTANT: This is NOT a shell script. It has interactive sections and
7
8
# things that need to be customized.
10
11
 
11
12
# While other install guides in this package are generic, this one is very
12
13
# specific to our intended configuration. It will be very helpful if trying to
13
 
# set up IVLE on Ubuntu 8.04 or higher; less helpful for other platforms.
 
14
# set up IVLE on Ubuntu 7.06 or higher; less helpful for other platforms.
14
15
# This refers to ivle.conf, also included.
15
16
#
16
17
# Author: Matt Giuca
17
18
# Date: 29/1/2008
18
19
 
19
 
##########################################################################
 
20
sudo vim /etc/apt/sources.list
 
21
 
 
22
# 7.10 (Gutsy) specific #
 
23
 
 
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:...)
 
28
 
 
29
# End 7.10 (Gutsy) specific #
 
30
 
 
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
 
35
# :wq
 
36
 
 
37
sudo apt-get update
 
38
 
20
39
# Apt packages
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
27
 
 
28
 
##########################################################################
29
 
# Configure postgres
30
 
##########################################################################
 
40
sudo apt-get install subversion
 
41
sudo apt-get install gcc libc6 libc6-dev make
 
42
# On 6.06 (Dapper):
 
43
sudo apt-get install python2.4-dev
 
44
# On 7.10 (Gutsy):
 
45
sudo apt-get install python2.5-dev
 
46
 
 
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'
 
50
 
 
51
tar -zxvf python-cjson-1.0.5.tar.gz
 
52
 
 
53
cd python-cjson-1.0.5
 
54
./setup.py build
 
55
sudo ./setup.py install
 
56
cd ..
 
57
 
 
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
 
61
cd webpy
 
62
python ./setup.py build
 
63
sudo python ./setup.py install
 
64
cd ..
 
65
 
 
66
sudo apt-get install python-svn python-webpy python2.4-gtk2 python-matplotlib
 
67
# End 6.06 (Dapper) specific
 
68
 
 
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
 
77
 
 
78
#
 
79
# Installing postgres
 
80
# ===============================
 
81
#
 
82
# Some of these instructions follow
 
83
#     https://help.ubuntu.com/community/PostgreSQL
 
84
# 1. install the base packages
 
85
 
 
86
sudo apt-get install postgresql
 
87
sudo apt-get install python-pygresql
31
88
 
32
89
# 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***>'"
 
90
sudo -u postgres psql template1
 
91
# At the prompt type (substituting <***password***> with a real one.
 
92
ALTER USER postgres WITH ENCRYPTED PASSWORD '<***password***>';
 
93
\q
35
94
 
36
 
##########################################################################
 
95
#
37
96
# Installing ivle
38
 
##########################################################################
39
 
#
 
97
# ===============================
40
98
# Check out the IVLE trunk
41
 
 
42
99
svn co https://ivle.svn.sourceforge.net/svnroot/ivle/trunk ivle_svn
43
 
cd ivle_svn
 
100
# Says the SourceForge certificate authority is not trusted.
 
101
# I chose "Accept (p)ermanently" - Problem??
44
102
 
45
103
# 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
 
104
cd <<ivle source directory>>/userdb
48
105
sudo -u postgres createdb ivle
49
 
sudo -u postgres createlang plpgsql ivle
50
 
sudo -u postgres psql -d ivle < userdb/users.sql
 
106
sudo -u postgres psql -d ivle < users.sql
 
107
 
 
108
# NOTE: From this point onwards it is 7.10 (Gutsy) specific. This is because I
 
109
# never was able to get IVLE to build with all dependencies on Dapper.
51
110
 
52
111
# Set up IVLE
 
112
cd ivle_svn
 
113
./setup.py listmake
53
114
./setup.py config
54
115
 
55
 
# -j is required to rebuild all jails, not just do an update
56
 
sudo ./setup.py build -j
 
116
# "Root directory" - type "/"
 
117
# "UID of web server process" - 1000 at this stage (informatics)
 
118
# Leave others default.
 
119
# Note: This will cause IVLE to get installed to /opt/ivle
 
120
 
 
121
./setup.py build
57
122
sudo ./setup.py install
58
123
 
59
124
# Create a user
60
 
sudo ivle-makeuser [OPTIONS] <login> 'Firstname Lastname' <rolenm> -p <password>
61
 
# role = guest/student/tutor/lecturer/admin
62
 
 
63
 
# Configure the Apache HTTP server
64
 
sudo cp doc/setup/ivle-both.conf /etc/apache2/sites-available/ivle
 
125
sudo ./makeuser.py <username>
 
126
 
 
127
# Set up the Apache HTTP server
 
128
sudo apt-get install apache2 libapache2-mod-python
 
129
 
 
130
# DO: Copy the file "ivle.conf" from this package to
 
131
# /etc/apache2/sites-available.
65
132
# MODIFY the first few lines so it is specific to your server.
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
76
 
 
77
 
# Replace the default with the IVLE site.
78
 
sudo a2dissite default
79
 
sudo a2ensite ivle
80
 
 
81
 
# Restart Apache.
82
 
sudo /etc/init.d/apache2 restart
83
 
 
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
88
 
sudo vim /etc/hosts
89
 
 
90
 
##########################################################################
91
 
# User management server: usrmgt-server
92
 
##########################################################################
93
 
 
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
97
 
 
98
 
# To start it now:
99
 
sudo /etc/init.d/usrmgt-server start
100
 
 
101
 
# To run it at boot time:
102
 
sudo update-rc.d usrmgt-server defaults 99  # create symlinks in /etc/rc*.d
103
 
 
104
 
##########################################################################
105
 
# Setting up phpBB Forum in IVLE
106
 
##########################################################################
107
 
# This should all be run from the SVN directory
108
 
 
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
 
133
 
 
134
# Replace the existing config link with the ivle one
 
135
cd /etc/apache2/sites-enabled/
 
136
sudo ln -fs /etc/apache2/sites-available/ivle.conf 000-default
 
137
 
 
138
# Make the directory corresponding to the directory for saved session
 
139
# objects in the apache config ivle.conf. Make sure it is owned by www-data,
 
140
# or at least readable and writable by it.
 
141
 
 
142
sudo mkdir /home/informatics/sessions
 
143
sudo chown www-data:www-data /home/informatics/sessions
 
144
 
 
145
# Restart the server
 
146
sudo apache2ctl -k restart
 
147
 
 
148
 
 
149
#
 
150
# Installing Pound
 
151
sudo apt-get install pound
 
152
 
 
153
# edit /etc/default/pound so that the line reading
 
154
#     startup=0
 
155
# instead reads
 
156
#     startup=1
 
157
#
 
158
# copy pound.cfg to /etc/pound/pound.cfg
 
159
# edit IP addresses in pound.cfg