Zope Subversion Repository |
|
Zope: zope.security/trunk/src/zope/security/simplepolicies.py
File:
[Zope] /
zope.security /
trunk /
src /
zope /
security / simplepolicies.py
(
download)
(
as text)
Revision:
125980,
Thu May 17 21:22:20 2012 UTC (12 months ago) by
tseaver
File size: 2212 byte(s)
Drop support for Python 2.4 and 2.5.
Replace deprecated 'zope.component.adapts' usage with equivalent
'zope.component.adapter' decorator.
Replace deprecated 'zope.interface.classProvides' usage with equivalent
'zope.interface.provider' decorator.
Replace deprecated 'zope.interface.implements' usage with equivalent
'zope.interface.implementer' decorator.
##############################################################################
#
# Copyright (c) 2001, 2002 Zope Foundation and Contributors.
# All Rights Reserved.
#
# This software is subject to the provisions of the Zope Public License,
# Version 2.1 (ZPL). A copy of the ZPL should accompany this distribution.
# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
# FOR A PARTICULAR PURPOSE.
#
##############################################################################
"""Simple 'ISecurityPolicy' implementations.
"""
import zope.interface
from zope.security.checker import CheckerPublic
from zope.security.interfaces import IInteraction, ISecurityPolicy
from zope.security._definitions import system_user
@zope.interface.implementer(IInteraction)
@zope.interface.provider(ISecurityPolicy)
class ParanoidSecurityPolicy(object):
def __init__(self, *participations):
self.participations = []
for participation in participations:
self.add(participation)
def add(self, participation):
if participation.interaction is not None:
raise ValueError("%r already belongs to an interaction"
% participation)
participation.interaction = self
self.participations.append(participation)
def remove(self, participation):
if participation.interaction is not self:
raise ValueError("%r does not belong to this interaction"
% participation)
self.participations.remove(participation)
participation.interaction = None
def checkPermission(self, permission, object):
if permission is CheckerPublic:
return True
users = [p.principal
for p in self.participations
if p.principal is not system_user]
return not users
@zope.interface.provider(ISecurityPolicy)
class PermissiveSecurityPolicy(ParanoidSecurityPolicy):
"""Allow all access."""
def checkPermission(self, permission, object):
return True