* Many artifacts around process execution
* None of them are perfect!
* Missing data:
* Parent process (Call chain)
* User that launched the process
* Limited number of last run timestamps
---
## Preparing for Process Execution
* By far the best preparation is to install Sysmon or process logging.
* This has some very small overhead but it is so worth it!
* Process execution logging gives us context as to activity on the
system.
---
## Tracking processes
* One of the critical questions we ask is `Where did this process come
from?`
* Context of where the process came from is important in establishing
initial access vector!
* We could collect all process execution from all endpoints, but:
* This will generate a large volume of events.
* Vast majority of events are not interesting.
* Often determining which process is interesting is determined by
context.
---
## Where did notepad process come from?
data:image/s3,"s3://crabby-images/81a40/81a40476a0536c63c23b80b4b0b900971f75a4bc" alt=""
---
## Using Generic.System.Pstree
data:image/s3,"s3://crabby-images/6e5aa/6e5aa724e47c50c77a114ea632f4ecb8d0c0883d" alt=""
---
## View process tree
data:image/s3,"s3://crabby-images/25664/25664ede5901146a020e796403fe724172f565b7" alt=""
---
## Inspect the process call chain
data:image/s3,"s3://crabby-images/c84ca/c84caceb39cd12863918bfd70cba31e442b0f3f1" alt=""