Factor out the allowIfCheckPasses logic
authorSverre Rabbelier <srabbelier@gmail.com>
Thu, 29 Jan 2009 23:04:12 +0000
changeset 1073 feea88d0e1d8
parent 1072 9cd86652481f
child 1074 94bc2a9ae103
Factor out the allowIfCheckPasses logic Keep allowDeveloper around as convenience method though. Patch by: Sverre Rabbelier
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):