ReportServlet.java
5.95 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
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
/*
* Decompiled with CFR 0_118.
*
* Could not load the following classes:
* com.day.cq.wcm.webservicesupport.ConfigurationManagerFactory
* javax.jcr.Node
* javax.servlet.ServletException
* org.apache.felix.scr.annotations.Component
* org.apache.felix.scr.annotations.Properties
* org.apache.felix.scr.annotations.Property
* org.apache.felix.scr.annotations.Reference
* org.apache.felix.scr.annotations.Service
* 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.resource.ValueMap
* org.apache.sling.api.servlets.SlingAllMethodsServlet
* org.apache.sling.settings.SlingSettingsService
* org.slf4j.Logger
* org.slf4j.LoggerFactory
*/
package com.day.cq.analytics.sitecatalyst.impl.servlets;
import com.day.cq.analytics.sitecatalyst.AnalyticsPageNameResolver;
import com.day.cq.analytics.sitecatalyst.SitecatalystWebservice;
import com.day.cq.analytics.sitecatalyst.util.SitecatalystJsonItemWriter;
import com.day.cq.wcm.webservicesupport.ConfigurationManagerFactory;
import java.io.CharArrayWriter;
import java.io.IOException;
import java.io.PrintWriter;
import java.io.Writer;
import javax.jcr.Node;
import javax.servlet.ServletException;
import org.apache.felix.scr.annotations.Component;
import org.apache.felix.scr.annotations.Properties;
import org.apache.felix.scr.annotations.Property;
import org.apache.felix.scr.annotations.Reference;
import org.apache.felix.scr.annotations.Service;
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.resource.ValueMap;
import org.apache.sling.api.servlets.SlingAllMethodsServlet;
import org.apache.sling.settings.SlingSettingsService;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@Component(metatype=0)
@Service
@Properties(value={@Property(name="sling.servlet.extensions", value={"json"}), @Property(name="sling.servlet.selectors", value={"sitecatalystreport"}), @Property(name="sling.servlet.resourceTypes", value={"sling/servlet/default"}), @Property(name="sling.servlet.methods", value={"GET"})})
public class ReportServlet
extends SlingAllMethodsServlet {
private static final String TIDY_PARAM = "tidy";
private static final String SYNCHRONOUS_PARAM = "synchronous";
@Reference
private SitecatalystWebservice webservice;
@Reference
private ConfigurationManagerFactory cfgManagerFactory;
@Reference
private SlingSettingsService settingsService;
@Reference
private AnalyticsPageNameResolver pageNameResolver;
private final Logger log;
public ReportServlet() {
this.log = LoggerFactory.getLogger(this.getClass());
}
protected void doGet(SlingHttpServletRequest request, SlingHttpServletResponse response) throws ServletException, IOException {
Resource resource = request.getResource();
if (resource.getChild("reportDescription") == null) {
response.sendError(500, "Invalid report description");
return;
}
if ("true".equals(request.getParameter("synchronous"))) {
response.sendError(500, "Synchronous reports are not supported anymore with API 1.4.");
return;
}
ValueMap reportValueMap = (ValueMap)resource.adaptTo(ValueMap.class);
Node reportNode = (Node)resource.adaptTo(Node.class);
try {
String reportBasePath = (String)reportValueMap.get("cq:reportBasePath", (Object)"/var/statistics/sitecatalyst") + reportNode.getPath();
SitecatalystJsonItemWriter itemWriter = new SitecatalystJsonItemWriter();
itemWriter.setTidy("true".equals(request.getParameter("tidy")));
CharArrayWriter charArray = new CharArrayWriter();
Resource report = resource.getResourceResolver().getResource(reportBasePath);
if (report == null) {
response.sendError(404, "No report data found for this report description");
return;
}
itemWriter.dump((Node)report.adaptTo(Node.class), (Writer)charArray, -1);
response.getWriter().println(charArray.toString());
}
catch (Exception e) {
this.log.error("Error while writing analytics report", (Throwable)e);
response.sendError(500, "Error while writing analytics report");
return;
}
}
protected void bindWebservice(SitecatalystWebservice sitecatalystWebservice) {
this.webservice = sitecatalystWebservice;
}
protected void unbindWebservice(SitecatalystWebservice sitecatalystWebservice) {
if (this.webservice == sitecatalystWebservice) {
this.webservice = null;
}
}
protected void bindCfgManagerFactory(ConfigurationManagerFactory configurationManagerFactory) {
this.cfgManagerFactory = configurationManagerFactory;
}
protected void unbindCfgManagerFactory(ConfigurationManagerFactory configurationManagerFactory) {
if (this.cfgManagerFactory == configurationManagerFactory) {
this.cfgManagerFactory = null;
}
}
protected void bindSettingsService(SlingSettingsService slingSettingsService) {
this.settingsService = slingSettingsService;
}
protected void unbindSettingsService(SlingSettingsService slingSettingsService) {
if (this.settingsService == slingSettingsService) {
this.settingsService = null;
}
}
protected void bindPageNameResolver(AnalyticsPageNameResolver analyticsPageNameResolver) {
this.pageNameResolver = analyticsPageNameResolver;
}
protected void unbindPageNameResolver(AnalyticsPageNameResolver analyticsPageNameResolver) {
if (this.pageNameResolver == analyticsPageNameResolver) {
this.pageNameResolver = null;
}
}
}