[Zope-Checkins] CVS: Zope3/lib/python/Zope/App/Security - ZopeSecurityPolicy.py:1.1.2.26

Gary Poster garyposter@earthlink.net
Fri, 17 May 2002 13:16:16 -0400


Update of /cvs-repository/Zope3/lib/python/Zope/App/Security
In directory cvs.zope.org:/tmp/cvs-serv15153/App/Security

Modified Files:
      Tag: Zope-3x-branch
	ZopeSecurityPolicy.py 
Log Message:
1) Fixed some of my own (wrapping) errors in CA and Traversal
2) added IBindingAware interface for services that need to know when they are bound and unbound to a local service manager
3) in subscribables, made event_types into event_type (YAGNI)
4) in subscribables, added ability to unsubscribe per subscription, not just whole-hog
5) in subscribables, added ability to query subscribable for subscriptions of a given subscriber
6) made ISubscribable extremely verbose, to hopefully describe exactly what's going on (see it for more smaller changes)
7) added ISubscriptionAware interface for objects that need to know when they have been subscribed and unsubscribed
8) built out local event service; once there are some views and once I have some more robust tests this *prototype* should by ready to fly.  Note that it is currently a standard service that can be added to any service manager, and thus the design does attempt to address many of the nested service manager issues.
9) as part of this, created the first indirect subscriber (all placeful
subscriptions will usually need to use indirect subscribers in order to retain their context when events are fired): PathSubscriber
10) removed an endless loop between local service managers and  ZopeSecurityPolicy in which both needed the other to function: ZopeSecurityPolicy now explicitly asks for adapters from the global service manager
11) unintentionally retained some of the "default=ComponentLookupError"-type argument signatures from my sandbox, but only within Container and Folder; I won't worry about undoing it though (unless I am otherwise requested) since it seems these interfaces are due for a dict-like overhaul anyway.

Also, if anyone needs a local event service setup for other tests (like the ObjectHub, for instance) see the LocalEventService/tests/EventSetup.py

more tests on the way for the local event service, and for the changes to the subscribable interface



=== Zope3/lib/python/Zope/App/Security/ZopeSecurityPolicy.py 1.1.2.25 => 1.1.2.26 ===
 getRolesForPrincipal       = principalRoleManager.getRolesForPrincipal
 
+globalContext=object()
+
 class ZopeSecurityPolicy:
 
     def __init__( self, ownerous=1, authenticated=1 ):
@@ -81,7 +83,7 @@
         # Check the placeful principal permissions and aggregate the
         # Roles in this context
         for c in ContainmentIterator(object):
-            ppm = getAdapter(c, IPrincipalPermissionManager, None)
+            ppm = getAdapter(c, IPrincipalPermissionManager, None, globalContext)
             if ppm is not None: 
                 for principal in principals.keys():
                     setting = ppm.getSetting(permission, principal)
@@ -90,7 +92,7 @@
                     elif setting is Allow:
                         return 1 # Explicit allow on principal
                     
-            prm = getAdapter(c, IPrincipalRoleManager, None)
+            prm = getAdapter(c, IPrincipalRoleManager, None, globalContext)
             if prm is not None:
                 for principal in principals.keys():
                     for role, setting in prm.getRolesForPrincipal(principal):
@@ -119,7 +121,7 @@
                         
         # Check the placeful role permissions, checking anonymous first
         for c in ContainmentIterator(object):
-            rpm = getAdapter(c, IRolePermissionManager, None)
+            rpm = getAdapter(c, IRolePermissionManager, None, globalContext)
             if rpm is not None:
                 for role in ['Anonymous'] + assigned_roles.keys():
                     setting = rpm.getSetting(permission, role)