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) |
---|