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

« back to all changes in this revision

Viewing changes to doc/setup/install_proc.txt

  • Committer: dcoles
  • Date: 2008-08-07 06:46:32 UTC
  • Revision ID: svn-v3-trunk0:2b9c9e99-6f39-0410-b283-7f802c844ae2:trunk:989
Groups: Added userservice/assign_group call. This allows a user with the 
CAP_MANAGEGROUPS permission to assign a user into a group. This records the 
assignment in the database and then regenerates a svn-groups.conf file which 
specifies which users can access which repository.

This commit introduces the /groups repository (which means a groups directory 
will have to be created in repositories area and the apache config will have to 
be updated to allow the new dav repositories to work - see the changes to 
ivle-svn.conf/ivle-both.conf and install_proc for exact details). There is also 
a new parameter svn_group_conf in the config file so you need to run `setup.py 
config` too.

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 7.10
 
4
# Target Platform: Ubuntu 8.04
5
5
#
6
6
# IMPORTANT: This is NOT a shell script. It has interactive sections and
7
7
# things that need to be customized.
10
10
 
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.
15
15
#
16
16
# Author: Matt Giuca
17
17
# Date: 29/1/2008
18
18
 
19
 
sudo vim /etc/apt/sources.list
20
 
 
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:...)
25
 
 
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
30
 
# :wq
31
 
 
32
19
##########################################################################
33
20
# Apt packages
34
21
##########################################################################
35
 
 
36
 
sudo apt-get update
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
43
 
 
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.
49
 
 
50
 
##########################################################################
51
 
# Python packages needed by IVLE or student code
52
 
##########################################################################
53
 
#
54
 
# See trunk/doc/dependencies.txt
55
 
 
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
58
 
 
59
 
cd python-cjson-1.0.5
60
 
./setup.py build
61
 
sudo ./setup.py install
62
 
cd ..
 
22
sudo apt-get install 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
63
27
 
64
28
##########################################################################
65
29
# Configure postgres
66
30
##########################################################################
67
 
#
68
 
# Some of these instructions follow
69
 
#     https://help.ubuntu.com/community/PostgreSQL
70
 
# 1. install the base packages
71
31
 
72
32
# Set the postgres user's postgres password
73
33
sudo -u postgres psql template1
74
 
# At the prompt type (substituting <***password***> with a real one.
 
34
# At the prompt type (substituting <***password***> with a real one).
75
35
ALTER USER postgres WITH ENCRYPTED PASSWORD '<***password***>';
76
36
\q
77
37
 
81
41
#
82
42
# Check out the IVLE trunk
83
43
 
84
 
export IVLE_SVN=ivle_svn
85
 
svn co https://ivle.svn.sourceforge.net/svnroot/ivle/trunk $IVLE_SVN
86
 
cd $IVLE_SVN
 
44
svn co https://ivle.svn.sourceforge.net/svnroot/ivle/trunk ivle_svn
 
45
cd ivle_svn
87
46
 
88
47
# Create a postgres database
89
48
# (only need the first line if it was previously created and is now changed)
90
49
sudo -u postgres dropdb ivle
91
50
sudo -u postgres createdb ivle
 
51
sudo -u postgres createlang plpgsql ivle
92
52
sudo -u postgres psql -d ivle < userdb/users.sql
93
53
 
94
54
# Set up IVLE
100
60
# Leave others default.
101
61
# Note: This will cause IVLE to get installed to /opt/ivle
102
62
 
103
 
./setup.py build
 
63
sudo ./setup.py build
104
64
sudo ./setup.py install
105
65
 
 
66
# Make the directory containing the svn auth.
 
67
# Make sure it is owned by www-data.
 
68
sudo mkdir /opt/ivle/svn
 
69
sudo chown -R www-data:www-data /opt/ivle/svn
 
70
 
 
71
# Make the "repositories", "sessions" and "logs" directories in the home.
 
72
# Make sure they are owned by www-data.
 
73
cd /home/informatics
 
74
sudo mkdir -p repositories/users repositories/groups sessions logs
 
75
sudo chown -R www-data:www-data repositories sessions logs
 
76
 
 
77
cd /home/informatics/ivle_svn
 
78
 
