org.owasp.validator.html.CleanResults Maven / Gradle / Ivy
/*
* Copyright (c) 2007-2008, Arshan Dabirsiaghi, Jason Li
*
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
* Neither the name of OWASP nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package org.owasp.validator.html;
import java.util.ArrayList;
import java.util.Date;
import org.w3c.dom.DocumentFragment;
/**
* This class contains the results of a scan.
*
* The list of error messages (errorMessages
) will let the user know
* what, if any HTML errors existed, and what, if any, security or
* validation-related errors existed, and what was done about them.
*
* @author Arshan Dabirsiaghi
*
*/
public class CleanResults {
private ArrayList errorMessages = new ArrayList();
private String cleanHTML;
private Date startOfScan;
private Date endOfScan;
private DocumentFragment cleanXMLDocumentFragment;
/*
* For extension.
*/
public CleanResults() {
}
public CleanResults(Date startOfScan, Date endOfScan, String cleanHTML, DocumentFragment XMLDocumentFragment, ArrayList errorMessages) {
this.startOfScan = startOfScan;
this.endOfScan = endOfScan;
this.cleanXMLDocumentFragment = XMLDocumentFragment;
this.cleanHTML = cleanHTML;
this.errorMessages = errorMessages;
}
/**
* This is called at the beginning of the scan to initialize the start time and create a new CleanResults object.
* @param date The begin time of the scan.
*/
public CleanResults(Date date) {
this.startOfScan = date;
}
public DocumentFragment getCleanXMLDocumentFragment() {
return cleanXMLDocumentFragment;
}
public void setCleanHTML(String cleanHTML) {
this.cleanHTML = cleanHTML;
}
/**
* Return the filtered HTML as a String.
* @return A String object which contains the serialized, safe HTML.
*/
public String getCleanHTML() {
return cleanHTML;
}
/**
* Return a list of error messages.
* @return An ArrayList object which contain the error messages after a scan.
*/
public ArrayList getErrorMessages() {
return errorMessages;
}
/**
* Return the time when scan finished.
* @return A Date object indicating the moment the scan finished.
*/
public Date getEndOfScan() {
return endOfScan;
}
/**
* Return the time when scan started.
* @return A Date object indicating the moment the scan started.
*/
public Date getStartOfScan() {
return startOfScan;
}
/**
* Return the time elapsed during the scan.
* @return A double primitive indicating the amount of time elapsed between the beginning and end of the scan in seconds.
*/
public double getScanTime() {
return (endOfScan.getTime() - startOfScan.getTime()) / 1000D;
}
/**
* Add an error message to the aggregate list of error messages during filtering.
* @param msg An error message to append to the list of aggregate error messages during filtering.
*/
public void addErrorMessage(String msg) {
errorMessages.add(msg);
}
/**
* Return the number of errors encountered during filtering.
*/
public int getNumberOfErrors() {
return errorMessages.size();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy