| 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 | # Delete members in acl_users. |
|---|
| 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 | # Delete member data in portal_memberdata. |
|---|
| 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 | # Delete members' home folders including all content items. |
|---|
| 62 | if delete_memberareas: |
|---|
| 63 | for member_id in member_ids: |
|---|
| 64 | self.deleteMemberArea(member_id) |
|---|
| 65 | |
|---|
| 66 | # Delete members' local roles. |
|---|
| 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) |
|---|