106
79
# Create a user
107
80
sudo ./makeuser.py [OPTIONS] <login> 'Firstname Lastname' <rolenm> -p <password>
108
81
# role = guest/student/tutor/lecturer/admin
109
82
 
110
83
# Configure the Apache HTTP server
111
 
sudo cp doc/setup/ivle.conf /etc/apache2/sites-available
 
84
sudo cp doc/setup/ivle-both.conf /etc/apache2/sites-available/ivle
112
85
# MODIFY the first few lines so it is specific to your server.
113
 
vim /etc/apache2/sites-available/ivle.conf
114
 
 
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
118
 
 
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.
122
 
 
123
 
sudo mkdir /home/informatics/sessions
124
 
sudo chown www-data:www-data /home/informatics/sessions
125
 
 
126
 
# Restart the server
127
 
sudo apache2ctl -k restart
 
86
# * Change ServerAdmin and ServerName (for error reporting).
 
87
# * Inside the first VirtualHost block, there are two ServerNames
 
88
#   (localhost and public.localhost). You must change these to the domains
 
89
#   for regular IVLE and published-browsing IVLE respectively.
 
90
# * Inside the second VirtualHost block, there is one ServerName
 
91
#   (svn.localhost). You must change this to the domain for svn access.
 
92
# * Change all paths beginning with /opt/ivle or /home/informatics to the
 
93
#   locations you have installed things in.
 
94
sudo vim /etc/apache2/sites-available/ivle
 
95
 
 
96
# Replace the default with the IVLE site.
 
97
sudo a2dissite default
 
98
sudo a2ensite ivle
 
99
 
 
100
# Restart Apache.
 
101
sudo /etc/init.d/apache2 restart
 
102
 
 
103
# Make sure the 3 domains given in Apache conf all lookup to your server.
 
104
# (By default these are localhost, public.localhost and svn.localhost).
 
105
# For testing purposes, this can be done by editing /etc/hosts, for example:
 
106
# 127.0.0.1     svn.localhost public.localhost
 
107
sudo vim /etc/hosts
 
108
 
 
109
##########################################################################
 
110
# User management server: usrmgt-server
 
111
##########################################################################
 
112
# To start the user management server:
 
113
cd /opt/ivle/scripts
 
114
sudo ./usrmgt-server
 
115
# usrmgt-password is the password entered in setup.py config (usrmgt_magic)
 
116
# Note that the port number and usrmgt password are recorded in
 
117
# the automatically created init.d script: doc/setup/usrmgt-server.init
 
118
 
 
119
# To run it at boot time:
 
120
sudo cp doc/setup/usrmgt-server.init /etc/init.d/usrmgt-server
 
121
sudo chown root:root /etc/init.d/usrmgt-server
 
122
sudo chmod 700 /etc/init.d/usrmgt-server  # so world can't read database magic
 
123
sudo update-rc.d usrmgt-server defaults 99  # create symlinks in /etc/rc*.d
128
124
 
129
125
##########################################################################
130
126
# Setting up phpBB Forum in IVLE
131
127
##########################################################################
132
 
#
133
 
# Change to the installed IVLE directory
 
128
# This should all be run from the SVN directory
 
129
 
 
130
# Create a postgres database
 
131
# (only need the first line if it was previously created and is now changed)
 
132
sudo -u postgres dropdb ivle_forum
 
133
sudo -u postgres createdb ivle_forum
 
134
sudo -u postgres psql -d ivle_forum < userdb/forum_schema.sql
 
135
sudo -u postgres psql -d ivle_forum < userdb/forum_data.sql
 
136
 
 
137
#Change to the installed IVLE directory
134
138
cd /opt/ivle
135
139
# Fix permissions for install
136
140
cd www/php/phpBB3
137
 
mkdir store
138
 
chmod 777 cache/ files/ store/ images/avatars/upload config.php
139
 
 
140
 
# Add database to Postgres server
141
 
sudo -u postgres createdb forum
142
 
 
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
155
 
 
156
 
# Remove the Install directory to enable access
157
 
rm -rf install/
158
 
 
159
 
# Disable Registration...
 
141
# At very minimum you apache user must be able to write to
 
142
# cache/ files/ store/ images/avatars/upload config.php
 
143
sudo chown -R www-data:www-data .
160
144
 
161
145
##########################################################################
162
146
# Installing Pound reverse proxy (optional)