# HG changeset patch # User Sverre Rabbelier # Date 1233270252 0 # Node ID feea88d0e1d83f9b6360d29ddbe32a1c1fb35716 # Parent 9cd86652481f6299756c9ef62e0a0c055fadd1fb Factor out the allowIfCheckPasses logic Keep allowDeveloper around as convenience method though. Patch by: Sverre Rabbelier diff -r 9cd86652481f -r feea88d0e1d8 app/soc/views/helper/access.py --- a/app/soc/views/helper/access.py Thu Jan 29 23:02:47 2009 +0000 +++ b/app/soc/views/helper/access.py Thu Jan 29 23:04:12 2009 +0000 @@ -98,20 +98,30 @@ return wrapper -def allowDeveloper(fun): - """Decorator that allows access if the current user is a Developer. +def allowIfCheckPasses(checker_name): + """Returns a decorator that allows access if the specified checker passes. """ from functools import wraps - @wraps(fun) - def wrapper(self, django_args, *args, **kwargs): - try: - # if the current user is a developer we allow access - return self.checkIsDeveloper(django_args) - except out_of_band.Error: - return fun(self, django_args, *args, **kwargs) - return wrapper + def decorator(fun): + """Decorator that allows access if the current user is a Developer. + """ + + @wraps(fun) + def wrapper(self, django_args, *args, **kwargs): + try: + # if the check passes we allow access regardless + return self.doCheck(checker_name, django_args, []) + except out_of_band.Error: + # otherwise we run the original check + return fun(self, django_args, *args, **kwargs) + return wrapper + + return decorator + + +allowDeveloper = allowIfCheckPasses('checkIsDeveloper') class Checker(object):