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 package info.magnolia.setup.for3_6_2;
35
36 import info.magnolia.cms.beans.config.ContentRepository;
37 import info.magnolia.cms.core.Content;
38 import info.magnolia.cms.core.ItemType;
39 import info.magnolia.cms.core.Path;
40 import info.magnolia.cms.security.Permission;
41 import info.magnolia.cms.util.NodeTypeFilter;
42 import info.magnolia.module.InstallContext;
43 import info.magnolia.module.delta.AllChildrenNodesOperation;
44 import info.magnolia.module.delta.TaskExecutionException;
45
46 import java.util.Iterator;
47
48 import javax.jcr.RepositoryException;
49
50 import org.slf4j.Logger;
51 import org.slf4j.LoggerFactory;
52
53
54
55
56
57
58
59
60 public class UpdateGroups extends AllChildrenNodesOperation {
61
62 private static Logger log = LoggerFactory.getLogger(UpdateGroups.class);
63
64 public UpdateGroups() {
65 super("Groups definition update", "Adds right to read their own node to all existing groups.", ContentRepository.USER_GROUPS, "/", new NodeTypeFilter(ItemType.GROUP));
66 }
67
68 public void operateOnChildNode(Content group, InstallContext installContext)
69 throws RepositoryException, TaskExecutionException {
70 try {
71 String handle = group.getHandle();
72 boolean hasAccess = false;
73 Content acls = group.getChildByName("acl_usergroups");
74 if (acls == null) {
75 acls = group.createContent("acl_usergroups", ItemType.CONTENTNODE);
76 group.save();
77 }
78 Iterator iter2 = acls.getChildren().iterator();
79 while (iter2.hasNext()) {
80 Content permission = (Content)iter2.next();
81 if (handle.equals(permission.getNodeData("path").getString()) && (permission.getNodeData("permissions").getLong() >= Permission.READ)) {
82 hasAccess = true;
83 break;
84 }
85 }
86 if (!hasAccess) {
87 Content acl = acls.createContent(Path.getUniqueLabel(installContext.getHierarchyManager(ContentRepository.USER_GROUPS), acls.getHandle(), "0"), ItemType.CONTENTNODE);
88 acl.createNodeData("path", handle);
89 acl.createNodeData("permissions", new Long(Permission.READ));
90 acls.save();
91 }
92 } catch (RepositoryException e) {
93 log.error(e.getMessage(), e);
94 throw new TaskExecutionException("Failed to update group permissions. See log file for more details.");
95 }
96 }
97 }