ServerCachesServlet.java
5.15 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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
/*
* Decompiled with CFR 0_118.
*
* Could not load the following classes:
* com.day.cq.commons.TidyJSONWriter
* com.day.cq.commons.servlets.AbstractPredicateServlet
* com.day.cq.commons.servlets.HtmlStatusResponseHelper
* com.day.cq.wcm.msm.api.LiveCopy
* javax.jcr.RangeIterator
* javax.jcr.Session
* javax.servlet.ServletException
* javax.servlet.http.HttpServletResponse
* org.apache.commons.collections.Predicate
* org.apache.felix.scr.annotations.Reference
* org.apache.felix.scr.annotations.sling.SlingServlet
* org.apache.sling.api.SlingHttpServletRequest
* org.apache.sling.api.SlingHttpServletResponse
* org.apache.sling.api.resource.Resource
* org.apache.sling.api.resource.ResourceResolver
* org.apache.sling.api.servlets.HtmlResponse
* org.slf4j.Logger
* org.slf4j.LoggerFactory
*/
package com.day.cq.wcm.msm.impl.servlets;
import com.day.cq.commons.TidyJSONWriter;
import com.day.cq.commons.servlets.AbstractPredicateServlet;
import com.day.cq.commons.servlets.HtmlStatusResponseHelper;
import com.day.cq.wcm.msm.api.LiveCopy;
import com.day.cq.wcm.msm.impl.LiveCopyManagerImpl;
import com.day.cq.wcm.msm.impl.LiveCopyServiceImpl;
import java.io.IOException;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.io.Writer;
import javax.jcr.RangeIterator;
import javax.jcr.Session;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.collections.Predicate;
import org.apache.felix.scr.annotations.Reference;
import org.apache.felix.scr.annotations.sling.SlingServlet;
import org.apache.sling.api.SlingHttpServletRequest;
import org.apache.sling.api.SlingHttpServletResponse;
import org.apache.sling.api.resource.Resource;
import org.apache.sling.api.resource.ResourceResolver;
import org.apache.sling.api.servlets.HtmlResponse;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@Deprecated
@SlingServlet(paths={"/libs/wcm/msm/content/commands/servercaches"}, methods={"POST", "GET"})
public class ServerCachesServlet
extends AbstractPredicateServlet {
private final Logger log = LoggerFactory.getLogger(ServerCachesServlet.class);
private static final String TIDY_PARAM = "tidy";
@Reference
private LiveCopyServiceImpl liveCopyService = null;
protected void doGet(SlingHttpServletRequest req, SlingHttpServletResponse resp, Predicate predicate) throws ServletException, IOException {
this.log.info("The Request to Flush the LiveCopyCache is deprecated. Remove usage if you have not been requesting from MSM ControlCenter");
LiveCopyManagerImpl lcm = this.liveCopyService.createLiveCopyManager(req.getResourceResolver());
StringWriter buf = new StringWriter();
TidyJSONWriter w = new TidyJSONWriter((Writer)buf);
w.setTidy("true".equals(req.getParameter("tidy")));
try {
w.object();
w.key("livecopiesCacheSize").value((long)this.liveCopyService.getIndexSize());
w.key("livecopiesCache");
w.array();
RangeIterator itr = lcm.getAll();
while (itr.hasNext()) {
w.value((Object)((LiveCopy)itr.next()).getPath());
}
w.endArray();
w.endObject();
}
catch (Exception e) {
throw new ServletException((Throwable)e);
}
resp.setContentType("application/json");
resp.setCharacterEncoding("utf-8");
resp.getWriter().print(buf.getBuffer().toString());
}
protected void doPost(SlingHttpServletRequest req, SlingHttpServletResponse response) throws ServletException, IOException {
HtmlResponse htmlResponse;
this.log.info("The Request to Flush the LiveCopyCache is deprecated. Remove usage if you have not been requesting from MSM ControlCenter");
String cmd = req.getParameter("cmd");
try {
if ("flush".equals(cmd)) {
if (((Session)req.getResourceResolver().adaptTo(Session.class)).hasPermission(req.getResource().getPath(), "set_property")) {
this.liveCopyService.setIndexDirty();
htmlResponse = HtmlStatusResponseHelper.createStatusResponse((boolean)true, (String)"Caches flushed.");
} else {
htmlResponse = HtmlStatusResponseHelper.createStatusResponse((boolean)false, (String)"Not Allowed.");
}
} else {
htmlResponse = HtmlStatusResponseHelper.createStatusResponse((boolean)true, (String)"No command.");
}
}
catch (Exception e) {
this.log.error("Error while flushing caches.", (Throwable)e);
htmlResponse = HtmlStatusResponseHelper.createStatusResponse((boolean)false, (String)("Error while flushing caches: " + e.getMessage()));
}
htmlResponse.send((HttpServletResponse)response, true);
}
protected void bindLiveCopyService(LiveCopyServiceImpl liveCopyServiceImpl) {
this.liveCopyService = liveCopyServiceImpl;
}
protected void unbindLiveCopyService(LiveCopyServiceImpl liveCopyServiceImpl) {
if (this.liveCopyService == liveCopyServiceImpl) {
this.liveCopyService = null;
}
}
}