| Classes in this File | Line Coverage | Branch Coverage | Complexity | ||||
| KualiExceptionHandlerAction | 
  | 
  | 4.0;4 | 
| 1 |  /* | |
| 2 |   * Copyright 2005-2008 The Kuali Foundation | |
| 3 |   *  | |
| 4 |   * Licensed under the Educational Community License, Version 2.0 (the "License"); | |
| 5 |   * you may not use this file except in compliance with the License. | |
| 6 |   * You may obtain a copy of the License at | |
| 7 |   *  | |
| 8 |   * http://www.opensource.org/licenses/ecl2.php | |
| 9 |   *  | |
| 10 |   * Unless required by applicable law or agreed to in writing, software | |
| 11 |   * distributed under the License is distributed on an "AS IS" BASIS, | |
| 12 |   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
| 13 |   * See the License for the specific language governing permissions and | |
| 14 |   * limitations under the License. | |
| 15 |   */ | |
| 16 | ||
| 17 |  package org.kuali.rice.kns.web.struts.action; | |
| 18 | ||
| 19 |  import java.util.Enumeration; | |
| 20 |  import java.util.HashMap; | |
| 21 |  import java.util.Map; | |
| 22 | ||
| 23 |  import javax.servlet.http.HttpServletRequest; | |
| 24 |  import javax.servlet.http.HttpServletResponse; | |
| 25 | ||
| 26 |  import org.apache.log4j.Logger; | |
| 27 |  import org.apache.struts.Globals; | |
| 28 |  import org.apache.struts.action.Action; | |
| 29 |  import org.apache.struts.action.ActionForm; | |
| 30 |  import org.apache.struts.action.ActionForward; | |
| 31 |  import org.apache.struts.action.ActionMapping; | |
| 32 |  import org.kuali.rice.core.util.RiceConstants; | |
| 33 |  import org.kuali.rice.kns.exception.KualiExceptionIncident; | |
| 34 |  import org.kuali.rice.kns.service.KNSServiceLocatorWeb; | |
| 35 |  import org.kuali.rice.kns.service.KualiExceptionIncidentService; | |
| 36 |  import org.kuali.rice.kns.util.IncidentReportUtils; | |
| 37 |  import org.kuali.rice.kns.util.KNSConstants; | |
| 38 |  import org.kuali.rice.kns.web.struts.form.KualiExceptionIncidentForm; | |
| 39 | ||
| 40 |  /** | |
| 41 |   * This is the struts action class for handling the exception for Kuali | |
| 42 |   * applications. | |
| 43 |   *  | |
| 44 |   */ | |
| 45 | 0 |  public class KualiExceptionHandlerAction extends Action { | 
| 46 | 0 |          private static final Logger LOG = Logger | 
| 47 |                          .getLogger(KualiExceptionHandlerAction.class); | |
| 48 | ||
| 49 |          /** | |
| 50 |           * This overridden method dispatches action to be taken based on | |
| 51 |           * "methodToCall" parameter. The exception is processed when there is no | |
| 52 |           * "methodToCall" specified. | |
| 53 |           *  | |
| 54 |           * @see org.apache.struts.action.Action#execute(org.apache.struts.action.ActionMapping, | |
| 55 |           *      org.apache.struts.action.ActionForm, | |
| 56 |           *      javax.servlet.http.HttpServletRequest, | |
| 57 |           *      javax.servlet.http.HttpServletResponse) | |
| 58 |           */ | |
| 59 |          public ActionForward execute(ActionMapping mapping, ActionForm form, | |
| 60 | HttpServletRequest request, HttpServletResponse response)  | |
| 61 |                          throws Exception { | |
| 62 | 0 |                  return executeException(mapping, form, request, response); | 
| 63 | }  | |
| 64 | ||
| 65 |          /** | |
| 66 |           * This overridden method processes the exception and post exception (when | |
| 67 |           * user either submit/cancel the exception JSP page). | |
| 68 |           * <ul> | |
| 69 |           * <li>Process application Exception - Exception is stored in Http Request</li> | |
| 70 |           * <li>Process exception incident reporting - No exception, only form data</li> | |
| 71 |           * </ul> | |
| 72 |           *  | |
| 73 |           * @see org.apache.struts.action.Action#execute(org.apache.struts.action.ActionMapping, | |
| 74 |           *      org.apache.struts.action.ActionForm, | |
| 75 |           *      javax.servlet.http.HttpServletRequest, | |
| 76 |           *      javax.servlet.http.HttpServletResponse) | |
| 77 |           */ | |
| 78 |          public ActionForward executeException(ActionMapping mapping, | |
| 79 | ActionForm form, HttpServletRequest request,  | |
| 80 |                          HttpServletResponse response) throws Exception { | |
| 81 | ||
| 82 | 0 |                  if (LOG.isDebugEnabled()) { | 
| 83 | 0 |                          String lm = String.format("ENTRY %s%n%s", form.getClass() | 
| 84 | .getSimpleName(), request.getRequestURI());  | |
| 85 | 0 |                          LOG.debug(lm); | 
| 86 | }  | |
| 87 | ||
| 88 |                  // Get exception thrown | |
| 89 | 0 |                  Exception e = (Exception) request.getAttribute(Globals.EXCEPTION_KEY); | 
| 90 | ||
| 91 |                  // Initialize defined action mapping from struts-config | |
| 92 | 0 |                  ActionForward returnForward = null; | 
| 93 | ||
| 94 |                  // In case there is no exception, either a post back after page was | |
| 95 |                  // filled in | |
| 96 |                  // or just an error from directly accessing this struts action | |
| 97 | 0 |                  if (e == null) { | 
| 98 | 0 |                          if (form instanceof KualiExceptionIncidentForm) { | 
| 99 | 0 |                                  KualiExceptionIncidentForm formObject = (KualiExceptionIncidentForm) form; | 
| 100 |                                  // Manage conditions: submit or cancel | |
| 101 | 0 |                                  if (!formObject.isCancel()) { | 
| 102 |                                          // Locate the post exception handler service. The service id | |
| 103 |                                          // is | |
| 104 |                                          // defined in the application properties | |
| 105 |                                          // Only process the post exception handling when the | |
| 106 |                                          // service | |
| 107 |                                          // is specified | |
| 108 | 0 |                                          KualiExceptionIncidentService reporterService = KNSServiceLocatorWeb | 
| 109 | .getKualiExceptionIncidentService();  | |
| 110 |                                          // An instance of the ExceptionIncident is created by | |
| 111 |                                          // the | |
| 112 |                                          // ExceptionIncidentService | |
| 113 | 0 |                                          Map reducedMap = new HashMap(); | 
| 114 | 0 |                                          Enumeration<String> names = request.getParameterNames(); | 
| 115 | 0 |                                          while (names.hasMoreElements()) { | 
| 116 | 0 |                                                  String name = names.nextElement(); | 
| 117 | 0 |                                                  reducedMap.put(name, request.getParameter(name)); | 
| 118 | 0 |                                          } | 
| 119 | 0 |                                          KualiExceptionIncident exceptionIncident = reporterService | 
| 120 | .getExceptionIncident(reducedMap);  | |
| 121 |                                          // Report the incident | |
| 122 | 0 |                                          reporterService.report(exceptionIncident); | 
| 123 | 0 |                                  } else { | 
| 124 |                                          // Set return after canceling | |
| 125 | 0 |                                          ActionForward cancelForward = mapping | 
| 126 | .findForward(KNSConstants.MAPPING_CANCEL);  | |
| 127 | 0 |                                          if (cancelForward == null) { | 
| 128 | 0 |                                                  cancelForward = returnForward; | 
| 129 |                                          } else { | |
| 130 | 0 |                                                  returnForward = cancelForward; | 
| 131 | }  | |
| 132 | }  | |
| 133 | 0 |                          } | 
| 134 |                  } else { | |
| 135 |                          // Process the received exception from HTTP request | |
| 136 | 0 |                          returnForward = processException(mapping, form, request, e); | 
| 137 | }  | |
| 138 | ||
| 139 |                  // Not specified, return | |
| 140 | 0 |                  if (returnForward == null) { | 
| 141 | 0 |                          returnForward = mapping.findForward(KNSConstants.MAPPING_CLOSE); | 
| 142 | }  | |
| 143 | ||
| 144 | 0 |                  if (LOG.isDebugEnabled()) { | 
| 145 | 0 |                          String lm = String.format("EXIT %s", | 
| 146 | (returnForward == null) ? "null" : returnForward.getPath());  | |
| 147 | 0 |                          LOG.debug(lm); | 
| 148 | }  | |
| 149 | ||
| 150 | 0 |                  return returnForward; | 
| 151 | }  | |
| 152 | ||
| 153 |          /** | |
| 154 |           * This method process the caught exception by creating an exception | |
| 155 |           * information properties list and forward these properties to the exception | |
| 156 |           * incident handler JSP. | |
| 157 |           *  | |
| 158 |           * @param exception | |
| 159 |           * @param mapping | |
| 160 |           * @param request | |
| 161 |           * @param documentId | |
| 162 |           *            Id of the document that Struts threw exception during its | |
| 163 |           *            processing. null if not the document processing that caused | |
| 164 |           *            the exception | |
| 165 |           * @return | |
| 166 |           * @throws Exception | |
| 167 |           */ | |
| 168 |          @SuppressWarnings("unchecked") | |
| 169 |          protected ActionForward processException(ActionMapping mapping, | |
| 170 | ActionForm form, HttpServletRequest request, Exception exception)  | |
| 171 |                          throws Exception { | |
| 172 |                  // Only process the exception handling when the service | |
| 173 |                  // is specified | |
| 174 | 0 |                  KualiExceptionIncidentService reporterService = KNSServiceLocatorWeb | 
| 175 | .getKualiExceptionIncidentService();  | |
| 176 |                  // Get exception properties from the Http Request | |
| 177 | 0 |                  Map<String, String> properties = (Map<String, String>) request | 
| 178 | .getAttribute(IncidentReportUtils.EXCEPTION_PROPERTIES);  | |
| 179 |                  // Construct the exception incident object | |
| 180 | 0 |                  KualiExceptionIncident ei = reporterService.getExceptionIncident( | 
| 181 | exception, properties);  | |
| 182 |                  // Set full exception properties in Http Request and forward to JSP | |
| 183 | 0 |                  request.setAttribute(KualiExceptionHandlerAction.class | 
| 184 | .getName(), ei.toProperties());  | |
| 185 | 0 |                  return mapping.findForward(RiceConstants.MAPPING_BASIC); | 
| 186 | }  | |
| 187 | }  |