001 /* 002 * Copyright 2011 The Kuali Foundation Licensed under the Educational Community 003 * License, Version 1.0 (the "License"); you may not use this file except in 004 * compliance with the License. You may obtain a copy of the License at 005 * http://www.opensource.org/licenses/ecl1.php Unless required by applicable law 006 * or agreed to in writing, software distributed under the License is 007 * distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 008 * KIND, either express or implied. See the License for the specific language 009 * governing permissions and limitations under the License. 010 */ 011 package org.kuali.rice.kns.web.spring; 012 013 import javax.servlet.http.HttpServletRequest; 014 import javax.servlet.http.HttpServletResponse; 015 016 import org.apache.log4j.Logger; 017 import org.kuali.rice.kns.UserSession; 018 import org.kuali.rice.kns.service.KNSServiceLocatorWeb; 019 import org.kuali.rice.kns.service.SessionDocumentService; 020 import org.kuali.rice.kns.uif.history.History; 021 import org.kuali.rice.kns.uif.history.HistoryEntry; 022 import org.kuali.rice.kns.uif.service.ViewService; 023 import org.kuali.rice.kns.uif.util.UifWebUtils; 024 import org.kuali.rice.kns.util.KNSConstants; 025 import org.kuali.rice.kns.util.WebUtils; 026 import org.kuali.rice.kns.web.spring.form.DocumentFormBase; 027 import org.kuali.rice.kns.web.spring.form.IncidentReportForm; 028 import org.kuali.rice.kns.web.spring.form.UifFormBase; 029 import org.springframework.web.servlet.ModelAndView; 030 031 /** 032 * Spring Exception intercepter 033 * 034 * <p> 035 * Gets the data needed for the incident report from the request and builds the 036 * model and view for the incident report. This resolver intercepts any unhandled 037 * exception. 038 * </p> 039 * 040 * @author Kuali Rice Team (rice.collab@kuali.org) 041 */ 042 public class UifHandlerExceptionResolver implements org.springframework.web.servlet.HandlerExceptionResolver { 043 044 private static final Logger LOG = Logger.getLogger(UifHandlerExceptionResolver.class); 045 046 /** 047 * Builds the incident report model and view from the 048 * request that threw the exception. 049 * 050 * @param request 051 * the request 052 * @param response 053 * the response 054 * @param handler 055 * the current handler when the exception occurred 056 * @param ex 057 * the exception 058 * @return the incident report model and view 059 * @see org.springframework.web.servlet.HandlerExceptionResolver#resolveException(javax.servlet.http.HttpServletRequest, 060 * javax.servlet.http.HttpServletResponse, java.lang.Object, 061 * java.lang.Exception) 062 */ 063 @Override 064 public ModelAndView resolveException(HttpServletRequest request, HttpServletResponse response, Object handler, 065 Exception ex) { 066 LOG.error("The following error was caught by the UifHandlerExceptionResolver : ", ex); 067 String incidentDocId = request.getParameter(KNSConstants.DOCUMENT_DOCUMENT_NUMBER); 068 String incidentViewId = ""; 069 070 // log exception 071 LOG.error(ex.getMessage(), ex); 072 073 UifFormBase form = UifWebUtils.getFormFromRequest(request); 074 if (form instanceof DocumentFormBase) { 075 incidentDocId = ((DocumentFormBase) form).getDocument().getDocumentNumber(); 076 incidentViewId = ((DocumentFormBase) form).getViewId(); 077 } 078 079 UserSession userSession = (UserSession) request.getSession().getAttribute(KNSConstants.USER_SESSION_KEY); 080 IncidentReportForm incidentReportForm = new IncidentReportForm(); 081 // Set the post url map to the incident report controller and not 082 // the one the exception occurred on 083 String postUrl = request.getRequestURL().toString(); 084 postUrl = postUrl.substring(0, postUrl.lastIndexOf("/")) + "/incidentReport"; 085 incidentReportForm.setFormPostUrl(postUrl); 086 incidentReportForm.setException(ex); 087 incidentReportForm.setIncidentDocId(incidentDocId); 088 incidentReportForm.setIncidentViewId(incidentViewId); 089 incidentReportForm.setController(handler.getClass().toString()); 090 incidentReportForm.setUserId(userSession.getPrincipalId()); 091 incidentReportForm.setUserName(userSession.getPrincipalName()); 092 incidentReportForm.setUserEmail(userSession.getPerson().getEmailAddress()); 093 incidentReportForm.setDevMode(!WebUtils.isProductionEnvironment()); 094 095 // Set the view object 096 incidentReportForm.setView(getViewService().getView("Incident-Report", 097 incidentReportForm.getViewRequestParameters())); 098 099 // Add a new History entry to avoid errors in the postHandle 100 History history = new History(); 101 HistoryEntry entry = new HistoryEntry("", "", "Incident Report", "", ""); 102 history.setCurrent(entry); 103 incidentReportForm.setFormHistory(history); 104 105 // Set render full view to force full render 106 incidentReportForm.setRenderFullView(true); 107 108 ModelAndView modelAndView = UifWebUtils.getUIFModelAndView(incidentReportForm, "Incident-Report", ""); 109 try { 110 UifWebUtils.postControllerHandle(request, response, handler, modelAndView); 111 } catch (Exception e) { 112 LOG.error("An error stopped the incident form from loading", e); 113 } 114 115 return modelAndView; 116 } 117 118 protected ViewService getViewService() { 119 return KNSServiceLocatorWeb.getViewService(); 120 } 121 122 protected SessionDocumentService getSessionDocumentService() { 123 return KNSServiceLocatorWeb.getSessionDocumentService(); 124 } 125 126 }