Mercurial > p > roundup > code
view roundup/cgi/exceptions.py @ 3117:460eb0209a9e
Permissions improvements.
- have Permissions only test the check function if itemid is suppled
- modify index templates to check for row-level Permission
- more documentation of security mechanisms
- better unit tests for security mechanisms
| author | Richard Jones <richard@users.sourceforge.net> |
|---|---|
| date | Fri, 28 Jan 2005 03:51:19 +0000 |
| parents | df4a3355ee8f |
| children | bbab97f8ffb2 |
line wrap: on
line source
#$Id: exceptions.py,v 1.6 2004-11-18 14:10:27 a1s Exp $ '''Exceptions for use in Roundup's web interface. ''' __docformat__ = 'restructuredtext' import cgi class HTTPException(Exception): pass class LoginError(HTTPException): pass class Unauthorised(HTTPException): pass class Redirect(HTTPException): pass class NotFound(HTTPException): pass class NotModified(HTTPException): pass class FormError(ValueError): """An 'expected' exception occurred during form parsing. That is, something we know can go wrong, and don't want to alarm the user with. We trap this at the user interface level and feed back a nice error to the user. """ pass class SendFile(Exception): """Send a file from the database.""" class SendStaticFile(Exception): """Send a static file from the instance html directory.""" class SeriousError(Exception): """Raised when we can't reasonably display an error message on a templated page. The exception value will be displayed in the error page, HTML escaped. """ def __str__(self): return ''' <html><head><title>Roundup issue tracker: An error has occurred</title> <link rel="stylesheet" type="text/css" href="@@file/style.css"> </head> <body class="body" marginwidth="0" marginheight="0"> <p class="error-message">%s</p> </body></html> '''%cgi.escape(self.args[0]) # vim: set filetype=python sts=4 sw=4 et si :
