All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.owasp.validator.html.CleanResults Maven / Gradle / Ivy

There is a newer version: 6.0.36
Show newest version
/*
 * 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;
	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy