1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117
|
##############################################################################
#
# Copyright (c) 2000-2008 Jens Vagelpohl 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.
#
##############################################################################
""" LDAP-based CMF membership tool
$Id: LDAPMembershipTool.py 1485 2008-06-04 16:08:38Z jens $
"""
from AccessControl import ClassSecurityInfo
from AccessControl import Unauthorized
from Globals import InitializeClass
from Products.CMFCore.permissions import ManageUsers
from Products.CMFCore.utils import _checkPermission
from Products.CMFCore.utils import getToolByName
from Products.CMFDefault.MembershipTool import MembershipTool
class LDAPMembershipTool(MembershipTool):
""" LDAP-enabled CMF Membership Tool """
security = ClassSecurityInfo()
meta_type = 'LDAP Membership Tool'
title = 'LDAP Membership Tool'
security.declarePrivate('addMember')
def addMember(self, id, password, roles, domains, properties=None):
""" Adds a new member to the user folder. Security checks will have
already been performed. Called by portal_registration.
"""
args = {}
acl = self.acl_users
login_attribute = acl.getProperty('_login_attr')
rdn_attribute = acl.getProperty('_rdnattr')
if ( rdn_attribute != login_attribute and
rdn_attribute not in properties.keys() ):
raise ValueError, 'RDN attribute %s not provided.' % rdn_attribute
args['user_pw'] = args['confirm_pw'] = password
args[login_attribute] = id
args['user_roles'] = roles
if rdn_attribute != login_attribute:
args[rdn_attribute] = properties[rdn_attribute]
if properties.get('email', None):
args['mail'] = properties['email']
if properties is not None:
for key, value in properties.items():
if key not in args.keys():
args[key] = value
acl.manage_addUser(REQUEST=None, kwargs=args)
self.createMemberarea(id)
if properties is not None:
member = self.getMemberById(id)
member.setMemberProperties(properties)
security.declareProtected(ManageUsers, 'deleteMembers')
def deleteMembers(self, member_ids, delete_memberareas=1,
delete_localroles=1):
""" Delete members specified by member_ids.
"""
# Delete members in acl_users.
acl_users = self.acl_users
if _checkPermission(ManageUsers, acl_users):
if isinstance(member_ids, basestring):
member_ids = (member_ids,)
member_ids = list(member_ids)
member_dns = []
for member_id in member_ids[:]:
user = acl_users.getUserById(member_id)
if user is None:
member_ids.remove(member_id)
else:
member_dns.append(user.getUserDN())
acl_users.manage_deleteUsers(dns=member_dns)
else:
raise Unauthorized('You need the \'Manage users\' '
'permission for the underlying User Folder.')
# Delete member data in portal_memberdata.
mdtool = getToolByName(self, 'portal_memberdata', None)
if mdtool is not None:
for member_id in member_ids:
mdtool.deleteMemberData(member_id)
# Delete members' home folders including all content items.
if delete_memberareas:
for member_id in member_ids:
self.deleteMemberArea(member_id)
# Delete members' local roles.
if delete_localroles:
utool = getToolByName(self, 'portal_url', None)
self.deleteLocalRoles( utool.getPortalObject(), member_ids,
reindex=1, recursive=1 )
return tuple(member_ids)
InitializeClass(LDAPMembershipTool)
|