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

« back to all changes in this revision

Viewing changes to www/dispatch/html.py

  • Committer: dcoles
  • Date: 2008-07-18 02:40:58 UTC
  • Revision ID: svn-v3-trunk0:2b9c9e99-6f39-0410-b283-7f802c844ae2:trunk:912
Makeuser: Makeuser will now chown all files in a users home directory to the
unixid provided by the database. This means remakeallusers.py can be used to
update everyones unixids after a database change. The makeuser script will also 
no longer generate a random unixid when one is not given on the command line.

Database: Change to database so that a sequence is used by default. The allowed  
range is 1000-29999 (let's start at 5000, because 1000+ is used by adduser.  
Reference: http://www.debian.org/doc/debian-policy/ch-opersys.html)
See SF Bug '[ 2012190 ] Student UID generation'
Migration script will reallocate all users a new unixid from the sequence.

Usermgt-Server: Now no longer generates a random unixid. Rely on the database 
to come up with a new sequence number.

Show diffs side-by-side

added added

removed removed

Lines of Context:
23
23
# content (the common parts of the HTML pages shared across the entire site).
24
24
# Does not include the login page. See login.py.
25
25
 
 
26
import cgi
 
27
import urllib
26
28
import os.path
27
29
 
28
30
import conf
29
31
import conf.apps
30
32
from common import util
 
33
import plugins.console
31
34
 
32
35
def write_html_head(req):
33
36
    """Writes the HTML header, given a request object.
39
42
    # Note the inline JavaScript, which provides the client with constants
40
43
    # derived from the server configuration.
41
44
    if req.title != None:
42
 
        titlepart = ' - ' + req.title
 
45
        titlepart = req.title + ' - '
43
46
    else:
44
47
        titlepart = ''
45
48
    req.write("""<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
46
49
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
47
50
<html xmlns="http://www.w3.org/1999/xhtml">
48
51
<head>
49
 
  <title>IVLE%s</title>
 
52
  <title>%sIVLE</title>
50
53
  <meta http-equiv="Content-Type" content="%s; charset=utf-8" />
51
 
  <script type="text/javascript">
52
 
    root_dir = "%s";
 
54
""" % (cgi.escape(titlepart), cgi.escape(req.content_type)))
 
55
    # Write inline JavaScript which gives the client code access to certain
 
56
    # server-side variables.
 
57
    if req.user:
 
58
        username = repr(req.user.login)
 
59
    else:
 
60
        username = "null"
 
61
    req.write("""  <script type="text/javascript">
 
62
    root_dir = %s;
 
63
    public_host = %s;
 
64
    username = %s;
53
65
  </script>
54
 
  <link rel="stylesheet" type="text/css" href="%s" />
55
 
""" % (titlepart, req.content_type,
56
 
        repr(conf.root_dir)[1:-1],
57
 
        util.make_path('media/common/ivle.css')))
 
66
""" % (repr(conf.root_dir), repr(conf.public_host), username))
 
67
    iconurl = get_icon_url(req.app, small=True)
 
68
    if iconurl:
 
69
        req.write("""  <link rel="shortcut icon" href="%s" />
 
70
""" % cgi.escape(iconurl))
 
71
    req.write("""  <link rel="stylesheet" type="text/css" href="%s" />
 
72
""" % cgi.escape(util.make_path('media/common/ivle.css')))
58
73
 
59
74
    # Write any app-specific style and script links
60
75
    for style in req.styles:
61
76
        req.write('  <link rel="stylesheet" type="text/css" href="%s" />\n'
62
 
            % util.make_path(style))
 
77
            % cgi.escape(util.make_path(style)))
63
78
    for script in req.scripts:
64
 
        req.write('  <script type="text/javascript" src="%s" />\n'
65
 
            % util.make_path(script))
 
79
        req.write('  <script type="text/javascript" src="%s"></script>\n'
 
80
            % cgi.escape(util.make_path(script)))
 
81
    req.write('  <script type="text/javascript">\n    /* Init Functions */\n')
 
82
    for init in req.scripts_init:
 
83
        req.write('    window.addEventListener("load", %s, false);\n'%init)
 
84
    req.write('  </script>\n')
66
85
 
67
86
    req.write("</head>\n\n")
68
87
 
69
88
    # Open the body element and write a bunch of stuff there (the header)
70
89
    req.write("""<body>
71
 
<div id="ivleheader">
 
90
<div id="ivleheader"></div>
 
91
<div id="ivleheader_text">
72
92
  <h1>IVLE</h1>
73
93
  <h2>Informatics Virtual Learning Environment</h2>
74
94
""")
75
95
 
76
 
    if req.username:
