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

« back to all changes in this revision

Viewing changes to ivle/webapp/errors.py

Move the login machinery to the new framework.

The login page is now redirected to by the XHTML Unauthorized page, and knows
to return to the right URL when authentication succeeds. It also means that we
no longer return a 200 with login page content for a totally unrelated page...

Some of the user stuff (disabling, Tos, etc.) is now broken, and /logout moved
to /+logout.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# IVLE - Informatics Virtual Learning Environment
 
2
# Copyright (C) 2007-2009 The University of Melbourne
 
3
#
 
4
# This program is free software; you can redistribute it and/or modify
 
5
# it under the terms of the GNU General Public License as published by
 
6
# the Free Software Foundation; either version 2 of the License, or
 
7
# (at your option) any later version.
 
8
#
 
9
# This program is distributed in the hope that it will be useful,
 
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
12
# GNU General Public License for more details.
 
13
#
 
14
# You should have received a copy of the GNU General Public License
 
15
# along with this program; if not, write to the Free Software
 
16
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 
17
 
 
18
# Author: Will Grant
 
19
 
 
20
class HTTPError(Exception):
 
21
    '''A base class for all HTTP errors.'''
 
22
 
 
23
class BadRequest(HTTPError):
 
24
    codename = 'Bad Request'
 
25
    code = 400
 
26
 
 
27
class Unauthorized(HTTPError):
 
28
    codename = 'Unauthorized'
 
29
    code = 401
 
30
 
 
31
class Forbidden(HTTPError):
 
32
    codename = 'Forbidden'
 
33
    code = 403
 
34
 
 
35
class NotFound(HTTPError):
 
36
    codename = 'Not Found'
 
37
    code = 404
 
38
 
 
39
class MethodNotAllowed(HTTPError):
 
40
    def __init__(self, allowed, *args, **kwargs):
 
41
        self.allowed = allowed
 
42
        super(HTTPError, self).__init__(*args, **kwargs)
 
43
 
 
44
    codename = 'Method Not Allowed'
 
45
    code = 405