| 1 |
from Products.CMFCore.CMFCorePermissions import SetOwnPassword |
|---|
| 2 |
from Products.CMFCore.utils import getToolByName |
|---|
| 3 |
from Products.CMFDefault.MembershipTool import MembershipTool as BaseTool |
|---|
| 4 |
from Products.CMFPlone import ToolNames |
|---|
| 5 |
from AccessControl import ClassSecurityInfo, getSecurityManager |
|---|
| 6 |
from Globals import InitializeClass |
|---|
| 7 |
from Acquisition import aq_base, aq_parent, aq_inner |
|---|
| 8 |
from Products.CMFCore.CMFCorePermissions import View |
|---|
| 9 |
from Products.CMFPlone.PloneBaseTool import PloneBaseTool |
|---|
| 10 |
from ZODB.POSException import ConflictError |
|---|
| 11 |
from Products.CMFCore.utils import _checkPermission |
|---|
| 12 |
|
|---|
| 13 |
from Products.CMFPlone.MembershipTool import MembershipTool |
|---|
| 14 |
|
|---|
| 15 |
|
|---|
| 16 |
|
|---|
| 17 |
def deleteMemberArea(self, member_id): |
|---|
| 18 |
""" Delete member area of member specified by member_id. |
|---|
| 19 |
""" |
|---|
| 20 |
members = self.getMembersFolder() |
|---|
| 21 |
if not members: |
|---|
| 22 |
return 0 |
|---|
| 23 |
if hasattr( aq_base(members), member_id ): |
|---|
| 24 |
members.manage_delObjects(member_id) |
|---|
| 25 |
return 1 |
|---|
| 26 |
else: |
|---|
| 27 |
return 0 |
|---|
| 28 |
|
|---|
| 29 |
|
|---|
| 30 |
def deleteMembers(self, member_ids, delete_memberareas=1, |
|---|
| 31 |
delete_localroles=1): |
|---|
| 32 |
""" Delete members specified by member_ids. |
|---|
| 33 |
""" |
|---|
| 34 |
|
|---|
| 35 |
|
|---|
| 36 |
acl_users = self.acl_users |
|---|
| 37 |
if _checkPermission('Manage Users', acl_users): |
|---|
| 38 |
if isinstance(member_ids, basestring): |
|---|
| 39 |
member_ids = (member_ids,) |
|---|
| 40 |
member_ids = list(member_ids) |
|---|
| 41 |
for member_id in member_ids[:]: |
|---|
| 42 |
if not acl_users.getUserById(member_id, None): |
|---|
| 43 |
member_ids.remove(member_id) |
|---|
| 44 |
try: |
|---|
| 45 |
acl_users.userFolderDelUsers(member_ids) |
|---|
| 46 |
except (NotImplementedError, 'NotImplemented'): |
|---|
| 47 |
raise NotImplementedError('The underlying User Folder ' |
|---|
| 48 |
'doesn\'t support deleting members.') |
|---|
| 49 |
else: |
|---|
| 50 |
raise AccessControl_Unauthorized('You need the \'Manage users\' ' |
|---|
| 51 |
'permission for the underlying User Folder.') |
|---|
| 52 |
|
|---|
| 53 |
|
|---|
| 54 |
mdtool = getToolByName(self, 'portal_memberdata', None) |
|---|
| 55 |
if mdtool is not None: |
|---|
| 56 |
for member_id in member_ids: |
|---|
| 57 |
members = mdtool._members |
|---|
| 58 |
if members.has_key(member_id): |
|---|
| 59 |
del members[member_id] |
|---|
| 60 |
|
|---|
| 61 |
|
|---|
| 62 |
if delete_memberareas: |
|---|
| 63 |
for member_id in member_ids: |
|---|
| 64 |
self.deleteMemberArea(member_id) |
|---|
| 65 |
|
|---|
| 66 |
|
|---|
| 67 |
if delete_localroles: |
|---|
| 68 |
utool = getToolByName(self, 'portal_url', None) |
|---|
| 69 |
self.deleteLocalRoles( utool.getPortalObject(), member_ids, |
|---|
| 70 |
reindex=1 ) |
|---|
| 71 |
|
|---|
| 72 |
return tuple(member_ids) |
|---|
| 73 |
|
|---|
| 74 |
MembershipTool.security = ClassSecurityInfo() |
|---|
| 75 |
MembershipTool.security.declareProtected('Manage Users', 'deleteMemberArea') |
|---|
| 76 |
MembershipTool.deleteMemberArea = deleteMemberArea |
|---|
| 77 |
MembershipTool.security.declareProtected('Manage Users', 'deleteMembers') |
|---|
| 78 |
MembershipTool.deleteMembers = deleteMembers |
|---|
| 79 |
|
|---|
| 80 |
InitializeClass(MembershipTool) |
|---|