/** Provides taint tracking configurations to be used in Unsafe Resource Fetching queries. */ import java import semmle.code.java.dataflow.FlowSources import semmle.code.java.dataflow.TaintTracking import semmle.code.java.security.RequestForgery import semmle.code.java.security.UnsafeAndroidAccess /** * A taint configuration tracking flow from untrusted inputs to a resource fetching call. */ module FetchUntrustedResourceConfig implements DataFlow::ConfigSig { predicate isSource(DataFlow::Node source) { source instanceof ActiveThreatModelSource } predicate isSink(DataFlow::Node sink) { sink instanceof UrlResourceSink } predicate isBarrier(DataFlow::Node sanitizer) { sanitizer instanceof RequestForgerySanitizer } predicate observeDiffInformedIncrementalMode() { any() } } /** * Detects taint flow from untrusted inputs to a resource fetching call. */ module FetchUntrustedResourceFlow = TaintTracking::Global;