# HG changeset patch # User Sverre Rabbelier # Date 1227195691 0 # Node ID 2b90baceac88ee5f5dfe02a71812ccaa48ff012a # Parent 3603fdafabf7b7b4ed01e78cca7d31ea66a5c179 Add a access.deny and access.allow method Respectively always deny, and always allow access to view a part of the site. diff -r 3603fdafabf7 -r 2b90baceac88 app/soc/views/helper/access.py --- a/app/soc/views/helper/access.py Thu Nov 20 15:41:14 2008 +0000 +++ b/app/soc/views/helper/access.py Thu Nov 20 15:41:31 2008 +0000 @@ -36,6 +36,7 @@ from soc.logic import accounts from soc.logic import models +from soc.views import helper from soc.views.simple import requestLogin import soc.views.out_of_band @@ -55,6 +56,37 @@ ' and sign in' ' again as %(role)s to view this page.') +DEF_PAGE_DENIED_MSG = ugettext_lazy( + 'Access to this page has been restricted') + + +def allow(request): + """Never returns an alternate HTTP response + + Args: + request: a django HTTP request + """ + + return + +def deny(request): + """Returns an alternate HTTP response + + Args: + request: a django HTTP request + + Returns: a subclass of django.http.HttpResponse which contains the + alternate response that should be returned by the calling view. + """ + + context = helper.responses.getUniversalContext(request) + context['login_title'] = 'Access denied' + context['login_header'] = 'Access denied' + context['login_message'] = DEF_PAGE_DENIED_MSG + + denied_response = helper.responses.respond(request, DEF_LOGIN_TMPL, context=context) + + raise soc.views.out_of_band.AccessViolationResponse(denied_response) def checkIsLoggedIn(request): """Returns an alternate HTTP response if Google Account is not logged in.