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

soot.jimple.infoflow.android.data.AndroidMemoryManager Maven / Gradle / Ivy

package soot.jimple.infoflow.android.data;

import java.util.Set;

import soot.RefType;
import soot.SootClass;
import soot.Type;
import soot.jimple.infoflow.data.Abstraction;
import soot.jimple.infoflow.data.FlowDroidMemoryManager;

/**
 * Specialized implementation of the memory manager interface for Android
 * 
 * @author Steven Arzt
 *
 */
public class AndroidMemoryManager extends FlowDroidMemoryManager {
	
	private final Set components;
	private boolean componentFilterApplied = false;
	
	/**
	 * Creates a new instance of the {@link AndroidMemoryManager} class
	 * @param tracingEnabled True if performance tracing data shall be recorded
	 * @param erasePathData Specifies whether data for tracking paths (current
	 * statement, corresponding call site) shall be erased.
	 * @param components The set of classes that are Android components
	 */
	public AndroidMemoryManager(boolean tracingEnabled,
			PathDataErasureMode erasePathData,
			Set components) {
		super(tracingEnabled, erasePathData);
		this.components = components;
	}
	
	@Override
	public Abstraction handleMemoryObject(Abstraction obj) {
		// We use the optimizations already present in FlowDroid
		obj = super.handleMemoryObject(obj);
		
		// If a complete component is tainted, it does make any sense to pursue
		// this taint further
		if (obj != null && obj.getAccessPath().getTaintSubFields()) {
			// Check for c.*
			if (obj.getAccessPath().isLocal()) {
				Type tp = obj.getAccessPath().getPlainValue().getType();
				Type runtimeType = obj.getAccessPath().getBaseType();
				if (isComponentType(tp) || isComponentType(runtimeType)
						|| isFilteredSystemType(tp) || isFilteredSystemType(runtimeType)) {
					componentFilterApplied = true;
					return null;
				}
			}
			
			// Check for c.d.e.*
			if (obj.getAccessPath().isInstanceFieldRef()) {
				Type tp = obj.getAccessPath().getLastField().getType();
				Type runtimeType = obj.getAccessPath().getLastFieldType();
				if (isComponentType(tp) || isComponentType(runtimeType)
						|| isFilteredSystemType(tp) || isFilteredSystemType(runtimeType)) {
					componentFilterApplied = true;
					return null;
				}
			}
		}
		
		return obj;
	}
	
	/**
	 * Checks whether the given type should be filtered out from the taint analysis
	 * @param tp The type to check
	 * @return True if the given type shall be filtered out from the taint analysis,
	 * otherwise false
	 */
	private boolean isFilteredSystemType(Type tp) {
		/*
		if (tp != null && tp instanceof RefType) {
			RefType rt = (RefType) tp;
			if (rt.getSootClass().getName().equals("android.view.View"))
				return true;
		}
		*/
		return false;
	}

	/**
	 * Checks whether the given type refers to an Android component
	 * @param tp The type to check
	 * @return True if the given type refers to one of the components declared
	 * in the app, otherwise false
	 */
	private boolean isComponentType(Type tp) {
		if (tp != null && tp instanceof RefType) {
			RefType rt = (RefType) tp;
			if (components.contains(rt.getSootClass())) {
				return true;
			}
		}
		return false;
	}
	
	/**
	 * Gets whether taints have been filtered out because they tainted whole
	 * components
	 * @return True if taints that referenced whole components were filtered
	 * out, otherwise false
	 */
	public boolean getComponentFilterApplied() {
		return this.componentFilterApplied;
	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy