MethodSteams are a code representation of an entire call-tree, i.e. one file that contains the original method and all the methods it calls (recursively).
CodeSteams are all the possible 'taint follow' paths that exist on a particular MethodSteam
Here are they in action in the HacmeBank's source code:
Part 1 : The MethodStream
A MethodStream is a file which contains all methods that are called from a particular source method.
For example the HacmeBank's WebService method:
data:image/s3,"s3://crabby-images/52caa/52caa8aeb2760a8e942f62c0115149371cf68b4c" alt=""
who calls the DataFactory method:
data:image/s3,"s3://crabby-images/1aeda/1aeda6d60abc7f012beacdd86ad4851d53732c4b" alt=""
who calls the SqlEngine method:
data:image/s3,"s3://crabby-images/b802c/b802c9c7b499213321c86559123ffc2f50cae641" alt=""
So, in this case the MethodStream for the CreateUser WebService method looks like this:
data:image/s3,"s3://crabby-images/9d6d8/9d6d80c20410512f0bd73d7c76f47504bc51d957" alt=""
and
data:image/s3,"s3://crabby-images/0c5f8/0c5f8c1859cb0823e44251b8ab74caf43b98e7c9" alt=""
(the above auto generated methods are methods that the engine was able to resolve but the source code was not available)
Part 2: The CodeStream
The CodeStream is a unique data-flow path created from a starting point inside a provided MethodStream, for example here is an SQL Injection:
data:image/s3,"s3://crabby-images/affd4/affd4240a0626b7374abe9eddd1a3c4f57cbba0c" alt=""
data:image/s3,"s3://crabby-images/dcbc6/dcbc6f861c3bcaa7557a8d2291cbecd65b3f915c" alt=""
Part 3: Following Taint Step by Step
step 1:
data:image/s3,"s3://crabby-images/c9c41/c9c4177aeeac8862656aeabdc579349bca464835" alt=""
step 2:
data:image/s3,"s3://crabby-images/cca1b/cca1be15df112cbe021af431a2e072f76b48e9da" alt=""
step 3:
data:image/s3,"s3://crabby-images/46ef5/46ef5ae772698bf147d7adf88aac1bba712527e7" alt=""
step 4:
data:image/s3,"s3://crabby-images/3caa1/3caa1042969d35aa9c9b52b88e90b8904fe3035d" alt=""
step 5:
data:image/s3,"s3://crabby-images/4a7d5/4a7d58402f5bf00835cc6c06dfddc6c9fc97577e" alt=""
step 6:
data:image/s3,"s3://crabby-images/bffe7/bffe766494672b8359b051d1df4d3cec234a1592" alt=""
step 7:
data:image/s3,"s3://crabby-images/0baff/0baff627e534b97f4f2dd551137959a5a78df5df" alt=""
step 8:
data:image/s3,"s3://crabby-images/4bcdf/4bcdfce484c4140b009dcc4db1d9eb15939e24c5" alt=""
step 9:
data:image/s3,"s3://crabby-images/bafe8/bafe87179362834a9d782388d0d3e32e3a5d72f8" alt=""
Part 4: Graph with trace
data:image/s3,"s3://crabby-images/39352/39352447be60b7cac9766bda2f48ab45c7cd15a5" alt=""