77
 
        req.write('  <p class="userhello">Welcome, <span '
78
 
            'class="username">%s</span> |\n'
 
96
    if req.user:
 
97
        # Get the user's nickname from the request session
 
98
        nickname = req.user.nick
 
99
        req.write('  <p class="userhello"><span id="usernick">%s</span> '
 
100
            '(<span class="username">%s</span>) |\n'
 
101
            '    <a href="%s">Settings</a> |\n'
79
102
            '    <a href="%s">Help</a> |\n'
80
 
            '    <a href="%s">Logout</a>\n'
 
103
            '    <a href="%s">Sign out</a>\n'
81
104
            '  </p>\n' %
82
 
            (req.username, get_help_url(req), util.make_path('logout')))
 
105
            (cgi.escape(nickname), cgi.escape(req.user.login),
 
106
             cgi.escape(util.make_path('settings')),
 
107
             cgi.escape(get_help_url(req)),
 
108
             cgi.escape(util.make_path('logout'))))
83
109
    else:
84
110
        req.write('  <p class="userhello">Not logged in.</p>')
85
111
 
 
112
    # ivleheader_tabs is a separate div, so it can be positioned absolutely
 
113
    req.write('</div>\n<div id="ivleheader_tabs">\n')
 
114
 
86
115
    # If the "debuginfo" app is installed, display a warning to the admin to
87
116
    # make sure it is removed in production.
88
117
    if "debuginfo" in conf.apps.app_url:
89
 
        req.write("  <p><small>Warning: debuginfo is enabled. Remove this "
90
 
            "app from conf.apps.app_url when placed into production."
91
 
            "</small></p>\n")
 
118
        req.write("  <p><small>Warning: debuginfo is enabled. Set "
 
119
            "enable_debuginfo = False in lib/conf/apps.py, when placing IVLE "
 
120
            "into production.</small></p>\n")
92
121
 
93
 
    if req.username:
 
122
    # If req has a "no_agreement" attribute, then it is because the user has
 
123
    # not signed the agreement; therefore we are displaying the TOS page.
 
124
    # Do not show apps (see dispatch.login).
 
125
    if req.user and not req.user.state == 'no_agreement':
94
126
        # Only print app tabs if logged in
95
127
        print_apps_list(req, req.app)
96
128
    req.write('</div>\n<div id="ivlebody">\n')
105
137
def get_help_url(req):
106
138
    """Gets the help URL most relevant to this page, to place as the
107
139
    "help" link at the top of the page."""
108
 
    if req.app == 'help':
 
140
    reqapp = req.app if hasattr(req, 'app') else None
 
141
    if reqapp == 'help':
109
142
        # We're already in help. Link to the exact current page
110
143
        # instead of the generic help page.
111
144
        return req.uri
112
 
    if conf.apps.app_url[req.app].hashelp:
113
 
        help_path = os.path.join('help', req.app)
 
145
    if reqapp is not None and reqapp in conf.apps.app_url and \
 
146
        conf.apps.app_url[reqapp].hashelp:
 
147
        help_path = os.path.join('help', reqapp)
114
148
    else:
115
149
        help_path = 'help'
116
150
    return util.make_path(help_path)
117
151
 
 
152
def get_icon_url(appurl, small=False):
 
153
    """Given an app's url name, gets the URL of the icon image for this app,
 
154
    relative to the site root. Returns None if the app has no icon."""
 
155
    if appurl is None: return None
 
156
    try:
 
157
        app = conf.apps.app_url[appurl]
 
158
    except KeyError:
 
159
        # Due to navigating to a bad app
 
160
        return None
 
161
    if small:
 
162
        icon_dir = conf.apps.app_icon_dir_small
 
163
    else:
 
164
        icon_dir = conf.apps.app_icon_dir
 
165
    if app.icon is None: return None
 
166
    return util.make_path(os.path.join(icon_dir, app.icon))
 
167
 
118
168
def print_apps_list(file, thisapp):
119
169
    """Prints all app tabs, as a UL. Prints a list item for each app that has
120
170
    a tab.
122
172
    file: Object with a "write" method - ie. the request object.
123
173
    Reads from: conf
124
174
    """
125
 
    file.write('  <ul class="apptabs">\n')
 
175
    file.write('  <ul id="apptabs">\n')
126
176
 
127
177
    for urlname in conf.apps.apps_in_tabs:
128
178
        app = conf.apps.app_url[urlname]
132
182
            li_attr = ''
133
183
        file.write('    <li%s>' % li_attr)
134
184
        if app.icon:
135
 
            file.write('<img src="%s" alt="" /> ' %
136
 
                util.make_path(os.path.join(conf.apps.app_icon_dir,
137
 
                app.icon)))
138
 
        file.write('<a href="%s">%s</a></li>\n'
139
 
            % (util.make_path(urlname), app.name))
 
185
            file.write('<img src="%s" alt="" /> '
 
186
                % urllib.quote(get_icon_url(urlname)))
 
187
        file.write('<a href="%s" title="%s">%s</a></li>\n'
 
188
            % (urllib.quote(util.make_path(urlname)), cgi.escape(app.desc),
 
189
                cgi.escape(app.name)))
140
190
 
141
191
    file.write('  </ul>\n')