1 /**
2 * Copyright 2005-2016 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 package org.kuali.rice.kns.util;
17
18
19 import java.io.Serializable;
20 import java.util.ArrayList;
21 import java.util.Iterator;
22 import java.util.List;
23
24 import org.apache.struts.action.ActionMessage;
25 import org.apache.struts.action.ActionMessages;
26 import org.kuali.rice.core.api.util.RiceKeyConstants;
27 import org.kuali.rice.krad.util.ErrorMessage;
28 import org.kuali.rice.krad.util.MessageMap;
29
30
31 /**
32 * Provides access to a copy of an ErrorMap and information derived from it. Necessary because ErrorMap implements the Map
33 * interface, which for some reason makes JSTL unwilling to translate ErrorMap.errorCount into a call to the getErrorCount method of
34 * that ErrorMap instance.
35 *
36 * Since I had to create this class to provide easy access to the error count (which must be computed as the sum of the sizes of the
37 * error message lists of all properties in the ErrorMap), I also moved in the existing code which massaged the contents of the
38 * ErrorMap for the purposes of export to the JSP.
39 *
40 * @deprecated Only used in KNS classes, use KRAD.
41 */
42 @Deprecated
43 public class ErrorContainer implements Serializable {
44 private final MessageMap errorMap;
45 private final int errorCount;
46
47 /**
48 * Constructs an ErrorContainer
49 *
50 * @param errorMap
51 */
52 public ErrorContainer(MessageMap errorMap) {
53 this.errorMap = errorMap;
54 this.errorCount = errorMap.getErrorCount();
55 }
56
57 /**
58 * @return number of errors in the ErrorMap used to initialize this container
59 */
60 public int getErrorCount() {
61 if (hasFormatterError()) {
62 return 0;
63 }
64 return errorCount;
65 }
66
67 /**
68 * @return simple List of all properies for which errorMessages exist in the ErrorMap used to initialize this container
69 */
70 public List getErrorPropertyList() {
71 List properties = new ArrayList();
72
73 for (Iterator iter = errorMap.getAllPropertiesWithErrors().iterator(); iter.hasNext();) {
74 properties.add(iter.next());
75 }
76
77 return properties;
78 }
79
80 /**
81 * This method checks whether the errorMap contains at least a formatter error.
82 * @return boolean true if the errorMap contains a formatter error and false otherwise
83 */
84 private boolean hasFormatterError() {
85 if (errorMap.getErrorCount()>0) {
86 for (String errorKey : errorMap.getAllPropertiesWithErrors()) {
87 List errorValues = errorMap.getMessages(errorKey);
88 for (ErrorMessage errorMessage : (List<ErrorMessage>)errorValues) {
89 if (errorMessage.getErrorKey().equals(RiceKeyConstants.ERROR_DOCUMENT_MAINTENANCE_FORMATTING_ERROR)) {
90 return true;
91 }
92 }
93 }
94 }
95 return false;
96 }
97
98 /**
99 * @return ActionMessages instance containing error messages constructed from the contents of the ErrorMap with which this
100 * container was initialized
101 */
102 public ActionMessages getRequestErrors() {
103 ActionMessages requestErrors = new ActionMessages();
104 for (Iterator iter = errorMap.getAllPropertiesWithErrors().iterator(); iter.hasNext();) {
105 String property = (String) iter.next();
106 List errorList = (List) errorMap.getErrorMessagesForProperty(property);
107
108 for (Iterator iterator = errorList.iterator(); iterator.hasNext();) {
109 ErrorMessage errorMessage = (ErrorMessage) iterator.next();
110
111 // add ActionMessage with any parameters
112 requestErrors.add(property, new ActionMessage(errorMessage.getErrorKey(), errorMessage.getMessageParameters()));
113 }
114 }
115 return requestErrors;
116 }
117 }