Cq561ProjectContentUpgrade.java
3.23 KB
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
/*
* Decompiled with CFR 0_118.
*
* Could not load the following classes:
* javax.jcr.Node
* javax.jcr.NodeIterator
* javax.jcr.Property
* javax.jcr.RepositoryException
* javax.jcr.Session
* org.slf4j.Logger
* org.slf4j.LoggerFactory
*/
package com.day.cq.compat.codeupgrade.impl.cq561;
import com.day.cq.compat.codeupgrade.internal.api.ProgressInfoProvider;
import javax.jcr.Node;
import javax.jcr.NodeIterator;
import javax.jcr.Property;
import javax.jcr.RepositoryException;
import javax.jcr.Session;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class Cq561ProjectContentUpgrade
implements ProgressInfoProvider {
private static final String SLING_TARGET = "sling:target";
private static final String PROJECTS_PATH = "/etc/projects";
private static final String RESOURCE_TYPE_PROJECT_CARD = "cq/gui/components/projects/admin/projectcard";
private static final String SLING_RESOURCE_TYPE_PROPERTY = "sling:resourceType";
private final Logger log;
private String progressInfo;
public Cq561ProjectContentUpgrade() {
this.log = LoggerFactory.getLogger(this.getClass());
this.progressInfo = "Migration has not started.";
}
@Override
public String getProgressInfo() {
return this.progressInfo;
}
void setProgressInfo(String info) {
this.progressInfo = info;
this.log.info(this.progressInfo);
}
void doUpgrade(Session session) throws Exception {
this.setProgressInfo("Start Project Content upgrade.");
Node projectNode = session.getNode("/etc/projects");
if (projectNode != null) {
if (this.migrateProjects(projectNode)) {
this.save(session);
}
} else {
this.setProgressInfo("Unable to find any projects under /etc/projects");
}
this.setProgressInfo("All done.");
}
public void save(Session session) throws RepositoryException, IllegalArgumentException {
if (session == null) {
throw new IllegalArgumentException("Session is invalid");
}
try {
session.save();
}
catch (RepositoryException e) {
session.refresh(false);
throw e;
}
}
private boolean migrateProjects(Node rootNode) throws RepositoryException {
boolean hasMigratedProjects = false;
NodeIterator tenantIterator = rootNode.getNodes();
while (tenantIterator.hasNext()) {
Node tenant = tenantIterator.nextNode();
NodeIterator projectIterator = tenant.getNodes();
while (projectIterator.hasNext()) {
Node project = projectIterator.nextNode();
boolean isOld = false;
if (project.hasProperty("sling:target")) {
isOld = true;
project.getProperty("sling:target").remove();
}
if (!isOld) continue;
this.setProgressInfo("Migrating project '" + project.getPath() + "' to 5.6.1 format.");
project.setProperty("sling:resourceType", "cq/gui/components/projects/admin/projectcard");
hasMigratedProjects = true;
}
}
return hasMigratedProjects;
}
}