WebsiteData weblog = null;
String context = request.getContextPath();
String servlet = request.getServletPath();
String reqURI = request.getRequestURI();
WeblogResourceRequest resourceRequest = null;
try {
// parse the incoming request and extract the relevant data
resourceRequest = new WeblogResourceRequest(request);
weblog = resourceRequest.getWeblog();
if(weblog == null) {
throw new RollerException("unable to lookup weblog: "+
resourceRequest.getWeblogHandle());
}
} catch(Exception e) {
// invalid resource request or weblog doesn't exist
log.debug("error creating weblog resource request", e);
response.sendError(HttpServletResponse.SC_NOT_FOUND);
return;
}
log.debug("Resource requested ["+resourceRequest.getResourcePath()+"]");
long resourceLastMod = 0;
InputStream resourceStream = null;
// first see if resource comes from weblog's shared theme
if(!Theme.CUSTOM.equals(weblog.getEditorTheme())) {
try {
ThemeManager themeMgr = RollerFactory.getRoller().getThemeManager();
Theme weblogTheme = themeMgr.getTheme(weblog.getEditorTheme());
File resource = weblogTheme.getResource(resourceRequest.getResourcePath());
if(resource != null) {
resourceLastMod = resource.lastModified();
resourceStream = new FileInputStream(resource);
}
} catch (Exception ex) {
// hmmm, some kind of error getting theme. that's an error.
response.sendError(HttpServletResponse.SC_INTERNAL_SERVER_ERROR);
return;
}
}
// if not from theme then see if resource is in weblog's upload dir
if(resourceStream == null) {
try {
FileManager fileMgr = RollerFactory.getRoller().getFileManager();
WeblogResource resource = fileMgr.getFile(weblog,
resourceRequest.getResourcePath());
resourceLastMod = resource.getLastModified();
resourceStream = resource.getInputStream();
} catch (Exception ex) {
// still not found? then we don't have it, 404.
log.debug("Unable to get resource", ex);
response.sendError(HttpServletResponse.SC_NOT_FOUND);
return;
}
}
// Respond with 304 Not Modified if it is not modified.
if (ModDateHeaderUtil.respondIfNotModified(request, response, resourceLastMod)) {
return;
} else {
// set last-modified date
ModDateHeaderUtil.setLastModifiedHeader(response, resourceLastMod);
}
// set the content type based on whatever is in our web.xml mime defs
response.setContentType(this.context.getMimeType(resourceRequest.getResourcePath()));
OutputStream out = null;
try {
// ok, lets serve up the file
byte[] buf = new byte[8192];