-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathJavascriptComboService.java
More file actions
executable file
·155 lines (131 loc) · 5.04 KB
/
JavascriptComboService.java
File metadata and controls
executable file
·155 lines (131 loc) · 5.04 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
144
145
146
147
148
149
150
151
152
153
154
155
package org.maring.util.js;
import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.HashMap;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class JavascriptComboService extends HttpServlet {
private static final long serialVersionUID = 1L;
private static final Logger log = LoggerFactory.getLogger(JavascriptComboService.class);
private static HashMap<String,StringBuffer> cachedFiles = new HashMap<String,StringBuffer>();
private boolean cachingEnabled = true;
@Override
public void init() throws ServletException {
if ( (System.getProperty("js.combo.service.caching.enabled") != null &&
System.getProperty("js.combo.service.caching.enabled").equalsIgnoreCase("FALSE"))
||
(System.getProperty("js.combo.service.caching.enabled") != null &&
System.getProperty("js.combo.service.caching.enabled").equalsIgnoreCase("NO"))
||
(this.getServletConfig().getInitParameter("js.combo.service.caching.enabled") != null &&
this.getServletConfig().getInitParameter("js.combo.service.caching.enabled").equalsIgnoreCase("FALSE"))
||
(this.getServletConfig().getInitParameter("js.combo.service.caching.enabled") != null &&
this.getServletConfig().getInitParameter("js.combo.service.caching.enabled").equalsIgnoreCase("NO"))
) {
log.info("file caching disabled");
this.cachingEnabled = false;
} else {
log.info("file caching enabled");
}
}
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
processRequest(req, resp);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
processRequest(req, resp);
}
private void processRequest(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String queryString = request.getQueryString();
if (log.isDebugEnabled()) {
log.debug("query string: " + queryString );
}
if (queryString == null || queryString.length() == 0) {
log.warn("request made without query string");
return;
}
String[] fileRefs;
if (queryString.contains("&")) {
fileRefs = queryString.split("&");
} else {
fileRefs = new String[1];
fileRefs[0] = queryString;
}
PrintWriter writer = response.getWriter();
if (fileRefs.length > 0) {
if (fileRefs[0].endsWith(".css")) {
response.setContentType("text/css");
} else if (fileRefs[0].endsWith(".js")) {
response.setContentType("text/javascript");
} else {
log.warn("unable to determine content type within request " + fileRefs[0]);
return;
}
}
int fileCount = 0;
for ( String fileRef : fileRefs ) {
fileCount++;
if (fileRef.endsWith(".css") || fileRef.endsWith(".js")) {
if (cachedFiles.containsKey(this.getServletContext().getRealPath(fileRef))) {
if (log.isDebugEnabled()) {
log.debug(fileRef + " found in cache");
}
writer.print(cachedFiles.get(this.getServletContext().getRealPath(fileRef)).toString());
} else {
if (log.isDebugEnabled()) {
log.debug("reading file: " + this.getServletContext().getRealPath(fileRef) + " ...");
}
StringBuffer fileData = new StringBuffer();
FileReader fileReader = null;
String realPath = this.getServletContext().getRealPath(fileRef);
if (realPath != null) {
try {
fileReader = new FileReader(this.getServletContext().getRealPath(fileRef));
} catch (FileNotFoundException fnfe) {
log.warn("file " + this.getServletContext().getRealPath(fileRef) + " was not found");
continue;
}
} else {
log.warn("file " + fileRef + " was not found");
continue;
}
BufferedReader reader = new BufferedReader(fileReader);
char[] buf = new char[1024];
int numRead=0;
while((numRead=reader.read(buf)) != -1){
String readData = String.valueOf(buf, 0, numRead);
fileData.append(readData);
buf = new char[1024];
}
reader.close();
writer.print(fileData.toString());
if (this.cachingEnabled){
if (log.isDebugEnabled()) {
log.debug("caching " + this.getServletContext().getRealPath(fileRef) + " ...");
}
cachedFiles.put(this.getServletContext().getRealPath(fileRef), fileData);
}
}
}
}
if (log.isDebugEnabled()) {
if (fileRefs[0].endsWith(".css")) {
log.debug("CSS response complete. " + fileCount + " files combined.");
} else if (fileRefs[0].endsWith(".js")) {
log.debug("JS response complete. " + fileCount + " files combined.");
}
}
}
}