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

« back to all changes in this revision

Viewing changes to www/README

  • Committer: matt.giuca
  • Date: 2009-01-14 10:10:12 UTC
  • mto: This revision was merged to the branch mainline in revision 1090.
  • Revision ID: svn-v3-trunk0:2b9c9e99-6f39-0410-b283-7f802c844ae2:branches%2Fstorm:1132
The new ivle.database.User class is now used in Request and usrmgt, which
    means it is now almost universally used in favour of ivle.user.User (now
    deprecated).

Noticeable change: The minor bug where the change to a user object in the
    database is not reflected in the user's session (eg. changing nick doesn't
    update title until log out).

ivle.dispatch:
    Session now contains 'login' (username string) rather than 'user' (full
        ivle.user.User object). This is a unicode string now.

    req.user is now a ivle.database.User object rather than an ivle.user.User
        object. This makes for a whole lot of really subtle differences, but
        largely conforms to the same interface. Note that strings must now all
        be unicode.

    login: Removed use of ivle.db. Now uses User object.

    html: Now handles unicode login and config options.

ivle.db: Removed update_user. Now replaced with Storm model.

ivle.database: Renamed has_cap back to hasCap (saved for later). Fixed small
    unicode bug.

ivle.makeuser.make_svn_auth now takes a store object.

usrmgt-server: Use new User class.

userservice: Now uses User class internally.
    get_user action now returns ISO 8601 date format, rather than a
        time tuple. (Wasn't being used).
    get_user action no longer transmits local_password (small security risk;
        note that it wasn't possible to see this for any user other than
        yourself unless admin).

ivle.util - added function object_to_dict.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
src directory - README
 
2
======================
 
3
 
 
4
This directory is the root of the IVLE web application proper. It is this
 
5
directory that should be installed into the web server to be executed.
 
6
Navigating to the place this directory is installed shall be the entrypoint
 
7
into the application.
 
8
 
 
9
Note that no files placed in this directory or its subdirectories will be
 
10
directly visible from the web, *except* those files placed in `/media` or its
 
11
subdirectories.
 
12
 
 
13
Apache configuration
 
14
--------------------
 
15
 
 
16
IVLE should be installed into a place on the file system, and then there
 
17
should be a symlink created from Apache. Apache should symlink its IVLE
 
18
directory to the "www" directory, a subdirectory of the IVLE trunk.
 
19
 
 
20
The Apache conf file should have the following directives added to it, which
 
21
configures the site to direct all URLs to the main dispatcher (except for
 
22
files in the /media directory).
 
23
 
 
24
    # IVLE directory configuration
 
25
    # See src/README for instructions and explanation
 
26
    <Directory "/ivle-directory"> 
 
27
        SetHandler mod_python
 
28
        PythonHandler dispatch
 
29
        #PythonDebug On
 
30
        Options FollowSymLinks
 
31
        PythonOption mod_python.file_session.database_directory /path/to/shared/sessions
 
32
    </Directory>
 
33
    <Directory "/ivle-directory/media"> 
 
34
        SetHandler None
 
35
    </Directory>
 
36
 
 
37
Where `ivle-directory` is the path to root directory of IVLE on the web
 
38
server (the symlink which points to "www").
 
39
 
 
40
Uncomment `PythonDebug On` to turn on debugging.
 
41
 
 
42
Note that this disables directory listings across the whole site (which
 
43
essentially only affects the /media directory).
 
44
 
 
45
Python Site configuration
 
46
-------------------------
 
47
 
 
48
The setup install script automatically configures ivle.pth in the Python site
 
49
packages directory. This section is for if you run into trouble.
 
50
 
 
51
You need to set up IVLE as a Python site to allow importing of IVLE modules.
 
52
If this step is done improperly, you will see "ImportError: No module named
 
53
dispatch".
 
54
 
 
55
Place a file in the Python site packages directory
 
56
(ie. /usr/lib/python2.5/site-packages) called "ivle.pth". In it place a
 
57
single line containing the full path to the "www" directory inside
 
58
trunk in the installed location.
 
59
 
 
60
See http://docs.python.org/lib/module-site.html for information about
 
61
configuring .pth files.
 
62
 
 
63
Application configuration
 
64
-------------------------
 
65
 
 
66
Additional settings must be written to allow IVLE to work (such as the root
 
67
URL and student file space directories). The web application will throw an
 
68
exception if these have not been set up (if conf/conf.py does not exist).
 
69
 
 
70
Run setup.py, a command-line tool, which will interactively create
 
71
conf/conf.py for you.
 
72
 
 
73
Special handling of media directory
 
74
-----------------------------------
 
75
 
 
76
One important exception: Apache must be configured so that the `/media`
 
77
directory and its subdirectories are served directly as-is, with no special
 
78
handling.
 
79
 
 
80
Files in the `/media` directory should be served with the standard MIME types
 
81
(eg. text/html for .html, image/png for .png). **No** server-side script
 
82
handling should take place in the media directory. That is, .py and .php files
 
83
should be simply served up as text/plain or whatever their default MIME type
 
84
is.
 
85
 
 
86
This simply means that the web server should NOT be configured to handle
 
87
scripts anywhere in the ivle directory, except for the above handling code.
 
88
 
 
89
Subdirectories
 
90
--------------
 
91
 
 
92
* /apps - Each plugin application has its own directory.
 
93
* /dispatch - Handler module for the top-level dispatch.
 
94
* /media - Contains files directly served by Apache (see above).
 
95
* /conf - Administrator configuration files (see /conf/README).