org.owasp.validator.html.CleanResults Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of com.liferay.portal.security.antisamy
Show all versions of com.liferay.portal.security.antisamy
Liferay Portal Security AntiSamy
/*
* Copyright (c) 2007-2021, 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.Collections;
import java.util.List;
import java.util.concurrent.Callable;
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 List errorMessages;
private Callable cleanHTML;
private long startOfScan;
private long elapsedScan;
/*
* A DOM object version of the clean HTML String. May be null even if clean HTML is set.
*/
private DocumentFragment cleanXMLDocumentFragment;
/*
* For extension.
*/
public CleanResults() {
this.errorMessages = new ArrayList();
}
/**
* Create a clean set of results.
* @param startOfScan - The time when the scan started.
* @param cleanHTML - The resulting clean HTML produced per the AntiSamy policy.
* @param XMLDocumentFragment - The XML Document fragment version of the clean HTML produced during the sanitzation process.
* @param errorMessages - Messages describing any errors that occurred during sanitization.
*/
public CleanResults(long startOfScan, final String cleanHTML,
DocumentFragment XMLDocumentFragment, List errorMessages) {
this(startOfScan,
new Callable() {
public String call() throws Exception {
return cleanHTML;
}
},
XMLDocumentFragment,
errorMessages);
}
/**
* Create a clean set of results.
* @param startOfScan - The time when the scan started.
* @param cleanHTML - The resulting clean HTML produced per the AntiSamy policy.
* @param XMLDocumentFragment - The XML Document fragment version of the clean HTML produced during the sanitization process.
* @param errorMessages - Messages describing any errors that occurred during sanitization.
*/
public CleanResults(long startOfScan, Callable cleanHTML,
DocumentFragment XMLDocumentFragment, List errorMessages) {
this.startOfScan = startOfScan;
this.elapsedScan = System.currentTimeMillis() - startOfScan;
this.cleanXMLDocumentFragment = XMLDocumentFragment;
this.cleanHTML = cleanHTML;
this.errorMessages = Collections.unmodifiableList(errorMessages);
}
/**
* Return the DOM version of the clean HTML.
*
* @return The XML Document fragment version of the clean HTML produced during the sanitization process.
* This may be null, even if the clean HTML String is not null.
*/
public DocumentFragment getCleanXMLDocumentFragment() {
return cleanXMLDocumentFragment;
}
/**
* Return the filtered HTML as a String.
*
* @return A String object which contains the serialized, safe HTML.
*/
public String getCleanHTML() {
try {
return cleanHTML.call();
} catch (Exception e) {
throw new RuntimeException(e);
}
}
/**
* Return a list of error messages -- but an empty list returned does not mean there was no attack
* present, due to the serialization and deserialization process automatically cleaning up some
* attacks. See the README for more discussion.
*
* @return An ArrayList object which contain the error messages after a
* scan.
*/
public List getErrorMessages() {
return errorMessages;
}
/**
* 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 elapsedScan / 1000D;
}
/**
* Return the number of errors encountered during filtering.
*
* @return The number of errors encountered during filtering.
*/
public int getNumberOfErrors() {
return errorMessages.size();
}
/**
* Get the time the scan started.
*
* @return time that scan started in milliseconds since epoch.
*/
public long getStartOfScan()
{
return startOfScan;
}
}