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

soot.jimple.infoflow.handlers.TaintPropagationHandler Maven / Gradle / Ivy

package soot.jimple.infoflow.handlers;

import java.util.Set;

import soot.Unit;
import soot.jimple.infoflow.InfoflowManager;
import soot.jimple.infoflow.data.Abstraction;

/**
 * Handler interface for callbacks during taint propagation
 * 
 * @author Steven Arzt
 * @author Malte Viering
 */
public interface TaintPropagationHandler {

	/**
	 * Enumeration containing the supported types of data flow edges
	 */
	public enum FlowFunctionType {
		NormalFlowFunction, CallFlowFunction, CallToReturnFlowFunction, ReturnFlowFunction
	}

	/**
	 * Handler function that is invoked when a taint is proagated in the data flow
	 * engine
	 * 
	 * @param stmt
	 *            The statement over which the taint is propagated
	 * @param taint
	 *            The taint being propagated
	 * @param manager
	 *            The manager object that gives access to the data flow engine
	 * @param type
	 *            The type of data flow edge being processed
	 */
	public void notifyFlowIn(Unit stmt, Abstraction taint, InfoflowManager manager, FlowFunctionType type);

	/**
	 * Handler function that is invoked when a new taint is generated in the data
	 * flow engine
	 * 
	 * @param stmt
	 *            The statement over which the taint is propagated
	 * @param d1
	 *            The abstraction at the beginning of the current method
	 * @param incoming
	 *            The original abstraction from which the outgoing ones were
	 *            computed
	 * @param outgoing
	 *            The set of taints being propagated
	 * @param manager
	 *            The manager object that gives access to the data flow engine
	 * @param type
	 *            The type of data flow edge being processed
	 * @return The new abstractions to be propagated on. If you do not want to
	 *         change the normal propagation behavior, just return the value of the
	 *         "taints" parameter as-is.
	 */
	public Set notifyFlowOut(Unit stmt, Abstraction d1, Abstraction incoming, Set outgoing,
			InfoflowManager manager, FlowFunctionType type);

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy