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

« back to all changes in this revision

Viewing changes to ivle/studpath.py

Replaced Python config files (conf.py) with new config files system, using
    configobj (INI-file style config files).

setup.py config now produces ./etc/ivle.conf, a new-style config file.
ivle/conf/conf.py is now part of the IVLE source code. It reads the new config
file and provides the same legacy interface, so all of IVLE still functions,
including setup.py config.

Added /etc to the source tree (config files will be stored here).
Added configobj as a dependency in doc/setup/install_proc.txt.

setup.py install copies ./etc/ivle.conf into /etc/ivle/ivle.conf.

Removed boilerplate code generation from setup/configure.py (that code is now
part of ivle/conf/conf.py which is now in the source tree).

Show diffs side-by-side

added added

removed removed

Lines of Context:
132
132
        return False
133
133
 
134
134
 
135
 
def authorize(req, user):
 
135
def authorize(req):
136
136
    """Given a request, checks whether req.user is allowed to
137
137
    access req.path. Returns None on authorization success. Raises
138
138
    HTTP_FORBIDDEN on failure.
145
145
    urlpath = os.path.normpath(req.path)
146
146
    # Now if it begins with ".." or separator, then it's illegal
147
147
    if urlpath.startswith("..") or urlpath.startswith(os.sep):
148
 
        return False
 
148
        req.throw_error(req.HTTP_FORBIDDEN)
149
149
 
150
150
    (owner, _) = util.split_path(urlpath)
151
 
    if user.login != owner:
152
 
        return False
153
 
    return True
 
151
    if req.user.login != owner:
 
152
        req.throw_error(req.HTTP_FORBIDDEN)
154
153
 
155
154
def authorize_public(req):
156
155
    """A different kind of authorization. Rather than making sure the
163
162
    raised on failure.
164
163
    """
165
164
    _, path = url_to_local(req.path)
166
 
 
167
 
    # Walk up the tree, and find the deepest directory.
168
 
    while not os.path.isdir(path):
169
 
        path = os.path.dirname(path)
170
 
 
171
 
    if not (worldreadable(path) and published(path)):
172
 
        return False
173
 
    return True
 
165
    dirpath, _ = os.path.split(path)
 
166
    if not (worldreadable(dirpath) and published(dirpath)):
 
167
        req.throw_error(req.HTTP_FORBIDDEN)