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.module.delta;
35
36 import info.magnolia.module.InstallContext;
37 import info.magnolia.repository.RepositoryConstants;
38
39 import java.util.Arrays;
40 import java.util.List;
41
42 import javax.jcr.RepositoryException;
43 import javax.jcr.Session;
44
45 import org.slf4j.Logger;
46 import org.slf4j.LoggerFactory;
47
48
49
50
51
52
53 public class RemoveNodesTask extends AbstractRepositoryTask {
54
55 private static final Logger log = LoggerFactory.getLogger(RemoveNodesTask.class);
56
57 private final String workspaceName;
58 private final List<String> pathsToRemove;
59 private final boolean displayInfoMessageForMissingNodes;
60
61 public RemoveNodesTask(String name, String workspace, List<String> pathsToRemove, boolean displayInfoMessageForMissingNodes) {
62 this(name, String.format("Remove nodes: '%s' from '%s' workspace.", Arrays.toString(pathsToRemove.toArray()), RepositoryConstants.CONFIG),
63 workspace, pathsToRemove, displayInfoMessageForMissingNodes);
64 }
65
66 public RemoveNodesTask(String name, String description, String workspaceName, List<String> pathsToRemove, boolean displayInfoMessageForMissingNodes) {
67 super(name, description);
68 this.pathsToRemove = pathsToRemove;
69 this.workspaceName = workspaceName;
70 this.displayInfoMessageForMissingNodes = displayInfoMessageForMissingNodes;
71 }
72
73 @Override
74 protected void doExecute(InstallContext ctx) throws RepositoryException, TaskExecutionException {
75 Session session = ctx.getJCRSession(this.workspaceName);
76 for (String path : this.pathsToRemove) {
77 if (!session.itemExists(path)) {
78 if (this.displayInfoMessageForMissingNodes) {
79 ctx.info("Could not remove node '" + path + "' from workspace '" + this.workspaceName + "'. Node does not exist.");
80 }
81 log.debug("Could not remove node '{}' from workspace '{}'. Node does not exist.", path, this.workspaceName);
82 } else {
83 session.getItem(path).remove();
84 }
85 }
86 }
87 }