use of fi.internetix.smvc.controllers.JSONRequestController in project pyramus by otavanopisto.
the class Servlet method doService.
private void doService(HttpServletRequest request, HttpServletResponse response) throws ServletException {
try {
userTransaction.begin();
} catch (Exception e) {
Logging.logException(e);
throw new ServletException(e);
}
RequestContext requestContext = null;
RequestController requestController;
RequestDispatchContext dispatchContext;
if (requestDispatcher != null && requestDispatcher.canHandle(request, response)) {
dispatchContext = requestDispatcher.getContext(request, response);
requestController = dispatchContext.getRequestController();
} else {
String uri = request.getRequestURI();
String ctxPath = request.getContextPath();
String controllerName = uri.substring(ctxPath.length() + 1);
if (StringUtils.isNotBlank(applicationPath)) {
controllerName = controllerName.substring(applicationPath.length());
}
requestController = RequestControllerMapper.getRequestController(controllerName);
dispatchContext = new RequestDispatchContext(requestController, new DefaultParameterHandlerImpl(request, decodeGETUtf));
}
int statusCode = StatusCode.OK;
try {
if (requestController == null) {
requestContext = new PageRequestContext(dispatchContext, request, response, getServletContext(), errorJspPage);
throw new PageNotFoundException(request.getLocale());
} else if (requestController instanceof PageController) {
requestContext = new PageRequestContext(dispatchContext, request, response, getServletContext(), errorJspPage);
} else if (requestController instanceof JSONRequestController) {
requestContext = new JSONRequestContext(dispatchContext, request, response, getServletContext());
} else if (requestController instanceof BinaryRequestController) {
requestContext = new BinaryRequestContext(dispatchContext, request, response, getServletContext());
}
// Let the controller authorize the request. Most common exceptions thrown include
// LoginRequiredException and AccessDeniedException
requestController.authorize(requestContext);
if (requestController instanceof PageController) {
((PageController) requestController).process((PageRequestContext) requestContext);
} else if (requestController instanceof JSONRequestController) {
((JSONRequestController) requestController).process((JSONRequestContext) requestContext);
} else if (requestController instanceof BinaryRequestController) {
((BinaryRequestController) requestController).process((BinaryRequestContext) requestContext);
}
} catch (LoginRequiredException lre) {
if (platformErrorListener != null)
platformErrorListener.onLoginRequiredException(request, response, lre);
Logging.logInfo("Login required for " + getCurrentUrl(request, true));
if (requestController instanceof PageController) {
HttpSession session = requestContext.getRequest().getSession(true);
session.setAttribute("loginRedirectUrl", lre.getRedirectUrl());
if (lre.getContextType() != null && lre.getContextId() != null) {
session.setAttribute("loginContextType", lre.getContextType());
session.setAttribute("loginContextId", lre.getContextId());
}
requestContext.setRedirectURL(loginUrl);
} else {
// TODO LoginRequiredException for requests other than pages?
statusCode = lre.getStatusCode();
requestContext.addMessage(Severity.WARNING, lre.getMessage());
}
} catch (PageNotFoundException pnfe) {
if (platformErrorListener != null)
platformErrorListener.onPageNotFoundException(request, response, pnfe);
Logging.logInfo("404 - " + getCurrentUrl(request, true));
statusCode = pnfe.getStatusCode();
if (requestContext != null) {
requestContext.getResponse().setStatus(HttpServletResponse.SC_NOT_FOUND);
requestContext.addMessage(Severity.WARNING, pnfe.getMessage());
} else {
response.setStatus(HttpServletResponse.SC_INTERNAL_SERVER_ERROR);
}
} catch (AccessDeniedException ade) {
if (platformErrorListener != null)
platformErrorListener.onAccessDeniedException(request, response, ade);
Logging.logInfo("403 - " + getCurrentUrl(request, true) + " - " + requestContext.getLoggedUserId());
statusCode = ade.getStatusCode();
requestContext.getResponse().setStatus(HttpServletResponse.SC_FORBIDDEN);
requestContext.addMessage(Severity.WARNING, ade.getMessage());
} catch (InvalidLoginException ile) {
Logging.logInfo("Invalid login credentials");
statusCode = ile.getStatusCode();
requestContext.addMessage(Severity.ERROR, ile.getMessage());
} catch (AlreadyLoggedInException ile) {
Logging.logInfo("Already logged in");
statusCode = ile.getStatusCode();
requestContext.addMessage(Severity.ERROR, ile.getMessage());
} catch (SmvcRuntimeException pre) {
if (platformErrorListener != null)
platformErrorListener.onSmvcRuntimeException(request, response, pre);
Logging.logException(pre);
statusCode = pre.getStatusCode();
requestContext.addMessage(Severity.ERROR, pre.getMessage());
} catch (Exception e) {
if (platformErrorListener != null)
platformErrorListener.onUncontrolledException(request, response, e);
// All other exceptions are considered to be fatal and unexpected, so the request
// transaction is rolled back, the stack trace of the exception is printed out, and
// an error view is shown
Logging.logException(e);
statusCode = StatusCode.UNDEFINED;
requestContext.addMessage(Severity.CRITICAL, e.getMessage());
} finally {
try {
// Pre-commit response
requestContext.writePreCommitResponse(statusCode);
if (statusCode == StatusCode.OK) {
userTransaction.commit();
} else {
userTransaction.rollback();
}
// Post-commit response
requestContext.writePostCommitResponse(statusCode);
} catch (Exception e) {
if (platformErrorListener != null)
platformErrorListener.onTransactionCommitException(request, response, e);
Logging.logException(e);
throw new ServletException(e);
}
}
}
Aggregations