## Triaging at scale * The artifact exchange contains many artifacts * Some are very simple * But we need to remember to collect them all! * When triaging an endpoint we want to quickly answer some questions * What happened here (Forensics) * What **bad** happened here (Detection) * Ideally a fire and forget approach * Easy to use - lots of impact! --- ## Triaging at scale ### VQL Uber artifacts * VQL Artifacts can be externally managed * Maintain a set of rules which can be managed independently of the main release. * `SQLite Hunter`: Automatically hunt and parse all Browser/OS artifacts * `Registry Hunter`: Automatically parse all registry relevant data. * `Evtx Hunter`: Hunt for event logs. * `Sigma Hayabusa`: Automatically detect suspicious activity in the event logs. --- ## SQLite Hunter * Designed for minimal configuration - just click and go! data:image/s3,"s3://crabby-images/44183/441839cea2d190a71672f71c5243eb0c8ffbea5e" alt="" --- ## SQLite Hunter * Automatically search for various SQLite files * Rules are based on categories * Maintained in their own open source repository at https://github.com/Velocidex/SQLiteHunter/ * Have evolved to parse other files **not only SQLite** * For example Windows Search Index * Firefox/Chrome extensions are JSON --- ## SQLite Hunter data:image/s3,"s3://crabby-images/2a482/2a48227bbe09914874c22da52116f2d04d2f3442" alt="" --- ## SQLite Hunter data:image/s3,"s3://crabby-images/076ff/076ff5a88d361987b376e29c33d8f65a1af20fc4" alt="" --- ## Registry Hunter * The Windows Registry is a treasure trove of information! * Contains critical information about installed software * System configuration * Sometimes has remnants of old activity * Contains thousands of keys and values * Need to know where to look * Sometimes we need to parse the values in some way (e.g. Binary Data or timestamps) * We really need to automate this! * https://github.com/Velocidex/registry_hunter/ * https://registry-hunter.velocidex.com/ --- ## Registry Hunter ### Analysis for each key is specified by rules data:image/s3,"s3://crabby-images/22f0c/22f0ce1ae3fb9f57f54b25c7b02b66d3aeaecce6" alt="" --- ## Registry Hunter ### Importing the latest artifact data:image/s3,"s3://crabby-images/769bb/769bb8e21870a6643a64c9a1b95bae1db19425ea" alt="" --- ## Registry Hunter * Designed for minimal configuration - just click and go! data:image/s3,"s3://crabby-images/5752d/5752d173fc49e64691101bbc01a19b89262a9704" alt="" --- ## Registry Hunter ### Postprocessing the results data:image/s3,"s3://crabby-images/885cc/885cccfc6a9bfcfd6b39ab76deaf63d855b9253d" alt="" --- ## Registry Hunter ### Stacking on a column data:image/s3,"s3://crabby-images/9c994/9c994f3360c0a998da85bff40b40ab1e9f95304b" alt="" --- ## Registry Hunter ### Open stacking groups window data:image/s3,"s3://crabby-images/786aa/786aa39079979b3506ec248dddd106e6025b2d33" alt="" --- ## Registry Hunter ### View stacking groups data:image/s3,"s3://crabby-images/3dcbd/3dcbd0aaf3784604d03bebb9bc42e2e161e2fe52" alt="" --- ## Registry Hunter ### Examine hits data:image/s3,"s3://crabby-images/c56f7/c56f74e0d5b5af196e799576d35d4e886d920b03" alt="" --- ## Registry Hunter ### Hunting with VQL * Sometimes we already know what we are looking for... * Lets see if anything mentions the word `Velociraptor` * The `=~` operator means `Regular Expression Match` ```sql SELECT * FROM source() WHERE Details =~ "velociraptor" ``` --- ## Registry Hunter ### Hunting with VQL data:image/s3,"s3://crabby-images/49cda/49cda7beca8a57d75088f2c51342d27b350072a2" alt="" --- ## Evtx Hunter * Event logs are an important source of information. * Many event sources, files and event IDs * Sometimes the best approach is the brute force approach! * Search for any event that happens to mention `Velociraptor`! * We dont need to know in advance what service will log it * Cast a wide net! --- ## Evtx Hunter data:image/s3,"s3://crabby-images/243a3/243a3f74f8635733be57131abb69c388bf9b7256" alt="" --- ## Evtx Hunter * Clean up the table by removing extra columns ```sql SELECT EventTime, Provider, EventID, EventData, Message FROM source(artifact="Windows.EventLogs.EvtxHunter") ``` data:image/s3,"s3://crabby-images/81ec0/81ec0ab3bbea56d8e1e142ee63b8376cb2b6be5a" alt="" --- ## Evtx Hunter ### Extra stacking gives many more event logs data:image/s3,"s3://crabby-images/e88a8/e88a80a2f7f918c5e14e59be3858015d6550587d" alt="" --- ## Evtx Hunter data:image/s3,"s3://crabby-images/49b9f/49b9fd64a13df0bc4222fb5a911d539306d2fd80" alt="" --- ## Sigma Hayabusa ### Detecting evil! * So far we saw what happened on the system * But - what **bad** happened on the system? * This is the difference between detection and forensics. * We previously did it manually - can we automate it? * Sigma is a way to write detection rules for event logs --- ## What is a Sigma Rule? ```yaml title: PSExec Lateral Movement logsource: product: windows service: system detection: selection: Channel: System EventID: 7045 selection_PSEXESVC_in_service: Service: PSEXESVC selection_PSEXESVC_in_path: ImagePath|contains: PSEXESVC condition: selection and (selection_PSEXESVC_in_service or selection_PSEXESVC_in_path) ``` --- ## Triaging Using Sigma * Endpoint tools can directly evaluate Sigma rules on the event logs data:image/s3,"s3://crabby-images/4d785/4d785fdb5fa6a01aa4528012e35f94191ead9deb" alt="" --- ## Collecting the sigma artifact data:image/s3,"s3://crabby-images/2478a/2478ae3a70ea4cc422f782e48a0a5673442142ef" alt="" --- ## Triaging an endpoint data:image/s3,"s3://crabby-images/ae465/ae46544623f3b80a95c6dd7afc81ddb80bb8a6ab" alt="" --- ## Stacking rules by title data:image/s3,"s3://crabby-images/71acc/71acc52b29886bdcccd333fd5b824be3eaf254ec" alt="" --- ## Viewing the stacking stats data:image/s3,"s3://crabby-images/643ce/643ce31c93994822fe012421a6c71e8ca99fe94f" alt="" --- ## Viewing common rows data:image/s3,"s3://crabby-images/f1081/f1081ba0c457ba6da7f6841952291d5200c6f7a8" alt=""