001    /**
002     * Copyright 2005-2014 The Kuali Foundation
003     *
004     * Licensed under the Educational Community License, Version 2.0 (the "License");
005     * you may not use this file except in compliance with the License.
006     * You may obtain a copy of the License at
007     *
008     * http://www.opensource.org/licenses/ecl2.php
009     *
010     * Unless required by applicable law or agreed to in writing, software
011     * distributed under the License is distributed on an "AS IS" BASIS,
012     * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013     * See the License for the specific language governing permissions and
014     * limitations under the License.
015     */
016    package org.kuali.rice.krad.datadictionary.validator;
017    
018    import org.apache.commons.logging.Log;
019    import org.kuali.rice.krad.uif.component.Component;
020    import org.springframework.beans.factory.support.KualiDefaultListableBeanFactory;
021    import org.springframework.core.io.ResourceLoader;
022    
023    import java.io.BufferedWriter;
024    import java.io.FileWriter;
025    import java.io.IOException;
026    import java.io.PrintStream;
027    
028    /**
029     * A combination view controller for the Rice Dictionary Validator that handles both the setup/execution of the
030     * validation and the output of the results.
031     *
032     * @author Kuali Rice Team (rice.collab@kuali.org)
033     */
034    public class ValidationController {
035        protected static final String endl = System.getProperty("line.separator");
036    
037        protected boolean displayWarnings;
038        protected boolean displayErrors;
039        protected boolean displayXmlPages;
040        protected boolean displayErrorMessages;
041        protected boolean displayWarningMessages;
042    
043        /**
044         * Constructor creating a new Rice Dictionary Validator with limited information during output
045         *
046         * @param displayErrors - True if the Validator should show the number of error during output
047         * @param displayWarnings - True if the Validator should show the number of warnings during output
048         * @param displayErrorMessages - True if the Validator should show the messages for the error reports
049         * @param displayWarningMessages - True if the Validator should show messages involving warnings
050         * @param displayXmlPages - True if the Validator should show the list of xml pages for the error reports
051         */
052        public ValidationController(boolean displayErrors, boolean displayWarnings, boolean displayErrorMessages,
053                boolean displayWarningMessages, boolean displayXmlPages) {
054            //LOG.debug("Creating new Rice Dictionary Validator with limited output");
055            this.displayErrors = displayErrors;
056            this.displayWarnings = displayWarnings;
057            this.displayErrorMessages = displayErrorMessages;
058            this.displayWarningMessages = displayWarningMessages;
059            this.displayXmlPages = displayXmlPages;
060        }
061    
062        /**
063         * Constructor creating a new Rice Dictionary Validator
064         */
065        public ValidationController() {
066            //LOG.debug("Creating new Rice Dictionary Validator");
067            displayErrors = true;
068            displayWarnings = true;
069            displayErrorMessages = true;
070            displayWarningMessages = true;
071            displayXmlPages = true;
072        }
073    
074        /**
075         * Validates a collection of Spring Beans with no output
076         *
077         * @param xmlFiles - The collection of xml files used to load the provided beans
078         * @param beans - Collection of preloaded beans
079         * @param failOnWarning - Whether detecting a warning should cause the validation to fail
080         * @return Returns true if the beans past validation
081         */
082        public boolean validate(String[] xmlFiles, ResourceLoader loader, KualiDefaultListableBeanFactory beans,
083                boolean failOnWarning) {
084            // LOG.debug("Validating without output");
085            Validator validator = new Validator();
086    
087            boolean passed = validator.validate(xmlFiles, loader, beans, failOnWarning);
088    
089            return passed;
090        }
091    
092        /**
093         * Validates a collection of Spring Beans with output going to a file
094         *
095         * @param xmlFiles - The collection of xml files used to load the provided beans
096         * @param loader - The source that was used to load the beans
097         * @param beans - Collection of preloaded beans
098         * @param outputFile - The file location to save the output to
099         * @param failOnWarning - Whether detecting a warning should cause the validation to fail
100         * @return Returns true if the beans past validation
101         */
102        public boolean validate(String[] xmlFiles, ResourceLoader loader, KualiDefaultListableBeanFactory beans,
103                String outputFile, boolean failOnWarning) {
104            Validator validator = new Validator();
105            // LOG.debug("Validating with file output to "+outputFile);
106    
107            boolean passed = validator.validate(xmlFiles, loader, beans, failOnWarning);
108    
109            writeToFile(outputFile, validator, passed);
110    
111            return passed;
112        }
113    
114        /**
115         * Validates a collection of Spring Beans with output going to a print stream
116         *
117         * @param xmlFiles - The collection of xml files used to load the provided beans
118         * @param loader - The source that was used to load the beans
119         * @param beans - Collection of preloaded beans
120         * @param stream - The PrintStream the output is sent to
121         * @param failOnWarning - Whether detecting a warning should cause the validation to fail
122         * @return Returns true if the beans past validation
123         */
124        public boolean validate(String[] xmlFiles, ResourceLoader loader, KualiDefaultListableBeanFactory beans,
125                PrintStream stream, boolean failOnWarning) {
126            Validator validator = new Validator();
127            // LOG.debug("Validating with Print Stream output");
128    
129            boolean passed = validator.validate(xmlFiles, loader, beans, failOnWarning);
130    
131            writeToStream(stream, validator, passed);
132    
133            return passed;
134        }
135    
136        /**
137         * Validates a collection of Spring Beans with output going to Log4j
138         *
139         * @param xmlFiles - The collection of xml files used to load the provided beans
140         * @param loader - The source that was used to load the beans
141         * @param beans - Collection of preloaded beans
142         * @param log - The Log4j logger the output is sent to
143         * @param failOnWarning - Whether detecting a warning should cause the validation to fail
144         * @return Returns true if the beans past validation
145         */
146        public boolean validate(String[] xmlFiles, ResourceLoader loader, KualiDefaultListableBeanFactory beans, Log log,
147                boolean failOnWarning) {
148            Validator validator = new Validator();
149            //LOG.debug("Validating with Log4j output");
150    
151            boolean passed = validator.validate(xmlFiles, loader, beans, failOnWarning);
152    
153            writeToLog(log, validator, passed);
154    
155            return passed;
156        }
157    
158        /**
159         * Validates a collection of Spring Beans with no output
160         *
161         * @param xmlFiles - The collection of xml files used to load the beans
162         * @param failOnWarning - Whether detecting a warning should cause the validation to fail
163         * @return Returns true if the beans past validation
164         */
165        public boolean validate(String[] xmlFiles, boolean failOnWarning) {
166            // LOG.debug("Validating without output");
167            Validator validator = new Validator();
168    
169            boolean passed = validator.validate(xmlFiles, failOnWarning);
170    
171            return passed;
172        }
173    
174        /**
175         * Validates a collection of Spring Beans with output going to a file
176         *
177         * @param xmlFiles - The collection of xml files used to load the beans
178         * @param outputFile - The file location to save the output to
179         * @param failOnWarning - Whether detecting a warning should cause the validation to fail
180         * @return Returns true if the beans past validation
181         */
182        public boolean validate(String[] xmlFiles, String outputFile, boolean failOnWarning) {
183            Validator validator = new Validator();
184            //LOG.debug("Validating with file output to "+outputFile);
185    
186            boolean passed = validator.validate(xmlFiles, failOnWarning);
187    
188            writeToFile(outputFile, validator, passed);
189    
190            return passed;
191        }
192    
193        /**
194         * Validates a collection of Spring Beans with output going to a print stream
195         *
196         * @param xmlFiles - The collection of xml files used to load the beans
197         * @param stream - The PrintStream the output is sent to
198         * @param failOnWarning - Whether detecting a warning should cause the validation to fail
199         * @return Returns true if the beans past validation
200         */
201        public boolean validate(String[] xmlFiles, PrintStream stream, boolean failOnWarning) {
202            Validator validator = new Validator();
203            //LOG.debug("Validating with Print Stream output");
204    
205            boolean passed = validator.validate(xmlFiles, failOnWarning);
206    
207            writeToStream(stream, validator, passed);
208    
209            return passed;
210        }
211    
212        /**
213         * Validates a collection of Spring Beans with output going to Log4j
214         *
215         * @param xmlFiles - The collection of xml files used to load the provided beans
216         * @param log - The Log4j logger the output is sent to
217         * @param failOnWarning - Whether detecting a warning should cause the validation to fail
218         * @return Returns true if the beans past validation
219         */
220        public boolean validate(String[] xmlFiles, Log log, boolean failOnWarning) {
221            Validator validator = new Validator();
222            //LOG.debug("Validating with Log4j output");
223    
224            boolean passed = validator.validate(xmlFiles, failOnWarning);
225    
226            writeToLog(log, validator, passed);
227    
228            return passed;
229        }
230    
231        /**
232         * Validates a Component with output going to Log4j
233         *
234         * @param object - The component to be validated
235         * @param log - The Log4j logger the output is sent to
236         * @param failOnWarning - Whether detecting a warning should cause the validation to fail
237         * @return Returns true if the beans past validation
238         */
239        public boolean validate(Component object, Log log, boolean failOnWarning) {
240            Validator validator = new Validator();
241            //LOG.debug("Validating with Log4j output");
242    
243            boolean passed = validator.validate(object, failOnWarning);
244    
245            writeToLog(log, validator, passed);
246    
247            return passed;
248        }
249    
250        /**
251         * Writes the results of the validation to an output file
252         *
253         * @param path - The path to the file to write results to
254         * @param validator - The filled validator
255         * @param passed - Whether the validation passed or not
256         */
257        protected void writeToFile(String path, Validator validator, boolean passed) {
258            try {
259                BufferedWriter fout = new BufferedWriter(new FileWriter(path));
260    
261                fout.write("Validation Results" + endl);
262                fout.write("Passed: " + passed + endl);
263                if (displayErrors) {
264                    fout.write("Number of Errors: " + validator.getNumberOfErrors() + endl);
265                }
266                if (displayWarnings) {
267                    fout.write("Number of Warnings: " + validator.getNumberOfWarnings() + endl);
268                }
269    
270                if (displayErrorMessages) {
271                    for (int i = 0; i < validator.getErrorReportSize(); i++) {
272                        if (displayWarningMessages) {
273                            fout.write(endl);
274                            fout.write(validator.getErrorReport(i).errorMessage());
275                        } else if (validator.getErrorReport(i).getErrorStatus() == ErrorReport.ERROR) {
276                            fout.write(endl);
277                            fout.write(validator.getErrorReport(i).errorMessage());
278                        }
279    
280                        if (displayXmlPages) {
281                            fout.write(validator.getErrorReport(i).errorPageList());
282                        }
283                    }
284                }
285    
286                fout.close();
287            } catch (IOException e) {
288                //LOG.warn("Exception when writing file", e);
289            }
290        }
291    
292        /**
293         * Writes the results of the validation to an output file
294         *
295         * @param stream - The PrintStream the output is sent to
296         * @param validator - The filled validator
297         * @param passed - Whether the validation passed or not
298         */
299        protected void writeToStream(PrintStream stream, Validator validator, boolean passed) {
300            stream.println("Validation Results");
301            stream.println("Passed: " + passed);
302            if (displayErrors) {
303                stream.println("Number of Errors: " + validator.getNumberOfErrors());
304            }
305            if (displayWarnings) {
306                stream.println("Number of Warnings: " + validator.getNumberOfWarnings());
307            }
308    
309            if (displayErrorMessages) {
310                for (int i = 0; i < validator.getErrorReportSize(); i++) {
311                    stream.println();
312                    if (displayWarningMessages) {
313                        stream.println(validator.getErrorReport(i).errorMessage());
314                    } else if (validator.getErrorReport(i).getErrorStatus() == ErrorReport.ERROR) {
315                        stream.println(validator.getErrorReport(i).errorMessage());
316                    }
317    
318                    if (displayXmlPages) {
319                        stream.println(validator.getErrorReport(i).errorPageList());
320                    }
321                }
322            }
323        }
324    
325        /**
326         * Writes the results of the validation to an output file
327         *
328         * @param log - The Log4j logger the output is sent to
329         * @param validator - The filled validator
330         * @param passed - Whether the validation passed or not
331         */
332        protected void writeToLog(Log log, Validator validator, boolean passed) {
333            log.info("Passed: " + passed);
334            if (displayErrors) {
335                log.info("Number of Errors: " + validator.getNumberOfErrors());
336            }
337            if (displayWarnings) {
338                log.info("Number of Warnings: " + validator.getNumberOfWarnings());
339            }
340    
341            if (displayErrorMessages) {
342                for (int i = 0; i < validator.getErrorReportSize(); i++) {
343                    if (validator.getErrorReport(i).getErrorStatus() == ErrorReport.ERROR) {
344                        if (displayXmlPages) {
345                            log.error(validator.getErrorReport(i).errorMessage() + validator.getErrorReport(i)
346                                    .errorPageList());
347                        } else {
348                            log.error(validator.getErrorReport(i).errorMessage());
349                        }
350    
351                    } else {
352                        if (displayWarningMessages) {
353                            if (displayXmlPages) {
354                                log.warn(validator.getErrorReport(i).errorMessage() + validator.getErrorReport(i)
355                                        .errorPageList());
356                            } else {
357                                log.warn(validator.getErrorReport(i).errorMessage());
358                            }
359                        }
360                    }
361    
362                }
363            }
364        }
365    
366        /**
367         * Sets the displayWarnings
368         *
369         * @param display - Display or not
370         */
371        public void setDisplayWarnings(boolean display) {
372            displayWarnings = display;
373        }
374    
375        /**
376         * Sets the displayErrors
377         *
378         * @param display - Display or not
379         */
380        public void setDisplayErrors(boolean display) {
381            displayErrors = display;
382        }
383    
384        /**
385         * Sets the displayXmlPages
386         *
387         * @param display - Display or not
388         */
389        public void setDisplayXmlPages(boolean display) {
390            displayXmlPages = display;
391        }
392    
393        /**
394         * Sets the displayErrorMessages
395         *
396         * @param display - Display or not
397         */
398        public void setDisplayErrorMessages(boolean display) {
399            displayErrorMessages = display;
400        }
401    
402        /**
403         * Sets the displayWarningMessages
404         *
405         * @param display - Display or not
406         */
407        public void setDisplayWarningMessages(boolean display) {
408            displayWarningMessages = display;
409        }
410    
411        /**
412         * Gets the displayWarnings, whether the number of warnings should be displayed
413         *
414         * @return displayWarnings
415         */
416        public boolean isDisplayWarnings() {
417            return displayWarnings;
418        }
419    
420        /**
421         * Gets the displayErrors, whether the number of errors should be displayed
422         *
423         * @return displayErros
424         */
425        public boolean isDisplayErrors() {
426            return displayErrors;
427        }
428    
429        /**
430         * Gets the displayXmlPages, whether the xml pages involved should be displayed
431         *
432         * @return displayXmlPages
433         */
434        public boolean isDisplayXmlPages() {
435            return displayXmlPages;
436        }
437    
438        /**
439         * Gets the displayErrorMessages, whether the error messages should be displayed
440         *
441         * @return displayErrorMessages
442         */
443        public boolean isDisplayErrorMessages() {
444            return displayErrorMessages;
445        }
446    
447        /**
448         * Gets the displayWarningMessages, whether the warning messages should be displayed
449         *
450         * @return displayWarningMessages
451         */
452        public boolean isDisplayWarningMessages() {
453            return displayWarningMessages;
454        }
455    }