annotate servlet2/src/main/java/digilib/servlet/Scaler.java @ 1128:fcafcc8996be

css validates now (no more directx filter). removed superfluous comma (js runs but ie6 still not really happy :-)
author robcast
date Fri, 09 Nov 2012 19:48:04 +0100
parents 4e368c85cce4
children 2ee261676828
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
903
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
1 package digilib.servlet;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
2
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
3 import java.io.File;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
4 import java.io.IOException;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
5 import java.util.List;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
6 import java.util.concurrent.ExecutionException;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
7 import java.util.concurrent.Future;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
8
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
9 import javax.servlet.ServletConfig;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
10 import javax.servlet.ServletContext;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
11 import javax.servlet.ServletException;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
12 import javax.servlet.http.HttpServlet;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
13 import javax.servlet.http.HttpServletRequest;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
14 import javax.servlet.http.HttpServletResponse;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
15
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
16 import org.apache.log4j.Logger;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
17
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
18 import digilib.auth.AuthOpException;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
19 import digilib.auth.AuthOps;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
20 import digilib.image.DocuImage;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
21 import digilib.image.ImageJobDescription;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
22 import digilib.image.ImageOpException;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
23 import digilib.image.ImageWorker;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
24 import digilib.io.DocuDirCache;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
25 import digilib.io.DocuDirectory;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
26 import digilib.io.ImageInput;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
27 import digilib.util.DigilibJobCenter;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
28
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
29 /**
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
30 * Version of Scaler servlet that uses a thread pool but not Servlet 3.0 async API.
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
31 */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
32 public class Scaler extends HttpServlet {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
33
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
34 private static final long serialVersionUID = -5439198888139362735L;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
35
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
36 /** digilib servlet version (for all components) */
1032
4e368c85cce4 CLOSED - # 22: wrong contrast setting. dito #23 (at least on OSX 10.7)
robcast
parents: 960
diff changeset
37 public static final String version = "2.1b2 noasync";
903
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
38
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
39 /** servlet error codes */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
40 public static enum Error {UNKNOWN, AUTH, FILE, IMAGE};
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
41
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
42 /** type of error message */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
43 public static enum ErrMsg {IMAGE, TEXT, CODE};
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
44
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
45 /** logger for accounting requests */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
46 protected static Logger accountlog = Logger.getLogger("account.request");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
47
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
48 /** gengeral logger for this class */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
49 protected static Logger logger = Logger.getLogger("digilib.scaler");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
50
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
51 /** logger for authentication related */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
52 protected static Logger authlog = Logger.getLogger("digilib.auth");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
53
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
54 /** DocuDirCache instance */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
55 protected DocuDirCache dirCache;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
56
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
57 /** Image executor */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
58 DigilibJobCenter<DocuImage> imageJobCenter;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
59
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
60 /** authentication error image file */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
61 public static File denyImgFile;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
62
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
63 /** image error image file */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
64 public static File errorImgFile;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
65
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
66 /** not found error image file */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
67 public static File notfoundImgFile;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
68
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
69 /** send files as is? */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
70 protected boolean sendFileAllowed = true;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
71
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
72 /** DigilibConfiguration instance */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
73 protected DigilibServletConfiguration dlConfig;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
74
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
75 /** use authorization database */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
76 protected boolean useAuthorization = true;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
77
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
78 /** AuthOps instance */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
79 protected AuthOps authOp;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
80
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
81 /**
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
82 * Initialisation on first run.
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
83 *
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
84 * @throws ServletException
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
85 *
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
86 * @see javax.servlet.Servlet#init(javax.servlet.ServletConfig)
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
87 */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
88 public void init(ServletConfig config) throws ServletException {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
89 super.init(config);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
90
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
91 System.out
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
92 .println("***** Digital Image Library Image Scaler Servlet (version "
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
93 + version + ") *****");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
94 // say hello in the log file
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
95 logger.info("***** Digital Image Library Image Scaler Servlet (version "
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
96 + version + ") *****");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
97
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
98 // get our ServletContext
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
99 ServletContext context = config.getServletContext();
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
100 // see if there is a Configuration instance
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
101 dlConfig = (DigilibServletConfiguration) context
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
102 .getAttribute("digilib.servlet.configuration");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
103 if (dlConfig == null) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
104 // no Configuration
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
105 throw new ServletException("No Configuration!");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
106 }
1032
4e368c85cce4 CLOSED - # 22: wrong contrast setting. dito #23 (at least on OSX 10.7)
robcast
parents: 960
diff changeset
107 // log DocuImage version
4e368c85cce4 CLOSED - # 22: wrong contrast setting. dito #23 (at least on OSX 10.7)
robcast
parents: 960
diff changeset
108 logger.info("Scaler uses " + dlConfig.getValue("servlet.docuimage.version"));
903
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
109 // set our AuthOps
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
110 useAuthorization = dlConfig.getAsBoolean("use-authorization");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
111 authOp = (AuthOps) dlConfig.getValue("servlet.auth.op");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
112
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
113 // DocuDirCache instance
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
114 dirCache = (DocuDirCache) dlConfig.getValue("servlet.dir.cache");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
115
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
116 // Executor
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
117 imageJobCenter = (DigilibJobCenter<DocuImage>) dlConfig
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
118 .getValue("servlet.worker.imageexecutor");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
119
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
120 denyImgFile = ServletOps.getFile(
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
121 (File) dlConfig.getValue("denied-image"), context);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
122 errorImgFile = ServletOps.getFile(
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
123 (File) dlConfig.getValue("error-image"), context);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
124 notfoundImgFile = ServletOps.getFile(
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
125 (File) dlConfig.getValue("notfound-image"), context);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
126 sendFileAllowed = dlConfig.getAsBoolean("sendfile-allowed");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
127 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
128
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
129 /** Returns modification time relevant to the request for caching.
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
130 *
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
131 * @see javax.servlet.http.HttpServlet#getLastModified(javax.servlet.http.HttpServletRequest)
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
132 */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
133 public long getLastModified(HttpServletRequest request) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
134 accountlog.debug("GetLastModified from " + request.getRemoteAddr()
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
135 + " for " + request.getQueryString());
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
136 long mtime = -1;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
137 // create new request
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
138 DigilibServletRequest dlReq = new DigilibServletRequest(request);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
139 DocuDirectory dd = dirCache.getDirectory(dlReq.getFilePath());
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
140 if (dd != null) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
141 mtime = dd.getDirMTime() / 1000 * 1000;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
142 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
143 logger.debug(" returns "+mtime);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
144 return mtime;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
145 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
146
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
147 /* (non-Javadoc)
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
148 * @see javax.servlet.http.HttpServlet#doGet(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse)
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
149 */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
150 public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
151 accountlog.info("GET from " + request.getRemoteAddr());
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
152 this.processRequest(request, response);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
153 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
154
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
155
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
156 /* (non-Javadoc)
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
157 * @see javax.servlet.http.HttpServlet#doPost(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse)
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
158 */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
159 public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
160 accountlog.info("POST from " + request.getRemoteAddr());
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
161 this.processRequest(request, response);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
162 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
163
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
164
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
165 protected void doHead(HttpServletRequest req, HttpServletResponse resp)
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
166 throws ServletException, IOException {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
167 logger.debug("HEAD from "+req.getRemoteAddr());
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
168 super.doHead(req, resp);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
169 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
170
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
171 protected void doOptions(HttpServletRequest req, HttpServletResponse resp)
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
172 throws ServletException, IOException {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
173 logger.debug("OPTIONS from "+req.getRemoteAddr());
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
174 super.doOptions(req, resp);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
175 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
176
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
177 /** Service this request using the response.
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
178 * @param request
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
179 * @param response
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
180 * @throws ServletException
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
181 */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
182 public void processRequest(HttpServletRequest request,
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
183 HttpServletResponse response) throws ServletException {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
184
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
185 if (dlConfig == null) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
186 logger.error("ERROR: No Configuration!");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
187 throw new ServletException("NO VALID digilib CONFIGURATION!");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
188 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
189
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
190 accountlog.debug("request: " + request.getQueryString());
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
191 logger.debug("request: " + request.getQueryString());
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
192 long startTime = System.currentTimeMillis();
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
193
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
194 // parse request
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
195 DigilibServletRequest dlRequest = new DigilibServletRequest(request);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
196 // extract the job information
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
197 ImageJobDescription jobTicket = ImageJobDescription.getInstance(dlRequest, dlConfig);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
198
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
199 // type of error reporting
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
200 ErrMsg errMsgType = ErrMsg.IMAGE;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
201 if (dlRequest.hasOption("errtxt")) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
202 errMsgType = ErrMsg.TEXT;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
203 } else if (dlRequest.hasOption("errcode")) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
204 errMsgType = ErrMsg.CODE;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
205 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
206
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
207 try {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
208 /*
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
209 * check if we can fast-track without scaling
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
210 */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
211 ImageInput fileToLoad = (ImageInput) jobTicket.getInput();
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
212
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
213 // check permissions
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
214 if (useAuthorization) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
215 // get a list of required roles (empty if no restrictions)
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
216 List<String> rolesRequired = authOp.rolesForPath(
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
217 jobTicket.getFilePath(), request);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
218 if (rolesRequired != null) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
219 authlog.debug("Role required: " + rolesRequired);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
220 authlog.debug("User: " + request.getRemoteUser());
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
221 // is the current request/user authorized?
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
222 if (!authOp.isRoleAuthorized(rolesRequired, request)) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
223 // send deny answer and abort
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
224 throw new AuthOpException();
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
225 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
226 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
227 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
228
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
229 // if requested, send image as a file
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
230 if (sendFileAllowed && jobTicket.getSendAsFile()) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
231 String mt = null;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
232 if (jobTicket.hasOption("rawfile")) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
233 mt = "application/octet-stream";
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
234 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
235 logger.debug("Sending RAW File as is.");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
236 ServletOps.sendFile(fileToLoad.getFile(), mt, null, response, logger);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
237 logger.info("Done in " + (System.currentTimeMillis() - startTime) + "ms");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
238 return;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
239 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
240
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
241 // if possible, send the image without actually having to transform it
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
242 if (! jobTicket.isTransformRequired()) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
243 logger.debug("Sending File as is.");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
244 ServletOps.sendFile(fileToLoad.getFile(), null, null, response, logger);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
245 logger.info("Done in " + (System.currentTimeMillis() - startTime) + "ms");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
246 return;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
247 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
248
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
249 // check load of workers
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
250 if (imageJobCenter.isBusy()) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
251 logger.error("Servlet overloaded!");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
252 response.sendError(HttpServletResponse.SC_SERVICE_UNAVAILABLE);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
253 return;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
254 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
255 // create job
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
256 ImageWorker job = new ImageWorker(dlConfig, jobTicket);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
257 // submit job
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
258 Future<DocuImage> jobResult = imageJobCenter.submit(job);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
259 // wait for result
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
260 DocuImage img = jobResult.get();
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
261 // forced destination image type
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
262 String mt = null;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
263 if (jobTicket.hasOption("jpg")) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
264 mt = "image/jpeg";
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
265 } else if (jobTicket.hasOption("png")) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
266 mt = "image/png";
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
267 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
268 // send image
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
269 ServletOps.sendImage(img, mt, response, logger);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
270 logger.debug("Job Processing Time: "
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
271 + (System.currentTimeMillis() - startTime) + "ms");
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
272
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
273 } catch (ImageOpException e) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
274 logger.error(e.getClass() + ": " + e.getMessage());
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
275 digilibError(errMsgType, Error.IMAGE, null, response);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
276 } catch (IOException e) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
277 logger.error(e.getClass() + ": " + e.getMessage());
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
278 digilibError(errMsgType, Error.FILE, null, response);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
279 } catch (AuthOpException e) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
280 logger.error(e.getClass() + ": " + e.getMessage());
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
281 digilibError(errMsgType, Error.AUTH, null, response);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
282 } catch (InterruptedException e) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
283 logger.error(e.getClass() + ": " + e.getMessage());
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
284 } catch (ExecutionException e) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
285 logger.error(e.getClass() + ": " + e.getMessage());
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
286 String causeMsg = e.getCause().getMessage();
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
287 logger.error("caused by: " + causeMsg);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
288 digilibError(errMsgType, Error.IMAGE, causeMsg, response);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
289 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
290
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
291 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
292
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
293 /**
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
294 * Sends an error to the client as text or image.
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
295 *
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
296 * @param type
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
297 * @param error
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
298 * @param msg
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
299 * @param response
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
300 */
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
301 public static void digilibError(ErrMsg type, Error error, String msg,
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
302 HttpServletResponse response) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
303 try {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
304 File img = null;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
305 int status = 0;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
306 if (error == Error.AUTH) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
307 if (msg == null) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
308 msg = "ERROR: Unauthorized access!";
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
309 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
310 img = denyImgFile;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
311 status = HttpServletResponse.SC_FORBIDDEN;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
312 } else if (error == Error.FILE) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
313 if (msg == null) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
314 msg = "ERROR: Image file not found!";
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
315 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
316 img = notfoundImgFile;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
317 status = HttpServletResponse.SC_NOT_FOUND;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
318 } else {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
319 if (msg == null) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
320 msg = "ERROR: Other image error!";
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
321 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
322 img = errorImgFile;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
323 status = HttpServletResponse.SC_BAD_REQUEST;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
324 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
325 if (response.isCommitted()) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
326 // response already committed
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
327 logger.error("Unable to send error: " + msg);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
328 return;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
329 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
330 if (type == ErrMsg.TEXT) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
331 ServletOps.htmlMessage(msg, response);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
332 } else if (type == ErrMsg.CODE) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
333 response.sendError(status, msg);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
334 } else if (img != null) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
335 // default: image
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
336 ServletOps.sendFile(img, null, null, response, logger);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
337 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
338 } catch (Exception e) {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
339 logger.error("Error sending error!", e);
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
340 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
341
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
342 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
343
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
344 public static String getVersion() {
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
345 return version;
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
346 }
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
347
7779b37d1d05 refactored into maven modules per servlet type.
robcast
parents:
diff changeset
348 }