Skip to content

Trend Micro Vision One Observed Attack Techniques

Overview

Trend Micro Vision One is an extended detection and response (XDR) platform that enhances threat detection, investigation, and response across multiple security layers. It provides a centralized view for improved security posture and faster threat remediation. This intake format will ingest Observed Attack Techniques from Trend Micro Vision One.

Warning

Important note - This format is currently in beta. We highly value your feedback to improve its performance.

  • Supported environment: SaaS
  • Detection based on: Alerts
  • Supported application or feature:
    • Observed Attack Techniques

Configure

How to create an API token

  1. Log in the Trend Vision One console
  2. On the left panel, click Administration then click API keys

    step 1

  3. Click Add API key

    step 2

  4. Type a name for the API key

  5. Select the SIEM role and an expiration time
  6. Check status to enable the API key

    step 3

  7. Copy the API key and click Close

    step 4

Instruction on Sekoia

Configure Your Intake

This section will guide you through creating the intake object in Sekoia, which provides a unique identifier called the "Intake key." The Intake key is essential for later configuration, as it references the Community, Entity, and Parser (Intake Format) used when receiving raw events on Sekoia.

  1. Go to the Sekoia Intake page.
  2. Click on the + New Intake button at the top right of the page.
  3. Search for your Intake by the product name in the search bar.
  4. Give it a Name and associate it with an Entity (and a Community if using multi-tenant mode).
  5. Click on Create.

Note

For more details on how to use the Intake page and to find the Intake key you just created, refer to this documentation.

Event Categories

The following table lists the data source offered by this integration.

Data Source Description
Network intrusion detection system None

In details, the following table denotes the type of events produced by this integration.

Name Values
Kind ``
Category intrusion_detection
Type info

Transformed Events Samples after Ingestion

This section demonstrates how the raw logs will be transformed by our parsers. It shows the extracted fields that will be available for use in the built-in detection rules and hunting activities in the events page. Understanding these transformations is essential for analysts to create effective detection mechanisms with custom detection rules and to leverage the full potential of the collected data.

{
    "message": "{\"source\": \"endpointActivityData\", \"uuid\": \"2d4af1a4-d784-4a91-9634-b0166f9118ef\", \"filters\": [{\"id\": \"F4231\", \"name\": \"Service Execution via Service Control Manager\", \"description\": \"Service Control Manager (services.exe) has executed a process\", \"mitreTacticIds\": [\"TA0002\"], \"mitreTechniqueIds\": [\"T1560.002\"], \"highlightedObjects\": [{\"type\": \"port\", \"field\": \"objectPort\", \"value\": 443}], \"riskLevel\": \"info\", \"type\": \"custom\"}], \"endpoint\": {\"endpointName\": \"LAB-Luwak-1048\", \"agentGuid\": \"b1cde761-16ad-4067-9a57-cbea882915df\", \"ips\": [\"150.183.13.135\", \"433e:5c7b:50b0:d145:2c61:9d1d:f317:627e\"]}, \"entityType\": \"endpoint\", \"entityName\": \"desktop 1 (110.205.134.245) or 110.205.134.245 | xxxx@gmail.com | arn:aws:lambda:*:%s:function:%s | k8s_container-8c55678bd-8r7zt_default_c1e0cf9a-47bb-41e7-ad41-bac976462a81_6411 | 6d7d30d2148a | -\", \"detectedDateTime\": \"2020-06-01T02:12:56Z\", \"ingestedDateTime\": \"2020-06-01T02:12:56Z\", \"detail\": {\"eventTime\": \"1649806995000\", \"tags\": [\"MITREV9.T1569.002\", \"XSAE.F4231\"], \"uuid\": \"2d4af1a4-d784-4a91-9634-b0166f9118ef\", \"productCode\": \"xes\", \"filterRiskLevel\": \"info\", \"bitwiseFilterRiskLevel\": 1, \"eventId\": \"1\", \"eventSubId\": 2, \"eventHashId\": \"-7817927890991207527\", \"firstSeen\": \"1649806995000\", \"lastSeen\": \"1649806995000\", \"endpointGuid\": \"b1cde761-16ad-4067-9a57-cbea882915df\", \"endpointHostName\": \"LAB-Luwak-1048\", \"endpointIp\": [\"433e:5c7b:50b0:d145:2c61:9d1d:f317:627e\", \"150.183.13.135\"], \"endpointMacAddress\": [\"00:50:56:89:09:9b\"], \"timezone\": \"UTC+08:00\", \"pname\": \"751\", \"pver\": \"1.2.0.2454\", \"plang\": 1, \"pplat\": 5889, \"osName\": \"Windows\", \"osVer\": \"10.0.19044\", \"osDescription\": \"Windows 10 Enterprise (64 bit) build 19044\", \"osType\": \"0x00000004\", \"processHashId\": \"8149551095598764453\", \"processName\": \"C:\\\\Windows\\\\System32\\\\services.exe\", \"processPid\": 672, \"sessionId\": 0, \"processUser\": \"SYSTEM\", \"processUserDomain\": \"NT AUTHORITY\", \"processLaunchTime\": \"1646826182237\", \"processCmd\": \"C:\\\\Windows\\\\system32\\\\services.exe\", \"authId\": \"999\", \"integrityLevel\": 16384, \"processFileHashId\": \"-4092577940452904134\", \"processFilePath\": \"C:\\\\Windows\\\\System32\\\\services.exe\", \"processFileHashSha1\": \"a75988a89b1e18c5af82f5f4f5e28f9c91c2cd3e\", \"processFileHashSha256\": \"ab6acff524930ed8fddd84787a8d65ec9ed0b6b62727dac4a23a1ec7a13b4b08\", \"processFileHashMd5\": \"dac02fbf9bebb39e34afe11bfddf2f83\", \"processSigner\": [\"Microsoft Windows Publisher\"], \"processSignerValid\": [true], \"processFileSize\": \"714856\", \"processFileCreation\": \"1618396713939\", \"processFileModifiedTime\": \"1618396713971\", \"processTrueType\": 7, \"objectHashId\": \"499492567380524547\", \"objectUser\": \"NETWORK SERVICE\", \"objectUserDomain\": \"NT AUTHORITY\", \"objectSessionId\": \"0\", \"objectFilePath\": \"C:\\\\Windows\\\\System32\\\\sppsvc.exe\", \"objectFileHashSha1\": \"42aeb6f7261c3c0521d19a77d2ea1956d122921f\", \"objectFileHashSha256\": \"be86edb76a659ddb715dbe985013683bf7831736a779178b28240ee74e393c21\", \"objectFileHashMd5\": \"e47a33a58764cd5cb567000035876e1a\", \"objectSigner\": [\"Microsoft Windows\"], \"objectSignerValid\": [true], \"objectFileSize\": \"4629328\", \"objectFileCreation\": \"1646822883174\", \"objectFileModifiedTime\": \"1646822883393\", \"objectTrueType\": 7, \"objectName\": \"C:\\\\Windows\\\\System32\\\\sppsvc.exe\", \"objectPid\": 3832, \"objectLaunchTime\": \"1649806995010\", \"objectCmd\": \"C:\\\\Windows\\\\system32\\\\sppsvc.exe\", \"objectAuthId\": \"996\", \"objectIntegrityLevel\": 16384, \"objectFileHashId\": \"-4729198244400997661\", \"objectRunAsLocalAccount\": false}}",
    "event": {
        "category": [
            "intrusion_detection"
        ],
        "end": "2022-04-12T23:43:15Z",
        "start": "2022-04-12T23:43:15Z",
        "type": [
            "info"
        ]
    },
    "@timestamp": "2020-06-01T02:12:56Z",
    "agent": {
        "id": "b1cde761-16ad-4067-9a57-cbea882915df"
    },
    "host": {
        "id": "b1cde761-16ad-4067-9a57-cbea882915df",
        "ip": [
            "150.183.13.135",
            "433e:5c7b:50b0:d145:2c61:9d1d:f317:627e"
        ],
        "name": "LAB-Luwak-1048",
        "os": {
            "full": "Windows 10 Enterprise (64 bit) build 19044",
            "name": "Windows",
            "version": "10.0.19044"
        }
    },
    "observer": {
        "product": "Vision One",
        "vendor": "TrendMicro"
    },
    "process": {
        "command_line": "C:\\Windows\\system32\\sppsvc.exe",
        "name": "services.exe",
        "parent": {
            "command_line": "C:\\Windows\\system32\\services.exe",
            "executable": "C:\\Windows\\System32\\services.exe",
            "hash": {
                "md5": "dac02fbf9bebb39e34afe11bfddf2f83",
                "sha1": "a75988a89b1e18c5af82f5f4f5e28f9c91c2cd3e",
                "sha256": "ab6acff524930ed8fddd84787a8d65ec9ed0b6b62727dac4a23a1ec7a13b4b08"
            },
            "pid": 672,
            "start": "2022-03-09T11:43:02.237000Z",
            "user": {
                "domain": "NT AUTHORITY",
                "name": "SYSTEM"
            }
        },
        "pid": 3832
    },
    "related": {
        "hash": [
            "a75988a89b1e18c5af82f5f4f5e28f9c91c2cd3e",
            "ab6acff524930ed8fddd84787a8d65ec9ed0b6b62727dac4a23a1ec7a13b4b08",
            "dac02fbf9bebb39e34afe11bfddf2f83"
        ],
        "ip": [
            "150.183.13.135",
            "433e:5c7b:50b0:d145:2c61:9d1d:f317:627e"
        ],
        "user": [
            "NETWORK SERVICE"
        ]
    },
    "threat": {
        "tactic": {
            "id": [
                "TA0002"
            ]
        },
        "technique": {
            "subtechnique": {
                "id": [
                    "T1560.002"
                ]
            }
        }
    },
    "user": {
        "domain": "NT AUTHORITY",
        "name": "NETWORK SERVICE"
    }
}
{
    "message": "{\"source\": \"endpointActivityData\", \"uuid\": \"541ec898-a229-49ae-831a-04f0a8fdb256\", \"detectedDateTime\": \"2024-11-26T16:45:02Z\", \"filters\": [{\"id\": \"F3457\", \"name\": \"Execution of System Discovery Tools\", \"description\": \"Detects the execution of system discovery tools\", \"highlightedObjects\": [{\"field\": \"objectCmd\", \"type\": \"command_line\", \"value\": \"\\\"C:\\\\Windows\\\\system32\\\\klist.exe\\\"\"}, {\"field\": \"processCmd\", \"type\": \"command_line\", \"value\": \"\\\"C:\\\\Windows\\\\system32\\\\WindowsPowerShell\\\\v1.0\\\\PowerShell_ISE.exe\\\" \"}, {\"field\": \"parentCmd\", \"type\": \"command_line\", \"value\": \"C:\\\\Windows\\\\Explorer.EXE\"}], \"mitreTacticIds\": [\"TA0007\"], \"mitreTechniqueIds\": [\"T1082\"], \"riskLevel\": \"low\", \"type\": \"preset\"}], \"detail\": {\"endpointGuid\": \"1c7a31e1-89e1-4192-aa7b-a341e6a8ebf1\", \"endpointHostName\": \"Windows10\", \"endpointIp\": [\"1802:d896:65fe:0b84:742d:0615:f69b:6600\", \"239.144.71.57\"], \"eventId\": \"1\", \"eventSubId\": 2, \"eventTime\": \"1732639502571\", \"filterRiskLevel\": \"low\", \"firstSeen\": \"1732639502571\", \"groupId\": \"3927f750-c536-480a-ae9f-d9ede20f4a9e\", \"integrityLevel\": 12288, \"lastSeen\": \"1732639502571\", \"logReceivedTime\": \"1732639512822\", \"logonUser\": [\"jdoe\"], \"objectCmd\": \"\\\"C:\\\\Windows\\\\system32\\\\klist.exe\\\"\", \"objectFileHashMd5\": \"c0ab059977511f3da83329c7562224e0\", \"objectFileHashSha1\": \"a4c1830c1e00779c50626a5ea93b8a54e2e3960b\", \"objectFileHashSha256\": \"f4c3734b96965947a3f42c6509538774bd0ecea110edfcb9f7463c83c90f32a7\", \"objectFilePath\": \"C:\\\\Windows\\\\System32\\\\klist.exe\", \"objectHashId\": \"-4153650555873691306\", \"objectIntegrityLevel\": 12288, \"objectName\": \"C:\\\\Windows\\\\System32\\\\klist.exe\", \"objectPid\": 3464, \"objectSigner\": [\"Microsoft Windows\"], \"objectSignerValid\": [true], \"objectTrueType\": 7, \"objectUser\": \"jdoe\", \"objectUserDomain\": \"Windows10\", \"osDescription\": \"Windows 10 Pro (64 bit) build 19045\", \"parentCmd\": \"C:\\\\Windows\\\\Explorer.EXE\", \"parentFileHashId\": \"1767110345653159701\", \"parentFileHashMd5\": \"a377274ae8e84c7e8ff5fd1b3bb9d080\", \"parentFileHashSha1\": \"b1db7fd8ea0d2fb6ca854609c9ff7de5a822b316\", \"parentFileHashSha256\": \"4e5fe7cf2873f4e4157d6592154179f6efe0b200dbb72fbdca039e4e4c72d4ac\", \"parentFilePath\": \"C:\\\\Windows\\\\explorer.exe\", \"parentHashId\": \"999588025188847480\", \"parentIntegrityLevel\": 12288, \"parentLaunchTime\": \"1732638953785\", \"parentName\": \"C:\\\\Windows\\\\explorer.exe\", \"parentPid\": 9920, \"parentSigner\": [\"Microsoft Windows\"], \"parentSignerValid\": [true], \"parentTrueType\": 7, \"parentUser\": \"jdoe\", \"parentUserDomain\": \"Windows10\", \"pname\": \"751\", \"processCmd\": \"\\\"C:\\\\Windows\\\\system32\\\\WindowsPowerShell\\\\v1.0\\\\PowerShell_ISE.exe\\\" \", \"processFileHashId\": \"-4900073020808934214\", \"processFileHashMd5\": \"fe6a3a98112b13aaad196444afcc041c\", \"processFileHashSha1\": \"0aea4fdd45c998bcf774e85ec478ab2e71fb8b4b\", \"processFileHashSha256\": \"09f94c21bc54d3de56b4007b0d650cb54a1dbbb91dc1d537426ac442448c4eed\", \"processFilePath\": \"C:\\\\Windows\\\\System32\\\\WindowsPowerShell\\\\v1.0\\\\powershell_ise.exe\", \"processHashId\": \"-5529997575794356190\", \"processLaunchTime\": \"1732639075967\", \"processName\": \"C:\\\\Windows\\\\System32\\\\WindowsPowerShell\\\\v1.0\\\\powershell_ise.exe\", \"processPid\": 5040, \"processSigner\": [\"Microsoft Windows\"], \"processSignerValid\": [true], \"processTrueType\": 7, \"processUser\": \"jdoe\", \"processUserDomain\": \"Windows10\", \"productCode\": \"xes\", \"tags\": [\"XSAE.F3457\", \"MITRE.T1082\"], \"uuid\": \"775a187e-723d-4889-a532-0835e28ab109\", \"plang\": 1, \"pver\": \"1.2.0.5608\", \"processSignerFlagsLibValid\": [false], \"eventHashId\": \"-1446580424195895092\", \"processFileSize\": \"212992\", \"eventSourceType\": 1, \"processSignerFlagsAdhoc\": [false], \"processFileModifiedTime\": \"1575651900000\", \"pplat\": 5889, \"processSignerFlagsRuntime\": [false], \"timezone\": \"UTC+00:00\", \"osVer\": \"10.0.19045\", \"authId\": \"1494147\", \"endpointMacAddress\": [\"8f:86:c0:d8:9d:ad\"], \"osType\": \"0x00000030\", \"processFileCreation\": \"1575712305614\", \"userDomain\": [\"Windows10\"], \"sessionId\": 2, \"osName\": \"Windows\", \"parentSignerFlagsLibValid\": [false], \"objectFileCreation\": \"1728117145131\", \"parentFileCreation\": \"1728117061706\", \"parentSessionId\": 2, \"objectFileSize\": \"76288\", \"parentFileModifiedTime\": \"1728117061831\", \"parentSignerFlagsAdhoc\": [false], \"parentAuthId\": \"1494147\", \"parentSignerFlagsRuntime\": [false], \"parentFileSize\": \"5845320\", \"objectFileModifiedTime\": \"1728117145131\", \"objectSignerFlagsRuntime\": [false], \"objectSessionId\": \"2\", \"objectRunAsLocalAccount\": false, \"objectSignerFlagsLibValid\": [false], \"objectLaunchTime\": \"1732639502565\", \"objectSignerFlagsAdhoc\": [false], \"objectAuthId\": \"1494147\", \"objectFileHashId\": \"-8054087497998296081\", \"processUserGroupSids\": [\"S-1-1-0\", \"S-1-5-114\"], \"objectUserGroupSids\": [\"S-1-1-0\", \"S-1-5-114\"]}, \"ingestedDateTime\": \"2024-11-26T16:45:25Z\", \"entityType\": \"endpoint\", \"entityName\": \"Windows10(1802:d896:65fe:0b84:742d:0615:f69b:6600,239.144.71.57)\", \"endpoint\": {\"ips\": [\"1802:d896:65fe:0b84:742d:0615:f69b:6600\", \"239.144.71.57\"], \"agentGuid\": \"9f6b89c4-c3b2-4b9f-9401-dae324506ceb\", \"endpointName\": \"Windows10\"}}",
    "event": {
        "category": [
            "intrusion_detection"
        ],
        "end": "2024-11-26T16:45:02.571000Z",
        "start": "2024-11-26T16:45:02.571000Z",
        "type": [
            "info"
        ]
    },
    "@timestamp": "2024-11-26T16:45:02Z",
    "agent": {
        "id": "9f6b89c4-c3b2-4b9f-9401-dae324506ceb"
    },
    "group": {
        "id": "3927f750-c536-480a-ae9f-d9ede20f4a9e"
    },
    "host": {
        "id": "1c7a31e1-89e1-4192-aa7b-a341e6a8ebf1",
        "ip": [
            "1802:d896:65fe:b84:742d:615:f69b:6600",
            "239.144.71.57"
        ],
        "name": "Windows10",
        "os": {
            "full": "Windows 10 Pro (64 bit) build 19045",
            "name": "Windows",
            "version": "10.0.19045"
        }
    },
    "observer": {
        "product": "Vision One",
        "vendor": "TrendMicro"
    },
    "process": {
        "command_line": "\"C:\\Windows\\system32\\klist.exe\"",
        "name": "powershell_ise.exe",
        "parent": {
            "command_line": "\"C:\\Windows\\system32\\WindowsPowerShell\\v1.0\\PowerShell_ISE.exe\" ",
            "executable": "C:\\Windows\\System32\\WindowsPowerShell\\v1.0\\powershell_ise.exe",
            "hash": {
                "md5": "fe6a3a98112b13aaad196444afcc041c",
                "sha1": "0aea4fdd45c998bcf774e85ec478ab2e71fb8b4b",
                "sha256": "09f94c21bc54d3de56b4007b0d650cb54a1dbbb91dc1d537426ac442448c4eed"
            },
            "parent": {
                "command_line": "C:\\Windows\\Explorer.EXE",
                "executable": "C:\\Windows\\explorer.exe",
                "hash": {
                    "md5": "a377274ae8e84c7e8ff5fd1b3bb9d080",
                    "sha1": "b1db7fd8ea0d2fb6ca854609c9ff7de5a822b316",
                    "sha256": "4e5fe7cf2873f4e4157d6592154179f6efe0b200dbb72fbdca039e4e4c72d4ac"
                },
                "name": "explorer.exe",
                "pid": "9920",
                "start": "2024-11-26T16:35:53.785000Z",
                "user": {
                    "domain": "Windows10",
                    "name": "jdoe"
                }
            },
            "pid": 5040,
            "start": "2024-11-26T16:37:55.967000Z",
            "user": {
                "domain": "Windows10",
                "name": "jdoe"
            }
        },
        "pid": 3464
    },
    "related": {
        "hash": [
            "09f94c21bc54d3de56b4007b0d650cb54a1dbbb91dc1d537426ac442448c4eed",
            "0aea4fdd45c998bcf774e85ec478ab2e71fb8b4b",
            "fe6a3a98112b13aaad196444afcc041c"
        ],
        "ip": [
            "1802:d896:65fe:b84:742d:615:f69b:6600",
            "239.144.71.57"
        ],
        "user": [
            "jdoe"
        ]
    },
    "threat": {
        "tactic": {
            "id": [
                "TA0007"
            ]
        },
        "technique": {
            "id": [
                "T1082"
            ]
        }
    },
    "user": {
        "domain": "Windows10",
        "name": "jdoe"
    }
}
{
    "message": "{\"source\": \"endpointActivityData\", \"uuid\": \"43483725-969b-4fb8-a453-c2353a9a5e12\", \"detectedDateTime\": \"2024-11-26T16:45:01Z\", \"filters\": [{\"id\": \"F3367\", \"name\": \"Sensitive File Locating via Powershell\", \"description\": \"Locate files deemed sensitive via Powershell\", \"highlightedObjects\": [{\"field\": \"objectRawDataStr\", \"type\": \"amsi_rawDataStr\", \"value\": [\"\\r\\n                                    if ($_.FullyQualifiedErrorId -ne \\\"NativeCommandErrorMessage\\\" -and $ErrorView -ne \\\"CategoryView\\\")\\r\\n                                    {\\r\\n                                        $myinv = $_.InvocationInfo\\r\\n                                        if ($myinv -and $myinv.MyCommand)\\r\\n                                        {\\r\\n                                            switch -regex ( $myinv.MyCommand.CommandType )\\r\\n                                            {\\r\\n                                                ([System.Management.Automation.CommandTypes]::ExternalScript)\\r\\n                                                {\\r\\n                                                    if ($myinv.MyCommand.Path)\\r\\n                                                    {\\r\\n                                                        $myinv.MyCommand.Path + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                                ([System.Management.Automation.CommandTypes]::Script)\\r\\n                                                {\\r\\n                                                    if ($myinv.MyCommand.ScriptBlock)\\r\\n                                                    {\\r\\n                                                        $myinv.MyCommand.ScriptBlock.ToString() + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                                default\\r\\n                                                {\\r\\n                                                    if ($myinv.InvocationName -match '^[&\\\\.]?$')\\r\\n                                                    {\\r\\n                                                        if ($myinv.MyCommand.Name)\\r\\n                                                        {\\r\\n                                                            $myinv.MyCommand.Name + \\\" : \\\"\\r\\n                                                        }\\r\\n                                                    }\\r\\n                                                    else\\r\\n                                                    {\\r\\n                                                        $myinv.InvocationName + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                            }\\r\\n                                        }\\r\\n                                        elseif ($myinv -and $myinv.InvocationName)\\r\\n                                        {\\r\\n                                            $myinv.InvocationName + \\\" : \\\"\\r\\n                                        }\\r\\n                                    }\\r\\n                                \", \"\\r\\n                                   if ($_.FullyQualifiedErrorId -eq \\\"NativeCommandErrorMessage\\\") {\\r\\n                                        $_.Exception.Message   \\r\\n                                   }\\r\\n                                   else\\r\\n                                   {\\r\\n                                        $myinv = $_.InvocationInfo\\r\\n                                        if ($myinv -and ($myinv.MyCommand -or ($_.CategoryInfo.Category -ne 'ParserError'))) {\\r\\n                                            $posmsg = $myinv.PositionMessage\\r\\n                                        } else {\\r\\n                                            $posmsg = \\\"\\\"\\r\\n                                        }\\r\\n                                        \\r\\n                                        if ($posmsg -ne \\\"\\\")\\r\\n                                        {\\r\\n                                            $posmsg = \\\"`n\\\" + $posmsg\\r\\n                                        }\\r\\n    \\t\\t\\t\\t    \\r\\n                                        if ( & { Set-StrictMode -Version 1; $_.PSMessageDetails } ) {\\r\\n                                            $posmsg = \\\" : \\\" +  $_.PSMessageDetails + $posmsg \\r\\n                                        }\\r\\n\\r\\n                                        $indent = 4\\r\\n                                        $width = $host.UI.RawUI.BufferSize.Width - $indent - 2\\r\\n\\r\\n                                        $errorCategoryMsg = & { Set-StrictMode -Version 1; $_.ErrorCategory_Message }\\r\\n                                        if ($errorCategoryMsg -ne $null)\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ CategoryInfo          : \\\" + $_.ErrorCategory_Message\\r\\n                                        }\\r\\n                                        else\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ CategoryInfo          : \\\" + $_.CategoryInfo\\r\\n                                        }\\r\\n                                        $posmsg += \\\"`n\\\"\\r\\n                                        foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n\\r\\n                                        $indentString = \\\"+ FullyQualifiedErrorId : \\\" + $_.FullyQualifiedErrorId\\r\\n                                        $posmsg += \\\"`n\\\"\\r\\n                                        foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n\\r\\n                                        $originInfo = & { Set-StrictMode -Version 1; $_.OriginInfo }\\r\\n                                        if (($originInfo -ne $null) -and ($originInfo.PSComputerName -ne $null))\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ PSComputerName        : \\\" + $originInfo.PSComputerName\\r\\n                                            $posmsg += \\\"`n\\\"\\r\\n                                            foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n                                        }\\r\\n\\r\\n                                        if ($ErrorView -eq \\\"CategoryView\\\") {\\r\\n                                            $_.CategoryInfo.GetMessage()\\r\\n                                        }\\r\\n                                        elseif (! $_.ErrorDetails -or ! $_.ErrorDetails.Message) {\\r\\n                                            $_.Exception.Message + $posmsg + \\\"`n \\\"\\r\\n                                        } else {\\r\\n                                            $_.ErrorDetails.Message + $posmsg\\r\\n                                        }\\r\\n                                   }\\r\\n                                \", \"{ Set-StrictMode -Version 1; $_.PSMessageDetails }\", \"{ Set-StrictMode -Version 1; $_.ErrorCategory_Message }\", \"{ Set-StrictMode -Version 1; $_.OriginInfo }\", \"{\\n    Write-Host $_.FullName\\n  }\", \"\\r\\n                                                  $_.PSParentPath.Replace(\\\"Microsoft.PowerShell.Core\\\\FileSystem::\\\", \\\"\\\")\\r\\n                                              \", \"\\r\\n                                    [String]::Format(\\\"{0,10}  {1,8}\\\", $_.LastWriteTime.ToString(\\\"d\\\"), $_.LastWriteTime.ToString(\\\"t\\\"))\\r\\n                                \", \"if ($_ -is [System.IO.DirectoryInfo]) { return '' }\\r\\nif ($_.Attributes -band [System.IO.FileAttributes]::Offline)\\r\\n{\\r\\n    return '({0})' -f $_.Length\\r\\n}\\r\\nreturn $_.Length\", \"{\\n  if (Test-Path $_) {\\n    Write-Host \\\"$_ found.\\\"\\n  }\\n}\", \"{\\n  if (Test-Path $_ -ErrorAction SilentlyContinue) {\\n    Write-Host \\\"$_ Found!\\\" -ForegroundColor red\\n  }\\n}\", \"{\\n  $Drive = $_\\n  Get-ChildItem $Drive -Recurse -Include $fileExtensions -ErrorAction SilentlyContinue -Force | ForEach-Object {\\n    $path = $_\\n    #Exclude files/folders with 'lang' in the name\\n    if ($Path.FullName | select-string \\\"(?i).*lang.*\\\") {\\n      #Write-Host \\\"$($_.FullName) found!\\\" -ForegroundColor red\\n    }\\n    if($Path.FullName | Select-String \\\"(?i).:\\\\\\\\.*\\\\\\\\.*Pass.*\\\"){\\n      write-host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'pass'\\\"\\n    }\\n    if($Path.FullName | Select-String \\\".:\\\\\\\\.*\\\\\\\\.*user.*\\\" ){\\n      Write-Host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'user' -excluding the 'users' directory\\\"\\n    }\\n    # If path name ends with common excel extensions\\n    elseif ($Path.FullName | Select-String \\\".*\\\\.xls\\\",\\\".*\\\\.xlsm\\\",\\\".*\\\\.xlsx\\\") {\\n      if ($ReadExcel -and $Excel) {\\n        Search-Excel -Source $Path.FullName -SearchText \\\"user\\\"\\n        Search-Excel -Source $Path.FullName -SearchText \\\"pass\\\"\\n      }\\n    }\\n    else {\\n      if ($path.Length -gt 0) {\\n        # Write-Host -ForegroundColor Blue \\\"Path name matches extension search: $path\\\"\\n      }\\n      if ($path.FullName | Select-String \\\"(?i).*SiteList\\\\.xml\\\") {\\n        Write-Host \\\"Possible MCaffee Site List Found: $($_.FullName)\\\"\\n        Write-Host \\\"Just going to leave this here: https://github.com/funoverip/mcafee-sitelist-pwd-decryption\\\" -ForegroundColor Yellow\\n      }\\n      $regexSearch.keys | ForEach-Object {\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\\n    }  \\n  }\\n}\", \"{\\n    $path = $_\\n    #Exclude files/folders with 'lang' in the name\\n    if ($Path.FullName | select-string \\\"(?i).*lang.*\\\") {\\n      #Write-Host \\\"$($_.FullName) found!\\\" -ForegroundColor red\\n    }\\n    if($Path.FullName | Select-String \\\"(?i).:\\\\\\\\.*\\\\\\\\.*Pass.*\\\"){\\n      write-host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'pass'\\\"\\n    }\\n    if($Path.FullName | Select-String \\\".:\\\\\\\\.*\\\\\\\\.*user.*\\\" ){\\n      Write-Host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'user' -excluding the 'users' directory\\\"\\n    }\\n    # If path name ends with common excel extensions\\n    elseif ($Path.FullName | Select-String \\\".*\\\\.xls\\\",\\\".*\\\\.xlsm\\\",\\\".*\\\\.xlsx\\\") {\\n      if ($ReadExcel -and $Excel) {\\n        Search-Excel -Source $Path.FullName -SearchText \\\"user\\\"\\n        Search-Excel -Source $Path.FullName -SearchText \\\"pass\\\"\\n      }\\n    }\\n    else {\\n      if ($path.Length -gt 0) {\\n        # Write-Host -ForegroundColor Blue \\\"Path name matches extension search: $path\\\"\\n      }\\n      if ($path.FullName | Select-String \\\"(?i).*SiteList\\\\.xml\\\") {\\n        Write-Host \\\"Possible MCaffee Site List Found: $($_.FullName)\\\"\\n        Write-Host \\\"Just going to leave this here: https://github.com/funoverip/mcafee-sitelist-pwd-decryption\\\" -ForegroundColor Yellow\\n      }\\n      $regexSearch.keys | ForEach-Object {\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\\n    }  \\n  }\", \"{\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\"]}, {\"field\": \"processCmd\", \"type\": \"command_line\", \"value\": \"\\\"C:\\\\Windows\\\\system32\\\\WindowsPowerShell\\\\v1.0\\\\PowerShell_ISE.exe\\\" \"}, {\"field\": \"parentPid\", \"type\": \"process_id\", \"value\": 9920}, {\"field\": \"processPid\", \"type\": \"process_id\", \"value\": 5040}, {\"field\": \"parentCmd\", \"type\": \"command_line\", \"value\": \"C:\\\\Windows\\\\Explorer.EXE\"}], \"mitreTacticIds\": [\"TA0009\"], \"mitreTechniqueIds\": [\"T1005\"], \"riskLevel\": \"low\", \"type\": \"preset\"}, {\"id\": \"F1971\", \"name\": \"Modify File Last Modified Timestamp With PowerShell\", \"description\": \"An attempt to modify file's last modified timestamp using Powershell was detected on an endpoint.\", \"highlightedObjects\": [{\"field\": \"processCmd\", \"type\": \"command_line\", \"value\": \"\\\"C:\\\\Windows\\\\system32\\\\WindowsPowerShell\\\\v1.0\\\\PowerShell_ISE.exe\\\" \"}, {\"field\": \"processPid\", \"type\": \"process_id\", \"value\": 5040}, {\"field\": \"objectRawDataStr\", \"type\": \"amsi_rawDataStr\", \"value\": [\"\\r\\n                                    if ($_.FullyQualifiedErrorId -ne \\\"NativeCommandErrorMessage\\\" -and $ErrorView -ne \\\"CategoryView\\\")\\r\\n                                    {\\r\\n                                        $myinv = $_.InvocationInfo\\r\\n                                        if ($myinv -and $myinv.MyCommand)\\r\\n                                        {\\r\\n                                            switch -regex ( $myinv.MyCommand.CommandType )\\r\\n                                            {\\r\\n                                                ([System.Management.Automation.CommandTypes]::ExternalScript)\\r\\n                                                {\\r\\n                                                    if ($myinv.MyCommand.Path)\\r\\n                                                    {\\r\\n                                                        $myinv.MyCommand.Path + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                                ([System.Management.Automation.CommandTypes]::Script)\\r\\n                                                {\\r\\n                                                    if ($myinv.MyCommand.ScriptBlock)\\r\\n                                                    {\\r\\n                                                        $myinv.MyCommand.ScriptBlock.ToString() + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                                default\\r\\n                                                {\\r\\n                                                    if ($myinv.InvocationName -match '^[&\\\\.]?$')\\r\\n                                                    {\\r\\n                                                        if ($myinv.MyCommand.Name)\\r\\n                                                        {\\r\\n                                                            $myinv.MyCommand.Name + \\\" : \\\"\\r\\n                                                        }\\r\\n                                                    }\\r\\n                                                    else\\r\\n                                                    {\\r\\n                                                        $myinv.InvocationName + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                            }\\r\\n                                        }\\r\\n                                        elseif ($myinv -and $myinv.InvocationName)\\r\\n                                        {\\r\\n                                            $myinv.InvocationName + \\\" : \\\"\\r\\n                                        }\\r\\n                                    }\\r\\n                                \", \"\\r\\n                                   if ($_.FullyQualifiedErrorId -eq \\\"NativeCommandErrorMessage\\\") {\\r\\n                                        $_.Exception.Message   \\r\\n                                   }\\r\\n                                   else\\r\\n                                   {\\r\\n                                        $myinv = $_.InvocationInfo\\r\\n                                        if ($myinv -and ($myinv.MyCommand -or ($_.CategoryInfo.Category -ne 'ParserError'))) {\\r\\n                                            $posmsg = $myinv.PositionMessage\\r\\n                                        } else {\\r\\n                                            $posmsg = \\\"\\\"\\r\\n                                        }\\r\\n                                        \\r\\n                                        if ($posmsg -ne \\\"\\\")\\r\\n                                        {\\r\\n                                            $posmsg = \\\"`n\\\" + $posmsg\\r\\n                                        }\\r\\n    \\t\\t\\t\\t    \\r\\n                                        if ( & { Set-StrictMode -Version 1; $_.PSMessageDetails } ) {\\r\\n                                            $posmsg = \\\" : \\\" +  $_.PSMessageDetails + $posmsg \\r\\n                                        }\\r\\n\\r\\n                                        $indent = 4\\r\\n                                        $width = $host.UI.RawUI.BufferSize.Width - $indent - 2\\r\\n\\r\\n                                        $errorCategoryMsg = & { Set-StrictMode -Version 1; $_.ErrorCategory_Message }\\r\\n                                        if ($errorCategoryMsg -ne $null)\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ CategoryInfo          : \\\" + $_.ErrorCategory_Message\\r\\n                                        }\\r\\n                                        else\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ CategoryInfo          : \\\" + $_.CategoryInfo\\r\\n                                        }\\r\\n                                        $posmsg += \\\"`n\\\"\\r\\n                                        foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n\\r\\n                                        $indentString = \\\"+ FullyQualifiedErrorId : \\\" + $_.FullyQualifiedErrorId\\r\\n                                        $posmsg += \\\"`n\\\"\\r\\n                                        foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n\\r\\n                                        $originInfo = & { Set-StrictMode -Version 1; $_.OriginInfo }\\r\\n                                        if (($originInfo -ne $null) -and ($originInfo.PSComputerName -ne $null))\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ PSComputerName        : \\\" + $originInfo.PSComputerName\\r\\n                                            $posmsg += \\\"`n\\\"\\r\\n                                            foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n                                        }\\r\\n\\r\\n                                        if ($ErrorView -eq \\\"CategoryView\\\") {\\r\\n                                            $_.CategoryInfo.GetMessage()\\r\\n                                        }\\r\\n                                        elseif (! $_.ErrorDetails -or ! $_.ErrorDetails.Message) {\\r\\n                                            $_.Exception.Message + $posmsg + \\\"`n \\\"\\r\\n                                        } else {\\r\\n                                            $_.ErrorDetails.Message + $posmsg\\r\\n                                        }\\r\\n                                   }\\r\\n                                \", \"{ Set-StrictMode -Version 1; $_.PSMessageDetails }\", \"{ Set-StrictMode -Version 1; $_.ErrorCategory_Message }\", \"{ Set-StrictMode -Version 1; $_.OriginInfo }\", \"{\\n    Write-Host $_.FullName\\n  }\", \"\\r\\n                                                  $_.PSParentPath.Replace(\\\"Microsoft.PowerShell.Core\\\\FileSystem::\\\", \\\"\\\")\\r\\n                                              \", \"\\r\\n                                    [String]::Format(\\\"{0,10}  {1,8}\\\", $_.LastWriteTime.ToString(\\\"d\\\"), $_.LastWriteTime.ToString(\\\"t\\\"))\\r\\n                                \", \"if ($_ -is [System.IO.DirectoryInfo]) { return '' }\\r\\nif ($_.Attributes -band [System.IO.FileAttributes]::Offline)\\r\\n{\\r\\n    return '({0})' -f $_.Length\\r\\n}\\r\\nreturn $_.Length\", \"{\\n  if (Test-Path $_) {\\n    Write-Host \\\"$_ found.\\\"\\n  }\\n}\", \"{\\n  if (Test-Path $_ -ErrorAction SilentlyContinue) {\\n    Write-Host \\\"$_ Found!\\\" -ForegroundColor red\\n  }\\n}\", \"{\\n  $Drive = $_\\n  Get-ChildItem $Drive -Recurse -Include $fileExtensions -ErrorAction SilentlyContinue -Force | ForEach-Object {\\n    $path = $_\\n    #Exclude files/folders with 'lang' in the name\\n    if ($Path.FullName | select-string \\\"(?i).*lang.*\\\") {\\n      #Write-Host \\\"$($_.FullName) found!\\\" -ForegroundColor red\\n    }\\n    if($Path.FullName | Select-String \\\"(?i).:\\\\\\\\.*\\\\\\\\.*Pass.*\\\"){\\n      write-host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'pass'\\\"\\n    }\\n    if($Path.FullName | Select-String \\\".:\\\\\\\\.*\\\\\\\\.*user.*\\\" ){\\n      Write-Host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'user' -excluding the 'users' directory\\\"\\n    }\\n    # If path name ends with common excel extensions\\n    elseif ($Path.FullName | Select-String \\\".*\\\\.xls\\\",\\\".*\\\\.xlsm\\\",\\\".*\\\\.xlsx\\\") {\\n      if ($ReadExcel -and $Excel) {\\n        Search-Excel -Source $Path.FullName -SearchText \\\"user\\\"\\n        Search-Excel -Source $Path.FullName -SearchText \\\"pass\\\"\\n      }\\n    }\\n    else {\\n      if ($path.Length -gt 0) {\\n        # Write-Host -ForegroundColor Blue \\\"Path name matches extension search: $path\\\"\\n      }\\n      if ($path.FullName | Select-String \\\"(?i).*SiteList\\\\.xml\\\") {\\n        Write-Host \\\"Possible MCaffee Site List Found: $($_.FullName)\\\"\\n        Write-Host \\\"Just going to leave this here: https://github.com/funoverip/mcafee-sitelist-pwd-decryption\\\" -ForegroundColor Yellow\\n      }\\n      $regexSearch.keys | ForEach-Object {\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\\n    }  \\n  }\\n}\", \"{\\n    $path = $_\\n    #Exclude files/folders with 'lang' in the name\\n    if ($Path.FullName | select-string \\\"(?i).*lang.*\\\") {\\n      #Write-Host \\\"$($_.FullName) found!\\\" -ForegroundColor red\\n    }\\n    if($Path.FullName | Select-String \\\"(?i).:\\\\\\\\.*\\\\\\\\.*Pass.*\\\"){\\n      write-host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'pass'\\\"\\n    }\\n    if($Path.FullName | Select-String \\\".:\\\\\\\\.*\\\\\\\\.*user.*\\\" ){\\n      Write-Host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'user' -excluding the 'users' directory\\\"\\n    }\\n    # If path name ends with common excel extensions\\n    elseif ($Path.FullName | Select-String \\\".*\\\\.xls\\\",\\\".*\\\\.xlsm\\\",\\\".*\\\\.xlsx\\\") {\\n      if ($ReadExcel -and $Excel) {\\n        Search-Excel -Source $Path.FullName -SearchText \\\"user\\\"\\n        Search-Excel -Source $Path.FullName -SearchText \\\"pass\\\"\\n      }\\n    }\\n    else {\\n      if ($path.Length -gt 0) {\\n        # Write-Host -ForegroundColor Blue \\\"Path name matches extension search: $path\\\"\\n      }\\n      if ($path.FullName | Select-String \\\"(?i).*SiteList\\\\.xml\\\") {\\n        Write-Host \\\"Possible MCaffee Site List Found: $($_.FullName)\\\"\\n        Write-Host \\\"Just going to leave this here: https://github.com/funoverip/mcafee-sitelist-pwd-decryption\\\" -ForegroundColor Yellow\\n      }\\n      $regexSearch.keys | ForEach-Object {\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\\n    }  \\n  }\", \"{\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\"]}, {\"field\": \"parentPid\", \"type\": \"process_id\", \"value\": 9920}, {\"field\": \"parentCmd\", \"type\": \"command_line\", \"value\": \"C:\\\\Windows\\\\Explorer.EXE\"}], \"mitreTacticIds\": [\"TA0005\"], \"mitreTechniqueIds\": [\"T1070\", \"T1070.006\"], \"riskLevel\": \"info\", \"type\": \"preset\"}], \"detail\": {\"endpointGuid\": \"9567d4bc-ce0b-45cf-b259-138beb4c80c3\", \"endpointHostName\": \"Windows10\", \"endpointIp\": [\"1802:d896:65fe:0b84:742d:0615:f69b:6600\", \"193.103.164.106\"], \"eventId\": \"11\", \"eventSubId\": 901, \"eventTime\": \"1732639501774\", \"filterRiskLevel\": \"low\", \"firstSeen\": \"1732639501774\", \"groupId\": \"a1c0d757-0961-40a4-8a00-bf9b2922d5de\", \"integrityLevel\": 12288, \"lastSeen\": \"1732639503446\", \"logReceivedTime\": \"1732639512822\", \"logonUser\": [\"jdoe\"], \"objectAppName\": \"PowerShell_C:\\\\Windows\\\\system32\\\\WindowsPowerShell\\\\v1.0\\\\PowerShell_ISE.exe_10.0.19041.1\", \"objectHashId\": \"-1780503710981816722\", \"objectRawDataStr\": [\"\\r\\n                                    if ($_.FullyQualifiedErrorId -ne \\\"NativeCommandErrorMessage\\\" -and $ErrorView -ne \\\"CategoryView\\\")\\r\\n                                    {\\r\\n                                        $myinv = $_.InvocationInfo\\r\\n                                        if ($myinv -and $myinv.MyCommand)\\r\\n                                        {\\r\\n                                            switch -regex ( $myinv.MyCommand.CommandType )\\r\\n                                            {\\r\\n                                                ([System.Management.Automation.CommandTypes]::ExternalScript)\\r\\n                                                {\\r\\n                                                    if ($myinv.MyCommand.Path)\\r\\n                                                    {\\r\\n                                                        $myinv.MyCommand.Path + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                                ([System.Management.Automation.CommandTypes]::Script)\\r\\n                                                {\\r\\n                                                    if ($myinv.MyCommand.ScriptBlock)\\r\\n                                                    {\\r\\n                                                        $myinv.MyCommand.ScriptBlock.ToString() + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                                default\\r\\n                                                {\\r\\n                                                    if ($myinv.InvocationName -match '^[&\\\\.]?$')\\r\\n                                                    {\\r\\n                                                        if ($myinv.MyCommand.Name)\\r\\n                                                        {\\r\\n                                                            $myinv.MyCommand.Name + \\\" : \\\"\\r\\n                                                        }\\r\\n                                                    }\\r\\n                                                    else\\r\\n                                                    {\\r\\n                                                        $myinv.InvocationName + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                            }\\r\\n                                        }\\r\\n                                        elseif ($myinv -and $myinv.InvocationName)\\r\\n                                        {\\r\\n                                            $myinv.InvocationName + \\\" : \\\"\\r\\n                                        }\\r\\n                                    }\\r\\n                                \", \"\\r\\n                                   if ($_.FullyQualifiedErrorId -eq \\\"NativeCommandErrorMessage\\\") {\\r\\n                                        $_.Exception.Message   \\r\\n                                   }\\r\\n                                   else\\r\\n                                   {\\r\\n                                        $myinv = $_.InvocationInfo\\r\\n                                        if ($myinv -and ($myinv.MyCommand -or ($_.CategoryInfo.Category -ne 'ParserError'))) {\\r\\n                                            $posmsg = $myinv.PositionMessage\\r\\n                                        } else {\\r\\n                                            $posmsg = \\\"\\\"\\r\\n                                        }\\r\\n                                        \\r\\n                                        if ($posmsg -ne \\\"\\\")\\r\\n                                        {\\r\\n                                            $posmsg = \\\"`n\\\" + $posmsg\\r\\n                                        }\\r\\n    \\t\\t\\t\\t    \\r\\n                                        if ( & { Set-StrictMode -Version 1; $_.PSMessageDetails } ) {\\r\\n                                            $posmsg = \\\" : \\\" +  $_.PSMessageDetails + $posmsg \\r\\n                                        }\\r\\n\\r\\n                                        $indent = 4\\r\\n                                        $width = $host.UI.RawUI.BufferSize.Width - $indent - 2\\r\\n\\r\\n                                        $errorCategoryMsg = & { Set-StrictMode -Version 1; $_.ErrorCategory_Message }\\r\\n                                        if ($errorCategoryMsg -ne $null)\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ CategoryInfo          : \\\" + $_.ErrorCategory_Message\\r\\n                                        }\\r\\n                                        else\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ CategoryInfo          : \\\" + $_.CategoryInfo\\r\\n                                        }\\r\\n                                        $posmsg += \\\"`n\\\"\\r\\n                                        foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n\\r\\n                                        $indentString = \\\"+ FullyQualifiedErrorId : \\\" + $_.FullyQualifiedErrorId\\r\\n                                        $posmsg += \\\"`n\\\"\\r\\n                                        foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n\\r\\n                                        $originInfo = & { Set-StrictMode -Version 1; $_.OriginInfo }\\r\\n                                        if (($originInfo -ne $null) -and ($originInfo.PSComputerName -ne $null))\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ PSComputerName        : \\\" + $originInfo.PSComputerName\\r\\n                                            $posmsg += \\\"`n\\\"\\r\\n                                            foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n                                        }\\r\\n\\r\\n                                        if ($ErrorView -eq \\\"CategoryView\\\") {\\r\\n                                            $_.CategoryInfo.GetMessage()\\r\\n                                        }\\r\\n                                        elseif (! $_.ErrorDetails -or ! $_.ErrorDetails.Message) {\\r\\n                                            $_.Exception.Message + $posmsg + \\\"`n \\\"\\r\\n                                        } else {\\r\\n                                            $_.ErrorDetails.Message + $posmsg\\r\\n                                        }\\r\\n                                   }\\r\\n                                \", \"{ Set-StrictMode -Version 1; $_.PSMessageDetails }\", \"{ Set-StrictMode -Version 1; $_.ErrorCategory_Message }\", \"{ Set-StrictMode -Version 1; $_.OriginInfo }\", \"{\\n    Write-Host $_.FullName\\n  }\", \"\\r\\n                                                  $_.PSParentPath.Replace(\\\"Microsoft.PowerShell.Core\\\\FileSystem::\\\", \\\"\\\")\\r\\n                                              \", \"\\r\\n                                    [String]::Format(\\\"{0,10}  {1,8}\\\", $_.LastWriteTime.ToString(\\\"d\\\"), $_.LastWriteTime.ToString(\\\"t\\\"))\\r\\n                                \", \"if ($_ -is [System.IO.DirectoryInfo]) { return '' }\\r\\nif ($_.Attributes -band [System.IO.FileAttributes]::Offline)\\r\\n{\\r\\n    return '({0})' -f $_.Length\\r\\n}\\r\\nreturn $_.Length\", \"{\\n  if (Test-Path $_) {\\n    Write-Host \\\"$_ found.\\\"\\n  }\\n}\", \"{\\n  if (Test-Path $_ -ErrorAction SilentlyContinue) {\\n    Write-Host \\\"$_ Found!\\\" -ForegroundColor red\\n  }\\n}\", \"{\\n  $Drive = $_\\n  Get-ChildItem $Drive -Recurse -Include $fileExtensions -ErrorAction SilentlyContinue -Force | ForEach-Object {\\n    $path = $_\\n    #Exclude files/folders with 'lang' in the name\\n    if ($Path.FullName | select-string \\\"(?i).*lang.*\\\") {\\n      #Write-Host \\\"$($_.FullName) found!\\\" -ForegroundColor red\\n    }\\n    if($Path.FullName | Select-String \\\"(?i).:\\\\\\\\.*\\\\\\\\.*Pass.*\\\"){\\n      write-host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'pass'\\\"\\n    }\\n    if($Path.FullName | Select-String \\\".:\\\\\\\\.*\\\\\\\\.*user.*\\\" ){\\n      Write-Host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'user' -excluding the 'users' directory\\\"\\n    }\\n    # If path name ends with common excel extensions\\n    elseif ($Path.FullName | Select-String \\\".*\\\\.xls\\\",\\\".*\\\\.xlsm\\\",\\\".*\\\\.xlsx\\\") {\\n      if ($ReadExcel -and $Excel) {\\n        Search-Excel -Source $Path.FullName -SearchText \\\"user\\\"\\n        Search-Excel -Source $Path.FullName -SearchText \\\"pass\\\"\\n      }\\n    }\\n    else {\\n      if ($path.Length -gt 0) {\\n        # Write-Host -ForegroundColor Blue \\\"Path name matches extension search: $path\\\"\\n      }\\n      if ($path.FullName | Select-String \\\"(?i).*SiteList\\\\.xml\\\") {\\n        Write-Host \\\"Possible MCaffee Site List Found: $($_.FullName)\\\"\\n        Write-Host \\\"Just going to leave this here: https://github.com/funoverip/mcafee-sitelist-pwd-decryption\\\" -ForegroundColor Yellow\\n      }\\n      $regexSearch.keys | ForEach-Object {\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\\n    }  \\n  }\\n}\", \"{\\n    $path = $_\\n    #Exclude files/folders with 'lang' in the name\\n    if ($Path.FullName | select-string \\\"(?i).*lang.*\\\") {\\n      #Write-Host \\\"$($_.FullName) found!\\\" -ForegroundColor red\\n    }\\n    if($Path.FullName | Select-String \\\"(?i).:\\\\\\\\.*\\\\\\\\.*Pass.*\\\"){\\n      write-host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'pass'\\\"\\n    }\\n    if($Path.FullName | Select-String \\\".:\\\\\\\\.*\\\\\\\\.*user.*\\\" ){\\n      Write-Host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'user' -excluding the 'users' directory\\\"\\n    }\\n    # If path name ends with common excel extensions\\n    elseif ($Path.FullName | Select-String \\\".*\\\\.xls\\\",\\\".*\\\\.xlsm\\\",\\\".*\\\\.xlsx\\\") {\\n      if ($ReadExcel -and $Excel) {\\n        Search-Excel -Source $Path.FullName -SearchText \\\"user\\\"\\n        Search-Excel -Source $Path.FullName -SearchText \\\"pass\\\"\\n      }\\n    }\\n    else {\\n      if ($path.Length -gt 0) {\\n        # Write-Host -ForegroundColor Blue \\\"Path name matches extension search: $path\\\"\\n      }\\n      if ($path.FullName | Select-String \\\"(?i).*SiteList\\\\.xml\\\") {\\n        Write-Host \\\"Possible MCaffee Site List Found: $($_.FullName)\\\"\\n        Write-Host \\\"Just going to leave this here: https://github.com/funoverip/mcafee-sitelist-pwd-decryption\\\" -ForegroundColor Yellow\\n      }\\n      $regexSearch.keys | ForEach-Object {\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\\n    }  \\n  }\", \"{\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\"], \"osDescription\": \"Windows 10 Pro (64 bit) build 19045\", \"parentCmd\": \"C:\\\\Windows\\\\Explorer.EXE\", \"parentFileHashId\": \"1767110345653159701\", \"parentFileHashMd5\": \"f8ad78f2ad64799786242d69ef77edd7\", \"parentFileHashSha1\": \"f021ca2dca81ee77aa80467096a804a26cd11364\", \"parentFileHashSha256\": \"f2e4604dfae18859b13a4efee601df6937e99dd96251c11205c30022b308868f\", \"parentFilePath\": \"C:\\\\Windows\\\\explorer.exe\", \"parentHashId\": \"999588025188847480\", \"parentIntegrityLevel\": 12288, \"parentLaunchTime\": \"1732638953785\", \"parentName\": \"C:\\\\Windows\\\\explorer.exe\", \"parentPid\": 9920, \"parentSigner\": [\"Microsoft Windows\"], \"parentSignerValid\": [true], \"parentTrueType\": 7, \"parentUser\": \"jdoe\", \"parentUserDomain\": \"Windows10\", \"pname\": \"751\", \"processCmd\": \"\\\"C:\\\\Windows\\\\system32\\\\WindowsPowerShell\\\\v1.0\\\\PowerShell_ISE.exe\\\" \", \"processFileHashId\": \"-4900073020808934214\", \"processFileHashMd5\": \"bd5cf4568d83088240e3b33f9f9838b1\", \"processFileHashSha1\": \"b1692a60d67dc55538f9a25ad3874a6a8f6bb089\", \"processFileHashSha256\": \"4388c298be8260741724ebf8b414ca063247d6a0d5d5aa5318f90edda3189cd2\", \"processFilePath\": \"C:\\\\Windows\\\\System32\\\\WindowsPowerShell\\\\v1.0\\\\powershell_ise.exe\", \"processHashId\": \"-5529997575794356190\", \"processLaunchTime\": \"1732639075967\", \"processName\": \"C:\\\\Windows\\\\System32\\\\WindowsPowerShell\\\\v1.0\\\\powershell_ise.exe\", \"processPid\": 5040, \"processSigner\": [\"Microsoft Windows\"], \"processSignerValid\": [true], \"processTrueType\": 7, \"processUser\": \"jdoe\", \"processUserDomain\": \"Windows10\", \"productCode\": \"xes\", \"tags\": [\"XSAE.F1971\", \"XSAE.F3367\", \"MITRE.T1005\", \"MITRE.T1070.006\", \"MITRE.T1070\"], \"uuid\": \"b2ece961-6eed-43f1-8890-a8d926840049\", \"plang\": 1, \"pver\": \"1.2.0.5608\", \"processSignerFlagsLibValid\": [false], \"eventHashId\": \"7588760429245659303\", \"processFileSize\": \"212992\", \"eventSourceType\": 1, \"processSignerFlagsAdhoc\": [false], \"objectFirstSeen\": \"1732639501774\", \"processFileModifiedTime\": \"1575651900000\", \"pplat\": 5889, \"processSignerFlagsRuntime\": [false], \"timezone\": \"UTC+00:00\", \"osVer\": \"10.0.19045\", \"authId\": \"1494147\", \"endpointMacAddress\": [\"8f:86:c0:d8:9d:ad\"], \"osType\": \"0x00000030\", \"processFileCreation\": \"1575712305614\", \"userDomain\": [\"Windows10\"], \"sessionId\": 2, \"osName\": \"Windows\", \"objectLastSeen\": \"1732639503446\", \"parentSignerFlagsLibValid\": [false], \"parentFileCreation\": \"1728117061706\", \"parentSessionId\": 2, \"parentFileModifiedTime\": \"1728117061831\", \"parentSignerFlagsAdhoc\": [false], \"parentAuthId\": \"1494147\", \"parentSignerFlagsRuntime\": [false], \"parentFileSize\": \"5845320\", \"objectSessionId\": \"19746\", \"objectRawDataSize\": [\"2995\", \"3802\", \"50\", \"55\", \"44\", \"32\", \"169\", \"169\", \"170\", \"56\", \"107\", \"1848\", \"1719\", \"411\"]}, \"ingestedDateTime\": \"2024-11-26T16:45:25Z\", \"entityType\": \"endpoint\", \"entityName\": \"Windows10(1802:d896:65fe:0b84:742d:0615:f69b:6600,193.103.164.106)\", \"endpoint\": {\"ips\": [\"1802:d896:65fe:0b84:742d:0615:f69b:6600\", \"193.103.164.106\"], \"agentGuid\": \"8e53268d-8348-4fd4-a314-b742448960c9\", \"endpointName\": \"Windows10\"}}",
    "event": {
        "category": [
            "intrusion_detection"
        ],
        "end": "2024-11-26T16:45:03.446000Z",
        "start": "2024-11-26T16:45:01.774000Z",
        "type": [
            "info"
        ]
    },
    "@timestamp": "2024-11-26T16:45:01Z",
    "action": {
        "properties": {
            "ScriptBlockText": [
                "\r\n                                                  $_.PSParentPath.Replace(\"Microsoft.PowerShell.Core\\FileSystem::\", \"\")\r\n                                              ",
                "\r\n                                    [String]::Format(\"{0,10}  {1,8}\", $_.LastWriteTime.ToString(\"d\"), $_.LastWriteTime.ToString(\"t\"))\r\n                                ",
                "\r\n                                    if ($_.FullyQualifiedErrorId -ne \"NativeCommandErrorMessage\" -and $ErrorView -ne \"CategoryView\")\r\n                                    {\r\n                                        $myinv = $_.InvocationInfo\r\n                                        if ($myinv -and $myinv.MyCommand)\r\n                                        {\r\n                                            switch -regex ( $myinv.MyCommand.CommandType )\r\n                                            {\r\n                                                ([System.Management.Automation.CommandTypes]::ExternalScript)\r\n                                                {\r\n                                                    if ($myinv.MyCommand.Path)\r\n                                                    {\r\n                                                        $myinv.MyCommand.Path + \" : \"\r\n                                                    }\r\n                                                    break\r\n                                                }\r\n                                                ([System.Management.Automation.CommandTypes]::Script)\r\n                                                {\r\n                                                    if ($myinv.MyCommand.ScriptBlock)\r\n                                                    {\r\n                                                        $myinv.MyCommand.ScriptBlock.ToString() + \" : \"\r\n                                                    }\r\n                                                    break\r\n                                                }\r\n                                                default\r\n                                                {\r\n                                                    if ($myinv.InvocationName -match '^[&\\.]?$')\r\n                                                    {\r\n                                                        if ($myinv.MyCommand.Name)\r\n                                                        {\r\n                                                            $myinv.MyCommand.Name + \" : \"\r\n                                                        }\r\n                                                    }\r\n                                                    else\r\n                                                    {\r\n                                                        $myinv.InvocationName + \" : \"\r\n                                                    }\r\n                                                    break\r\n                                                }\r\n                                            }\r\n                                        }\r\n                                        elseif ($myinv -and $myinv.InvocationName)\r\n                                        {\r\n                                            $myinv.InvocationName + \" : \"\r\n                                        }\r\n                                    }\r\n                                ",
                "\r\n                                   if ($_.FullyQualifiedErrorId -eq \"NativeCommandErrorMessage\") {\r\n                                        $_.Exception.Message   \r\n                                   }\r\n                                   else\r\n                                   {\r\n                                        $myinv = $_.InvocationInfo\r\n                                        if ($myinv -and ($myinv.MyCommand -or ($_.CategoryInfo.Category -ne 'ParserError'))) {\r\n                                            $posmsg = $myinv.PositionMessage\r\n                                        } else {\r\n                                            $posmsg = \"\"\r\n                                        }\r\n                                        \r\n                                        if ($posmsg -ne \"\")\r\n                                        {\r\n                                            $posmsg = \"`n\" + $posmsg\r\n                                        }\r\n    \t\t\t\t    \r\n                                        if ( & { Set-StrictMode -Version 1; $_.PSMessageDetails } ) {\r\n                                            $posmsg = \" : \" +  $_.PSMessageDetails + $posmsg \r\n                                        }\r\n\r\n                                        $indent = 4\r\n                                        $width = $host.UI.RawUI.BufferSize.Width - $indent - 2\r\n\r\n                                        $errorCategoryMsg = & { Set-StrictMode -Version 1; $_.ErrorCategory_Message }\r\n                                        if ($errorCategoryMsg -ne $null)\r\n                                        {\r\n                                            $indentString = \"+ CategoryInfo          : \" + $_.ErrorCategory_Message\r\n                                        }\r\n                                        else\r\n                                        {\r\n                                            $indentString = \"+ CategoryInfo          : \" + $_.CategoryInfo\r\n                                        }\r\n                                        $posmsg += \"`n\"\r\n                                        foreach($line in @($indentString -split \"(.{$width})\")) { if($line) { $posmsg += (\" \" * $indent + $line) } }\r\n\r\n                                        $indentString = \"+ FullyQualifiedErrorId : \" + $_.FullyQualifiedErrorId\r\n                                        $posmsg += \"`n\"\r\n                                        foreach($line in @($indentString -split \"(.{$width})\")) { if($line) { $posmsg += (\" \" * $indent + $line) } }\r\n\r\n                                        $originInfo = & { Set-StrictMode -Version 1; $_.OriginInfo }\r\n                                        if (($originInfo -ne $null) -and ($originInfo.PSComputerName -ne $null))\r\n                                        {\r\n                                            $indentString = \"+ PSComputerName        : \" + $originInfo.PSComputerName\r\n                                            $posmsg += \"`n\"\r\n                                            foreach($line in @($indentString -split \"(.{$width})\")) { if($line) { $posmsg += (\" \" * $indent + $line) } }\r\n                                        }\r\n\r\n                                        if ($ErrorView -eq \"CategoryView\") {\r\n                                            $_.CategoryInfo.GetMessage()\r\n                                        }\r\n                                        elseif (! $_.ErrorDetails -or ! $_.ErrorDetails.Message) {\r\n                                            $_.Exception.Message + $posmsg + \"`n \"\r\n                                        } else {\r\n                                            $_.ErrorDetails.Message + $posmsg\r\n                                        }\r\n                                   }\r\n                                ",
                "if ($_ -is [System.IO.DirectoryInfo]) { return '' }\r\nif ($_.Attributes -band [System.IO.FileAttributes]::Offline)\r\n{\r\n    return '({0})' -f $_.Length\r\n}\r\nreturn $_.Length",
                "{\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\n        if ($passwordFound) {\n          Write-Host \"Possible Password found: $_\" -ForegroundColor Yellow\n          Write-Host $Path.FullName\n          Write-Host -ForegroundColor Blue \"$_ triggered\"\n          Write-Host $passwordFound -ForegroundColor Red\n        }\n      }",
                "{\n    $path = $_\n    #Exclude files/folders with 'lang' in the name\n    if ($Path.FullName | select-string \"(?i).*lang.*\") {\n      #Write-Host \"$($_.FullName) found!\" -ForegroundColor red\n    }\n    if($Path.FullName | Select-String \"(?i).:\\\\.*\\\\.*Pass.*\"){\n      write-host -ForegroundColor Blue \"$($path.FullName) contains the word 'pass'\"\n    }\n    if($Path.FullName | Select-String \".:\\\\.*\\\\.*user.*\" ){\n      Write-Host -ForegroundColor Blue \"$($path.FullName) contains the word 'user' -excluding the 'users' directory\"\n    }\n    # If path name ends with common excel extensions\n    elseif ($Path.FullName | Select-String \".*\\.xls\",\".*\\.xlsm\",\".*\\.xlsx\") {\n      if ($ReadExcel -and $Excel) {\n        Search-Excel -Source $Path.FullName -SearchText \"user\"\n        Search-Excel -Source $Path.FullName -SearchText \"pass\"\n      }\n    }\n    else {\n      if ($path.Length -gt 0) {\n        # Write-Host -ForegroundColor Blue \"Path name matches extension search: $path\"\n      }\n      if ($path.FullName | Select-String \"(?i).*SiteList\\.xml\") {\n        Write-Host \"Possible MCaffee Site List Found: $($_.FullName)\"\n        Write-Host \"Just going to leave this here: https://github.com/funoverip/mcafee-sitelist-pwd-decryption\" -ForegroundColor Yellow\n      }\n      $regexSearch.keys | ForEach-Object {\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\n        if ($passwordFound) {\n          Write-Host \"Possible Password found: $_\" -ForegroundColor Yellow\n          Write-Host $Path.FullName\n          Write-Host -ForegroundColor Blue \"$_ triggered\"\n          Write-Host $passwordFound -ForegroundColor Red\n        }\n      }\n    }  \n  }",
                "{\n    Write-Host $_.FullName\n  }",
                "{\n  $Drive = $_\n  Get-ChildItem $Drive -Recurse -Include $fileExtensions -ErrorAction SilentlyContinue -Force | ForEach-Object {\n    $path = $_\n    #Exclude files/folders with 'lang' in the name\n    if ($Path.FullName | select-string \"(?i).*lang.*\") {\n      #Write-Host \"$($_.FullName) found!\" -ForegroundColor red\n    }\n    if($Path.FullName | Select-String \"(?i).:\\\\.*\\\\.*Pass.*\"){\n      write-host -ForegroundColor Blue \"$($path.FullName) contains the word 'pass'\"\n    }\n    if($Path.FullName | Select-String \".:\\\\.*\\\\.*user.*\" ){\n      Write-Host -ForegroundColor Blue \"$($path.FullName) contains the word 'user' -excluding the 'users' directory\"\n    }\n    # If path name ends with common excel extensions\n    elseif ($Path.FullName | Select-String \".*\\.xls\",\".*\\.xlsm\",\".*\\.xlsx\") {\n      if ($ReadExcel -and $Excel) {\n        Search-Excel -Source $Path.FullName -SearchText \"user\"\n        Search-Excel -Source $Path.FullName -SearchText \"pass\"\n      }\n    }\n    else {\n      if ($path.Length -gt 0) {\n        # Write-Host -ForegroundColor Blue \"Path name matches extension search: $path\"\n      }\n      if ($path.FullName | Select-String \"(?i).*SiteList\\.xml\") {\n        Write-Host \"Possible MCaffee Site List Found: $($_.FullName)\"\n        Write-Host \"Just going to leave this here: https://github.com/funoverip/mcafee-sitelist-pwd-decryption\" -ForegroundColor Yellow\n      }\n      $regexSearch.keys | ForEach-Object {\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\n        if ($passwordFound) {\n          Write-Host \"Possible Password found: $_\" -ForegroundColor Yellow\n          Write-Host $Path.FullName\n          Write-Host -ForegroundColor Blue \"$_ triggered\"\n          Write-Host $passwordFound -ForegroundColor Red\n        }\n      }\n    }  \n  }\n}",
                "{\n  if (Test-Path $_ -ErrorAction SilentlyContinue) {\n    Write-Host \"$_ Found!\" -ForegroundColor red\n  }\n}",
                "{\n  if (Test-Path $_) {\n    Write-Host \"$_ found.\"\n  }\n}",
                "{ Set-StrictMode -Version 1; $_.ErrorCategory_Message }",
                "{ Set-StrictMode -Version 1; $_.OriginInfo }",
                "{ Set-StrictMode -Version 1; $_.PSMessageDetails }"
            ]
        }
    },
    "agent": {
        "id": "8e53268d-8348-4fd4-a314-b742448960c9"
    },
    "group": {
        "id": "a1c0d757-0961-40a4-8a00-bf9b2922d5de"
    },
    "host": {
        "id": "9567d4bc-ce0b-45cf-b259-138beb4c80c3",
        "ip": [
            "1802:d896:65fe:b84:742d:615:f69b:6600",
            "193.103.164.106"
        ],
        "name": "Windows10",
        "os": {
            "full": "Windows 10 Pro (64 bit) build 19045",
            "name": "Windows",
            "version": "10.0.19045"
        }
    },
    "observer": {
        "product": "Vision One",
        "vendor": "TrendMicro"
    },
    "process": {
        "name": "powershell_ise.exe",
        "parent": {
            "command_line": "\"C:\\Windows\\system32\\WindowsPowerShell\\v1.0\\PowerShell_ISE.exe\" ",
            "executable": "C:\\Windows\\System32\\WindowsPowerShell\\v1.0\\powershell_ise.exe",
            "hash": {
                "md5": "bd5cf4568d83088240e3b33f9f9838b1",
                "sha1": "b1692a60d67dc55538f9a25ad3874a6a8f6bb089",
                "sha256": "4388c298be8260741724ebf8b414ca063247d6a0d5d5aa5318f90edda3189cd2"
            },
            "parent": {
                "command_line": "C:\\Windows\\Explorer.EXE",
                "executable": "C:\\Windows\\explorer.exe",
                "hash": {
                    "md5": "f8ad78f2ad64799786242d69ef77edd7",
                    "sha1": "f021ca2dca81ee77aa80467096a804a26cd11364",
                    "sha256": "f2e4604dfae18859b13a4efee601df6937e99dd96251c11205c30022b308868f"
                },
                "name": "explorer.exe",
                "pid": "9920",
                "start": "2024-11-26T16:35:53.785000Z",
                "user": {
                    "domain": "Windows10",
                    "name": "jdoe"
                }
            },
            "pid": 5040,
            "start": "2024-11-26T16:37:55.967000Z",
            "user": {
                "domain": "Windows10",
                "name": "jdoe"
            }
        }
    },
    "related": {
        "hash": [
            "4388c298be8260741724ebf8b414ca063247d6a0d5d5aa5318f90edda3189cd2",
            "b1692a60d67dc55538f9a25ad3874a6a8f6bb089",
            "bd5cf4568d83088240e3b33f9f9838b1"
        ],
        "ip": [
            "1802:d896:65fe:b84:742d:615:f69b:6600",
            "193.103.164.106"
        ]
    },
    "threat": {
        "tactic": {
            "id": [
                "TA0005",
                "TA0009"
            ]
        },
        "technique": {
            "id": [
                "T1005",
                "T1070"
            ],
            "subtechnique": {
                "id": [
                    "T1070.006"
                ]
            }
        }
    }
}

Extracted Fields

The following table lists the fields that are extracted, normalized under the ECS format, analyzed and indexed by the parser. It should be noted that infered fields are not listed.

Name Type Description
@timestamp date Date/time when the event originated.
action.properties.ScriptBlockText keyword
agent.id keyword Unique identifier of this agent.
event.category keyword Event category. The second categorization field in the hierarchy.
event.end date event.end contains the date when the event ended or when the activity was last observed.
event.start date event.start contains the date when the event started or when the activity was first observed.
event.type keyword Event type. The third categorization field in the hierarchy.
group.id keyword Unique identifier for the group on the system/platform.
host.id keyword Unique host id.
host.ip ip Host ip addresses.
host.name keyword Name of the host.
host.os.full keyword Operating system name, including the version or code name.
host.os.name keyword Operating system name, without the version.
host.os.version keyword Operating system version as a raw string.
observer.product keyword The product name of the observer.
observer.vendor keyword Vendor name of the observer.
process.command_line wildcard Full command line that started the process.
process.executable keyword Absolute path to the process executable.
process.hash.md5 keyword MD5 hash.
process.hash.sha1 keyword SHA1 hash.
process.hash.sha256 keyword SHA256 hash.
process.name keyword Process name.
process.parent.command_line wildcard Full command line that started the process.
process.parent.executable keyword Absolute path to the process executable.
process.parent.hash.md5 keyword MD5 hash.
process.parent.hash.sha1 keyword SHA1 hash.
process.parent.hash.sha256 keyword SHA256 hash.
process.parent.parent.command_line keyword
process.parent.parent.executable keyword
process.parent.parent.hash.md5 keyword
process.parent.parent.hash.sha1 keyword
process.parent.parent.hash.sha256 keyword
process.parent.parent.name keyword
process.parent.parent.pid keyword
process.parent.parent.start datetime
process.parent.parent.user.domain keyword
process.parent.parent.user.name keyword
process.parent.pid long Process id.
process.parent.start date The time the process started.
process.parent.user.domain keyword
process.pid long Process id.
threat.tactic.id keyword Threat tactic id.
threat.technique.id keyword Threat technique id.
threat.technique.subtechnique.id keyword Threat subtechnique id.
user.domain keyword Name of the directory the user is a member of.
user.name keyword Short name or login of the user.

For more information on the Intake Format, please find the code of the Parser, Smart Descriptions, and Supported Events here.

Detection section

The following section provides information for those who wish to learn more about the detection capabilities enabled by collecting this intake. It includes details about the built-in rule catalog, event categories, and ECS fields extracted from raw events. This is essential for users aiming to create custom detection rules, perform hunting activities, or pivot in the events page.

The following Sekoia.io built-in rules match the intake Trend Micro Vision One OAT [BETA]. This documentation is updated automatically and is based solely on the fields used by the intake which are checked against our rules. This means that some rules will be listed but might not be relevant with the intake.

SEKOIA.IO x Trend Micro Vision One OAT [BETA] on ATT&CK Navigator

AMSI Deactivation Using Registry Key

The rule detects attempts to deactivate/disable the AMSI provider by deleting the associated registry key.

  • Effort: master
AccCheckConsole Executing Dll

Detects suspicious LOLBIN AccCheckConsole execution with parameters as used to load an arbitrary DLL.

  • Effort: advanced
Active Directory Data Export Using Csvde

Detects the use of Csvde, a command-line tool from Windows Server that can be used to export Active Directory data to CSV files. This export doesn't include password hashes, but can be used as a discovery tool to enumerate users, machines and group memberships.

  • Effort: elementary
AdFind Usage

Detects the usage of the AdFind tool. AdFind.exe is a free tool that extracts information from Active Directory. Wizard Spider (Bazar, TrickBot, Ryuk), FIN6 and MAZE operators have used AdFind.exe to collect information about Active Directory organizational units and trust objects

  • Effort: elementary
Add User to Privileged Group

Add user in a potential privileged group which can be used to elevate privileges on the system.

  • Effort: advanced
Address Space Layout Randomization (ASLR) Alteration

ASLR is a security feature used by the Operating System to mitigate memory exploit, attacker might want to disable it

  • Effort: intermediate
Adexplorer Usage

Detects the usage of Adexplorer, a legitimate tool from the Sysinternals suite that could be abused by attackers as it can saves snapshots of the Active Directory Database.

  • Effort: advanced
Adidnsdump Enumeration

Detects use of the tool adidnsdump for enumeration and discovering DNS records.

  • Effort: advanced
Advanced IP Scanner

Detects the use of Advanced IP Scanner. Seems to be a popular tool for ransomware groups.

  • Effort: master
Audio Capture via PowerShell

Detects audio capture via PowerShell Cmdlet

  • Effort: intermediate
AutoIt3 Execution From Suspicious Folder

Detects AutoIt3 execution from an unusual/suspicious folder. Legitimate folders are "Program Files" and "AppData\Local". AutoIt3.exe is a legitimate process used to execute AutoIt program files, which are used by legitimate software, custom scripts, but also malware. Finding AutoIt3 execution from unusual/suspicious folder can help detect malware activities, such as DarkGate execution. The detection rule can be tailored to your environment and your use of AutoIt3 by filtering out folder's execution of legitimate applications or scripts.

  • Effort: advanced
Autorun Keys Modification

Detects modification of autostart extensibility point (ASEP) in registry. Prerequisites are Logging for Registry events in the Sysmon configuration (events 12 and 13).

  • Effort: master
AzureEdge in Command Line

Detects use of azureedge in the command line.

  • Effort: advanced
BITSAdmin Download

Detects command to download file using BITSAdmin, a built-in tool in Windows. This technique is used by several threat actors to download scripts or payloads on infected system.

  • Effort: advanced
BazarLoader Persistence Using Schtasks

Detects possible BazarLoader persistence using schtasks. BazarLoader will create a Scheduled Task using a specific command line to establish its persistence.

  • Effort: intermediate
Bloodhound and Sharphound Tools Usage

Detects default process names and default command line parameters used by Bloodhound and Sharphound tools.

  • Effort: intermediate
Blue Mockingbird Malware

Attempts to detect system changes made by Blue Mockingbird

  • Effort: elementary
CMSTP Execution

Detects various indicators of Microsoft Connection Manager Profile Installer execution

  • Effort: intermediate
COM Hijack Via Sdclt

Detects changes to 'HKCU\Software\Classes\Folder\shell\open\command\DelegateExecute', to bypass UAC using 'sdclt.exe'.

  • Effort: intermediate
CVE 2022-1292

The c_rehash script does not properly sanitise shell metacharacters to prevent command injection. This script is distributed by some operating systems in a manner where it is automatically executed. On such operating systems, an attacker could execute arbitrary commands with the privileges of the script.

  • Effort: advanced
Capture a network trace with netsh.exe

Detects capture a network trace via netsh.exe trace functionality

  • Effort: intermediate
CertOC Loading Dll

Detects when a user installs certificates by using CertOC.exe to loads the target DLL file.

  • Effort: intermediate
Certificate Authority Modification

Installation of new certificate(s) in the Certificate Authority can be used to trick user when spoofing website or to add trusted destinations.

  • Effort: master
Certify Or Certipy

Detects the use of certify and certipy which are two different tools used to enumerate and abuse Active Directory Certificate Services.

  • Effort: advanced
Change Default File Association

When a file is opened, the default program used to open the file (also called the file association or handler) is checked. File association selections are stored in the Windows Registry and can be edited by users, administrators, or programs that have Registry access or by administrators using the built-in assoc utility. Applications can modify the file association for a given file extension to call an arbitrary program when a file with the given extension is opened.

  • Effort: advanced
Clear EventLogs Through CommandLine

Detects a command that clears event logs which could indicate an attempt from an attacker to erase its previous traces.

  • Effort: intermediate
Cmdkey Cached Credentials Recon

Detects usage of cmdkey to look for cached credentials.

  • Effort: intermediate
Cobalt Strike Default Beacons Names

Detects the default names of Cobalt Strike beacons / payloads.

  • Effort: intermediate
Commonly Used Commands To Stop Services And Remove Backups

Detects specific commands used regularly by ransomwares to stop services or remove backups

  • Effort: intermediate
Component Object Model Hijacking

Detects component object model hijacking. An attacker can establish persistence with COM objects.

  • Effort: advanced
Compress Data for Exfiltration via Archiver

Detects data compressed by specific tools.

  • Effort: master
Compression Followed By Suppression

Detects when a file is compressed and deleted.

  • Effort: advanced
Container Credential Access

Adversaries could abuse containers tools to obtain credential like Kubernetes secret or Kubernetes service account access token

  • Effort: intermediate
Control Panel Items

Detects the malicious use of a control panel item

  • Effort: advanced
Copy Of Legitimate System32 Executable

A script has copied a System32 executable.

  • Effort: intermediate
Copying Browser Files With Credentials

Detects copy of sensitive data (passwords, cookies, credit cards) included in web browsers files.

  • Effort: elementary
Copying Sensitive Files With Credential Data

Detects copy of files with well-known filenames (sensitive files with credential data) using esentutl. This requires Windows Security event log with the Detailed File Share logging policy enabled.

  • Effort: elementary
Correlation Multi Service Disable

The rule detects a high number of services stopped or de-activated in a short period of time.

  • Effort: master
Correlation Priv Esc Via Remote Thread

Detect a process that obtains system privilege via a remote thread

  • Effort: intermediate
Credential Harvesting Via Vaultcmd.exe

Detects when the process vaultcmd is used for credential harvesting.

  • Effort: advanced
Cryptomining

Detection of domain names potentially related to cryptomining activities.

  • Effort: master
DHCP Callout DLL Installation

Detects the installation of a Callout DLL via CalloutDlls and CalloutEnabled parameter in Registry, which can be used to execute code in context of the DHCP server (restart required).

  • Effort: intermediate
DNS Exfiltration and Tunneling Tools Execution

Well-known DNS exfiltration tools execution

  • Effort: intermediate
DNS Query For Iplookup

Detects dns query of observables tagged as iplookup.

  • Effort: master
DNS ServerLevelPluginDll Installation

Detects the installation of a plugin DLL via ServerLevelPluginDll parameter in Windows Registry or in command line, which can be used to execute code in context of the DNS server (restart required). To fully use this rule, prerequesites are logging for Registry events in the Sysmon configuration (events 12, 13 and 14).

  • Effort: master
Data Compressed With Rar

An adversary may compress data in order to make it portable and minimize the amount of data sent over the network, this could be done the popular rar command line program.

  • Effort: master
Data Compressed With Rar With Password

An adversary may compress data in order to make it portable and minimize the amount of data sent over the network, this could be done the popular rar command line program. This is a more specific one for rar where the arguments allow to encrypt both file data and headers with a given password.

  • Effort: intermediate
Debugging Software Deactivation

Deactivation of some debugging softwares using taskkill command. It was observed being used by Ransomware operators.

  • Effort: elementary
Default Encoding To UTF-8 PowerShell

Detects PowerShell encoding to UTF-8, which is used by Sliver implants. The command line just sets the default encoding to UTF-8 in PowerShell.

  • Effort: advanced
Disable .NET ETW Through COMPlus_ETWEnabled

Detects potential adversaries stopping ETW providers recording loaded .NET assemblies. Prerequisites are logging for Registry events or logging command line parameters (both is better). Careful for registry events, if SwiftOnSecurity's SYSMON default configuration is used, you will need to update the configuration to include the .NETFramework registry key path. Same issue with Windows 4657 EventID logging, the registry path must be specified.

  • Effort: intermediate
Disable Task Manager Through Registry Key

Detects commands used to disable the Windows Task Manager by modifying the proper registry key in order to impair security tools. This technique is used by the Agent Tesla RAT, among others.

  • Effort: elementary
Disable Windows Defender Credential Guard

Detects registry keys being changed to disable Windows Defender Credential Guard. The rule requires to log Registry Keys modifications or creations, which can be done using Sysmon Event IDs 12,13 and 14.

  • Effort: intermediate
Disabled IE Security Features

Detects from the command lines or the registry, changes that indicate unwanted modifications to registry keys that disable important Internet Explorer security features. This has been used by attackers during Operation Ke3chang.

  • Effort: advanced
Discovery Commands Correlation

Detects some frequent discovery commands used by some ransomware operators.

  • Effort: intermediate
Dism Disabling Windows Defender

Detects windows defender disabled by dism.

  • Effort: advanced
Docker Escape Bind Mount

Catch Docker escape via mount escape followed by chroot

  • Effort: intermediate
Domain Group And Permission Enumeration

Detects adversaries attempts to find domain-level groups and permission settings. Commands such as net group /domain of the Net utility can list domain-level groups The knowledge of domain-level permission groups can help adversaries determine which groups exist and which users belong to a particular group. Adversaries may use this information to determine which users have elevated permissions, such as domain administrators. Wizard Spider, FIN6, and other groups used net in their campaigns.

  • Effort: advanced
Domain Trust Discovery Through LDAP

Detects attempts to gather information on domain trust relationships that may be used to identify lateral movement opportunities. "trustedDomain" which is detected here is a Microsoft Active Directory ObjectClass Type that represents a domain that is trusted by, or trusting, the local AD DOMAIN. Several tools are using LDAP queries in the end to get the information (DSQuery, sometimes ADFind as well, etc.)

  • Effort: elementary
Dynamic DNS Contacted

Detect communication with dynamic dns domain. This kind of domain is often used by attackers. This rule can trigger false positive in non-controlled environment because dynamic dns is not always malicious.

  • Effort: master
Dynamic Linker Hijacking From Environment Variable

LD_PRELOAD and LD_LIBRARY_PATH are environment variables used by the Operating System at the runtime to load shared objects (library.ies) when executing a new process, attacker can overwrite this variable to attempts a privileges escalation.

  • Effort: master
ETW Tampering

Detects a command that clears or disables any ETW Trace log which could indicate a logging evasion

  • Effort: intermediate
Elevated Msiexec Via Repair Functionality

Detects when msiexec.exe is used with the repair functionality. The process gains elevated privileges. Attackers can use this to exploit the CVE-2024-38014.

  • Effort: master
Elevated Shell Launched By Browser

Detects when openwith.exe is launched with privileges followed by a browser launching an elevated shell. Related to the CVE-2024-38014.

  • Effort: master
Elise Backdoor

Detects Elise backdoor activity as used by Lotus Blossom

  • Effort: elementary
Empire Monkey Activity

Detects EmpireMonkey APT reported Activity

  • Effort: elementary
Enabling Restricted Admin Mode

Detects when the restricted admin mode is enabled.

  • Effort: elementary
Equation Group DLL_U Load

Detects a specific tool and export used by EquationGroup

  • Effort: elementary
Erase Shell History

Malware and attacker try to reduce their fingerprints on compromised host by deleting shell history.

  • Effort: advanced
Exchange Mailbox Export

Detection of a standard Exchange Mailbox export, which stores all mails from a user in a pst file, from command line or PowerShell script.

  • Effort: intermediate
Exfiltration And Tunneling Tools Execution

Execution of well known tools for data exfiltration and tunneling

  • Effort: advanced
Exfiltration Domain

Detects traffic toward a domain flagged as a possible exfiltration vector.

  • Effort: master
Exfiltration Domain In Command Line

Detects commands containing a domain linked to http exfiltration.

  • Effort: intermediate
Exfiltration Via Pscp

Detects the use of pscp which is a file sharing services.

  • Effort: advanced
Exploit For CVE-2017-0261 Or CVE-2017-0262

Detects Winword starting uncommon sub process FLTLDR.exe as used in exploits for CVE-2017-0261 and CVE-2017-0262 through command line or PowerShell script. This is a very basic detection method relying on the rare usage of EPS files from Winword.

  • Effort: advanced
Exploited CVE-2020-10189 Zoho ManageEngine

Detects the exploitation of Zoho ManageEngine Desktop Central Java Deserialization vulnerability reported as CVE-2020-10189.

  • Effort: elementary
Exploiting SetupComplete.cmd CVE-2019-1378

Detects exploitation attempts of privilege escalation vulnerability via SetupComplete.cmd and PartnerSetupComplete.cmd described in CVE-2019-1378.

  • Effort: intermediate
Explorer Process Executing HTA File

Detects a suspicious execution of an HTA file by the explorer.exe process. This unusual activity was observed when running IcedID malspam.

  • Effort: intermediate
Fail2ban Unban IP

An IP was ubaned by Fail2ban. It could be use to allow malicous traffic.

  • Effort: advanced
Formbook Hijacked Process Command

Detects process hijacked by Formbook malware which executes specific commands to delete the dropper or copy browser credentials to the database before sending them to the C2.

  • Effort: intermediate
FromBase64String Command Line

Detects suspicious FromBase64String expressions in command line arguments.

  • Effort: master
Generic-reverse-shell-oneliner

To bypass some security equipement or for a sack of simplicity attackers can open raw reverse shell using shell commands

  • Effort: intermediate
Gpresult Usage

Detects when an account uses gpresult to get information on gpo.

  • Effort: advanced
Grabbing Sensitive Hives Via Reg Utility

Detects dump of SAM, System or Security hives using reg.exe utility. Adversaries may attempt to dump these Windows Registry to retrieve password hashes and access credentials.

  • Effort: intermediate
HTML Smuggling Suspicious Usage

Based on several samples from different botnets, this rule aims at detecting HTML infection chain by looking for HTML created files followed by suspicious files being executed.

  • Effort: intermediate
HackTools Suspicious Names

Quick-win rule to detect the default process names or file names of several HackTools.

  • Effort: elementary
HackTools Suspicious Process Names In Command Line

Detects the default process name of several HackTools and also check in command line. This rule is here for quickwins as it obviously has many blind spots.

  • Effort: intermediate
Hiding Files With Attrib.exe

Detects usage of attrib.exe to hide files from users.

  • Effort: advanced
High Privileges Network Share Removal

Detects high privileges shares being deleted with the net share command.

  • Effort: intermediate
ICacls Granting Access To All

Detects suspicious icacls command granting access to all, used by the ransomware Ryuk to delete every access-based restrictions on files and directories. ICacls is a built-in Windows command to interact with the Discretionary Access Control Lists (DACLs) which can grand adversaries higher permissions on specific files and folders.

  • Effort: elementary
Inhibit System Recovery Deleting Backups

Detects adversaries attempts to delete backups or inhibit system recovery. This rule relies on differents known techniques using Windows events logs from Sysmon (ID 1), and PowerShell (ID 4103, 4104).

  • Effort: intermediate
Interactive Terminal Spawned via Python

Identifies when a terminal (tty) is spawned via Python. Attackers may upgrade a simple reverse shell to a fully interactive tty after obtaining initial access to a host.

  • Effort: advanced
Invoke-TheHash Commandlets

Detects suspicious Invoke-TheHash PowerShell commandlet used for performing pass the hash WMI and SMB tasks.

  • Effort: elementary
KeePass Config XML In Command-Line

Detects a command-line interaction with the KeePass Config XML file. It could be used to retrieve informations or to be abused for persistence.

  • Effort: intermediate
Kernel Module Alteration

Kernel module installation can be used to configure system settings to automatically execute a program during system boot or logon to maintain persistence or gain higher-level privileges on compromised systems. The prerequisites are to enable monitoring of the finit_module, init_module, delete_module syscalls using Auditbeat.

  • Effort: advanced
Language Discovery

Detects when a user makes a query on the language of the system.

  • Effort: advanced
Lazarus Loaders

Detects different loaders used by the Lazarus Group APT

  • Effort: elementary
Legitimate Process Execution From Unusual Folder

Detects the execution of a legitimate, windows built-in process name from an unusual / suspicious folder. Legitimate folders are c:\windows\system32\, \SystemRoot\system32\, c:\windows\syswow64\ and c:\windows\winsxs. Many malwares/attackers use legitimate names to masquerade but if they are not Administrator yet, they often can't write file into these legitimate folders.

  • Effort: advanced
Leviathan Registry Key Activity

Detects registry key used by Leviathan APT in Malaysian focused campaign.

  • Effort: elementary
Linux Bash Reverse Shell

To bypass some security equipement or for a sack of simplicity attackers can open raw reverse shell using shell commands

  • Effort: intermediate
Linux Remove Immutable Attribute

Adversaries may used chattr utility to alter file and folder attributes to control sudden operations like the deletion and modification of files.

  • Effort: intermediate
Linux Shared Lib Injection Via Ldso Preload

Detect ld.so.preload modification for shared lib injection, technique used by attackers to load arbitrary code into process

  • Effort: intermediate
Linux Suspicious Nohup Exec

Detects suspicious usage of nohup which could be leveraged by an attacker to keep a process running or break out from restricted environments

  • Effort: intermediate
Linux Suspicious Search

Adversaries may search for private key on compromised systems

  • Effort: intermediate
Listing Systemd Environment

Detects a listing of systemd environment variables. This command could be used to do reconnaissance on a compromised host.

  • Effort: advanced
Logon Scripts (UserInitMprLogonScript)

Detects creation or execution of UserInitMprLogonScript persistence method. The rule requires to log for process command lines and registry creations or update, which can be done using Sysmon Event IDs 1, 12, 13 and 14.

  • Effort: advanced
MSBuild Abuse

Detection of MSBuild uses by attackers to infect an host. Focuses on XML compilation which is a Metasploit payload, and on connections made by this process which is unusual.

  • Effort: intermediate
Malicious Browser Extensions

Detects browser extensions being loaded with the --load-extension and -base-url options, which works on Chromium-based browsers. We are looking for potentially malicious browser extensions. These extensions can get access to informations.

  • Effort: advanced
Malicious PowerShell Keywords

Detects keywords from well-known PowerShell exploitation frameworks

  • Effort: advanced
Malspam Execution Registering Malicious DLL

Detects the creation of a file in the C:\Datop folder, or DLL registering a file in the C:\Datop folder. Files located in the Datop folder are very characteristic of malspam execution related to Qakbot or SquirrelWaffle. Prerequisites are Logging for File Creation events, which can be done in the Sysmon configuration (events 11), for the first part of the pattern (TargetFilename).

  • Effort: elementary
Malware Persistence Registry Key

Detects registry key used by several malware, especially Formbook spyware in two ways, either the Sysmon registry events, or the commands line.

  • Effort: master
MalwareBytes Uninstallation

Detects command line being used by attackers to uninstall Malwarebytes.

  • Effort: intermediate
MavInject Process Injection

Detects process injection using the signed Windows tool Mavinject32.exe (which is a LOLBAS)

  • Effort: intermediate
Meterpreter or Cobalt Strike Getsystem Service Installation

Detects the use of getsystem Meterpreter/Cobalt Strike command by detecting some of the techniques being used (technique 1,2 and 5).

  • Effort: elementary
Microsoft Defender Antivirus Disable Scheduled Tasks

The rule detects attempts to deactivate/disable Windows Defender scheduled tasks via command line or PowerShell scripts.

  • Effort: intermediate
Microsoft Defender Antivirus Disable SecurityHealth

The rule detects attempts to deactivate/disable Windows Defender SecurityHealth through command line, PowerShell scripts, and registry. To fully use this rule Windows Registry logging is recommended.

  • Effort: intermediate
Microsoft Defender Antivirus Disable Services

The rule detects attempts to deactivate/disable Windows Defender through command line and registry.

  • Effort: intermediate
Microsoft Defender Antivirus Disable Using Registry

The rule detects attempts to deactivate/disable Microsoft Defender Antivirus using registry modification via command line or PowerShell scripts.

  • Effort: master
Microsoft Defender Antivirus Disabled Base64 Encoded

Detects attempts to deactivate/disable Windows Defender through base64 encoded PowerShell command line or scripts.

  • Effort: intermediate
Microsoft Defender Antivirus History Directory Deleted

Windows Defender history directory has been deleted. This could be an attempt by an attacker to remove its traces.

  • Effort: elementary
Microsoft Defender Antivirus Restoration Abuse

The rule detects attempts to abuse Windows Defender file restoration tool. The Windows Defender process is allowed to write files in its own protected directory. This functionality can be used by a threat actor to overwrite Windows Defender files in order to prevent it from running correctly or use Windows Defender to execute a malicious DLL.

  • Effort: intermediate
Microsoft Defender Antivirus Set-MpPreference Base64 Encoded

Detects changes of preferences for Windows Defender through command line or PowerShell scripts. Configure Windows Defender using base64-encoded commands is suspicious and could be related to malicious activities.

  • Effort: intermediate
Microsoft Defender Antivirus Signatures Removed With MpCmdRun

Detects attempts to remove Windows Defender Signatures using MpCmdRun legitimate Windows Defender executable. No signatures mean Windows Defender will be less effective (or completely useless depending on the option used).

  • Effort: elementary
Microsoft Exchange PowerShell Snap-Ins To Export Exchange Mailbox Data

Detects PowerShell SnapIn command line or PowerShell script, often used with Get-Mailbox to export Exchange mailbox data.

  • Effort: intermediate
Microsoft IIS Module Installation

Detects the installation of a new IIS module from the command line. It can used used to backdoor an IIS/OWA/Sharepoint server.

  • Effort: advanced
Microsoft Office Macro Security Registry Modifications

Detects registry changes allowing an attacker to make Microsoft Office products runs Macros without warning. Events are collected either from ETW/Sysmon/EDR depending of the integration.

  • Effort: master
Microsoft Windows Active Directory Module Commandlets

Detects use of commandlets linked to the AD Module.

  • Effort: advanced
Mimikatz Basic Commands

Detects Mimikatz most popular commands.

  • Effort: elementary
Msdt (Follina) File Browse Process Execution

Detects various Follina vulnerability exploitation techniques. This is based on the Compatability Troubleshooter which is abused to do code execution.

  • Effort: elementary
Mshta JavaScript Execution

Identifies suspicious mshta.exe commands that execute JavaScript supplied as a command line argument.

  • Effort: elementary
Mustang Panda Dropper

Detects specific process parameters as used by Mustang Panda droppers

  • Effort: elementary
NTDS.dit File Interaction Through Command Line

Detects interaction with the file NTDS.dit through command line. This is usually really suspicious and could indicate an attacker trying copy the file to then look for users password hashes.

  • Effort: intermediate
Net.exe User Account Creation

Identifies creation of local users via the net.exe command

  • Effort: master
NetSh Used To Disable Windows Firewall

Detects NetSh commands used to disable the Windows Firewall

  • Effort: intermediate
Netsh Allow Command

Netsh command line to allow a program to pass through firewall.

  • Effort: advanced
Netsh Allowed Python Program

Detects netsh command that performs modification on Firewall rules to allow the program python.exe. This activity is most likely related to the deployment of a Python server or an application that needs to communicate over a network. Threat actors could use it for data extraction, hosting a webshell or else.

  • Effort: intermediate
Netsh Port Forwarding

Detects netsh commands that enable a port forwarding between to hosts. This can be used by attackers to tunnel RDP or SMB shares for example.

  • Effort: intermediate
Netsh Port Opening

Detects netsh commands that opens a specific port. Can be used by malware or attackers for lateralisation/exfiltration (e.g. SMB/RDP opening).

  • Effort: master
Netsh Program Allowed With Suspicious Location

Detects Netsh commands that allow a suspcious application location on Windows Firewall, seen on kasidet worm. Last part of the existing rule (commandline startwith) was not added to this rule because it is not relevant.

  • Effort: advanced
Netsh RDP Port Forwarding

Detects netsh commands that configure a port forwarding of port 3389 used for RDP. This is commonly used by attackers during lateralization on windows environments.

  • Effort: elementary
Netsh RDP Port Opening

Detects netsh commands that opens the port 3389 used for RDP, used in Sarwent Malware.

  • Effort: intermediate
Network Scanning and Discovery

Tools and command lines used for network discovery from current system

  • Effort: advanced
Network Share Discovery

Adversaries may look for folders and drives shared on remote systems as a means of identifying sources of information to gather as a precursor for Collection and to identify potential systems of interest for Lateral Movement. Networks often contain shared network drives and folders that enable users to access file directories on various systems across a network. File sharing over a Windows network occurs over the SMB protocol. This technique is frequently leveraged by threat actors such as APT32, APT41, Wizard Spider. But also, through the use of some malware such as Cobalt Strike, Empire, PlugX and Ramsay.

  • Effort: master
Network Sniffing

List of common tools used for network packages sniffing

  • Effort: advanced
Network Sniffing Windows

Network sniffing refers to using the network interface on a system to monitor or capture information sent over a wired or wireless connection. An adversary may place a network interface into promiscuous mode to passively access data in transit over the network, or use span ports to capture a larger amount of data.

  • Effort: intermediate
New DLL Added To AppCertDlls Registry Key

Dynamic-link libraries (DLLs) that are specified in the AppCertDLLs value in the Registry key can be abused to obtain persistence and privilege escalation by causing a malicious DLL to be loaded and run in the context of separate processes on the computer. Logging for Registry events is needed in the Sysmon configuration (events 12 and 13).

  • Effort: intermediate
New Service Creation

Detects creation of a new service from command line

  • Effort: advanced
Ngrok Process Execution

Detects possible Ngrok execution, which can be used by attacker for RDP tunneling.

  • Effort: intermediate
NjRat Registry Changes

Detects changes for the RUN registry key which happen when a victim is infected by NjRAT. Please note that even if NjRat is well-known for the behavior the rule catches, the rule is a bit larger and could catch other malwares.

  • Effort: master
Njrat Registry Values

Detects specifis registry values that are related to njRat usage.

  • Effort: intermediate
NlTest Usage

Detects attempts to gather information on domain trust relationships that may be used to identify lateral movement opportunities. These command lines were observed in numerous attacks, but also sometimes from legitimate administrators for debugging purposes. The rule does not cover very basics commands but rather the ones that are interesting for attackers to gather information on a domain.

  • Effort: advanced
Non-Legitimate Executable Using AcceptEula Parameter

Detects accepteula in command line with non-legitimate executable name. Some attackers are masquerading SysInternals tools with decoy names to prevent detection.

  • Effort: advanced
Ntfsinfo Usage

Detects when the command ntfsinfo is used. An attacker can access to information on the volume from NTFS and have a directory dump of NTFS files.

  • Effort: advanced
Office Application Startup Office Test

Detects the addition of office test registry that allows a user to specify an arbitrary DLL that will be executed everytime an Office application is started. An adversaries may abuse the Microsoft Office "Office Test" Registry key to obtain persistence on a compromised system.

  • Effort: elementary
Openfiles Usage

Detects when the command openfiles, to get information on files opened remotely, is used.

  • Effort: advanced
Opening Of a Password File

Command line detection of common office software opening some password related file. It could be a security breach if an unauthorized user access it.

  • Effort: master
Outlook Registry Access

Detection of accesses to Microsoft Outlook registry hive, which might contain sensitive information.

  • Effort: master
Pandemic Windows Implant

Detects Pandemic Windows Implant through registry keys or specific command lines. Prerequisites: Logging for Registry events is needed, which can be done in the Sysmon configuration (events 12 and 13).

  • Effort: intermediate
PasswordDump SecurityXploded Tool

Detects the execution of the PasswordDump SecurityXploded Tool

  • Effort: elementary
Permission Discovery Via Wmic

Detects discovery of permission on local groups via the tool wmic.

  • Effort: advanced
Phorpiex DriveMgr Command

Detects specific command used by the Phorpiex botnet to execute a copy of the loader during its self-spreading stage. As described by Microsoft, this behavior is unique and easily identifiable due to the use of folders named with underscores "__" and the PE name "DriveMgr.exe".

  • Effort: elementary
Phorpiex Process Masquerading

Detects specific process executable path used by the Phorpiex botnet to masquerade its system process network activity. It looks for a pattern of a system process executable name that is not legitimate and running from a folder that is created via a random algorithm 13-15 numbers long.

  • Effort: elementary
Phosphorus (APT35) Exchange Discovery

According to the Miscosoft's report, the group Phosphorus (part of APT35) uses a specific PowerShell command to collect information about its the environment of compromised Microsoft Exchange servers. The command is the following: Get-Recipient | Select Name -ExpandProperty EmailAddresses -first 1 | Select SmtpAddress | ft -hidetableheaders

  • Effort: elementary
Phosphorus Domain Controller Discovery

According to the Miscosoft's report, the group Phosphorus (part of APT35) uses a specific PowerShell command to collect information about the Domain Controller. The command is the following: "powershell.exe" /c Get-WMIObject Win32_NTDomain | findstr DomainController

  • Effort: intermediate
PowerCat Function Loading

Detect a basic execution of PowerCat. PowerCat is a PowerShell function allowing to do basic connections, file transfer, shells, relays, generate payloads.

  • Effort: intermediate
PowerShell AMSI Deactivation Bypass Using .NET Reflection

Detects Request to amsiInitFailed that can be used to disable AMSI (Antimalware Scan Interface) Scanning. More information about Antimalware Scan Interface https://docs.microsoft.com/en-us/windows/win32/amsi/antimalware-scan-interface-portal.

  • Effort: advanced
PowerShell Commands Invocation

Detects the execution to invoke a powershell command. This was used in an intrusion using Gootloader to access Mimikatz.

  • Effort: advanced
PowerShell Credential Prompt

Detects PowerShell calling a credential prompt (using PromptForCredential), like $Credential = $host.ui.PromptForCredential("Need credentials", "Please enter your user name and password.", "", "NetBiosUserName"). The same result can be obtained by using the Get-Credential function but detecting it will trigger a lot of FP.

  • Effort: advanced
PowerShell Data Compressed

Detects data compression through a PowerShell command (could be used by an adversary for exfiltration).

  • Effort: advanced
PowerShell Downgrade Attack

Detects PowerShell downgrade attack by comparing the host versions with the actually used engine version 2.0

  • Effort: elementary
PowerShell Download From URL

Detects a Powershell process that contains download commands in its command line string.

  • Effort: advanced
PowerShell EncodedCommand

Detects popular file extensions in commands obfuscated in base64 run through the EncodedCommand option.

  • Effort: advanced
PowerShell Execution Via Rundll32

Detects PowerShell Strings applied to rundll as seen in PowerShdll.dll Rule modified

  • Effort: intermediate
PowerShell Invoke Expression With Registry

Detects keywords from well-known PowerShell techniques to get registry key values

  • Effort: advanced
PowerShell Invoke-Obfuscation Obfuscated IEX Invocation

Detects all variations of obfuscated powershell IEX invocation code generated by Invoke-Obfuscation framework

  • Effort: advanced
PowerShell Malicious Nishang PowerShell Commandlets

Detects Commandlet names and arguments from the Nishang exploitation framework.

  • Effort: advanced
PowerShell Malicious PowerShell Commandlets

Detects Commandlet names from well-known PowerShell exploitation frameworks (PowerSploit...).

  • Effort: master
PowerShell NTFS Alternate Data Stream

Detects writing data into NTFS alternate data streams from PowerShell. Needs Script Block Logging (Event ID 4104)

  • Effort: advanced
PowerView commandlets 1

Detects PowerView commandlets which perform network and Windows domain enumeration and exploitation. It provides replaces for almost all Windows net commands, letting you query users, machines, domain controllers, user descriptions, share, sessions, and more.

  • Effort: advanced
PowerView commandlets 2

Detects PowerView commandlets which perform network and Windows domain enumeration and exploitation. It provides replaces for almost all Windows net commands, letting you query users, machines, domain controllers, user descriptions, share, sessions, and more.

  • Effort: advanced
Powershell AMSI Bypass

This rule aims to detect attempts to bypass AMSI in powershell using specific techniques.

  • Effort: advanced
Powershell UploadString Function

Powershell's uploadXXX functions are a category of methods which can be used to exfiltrate data through native means on a Windows host.

  • Effort: intermediate
Powershell Web Request

Detects the use of various web request methods executed remotely via Windows PowerShell.

  • Effort: advanced
Privilege Escalation Awesome Scripts (PEAS)

Detect PEAS privileges escalation scripts and binaries

  • Effort: elementary
Process Memory Dump Using Comsvcs

Detects the use of comsvcs in command line to dump a specific process memory. This technique is used by attackers for privilege escalation and pivot.

  • Effort: intermediate
Process Memory Dump Using Createdump

Detects the use of createdump.exe in command line to dump the memory of a process. This technique is used by attackers for privilege escalation and pivot.

  • Effort: elementary
Process Memory Dump Using Rdrleakdiag

Detects the use of rdrleakdiag.exe in command line to dump the memory of a process. This technique is used by attackers for privilege escalation and pivot.

  • Effort: elementary
Process Trace Alteration

PTrace syscall provides a means by which one process ("tracer") may observe and control the execution of another process ("tracee") and examine and change the tracee's memory and registers. Attacker might want to abuse ptrace functionnality to analyse memory process. It requires to be admin or set ptrace_scope to 0 to allow all user to trace any process.

  • Effort: advanced
PsExec Process

Detects PsExec execution, command line which contains pstools or installation of the PsExec service. PsExec is a SysInternals which can be used to execute a program on another computer. The tool is as much used by attackers as by administrators.

  • Effort: advanced
Putty Sessions Listing

Detects attempts to list Putty sessions through registry. To fully work, this rule requires to log registry accesses, which can be done with the Windows Event ID 4656 or 4663 but for that specific configuration is needed.

  • Effort: master
Python Exfiltration Tools

Python has some built-in modules or library that could be installed and later be used as exflitration tool by an attacker

  • Effort: advanced
Python HTTP Server

Detects command used to start a Simple HTTP server in Python. Threat actors could use it for data extraction, hosting a webshell or else.

  • Effort: intermediate
QakBot Process Creation

Detects QakBot like process executions

  • Effort: intermediate
Qakbot Persistence Using Schtasks

Detects possible Qakbot persistence using schtasks.

  • Effort: intermediate
RDP Port Change Using Powershell

Detects RDP port configuration change using a PowerShell command such as 'Set-ItemProperty -Path "HKLM:\System\CurrentControlSet\Control\Terminal Server\WinStations\RDP-Tcp" -Name PortNumber -Value XXX Restart-Service termservice -force'. Threat actors can change RDP to another port to bypass protections, avoid detection based on the port, or to take full control of the system.

  • Effort: intermediate
RDP Session Discovery

Detects use of RDP session discovery via qwinsta or quser. Used by some threat actors to know if someone is working via RDP on a server.

  • Effort: advanced
RTLO Character

Detects RTLO (Right-To-Left character) in file and process names.

  • Effort: elementary
Raccine Uninstall

Detects commands that indicate a Raccine removal from an end system. Raccine is a free ransomware protection tool.

  • Effort: elementary
Rclone Process

Detects Rclone executable or Rclone execution by using the process name, the execution through a command obfuscated or not.

  • Effort: advanced
Reconnaissance Commands Activities

Based on Cynet, Microsoft and Kaspersky analysis of Qakbot, this rule tries to detect some discovery TTPs.

  • Effort: intermediate
RedMimicry Winnti Playbook Registry Manipulation

Detects actions caused by the RedMimicry Winnti playbook. Logging for Registry events is needed in the Sysmon configuration (events 12 and 13).

  • Effort: elementary
Remote Access Tool Domain

Detects traffic toward a domain flagged as a Remote Administration Tool (RAT).

  • Effort: master
Remote Monitoring and Management Software - AnyDesk

Detect artifacts related to the installation or execution of the Remote Monitoring and Management tool AnyDesk.

  • Effort: master
Remote Monitoring and Management Software - Atera

Detect artifacts related to the installation or execution of the Remote Monitoring and Management tool Atera.

  • Effort: master
Remote System Discovery Via Telnet

Detects use of the protocol telnet to access information.

  • Effort: advanced
Rubeus Tool Command-line

Detects command line parameters used by Rubeus, a toolset to interact with Kerberos and abuse it.

  • Effort: advanced
SOCKS Tunneling Tool

Detects the usage of a SOCKS tunneling tool, often used by threat actors. These tools often use the socks5 commandline argument, however socks4 can sometimes be used as well. Unfortunately, socks alone (without any number) triggered too many false positives.

  • Effort: intermediate
Schtasks Persistence With High Privileges

Detection of scheduled task with high privileges used by attacker for persistence.

  • Effort: elementary
Sekoia.io EICAR Detection

Detects observables in Sekoia.io CTI tagged as EICAR, which are fake samples meant to test detection.

  • Effort: master
Shadow Copies

Detects command line used to create and list shadow copies. An adversary may attempt to get information on shadow volumes to perform deletion or extract password hashes from the ntds.dit file. This rule requires command line logging or Windows PowerShell events (4104).

  • Effort: master
Shell PID Injection

Detects when shells PID are listed and injected in another process. It can be performed to reuse sudo token related to shell in order to elevate privilege and maintain persistence.

  • Effort: intermediate
Socat Relaying Socket

Socat is a linux tool used to relay local socket or internal network connection, this technics is often used by attacker to bypass security equipment such as firewall

  • Effort: advanced
Socat Reverse Shell Detection

Socat is a linux tool used to relay or open reverse shell that is often used by attacker to bypass security equipment.

  • Effort: elementary
Spyware Persistence Using Schtasks

Detects possible Agent Tesla or Formbook persistence using schtasks. The name of the scheduled task used by these malware is very specific (Updates/randomstring).

  • Effort: intermediate
Stop Backup Services

Detects adversaries attempts to stop backups services or disable Windows previous files versions feature. This could be related to ransomware operators or legit administrators. This rule relies Windows command line logging and registry logging, and PowerShell (ID 4103, 4104).

  • Effort: master
Suncrypt Parameters

Detects SunCrypt ransomware's parameters, most of which are unique.

  • Effort: elementary
Suspicious Cmd File Copy Command To Network Share

Copy suspicious files through Windows cmd prompt to network share

  • Effort: intermediate
Suspicious Cmd.exe Command Line

Detection on suspicious cmd.exe command line seen being used by some attackers (e.g. Lazarus with Word macros). This requires Windows process command line logging.

  • Effort: master
Suspicious CodePage Switch with CHCP

Detects a code page switch in command line

  • Effort: intermediate
Suspicious CommandLine Lsassy Pattern

Detects the characteristic lsassy loop used to identify lsass PIDs

  • Effort: intermediate
Suspicious Control Process

Detects suspicious execution of control.exe process when used to execute a DLL file.

  • Effort: advanced
Suspicious DLL Loading By Ordinal

Detects suspicious DLL Loading by ordinal number in a non legitimate or rare folders. For example, Sofacy (APT28) used this technique to load their Trojan in a campaign of 2018.

  • Effort: intermediate
Suspicious Desktopimgdownldr Execution

Detects a suspicious Desktopimgdownldr execution. Desktopimgdownldr.exe is a Windows binary used to configure lockscreen/desktop image and can be abused to download malicious file.

  • Effort: intermediate
Suspicious Double Extension

Detects suspicious use of an .exe extension after a non-executable file extension like .pdf.exe, a set of spaces or underlines to cloak the executable file in spearphishing campaigns

  • Effort: advanced
Suspicious Finger Usage

Detects suspicious aged finger.exe tool execution often used in malware attacks nowadays. An attacker can use finger to silently retrieve a command, a script or a payload from a remote server. For example, the tool Darkfinger-C2 uses this technique to download files from the C2 channel.

  • Effort: intermediate
Suspicious Headless Web Browser Execution To Download File

Detects a suspicious command used to execute a Chromium-based web browser (Chrome or Edge) using the headless mode, meaning that the browser window wouldn't be visible, and the dump mode to download a file. This technique can be used to fingerprint the compromised host, in particular by the Ducktail infostealer.

  • Effort: elementary
Suspicious Microsoft Defender Antivirus Exclusion Command

Detects PowerShell commands aiming to exclude path, process, IP address, or extension from scheduled and real-time scanning. These commands can be used by attackers or malware to avoid being detected by Windows Defender. Depending on the environment and the installed software, this detection rule could raise false positives. We recommend customizing this rule by filtering legitimate processes that use Windows Defender exclusion command in your environment.

  • Effort: master
Suspicious Mshta Execution

Detects suspicious mshta.exe execution patterns, either involving file polyglotism, remote file (http, ftp or ldap) or suspicious location. This technique is often used by threat actors.

  • Effort: intermediate
Suspicious Netsh DLL Persistence

Detects persitence via netsh helper. Netsh interacts with other operating system components using dynamic-link library (DLL) files. Adversaries may establish persistence by executing malicious content triggered by Netsh Helper DLLs.

  • Effort: elementary
Suspicious Network Args In Command Line

Detection on some commonly observed suspicious processes command lines using HTTP schema with port 443.

  • Effort: intermediate
Suspicious PowerShell Invocations - Generic

Detects suspicious PowerShell invocation command parameters through command line logging or ScriptBlock Logging.

  • Effort: intermediate
Suspicious PowerShell Invocations - Specific

Detects suspicious PowerShell invocation command parameters.

  • Effort: intermediate
Suspicious PowerShell Keywords

Detects keywords that could indicate the use of some PowerShell exploitation framework.

  • Effort: advanced
Suspicious PrinterPorts Creation (CVE-2020-1048)

Detects new commands that add new printer port which point to suspicious file

  • Effort: advanced
Suspicious Process Requiring DLL Starts Without DLL

Detects potential process injection and hollowing on processes that usually require a DLL to be launched, but are launched without any argument.

  • Effort: intermediate
Suspicious Regasm Regsvcs Usage

catch abuse of regsvcs and regasm lolbin by attacker

  • Effort: advanced
Suspicious Regsvr32 Execution

Detects suspicious regsvr32.exe executions, either regsvr32 registering a DLL in an unusual repository (temp/, appdata/ or public/), or regsvr32 executed by an unusual parent process, or regsvr32 executing an unusual process, or regsvr32 registering a media file and not a DLL (as seen in IcedID campaigns), or regsvr32 registering a ocx file in appdata/.

  • Effort: advanced
Suspicious Rundll32.exe Execution

The process rundll32.exe executes a newly dropped DLL with update /i in the command line. This specific technic was observed at least being used by the IcedID loading mechanism dubbed Gziploader.

  • Effort: intermediate
Suspicious Taskkill Command

Detects rare taskkill command being used. It could be related to Baby Shark malware.

  • Effort: intermediate
Suspicious VBS Execution Parameter

Detects suspicious VBS file execution with a specific parameter by cscript. It was observed in the Operation CloudHopper.

  • Effort: elementary
Suspicious Windows Installer Execution

Detects suspicious execution of the Windows Installer service (msiexec.exe) which could be used to install a malicious MSI package hosted on a remote server.

  • Effort: intermediate
Suspicious Windows Script Execution

Detects wscript.exe or cscript.exe executing a script in user directories (C:\ProgramData or C:\Users) with a .txt extension, which is very suspicious. It could strongly correspond to a malware dropper, as seen during SquirrelWaffle maldoc campaign.

  • Effort: intermediate
Suspicious XOR Encoded PowerShell Command Line

Detects suspicious powershell process which includes bxor command, alternative obfuscation method to b64 encoded commands.

  • Effort: advanced
Suspicious certutil command

Detects suspicious certutil command which can be used by threat actors to download and/or decode payload.

  • Effort: intermediate
Sysprep On AppData Folder

Detects suspicious Sysprep process start with AppData folder as target (as used by Trojan Syndicasec in Thrip report by Symantec). Sysprep is a Windows tool used to change Windows images from a generalized state to a specialized state, and then back to a generalized state. It can be used to remove all system-specific information and reset the computer.

  • Effort: intermediate
System Info Discovery

System info discovery, attempt to detects basic command use to fingerprint a host.

  • Effort: master
System Network Connections Discovery

Detects system network connections discovery via powershell and cmd.

  • Effort: advanced
TOR Usage Generic Rule

Detects TOR usage globally, whether the IP is a destination or source. TOR is short for The Onion Router, and it gets its name from how it works. TOR intercepts the network traffic from one or more apps on user’s computer, usually the user web browser, and shuffles it through a number of randomly-chosen computers before passing it on to its destination. This disguises user location, and makes it harder for servers to pick him/her out on repeat visits, or to tie together separate visits to different sites, this making tracking and surveillance more difficult. Before a network packet starts its journey, user’s computer chooses a random list of relays and repeatedly encrypts the data in multiple layers, like an onion. Each relay knows only enough to strip off the outermost layer of encryption, before passing what’s left on to the next relay in the list.

  • Effort: master
TrustedInstaller Impersonation

The rule detects attempts to impersonate TrustedInstaller. TrustedInstaller rights could allow a threat actor to delete or modify protected file or create/delete/modify files in protected folders. This technique is used by threat actors to disable Windows Defender.

  • Effort: intermediate
UAC Bypass Via Sdclt

Detects changes to HKCU\Software\Classes\exefile\shell\runas\command\isolatedCommand by an attacker in order to bypass User Account Control (UAC)

  • Effort: elementary
Usage Of Procdump With Common Arguments

Detects the usage of Procdump sysinternals tool with some common arguments and followed by common patterns.

  • Effort: intermediate
Usage Of Sysinternals Tools

Detects the usage of Sysinternals Tools due to accepteula key being added to Registry. The rule detects it either from the command line usage or from the regsitry events. For the later prerequisite is logging for registry events in the Sysmon configuration (events 12 and 13).

  • Effort: master
Venom Multi-hop Proxy agent detection

Detects Venom Multi-hop Proxy agent.

  • Effort: intermediate
WMI Fingerprint Commands

Detects attacker fingerprint activities based on the correlation of specific WMIC commands. This has been observed with Aurora malware.

  • Effort: intermediate
WMI Install Of Binary

Detection of WMI used to install a binary on the host. It is often used by attackers as a signed binary to infect an host.

  • Effort: elementary
WMIC Command To Determine The Antivirus

Detects WMIC command to determine the antivirus on a system, characteristic of the ZLoader malware (and possibly others)

  • Effort: advanced
WMIC Uninstall Product

Detects products being uninstalled using WMIC command.

  • Effort: intermediate
WMImplant Hack Tool

WMImplant is a powershell framework used by attacker for reconnaissance and exfiltration, this rule attempts to detect WMimplant arguments and invokes commands.

  • Effort: intermediate
Wdigest Enable UseLogonCredential

Detects modification of the Windows Registry value of HKLM\SYSTEM\CurrentControlSet\Control\SecurityProviders\WDigest\UseLogonCredential. This technique is used to extract passwords in clear-text using WDigest. The rule requires to log for Registry Events, which can be done using Sysmon Event IDs 12, 13 and 14.

  • Effort: elementary
WiFi Credentials Harvesting Using Netsh

Detects the harvesting of WiFi credentials using netsh.exe.

  • Effort: advanced
Windows Defender Deactivation Using PowerShell Script

Detects attempts to deactivate Windows Defender with PowerShell using ScriptBlockLogging.

  • Effort: master
Windows Defender Logging Modification Via Registry

Detects when the logging for defender is disabled in the registry.

  • Effort: elementary
Windows Firewall Changes

Detects changes on Windows Firewall configuration

  • Effort: master
Windows Registry Persistence COM Key Linking

Detects COM object hijacking via TreatAs subkey. Logging for Registry events is needed in the Sysmon configuration with this kind of rule <TargetObject name="testr12" condition="end with">\TreatAs\(Default)</TargetObject>.

  • Effort: master
Wmic Process Call Creation

The WMI command-line (WMIC) utility provides a command-line interface for Windows Management Instrumentation (WMI). WMIC is compatible with existing shells and utility commands. Although WMI is supposed to be an administration tool, it is wildy abused by threat actors. One of the reasons is WMI is quite stealthy. This rule detects the wmic command line launching a process on a remote or local host.

  • Effort: intermediate
Wmic Service Call

Detects either remote or local code execution using wmic tool.

  • Effort: intermediate
Wmic Suspicious Commands

Detects suspicious commands used by the process wmic to get informations on the system.

  • Effort: advanced
XCopy Suspicious Usage

Detects the usage of xcopy with suspicious command line options (used by Judgment Panda APT in the past). The rule is based on command line only in case xcopy is renamed.

  • Effort: advanced
XSL Script Processing And SquiblyTwo Attack

Detection of an attack where adversaries may bypass application control and obscure execution of code by embedding scripts inside XSL files. Another variation of this technique, dubbed "Squiblytwo", involves to invoke JScript or VBScript within an XSL file.

  • Effort: intermediate
ZIP LNK Infection Chain

Detection of an ZIP download followed by a child-process of explorer, followed by multiple Windows processes.This is widely used as an infection chain mechanism.

  • Effort: advanced
xWizard Execution

Detects the execution of Xwizard tool with specific arguments which utilized to run custom class properties.

  • Effort: master

Event Categories

The following table lists the data source offered by this integration.

Data Source Description
Network intrusion detection system None

In details, the following table denotes the type of events produced by this integration.

Name Values
Kind ``
Category intrusion_detection
Type info

Transformed Events Samples after Ingestion

This section demonstrates how the raw logs will be transformed by our parsers. It shows the extracted fields that will be available for use in the built-in detection rules and hunting activities in the events page. Understanding these transformations is essential for analysts to create effective detection mechanisms with custom detection rules and to leverage the full potential of the collected data.

{
    "message": "{\"source\": \"endpointActivityData\", \"uuid\": \"2d4af1a4-d784-4a91-9634-b0166f9118ef\", \"filters\": [{\"id\": \"F4231\", \"name\": \"Service Execution via Service Control Manager\", \"description\": \"Service Control Manager (services.exe) has executed a process\", \"mitreTacticIds\": [\"TA0002\"], \"mitreTechniqueIds\": [\"T1560.002\"], \"highlightedObjects\": [{\"type\": \"port\", \"field\": \"objectPort\", \"value\": 443}], \"riskLevel\": \"info\", \"type\": \"custom\"}], \"endpoint\": {\"endpointName\": \"LAB-Luwak-1048\", \"agentGuid\": \"b1cde761-16ad-4067-9a57-cbea882915df\", \"ips\": [\"150.183.13.135\", \"433e:5c7b:50b0:d145:2c61:9d1d:f317:627e\"]}, \"entityType\": \"endpoint\", \"entityName\": \"desktop 1 (110.205.134.245) or 110.205.134.245 | xxxx@gmail.com | arn:aws:lambda:*:%s:function:%s | k8s_container-8c55678bd-8r7zt_default_c1e0cf9a-47bb-41e7-ad41-bac976462a81_6411 | 6d7d30d2148a | -\", \"detectedDateTime\": \"2020-06-01T02:12:56Z\", \"ingestedDateTime\": \"2020-06-01T02:12:56Z\", \"detail\": {\"eventTime\": \"1649806995000\", \"tags\": [\"MITREV9.T1569.002\", \"XSAE.F4231\"], \"uuid\": \"2d4af1a4-d784-4a91-9634-b0166f9118ef\", \"productCode\": \"xes\", \"filterRiskLevel\": \"info\", \"bitwiseFilterRiskLevel\": 1, \"eventId\": \"1\", \"eventSubId\": 2, \"eventHashId\": \"-7817927890991207527\", \"firstSeen\": \"1649806995000\", \"lastSeen\": \"1649806995000\", \"endpointGuid\": \"b1cde761-16ad-4067-9a57-cbea882915df\", \"endpointHostName\": \"LAB-Luwak-1048\", \"endpointIp\": [\"433e:5c7b:50b0:d145:2c61:9d1d:f317:627e\", \"150.183.13.135\"], \"endpointMacAddress\": [\"00:50:56:89:09:9b\"], \"timezone\": \"UTC+08:00\", \"pname\": \"751\", \"pver\": \"1.2.0.2454\", \"plang\": 1, \"pplat\": 5889, \"osName\": \"Windows\", \"osVer\": \"10.0.19044\", \"osDescription\": \"Windows 10 Enterprise (64 bit) build 19044\", \"osType\": \"0x00000004\", \"processHashId\": \"8149551095598764453\", \"processName\": \"C:\\\\Windows\\\\System32\\\\services.exe\", \"processPid\": 672, \"sessionId\": 0, \"processUser\": \"SYSTEM\", \"processUserDomain\": \"NT AUTHORITY\", \"processLaunchTime\": \"1646826182237\", \"processCmd\": \"C:\\\\Windows\\\\system32\\\\services.exe\", \"authId\": \"999\", \"integrityLevel\": 16384, \"processFileHashId\": \"-4092577940452904134\", \"processFilePath\": \"C:\\\\Windows\\\\System32\\\\services.exe\", \"processFileHashSha1\": \"a75988a89b1e18c5af82f5f4f5e28f9c91c2cd3e\", \"processFileHashSha256\": \"ab6acff524930ed8fddd84787a8d65ec9ed0b6b62727dac4a23a1ec7a13b4b08\", \"processFileHashMd5\": \"dac02fbf9bebb39e34afe11bfddf2f83\", \"processSigner\": [\"Microsoft Windows Publisher\"], \"processSignerValid\": [true], \"processFileSize\": \"714856\", \"processFileCreation\": \"1618396713939\", \"processFileModifiedTime\": \"1618396713971\", \"processTrueType\": 7, \"objectHashId\": \"499492567380524547\", \"objectUser\": \"NETWORK SERVICE\", \"objectUserDomain\": \"NT AUTHORITY\", \"objectSessionId\": \"0\", \"objectFilePath\": \"C:\\\\Windows\\\\System32\\\\sppsvc.exe\", \"objectFileHashSha1\": \"42aeb6f7261c3c0521d19a77d2ea1956d122921f\", \"objectFileHashSha256\": \"be86edb76a659ddb715dbe985013683bf7831736a779178b28240ee74e393c21\", \"objectFileHashMd5\": \"e47a33a58764cd5cb567000035876e1a\", \"objectSigner\": [\"Microsoft Windows\"], \"objectSignerValid\": [true], \"objectFileSize\": \"4629328\", \"objectFileCreation\": \"1646822883174\", \"objectFileModifiedTime\": \"1646822883393\", \"objectTrueType\": 7, \"objectName\": \"C:\\\\Windows\\\\System32\\\\sppsvc.exe\", \"objectPid\": 3832, \"objectLaunchTime\": \"1649806995010\", \"objectCmd\": \"C:\\\\Windows\\\\system32\\\\sppsvc.exe\", \"objectAuthId\": \"996\", \"objectIntegrityLevel\": 16384, \"objectFileHashId\": \"-4729198244400997661\", \"objectRunAsLocalAccount\": false}}",
    "event": {
        "category": [
            "intrusion_detection"
        ],
        "end": "2022-04-12T23:43:15Z",
        "start": "2022-04-12T23:43:15Z",
        "type": [
            "info"
        ]
    },
    "@timestamp": "2020-06-01T02:12:56Z",
    "agent": {
        "id": "b1cde761-16ad-4067-9a57-cbea882915df"
    },
    "host": {
        "id": "b1cde761-16ad-4067-9a57-cbea882915df",
        "ip": [
            "150.183.13.135",
            "433e:5c7b:50b0:d145:2c61:9d1d:f317:627e"
        ],
        "name": "LAB-Luwak-1048",
        "os": {
            "full": "Windows 10 Enterprise (64 bit) build 19044",
            "name": "Windows",
            "version": "10.0.19044"
        }
    },
    "observer": {
        "product": "Vision One",
        "vendor": "TrendMicro"
    },
    "process": {
        "command_line": "C:\\Windows\\system32\\sppsvc.exe",
        "name": "services.exe",
        "parent": {
            "command_line": "C:\\Windows\\system32\\services.exe",
            "executable": "C:\\Windows\\System32\\services.exe",
            "hash": {
                "md5": "dac02fbf9bebb39e34afe11bfddf2f83",
                "sha1": "a75988a89b1e18c5af82f5f4f5e28f9c91c2cd3e",
                "sha256": "ab6acff524930ed8fddd84787a8d65ec9ed0b6b62727dac4a23a1ec7a13b4b08"
            },
            "pid": 672,
            "start": "2022-03-09T11:43:02.237000Z",
            "user": {
                "domain": "NT AUTHORITY",
                "name": "SYSTEM"
            }
        },
        "pid": 3832
    },
    "related": {
        "hash": [
            "a75988a89b1e18c5af82f5f4f5e28f9c91c2cd3e",
            "ab6acff524930ed8fddd84787a8d65ec9ed0b6b62727dac4a23a1ec7a13b4b08",
            "dac02fbf9bebb39e34afe11bfddf2f83"
        ],
        "ip": [
            "150.183.13.135",
            "433e:5c7b:50b0:d145:2c61:9d1d:f317:627e"
        ],
        "user": [
            "NETWORK SERVICE"
        ]
    },
    "threat": {
        "tactic": {
            "id": [
                "TA0002"
            ]
        },
        "technique": {
            "subtechnique": {
                "id": [
                    "T1560.002"
                ]
            }
        }
    },
    "user": {
        "domain": "NT AUTHORITY",
        "name": "NETWORK SERVICE"
    }
}
{
    "message": "{\"source\": \"endpointActivityData\", \"uuid\": \"541ec898-a229-49ae-831a-04f0a8fdb256\", \"detectedDateTime\": \"2024-11-26T16:45:02Z\", \"filters\": [{\"id\": \"F3457\", \"name\": \"Execution of System Discovery Tools\", \"description\": \"Detects the execution of system discovery tools\", \"highlightedObjects\": [{\"field\": \"objectCmd\", \"type\": \"command_line\", \"value\": \"\\\"C:\\\\Windows\\\\system32\\\\klist.exe\\\"\"}, {\"field\": \"processCmd\", \"type\": \"command_line\", \"value\": \"\\\"C:\\\\Windows\\\\system32\\\\WindowsPowerShell\\\\v1.0\\\\PowerShell_ISE.exe\\\" \"}, {\"field\": \"parentCmd\", \"type\": \"command_line\", \"value\": \"C:\\\\Windows\\\\Explorer.EXE\"}], \"mitreTacticIds\": [\"TA0007\"], \"mitreTechniqueIds\": [\"T1082\"], \"riskLevel\": \"low\", \"type\": \"preset\"}], \"detail\": {\"endpointGuid\": \"1c7a31e1-89e1-4192-aa7b-a341e6a8ebf1\", \"endpointHostName\": \"Windows10\", \"endpointIp\": [\"1802:d896:65fe:0b84:742d:0615:f69b:6600\", \"239.144.71.57\"], \"eventId\": \"1\", \"eventSubId\": 2, \"eventTime\": \"1732639502571\", \"filterRiskLevel\": \"low\", \"firstSeen\": \"1732639502571\", \"groupId\": \"3927f750-c536-480a-ae9f-d9ede20f4a9e\", \"integrityLevel\": 12288, \"lastSeen\": \"1732639502571\", \"logReceivedTime\": \"1732639512822\", \"logonUser\": [\"jdoe\"], \"objectCmd\": \"\\\"C:\\\\Windows\\\\system32\\\\klist.exe\\\"\", \"objectFileHashMd5\": \"c0ab059977511f3da83329c7562224e0\", \"objectFileHashSha1\": \"a4c1830c1e00779c50626a5ea93b8a54e2e3960b\", \"objectFileHashSha256\": \"f4c3734b96965947a3f42c6509538774bd0ecea110edfcb9f7463c83c90f32a7\", \"objectFilePath\": \"C:\\\\Windows\\\\System32\\\\klist.exe\", \"objectHashId\": \"-4153650555873691306\", \"objectIntegrityLevel\": 12288, \"objectName\": \"C:\\\\Windows\\\\System32\\\\klist.exe\", \"objectPid\": 3464, \"objectSigner\": [\"Microsoft Windows\"], \"objectSignerValid\": [true], \"objectTrueType\": 7, \"objectUser\": \"jdoe\", \"objectUserDomain\": \"Windows10\", \"osDescription\": \"Windows 10 Pro (64 bit) build 19045\", \"parentCmd\": \"C:\\\\Windows\\\\Explorer.EXE\", \"parentFileHashId\": \"1767110345653159701\", \"parentFileHashMd5\": \"a377274ae8e84c7e8ff5fd1b3bb9d080\", \"parentFileHashSha1\": \"b1db7fd8ea0d2fb6ca854609c9ff7de5a822b316\", \"parentFileHashSha256\": \"4e5fe7cf2873f4e4157d6592154179f6efe0b200dbb72fbdca039e4e4c72d4ac\", \"parentFilePath\": \"C:\\\\Windows\\\\explorer.exe\", \"parentHashId\": \"999588025188847480\", \"parentIntegrityLevel\": 12288, \"parentLaunchTime\": \"1732638953785\", \"parentName\": \"C:\\\\Windows\\\\explorer.exe\", \"parentPid\": 9920, \"parentSigner\": [\"Microsoft Windows\"], \"parentSignerValid\": [true], \"parentTrueType\": 7, \"parentUser\": \"jdoe\", \"parentUserDomain\": \"Windows10\", \"pname\": \"751\", \"processCmd\": \"\\\"C:\\\\Windows\\\\system32\\\\WindowsPowerShell\\\\v1.0\\\\PowerShell_ISE.exe\\\" \", \"processFileHashId\": \"-4900073020808934214\", \"processFileHashMd5\": \"fe6a3a98112b13aaad196444afcc041c\", \"processFileHashSha1\": \"0aea4fdd45c998bcf774e85ec478ab2e71fb8b4b\", \"processFileHashSha256\": \"09f94c21bc54d3de56b4007b0d650cb54a1dbbb91dc1d537426ac442448c4eed\", \"processFilePath\": \"C:\\\\Windows\\\\System32\\\\WindowsPowerShell\\\\v1.0\\\\powershell_ise.exe\", \"processHashId\": \"-5529997575794356190\", \"processLaunchTime\": \"1732639075967\", \"processName\": \"C:\\\\Windows\\\\System32\\\\WindowsPowerShell\\\\v1.0\\\\powershell_ise.exe\", \"processPid\": 5040, \"processSigner\": [\"Microsoft Windows\"], \"processSignerValid\": [true], \"processTrueType\": 7, \"processUser\": \"jdoe\", \"processUserDomain\": \"Windows10\", \"productCode\": \"xes\", \"tags\": [\"XSAE.F3457\", \"MITRE.T1082\"], \"uuid\": \"775a187e-723d-4889-a532-0835e28ab109\", \"plang\": 1, \"pver\": \"1.2.0.5608\", \"processSignerFlagsLibValid\": [false], \"eventHashId\": \"-1446580424195895092\", \"processFileSize\": \"212992\", \"eventSourceType\": 1, \"processSignerFlagsAdhoc\": [false], \"processFileModifiedTime\": \"1575651900000\", \"pplat\": 5889, \"processSignerFlagsRuntime\": [false], \"timezone\": \"UTC+00:00\", \"osVer\": \"10.0.19045\", \"authId\": \"1494147\", \"endpointMacAddress\": [\"8f:86:c0:d8:9d:ad\"], \"osType\": \"0x00000030\", \"processFileCreation\": \"1575712305614\", \"userDomain\": [\"Windows10\"], \"sessionId\": 2, \"osName\": \"Windows\", \"parentSignerFlagsLibValid\": [false], \"objectFileCreation\": \"1728117145131\", \"parentFileCreation\": \"1728117061706\", \"parentSessionId\": 2, \"objectFileSize\": \"76288\", \"parentFileModifiedTime\": \"1728117061831\", \"parentSignerFlagsAdhoc\": [false], \"parentAuthId\": \"1494147\", \"parentSignerFlagsRuntime\": [false], \"parentFileSize\": \"5845320\", \"objectFileModifiedTime\": \"1728117145131\", \"objectSignerFlagsRuntime\": [false], \"objectSessionId\": \"2\", \"objectRunAsLocalAccount\": false, \"objectSignerFlagsLibValid\": [false], \"objectLaunchTime\": \"1732639502565\", \"objectSignerFlagsAdhoc\": [false], \"objectAuthId\": \"1494147\", \"objectFileHashId\": \"-8054087497998296081\", \"processUserGroupSids\": [\"S-1-1-0\", \"S-1-5-114\"], \"objectUserGroupSids\": [\"S-1-1-0\", \"S-1-5-114\"]}, \"ingestedDateTime\": \"2024-11-26T16:45:25Z\", \"entityType\": \"endpoint\", \"entityName\": \"Windows10(1802:d896:65fe:0b84:742d:0615:f69b:6600,239.144.71.57)\", \"endpoint\": {\"ips\": [\"1802:d896:65fe:0b84:742d:0615:f69b:6600\", \"239.144.71.57\"], \"agentGuid\": \"9f6b89c4-c3b2-4b9f-9401-dae324506ceb\", \"endpointName\": \"Windows10\"}}",
    "event": {
        "category": [
            "intrusion_detection"
        ],
        "end": "2024-11-26T16:45:02.571000Z",
        "start": "2024-11-26T16:45:02.571000Z",
        "type": [
            "info"
        ]
    },
    "@timestamp": "2024-11-26T16:45:02Z",
    "agent": {
        "id": "9f6b89c4-c3b2-4b9f-9401-dae324506ceb"
    },
    "group": {
        "id": "3927f750-c536-480a-ae9f-d9ede20f4a9e"
    },
    "host": {
        "id": "1c7a31e1-89e1-4192-aa7b-a341e6a8ebf1",
        "ip": [
            "1802:d896:65fe:b84:742d:615:f69b:6600",
            "239.144.71.57"
        ],
        "name": "Windows10",
        "os": {
            "full": "Windows 10 Pro (64 bit) build 19045",
            "name": "Windows",
            "version": "10.0.19045"
        }
    },
    "observer": {
        "product": "Vision One",
        "vendor": "TrendMicro"
    },
    "process": {
        "command_line": "\"C:\\Windows\\system32\\klist.exe\"",
        "name": "powershell_ise.exe",
        "parent": {
            "command_line": "\"C:\\Windows\\system32\\WindowsPowerShell\\v1.0\\PowerShell_ISE.exe\" ",
            "executable": "C:\\Windows\\System32\\WindowsPowerShell\\v1.0\\powershell_ise.exe",
            "hash": {
                "md5": "fe6a3a98112b13aaad196444afcc041c",
                "sha1": "0aea4fdd45c998bcf774e85ec478ab2e71fb8b4b",
                "sha256": "09f94c21bc54d3de56b4007b0d650cb54a1dbbb91dc1d537426ac442448c4eed"
            },
            "parent": {
                "command_line": "C:\\Windows\\Explorer.EXE",
                "executable": "C:\\Windows\\explorer.exe",
                "hash": {
                    "md5": "a377274ae8e84c7e8ff5fd1b3bb9d080",
                    "sha1": "b1db7fd8ea0d2fb6ca854609c9ff7de5a822b316",
                    "sha256": "4e5fe7cf2873f4e4157d6592154179f6efe0b200dbb72fbdca039e4e4c72d4ac"
                },
                "name": "explorer.exe",
                "pid": "9920",
                "start": "2024-11-26T16:35:53.785000Z",
                "user": {
                    "domain": "Windows10",
                    "name": "jdoe"
                }
            },
            "pid": 5040,
            "start": "2024-11-26T16:37:55.967000Z",
            "user": {
                "domain": "Windows10",
                "name": "jdoe"
            }
        },
        "pid": 3464
    },
    "related": {
        "hash": [
            "09f94c21bc54d3de56b4007b0d650cb54a1dbbb91dc1d537426ac442448c4eed",
            "0aea4fdd45c998bcf774e85ec478ab2e71fb8b4b",
            "fe6a3a98112b13aaad196444afcc041c"
        ],
        "ip": [
            "1802:d896:65fe:b84:742d:615:f69b:6600",
            "239.144.71.57"
        ],
        "user": [
            "jdoe"
        ]
    },
    "threat": {
        "tactic": {
            "id": [
                "TA0007"
            ]
        },
        "technique": {
            "id": [
                "T1082"
            ]
        }
    },
    "user": {
        "domain": "Windows10",
        "name": "jdoe"
    }
}
{
    "message": "{\"source\": \"endpointActivityData\", \"uuid\": \"43483725-969b-4fb8-a453-c2353a9a5e12\", \"detectedDateTime\": \"2024-11-26T16:45:01Z\", \"filters\": [{\"id\": \"F3367\", \"name\": \"Sensitive File Locating via Powershell\", \"description\": \"Locate files deemed sensitive via Powershell\", \"highlightedObjects\": [{\"field\": \"objectRawDataStr\", \"type\": \"amsi_rawDataStr\", \"value\": [\"\\r\\n                                    if ($_.FullyQualifiedErrorId -ne \\\"NativeCommandErrorMessage\\\" -and $ErrorView -ne \\\"CategoryView\\\")\\r\\n                                    {\\r\\n                                        $myinv = $_.InvocationInfo\\r\\n                                        if ($myinv -and $myinv.MyCommand)\\r\\n                                        {\\r\\n                                            switch -regex ( $myinv.MyCommand.CommandType )\\r\\n                                            {\\r\\n                                                ([System.Management.Automation.CommandTypes]::ExternalScript)\\r\\n                                                {\\r\\n                                                    if ($myinv.MyCommand.Path)\\r\\n                                                    {\\r\\n                                                        $myinv.MyCommand.Path + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                                ([System.Management.Automation.CommandTypes]::Script)\\r\\n                                                {\\r\\n                                                    if ($myinv.MyCommand.ScriptBlock)\\r\\n                                                    {\\r\\n                                                        $myinv.MyCommand.ScriptBlock.ToString() + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                                default\\r\\n                                                {\\r\\n                                                    if ($myinv.InvocationName -match '^[&\\\\.]?$')\\r\\n                                                    {\\r\\n                                                        if ($myinv.MyCommand.Name)\\r\\n                                                        {\\r\\n                                                            $myinv.MyCommand.Name + \\\" : \\\"\\r\\n                                                        }\\r\\n                                                    }\\r\\n                                                    else\\r\\n                                                    {\\r\\n                                                        $myinv.InvocationName + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                            }\\r\\n                                        }\\r\\n                                        elseif ($myinv -and $myinv.InvocationName)\\r\\n                                        {\\r\\n                                            $myinv.InvocationName + \\\" : \\\"\\r\\n                                        }\\r\\n                                    }\\r\\n                                \", \"\\r\\n                                   if ($_.FullyQualifiedErrorId -eq \\\"NativeCommandErrorMessage\\\") {\\r\\n                                        $_.Exception.Message   \\r\\n                                   }\\r\\n                                   else\\r\\n                                   {\\r\\n                                        $myinv = $_.InvocationInfo\\r\\n                                        if ($myinv -and ($myinv.MyCommand -or ($_.CategoryInfo.Category -ne 'ParserError'))) {\\r\\n                                            $posmsg = $myinv.PositionMessage\\r\\n                                        } else {\\r\\n                                            $posmsg = \\\"\\\"\\r\\n                                        }\\r\\n                                        \\r\\n                                        if ($posmsg -ne \\\"\\\")\\r\\n                                        {\\r\\n                                            $posmsg = \\\"`n\\\" + $posmsg\\r\\n                                        }\\r\\n    \\t\\t\\t\\t    \\r\\n                                        if ( & { Set-StrictMode -Version 1; $_.PSMessageDetails } ) {\\r\\n                                            $posmsg = \\\" : \\\" +  $_.PSMessageDetails + $posmsg \\r\\n                                        }\\r\\n\\r\\n                                        $indent = 4\\r\\n                                        $width = $host.UI.RawUI.BufferSize.Width - $indent - 2\\r\\n\\r\\n                                        $errorCategoryMsg = & { Set-StrictMode -Version 1; $_.ErrorCategory_Message }\\r\\n                                        if ($errorCategoryMsg -ne $null)\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ CategoryInfo          : \\\" + $_.ErrorCategory_Message\\r\\n                                        }\\r\\n                                        else\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ CategoryInfo          : \\\" + $_.CategoryInfo\\r\\n                                        }\\r\\n                                        $posmsg += \\\"`n\\\"\\r\\n                                        foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n\\r\\n                                        $indentString = \\\"+ FullyQualifiedErrorId : \\\" + $_.FullyQualifiedErrorId\\r\\n                                        $posmsg += \\\"`n\\\"\\r\\n                                        foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n\\r\\n                                        $originInfo = & { Set-StrictMode -Version 1; $_.OriginInfo }\\r\\n                                        if (($originInfo -ne $null) -and ($originInfo.PSComputerName -ne $null))\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ PSComputerName        : \\\" + $originInfo.PSComputerName\\r\\n                                            $posmsg += \\\"`n\\\"\\r\\n                                            foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n                                        }\\r\\n\\r\\n                                        if ($ErrorView -eq \\\"CategoryView\\\") {\\r\\n                                            $_.CategoryInfo.GetMessage()\\r\\n                                        }\\r\\n                                        elseif (! $_.ErrorDetails -or ! $_.ErrorDetails.Message) {\\r\\n                                            $_.Exception.Message + $posmsg + \\\"`n \\\"\\r\\n                                        } else {\\r\\n                                            $_.ErrorDetails.Message + $posmsg\\r\\n                                        }\\r\\n                                   }\\r\\n                                \", \"{ Set-StrictMode -Version 1; $_.PSMessageDetails }\", \"{ Set-StrictMode -Version 1; $_.ErrorCategory_Message }\", \"{ Set-StrictMode -Version 1; $_.OriginInfo }\", \"{\\n    Write-Host $_.FullName\\n  }\", \"\\r\\n                                                  $_.PSParentPath.Replace(\\\"Microsoft.PowerShell.Core\\\\FileSystem::\\\", \\\"\\\")\\r\\n                                              \", \"\\r\\n                                    [String]::Format(\\\"{0,10}  {1,8}\\\", $_.LastWriteTime.ToString(\\\"d\\\"), $_.LastWriteTime.ToString(\\\"t\\\"))\\r\\n                                \", \"if ($_ -is [System.IO.DirectoryInfo]) { return '' }\\r\\nif ($_.Attributes -band [System.IO.FileAttributes]::Offline)\\r\\n{\\r\\n    return '({0})' -f $_.Length\\r\\n}\\r\\nreturn $_.Length\", \"{\\n  if (Test-Path $_) {\\n    Write-Host \\\"$_ found.\\\"\\n  }\\n}\", \"{\\n  if (Test-Path $_ -ErrorAction SilentlyContinue) {\\n    Write-Host \\\"$_ Found!\\\" -ForegroundColor red\\n  }\\n}\", \"{\\n  $Drive = $_\\n  Get-ChildItem $Drive -Recurse -Include $fileExtensions -ErrorAction SilentlyContinue -Force | ForEach-Object {\\n    $path = $_\\n    #Exclude files/folders with 'lang' in the name\\n    if ($Path.FullName | select-string \\\"(?i).*lang.*\\\") {\\n      #Write-Host \\\"$($_.FullName) found!\\\" -ForegroundColor red\\n    }\\n    if($Path.FullName | Select-String \\\"(?i).:\\\\\\\\.*\\\\\\\\.*Pass.*\\\"){\\n      write-host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'pass'\\\"\\n    }\\n    if($Path.FullName | Select-String \\\".:\\\\\\\\.*\\\\\\\\.*user.*\\\" ){\\n      Write-Host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'user' -excluding the 'users' directory\\\"\\n    }\\n    # If path name ends with common excel extensions\\n    elseif ($Path.FullName | Select-String \\\".*\\\\.xls\\\",\\\".*\\\\.xlsm\\\",\\\".*\\\\.xlsx\\\") {\\n      if ($ReadExcel -and $Excel) {\\n        Search-Excel -Source $Path.FullName -SearchText \\\"user\\\"\\n        Search-Excel -Source $Path.FullName -SearchText \\\"pass\\\"\\n      }\\n    }\\n    else {\\n      if ($path.Length -gt 0) {\\n        # Write-Host -ForegroundColor Blue \\\"Path name matches extension search: $path\\\"\\n      }\\n      if ($path.FullName | Select-String \\\"(?i).*SiteList\\\\.xml\\\") {\\n        Write-Host \\\"Possible MCaffee Site List Found: $($_.FullName)\\\"\\n        Write-Host \\\"Just going to leave this here: https://github.com/funoverip/mcafee-sitelist-pwd-decryption\\\" -ForegroundColor Yellow\\n      }\\n      $regexSearch.keys | ForEach-Object {\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\\n    }  \\n  }\\n}\", \"{\\n    $path = $_\\n    #Exclude files/folders with 'lang' in the name\\n    if ($Path.FullName | select-string \\\"(?i).*lang.*\\\") {\\n      #Write-Host \\\"$($_.FullName) found!\\\" -ForegroundColor red\\n    }\\n    if($Path.FullName | Select-String \\\"(?i).:\\\\\\\\.*\\\\\\\\.*Pass.*\\\"){\\n      write-host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'pass'\\\"\\n    }\\n    if($Path.FullName | Select-String \\\".:\\\\\\\\.*\\\\\\\\.*user.*\\\" ){\\n      Write-Host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'user' -excluding the 'users' directory\\\"\\n    }\\n    # If path name ends with common excel extensions\\n    elseif ($Path.FullName | Select-String \\\".*\\\\.xls\\\",\\\".*\\\\.xlsm\\\",\\\".*\\\\.xlsx\\\") {\\n      if ($ReadExcel -and $Excel) {\\n        Search-Excel -Source $Path.FullName -SearchText \\\"user\\\"\\n        Search-Excel -Source $Path.FullName -SearchText \\\"pass\\\"\\n      }\\n    }\\n    else {\\n      if ($path.Length -gt 0) {\\n        # Write-Host -ForegroundColor Blue \\\"Path name matches extension search: $path\\\"\\n      }\\n      if ($path.FullName | Select-String \\\"(?i).*SiteList\\\\.xml\\\") {\\n        Write-Host \\\"Possible MCaffee Site List Found: $($_.FullName)\\\"\\n        Write-Host \\\"Just going to leave this here: https://github.com/funoverip/mcafee-sitelist-pwd-decryption\\\" -ForegroundColor Yellow\\n      }\\n      $regexSearch.keys | ForEach-Object {\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\\n    }  \\n  }\", \"{\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\"]}, {\"field\": \"processCmd\", \"type\": \"command_line\", \"value\": \"\\\"C:\\\\Windows\\\\system32\\\\WindowsPowerShell\\\\v1.0\\\\PowerShell_ISE.exe\\\" \"}, {\"field\": \"parentPid\", \"type\": \"process_id\", \"value\": 9920}, {\"field\": \"processPid\", \"type\": \"process_id\", \"value\": 5040}, {\"field\": \"parentCmd\", \"type\": \"command_line\", \"value\": \"C:\\\\Windows\\\\Explorer.EXE\"}], \"mitreTacticIds\": [\"TA0009\"], \"mitreTechniqueIds\": [\"T1005\"], \"riskLevel\": \"low\", \"type\": \"preset\"}, {\"id\": \"F1971\", \"name\": \"Modify File Last Modified Timestamp With PowerShell\", \"description\": \"An attempt to modify file's last modified timestamp using Powershell was detected on an endpoint.\", \"highlightedObjects\": [{\"field\": \"processCmd\", \"type\": \"command_line\", \"value\": \"\\\"C:\\\\Windows\\\\system32\\\\WindowsPowerShell\\\\v1.0\\\\PowerShell_ISE.exe\\\" \"}, {\"field\": \"processPid\", \"type\": \"process_id\", \"value\": 5040}, {\"field\": \"objectRawDataStr\", \"type\": \"amsi_rawDataStr\", \"value\": [\"\\r\\n                                    if ($_.FullyQualifiedErrorId -ne \\\"NativeCommandErrorMessage\\\" -and $ErrorView -ne \\\"CategoryView\\\")\\r\\n                                    {\\r\\n                                        $myinv = $_.InvocationInfo\\r\\n                                        if ($myinv -and $myinv.MyCommand)\\r\\n                                        {\\r\\n                                            switch -regex ( $myinv.MyCommand.CommandType )\\r\\n                                            {\\r\\n                                                ([System.Management.Automation.CommandTypes]::ExternalScript)\\r\\n                                                {\\r\\n                                                    if ($myinv.MyCommand.Path)\\r\\n                                                    {\\r\\n                                                        $myinv.MyCommand.Path + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                                ([System.Management.Automation.CommandTypes]::Script)\\r\\n                                                {\\r\\n                                                    if ($myinv.MyCommand.ScriptBlock)\\r\\n                                                    {\\r\\n                                                        $myinv.MyCommand.ScriptBlock.ToString() + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                                default\\r\\n                                                {\\r\\n                                                    if ($myinv.InvocationName -match '^[&\\\\.]?$')\\r\\n                                                    {\\r\\n                                                        if ($myinv.MyCommand.Name)\\r\\n                                                        {\\r\\n                                                            $myinv.MyCommand.Name + \\\" : \\\"\\r\\n                                                        }\\r\\n                                                    }\\r\\n                                                    else\\r\\n                                                    {\\r\\n                                                        $myinv.InvocationName + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                            }\\r\\n                                        }\\r\\n                                        elseif ($myinv -and $myinv.InvocationName)\\r\\n                                        {\\r\\n                                            $myinv.InvocationName + \\\" : \\\"\\r\\n                                        }\\r\\n                                    }\\r\\n                                \", \"\\r\\n                                   if ($_.FullyQualifiedErrorId -eq \\\"NativeCommandErrorMessage\\\") {\\r\\n                                        $_.Exception.Message   \\r\\n                                   }\\r\\n                                   else\\r\\n                                   {\\r\\n                                        $myinv = $_.InvocationInfo\\r\\n                                        if ($myinv -and ($myinv.MyCommand -or ($_.CategoryInfo.Category -ne 'ParserError'))) {\\r\\n                                            $posmsg = $myinv.PositionMessage\\r\\n                                        } else {\\r\\n                                            $posmsg = \\\"\\\"\\r\\n                                        }\\r\\n                                        \\r\\n                                        if ($posmsg -ne \\\"\\\")\\r\\n                                        {\\r\\n                                            $posmsg = \\\"`n\\\" + $posmsg\\r\\n                                        }\\r\\n    \\t\\t\\t\\t    \\r\\n                                        if ( & { Set-StrictMode -Version 1; $_.PSMessageDetails } ) {\\r\\n                                            $posmsg = \\\" : \\\" +  $_.PSMessageDetails + $posmsg \\r\\n                                        }\\r\\n\\r\\n                                        $indent = 4\\r\\n                                        $width = $host.UI.RawUI.BufferSize.Width - $indent - 2\\r\\n\\r\\n                                        $errorCategoryMsg = & { Set-StrictMode -Version 1; $_.ErrorCategory_Message }\\r\\n                                        if ($errorCategoryMsg -ne $null)\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ CategoryInfo          : \\\" + $_.ErrorCategory_Message\\r\\n                                        }\\r\\n                                        else\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ CategoryInfo          : \\\" + $_.CategoryInfo\\r\\n                                        }\\r\\n                                        $posmsg += \\\"`n\\\"\\r\\n                                        foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n\\r\\n                                        $indentString = \\\"+ FullyQualifiedErrorId : \\\" + $_.FullyQualifiedErrorId\\r\\n                                        $posmsg += \\\"`n\\\"\\r\\n                                        foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n\\r\\n                                        $originInfo = & { Set-StrictMode -Version 1; $_.OriginInfo }\\r\\n                                        if (($originInfo -ne $null) -and ($originInfo.PSComputerName -ne $null))\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ PSComputerName        : \\\" + $originInfo.PSComputerName\\r\\n                                            $posmsg += \\\"`n\\\"\\r\\n                                            foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n                                        }\\r\\n\\r\\n                                        if ($ErrorView -eq \\\"CategoryView\\\") {\\r\\n                                            $_.CategoryInfo.GetMessage()\\r\\n                                        }\\r\\n                                        elseif (! $_.ErrorDetails -or ! $_.ErrorDetails.Message) {\\r\\n                                            $_.Exception.Message + $posmsg + \\\"`n \\\"\\r\\n                                        } else {\\r\\n                                            $_.ErrorDetails.Message + $posmsg\\r\\n                                        }\\r\\n                                   }\\r\\n                                \", \"{ Set-StrictMode -Version 1; $_.PSMessageDetails }\", \"{ Set-StrictMode -Version 1; $_.ErrorCategory_Message }\", \"{ Set-StrictMode -Version 1; $_.OriginInfo }\", \"{\\n    Write-Host $_.FullName\\n  }\", \"\\r\\n                                                  $_.PSParentPath.Replace(\\\"Microsoft.PowerShell.Core\\\\FileSystem::\\\", \\\"\\\")\\r\\n                                              \", \"\\r\\n                                    [String]::Format(\\\"{0,10}  {1,8}\\\", $_.LastWriteTime.ToString(\\\"d\\\"), $_.LastWriteTime.ToString(\\\"t\\\"))\\r\\n                                \", \"if ($_ -is [System.IO.DirectoryInfo]) { return '' }\\r\\nif ($_.Attributes -band [System.IO.FileAttributes]::Offline)\\r\\n{\\r\\n    return '({0})' -f $_.Length\\r\\n}\\r\\nreturn $_.Length\", \"{\\n  if (Test-Path $_) {\\n    Write-Host \\\"$_ found.\\\"\\n  }\\n}\", \"{\\n  if (Test-Path $_ -ErrorAction SilentlyContinue) {\\n    Write-Host \\\"$_ Found!\\\" -ForegroundColor red\\n  }\\n}\", \"{\\n  $Drive = $_\\n  Get-ChildItem $Drive -Recurse -Include $fileExtensions -ErrorAction SilentlyContinue -Force | ForEach-Object {\\n    $path = $_\\n    #Exclude files/folders with 'lang' in the name\\n    if ($Path.FullName | select-string \\\"(?i).*lang.*\\\") {\\n      #Write-Host \\\"$($_.FullName) found!\\\" -ForegroundColor red\\n    }\\n    if($Path.FullName | Select-String \\\"(?i).:\\\\\\\\.*\\\\\\\\.*Pass.*\\\"){\\n      write-host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'pass'\\\"\\n    }\\n    if($Path.FullName | Select-String \\\".:\\\\\\\\.*\\\\\\\\.*user.*\\\" ){\\n      Write-Host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'user' -excluding the 'users' directory\\\"\\n    }\\n    # If path name ends with common excel extensions\\n    elseif ($Path.FullName | Select-String \\\".*\\\\.xls\\\",\\\".*\\\\.xlsm\\\",\\\".*\\\\.xlsx\\\") {\\n      if ($ReadExcel -and $Excel) {\\n        Search-Excel -Source $Path.FullName -SearchText \\\"user\\\"\\n        Search-Excel -Source $Path.FullName -SearchText \\\"pass\\\"\\n      }\\n    }\\n    else {\\n      if ($path.Length -gt 0) {\\n        # Write-Host -ForegroundColor Blue \\\"Path name matches extension search: $path\\\"\\n      }\\n      if ($path.FullName | Select-String \\\"(?i).*SiteList\\\\.xml\\\") {\\n        Write-Host \\\"Possible MCaffee Site List Found: $($_.FullName)\\\"\\n        Write-Host \\\"Just going to leave this here: https://github.com/funoverip/mcafee-sitelist-pwd-decryption\\\" -ForegroundColor Yellow\\n      }\\n      $regexSearch.keys | ForEach-Object {\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\\n    }  \\n  }\\n}\", \"{\\n    $path = $_\\n    #Exclude files/folders with 'lang' in the name\\n    if ($Path.FullName | select-string \\\"(?i).*lang.*\\\") {\\n      #Write-Host \\\"$($_.FullName) found!\\\" -ForegroundColor red\\n    }\\n    if($Path.FullName | Select-String \\\"(?i).:\\\\\\\\.*\\\\\\\\.*Pass.*\\\"){\\n      write-host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'pass'\\\"\\n    }\\n    if($Path.FullName | Select-String \\\".:\\\\\\\\.*\\\\\\\\.*user.*\\\" ){\\n      Write-Host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'user' -excluding the 'users' directory\\\"\\n    }\\n    # If path name ends with common excel extensions\\n    elseif ($Path.FullName | Select-String \\\".*\\\\.xls\\\",\\\".*\\\\.xlsm\\\",\\\".*\\\\.xlsx\\\") {\\n      if ($ReadExcel -and $Excel) {\\n        Search-Excel -Source $Path.FullName -SearchText \\\"user\\\"\\n        Search-Excel -Source $Path.FullName -SearchText \\\"pass\\\"\\n      }\\n    }\\n    else {\\n      if ($path.Length -gt 0) {\\n        # Write-Host -ForegroundColor Blue \\\"Path name matches extension search: $path\\\"\\n      }\\n      if ($path.FullName | Select-String \\\"(?i).*SiteList\\\\.xml\\\") {\\n        Write-Host \\\"Possible MCaffee Site List Found: $($_.FullName)\\\"\\n        Write-Host \\\"Just going to leave this here: https://github.com/funoverip/mcafee-sitelist-pwd-decryption\\\" -ForegroundColor Yellow\\n      }\\n      $regexSearch.keys | ForEach-Object {\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\\n    }  \\n  }\", \"{\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\"]}, {\"field\": \"parentPid\", \"type\": \"process_id\", \"value\": 9920}, {\"field\": \"parentCmd\", \"type\": \"command_line\", \"value\": \"C:\\\\Windows\\\\Explorer.EXE\"}], \"mitreTacticIds\": [\"TA0005\"], \"mitreTechniqueIds\": [\"T1070\", \"T1070.006\"], \"riskLevel\": \"info\", \"type\": \"preset\"}], \"detail\": {\"endpointGuid\": \"9567d4bc-ce0b-45cf-b259-138beb4c80c3\", \"endpointHostName\": \"Windows10\", \"endpointIp\": [\"1802:d896:65fe:0b84:742d:0615:f69b:6600\", \"193.103.164.106\"], \"eventId\": \"11\", \"eventSubId\": 901, \"eventTime\": \"1732639501774\", \"filterRiskLevel\": \"low\", \"firstSeen\": \"1732639501774\", \"groupId\": \"a1c0d757-0961-40a4-8a00-bf9b2922d5de\", \"integrityLevel\": 12288, \"lastSeen\": \"1732639503446\", \"logReceivedTime\": \"1732639512822\", \"logonUser\": [\"jdoe\"], \"objectAppName\": \"PowerShell_C:\\\\Windows\\\\system32\\\\WindowsPowerShell\\\\v1.0\\\\PowerShell_ISE.exe_10.0.19041.1\", \"objectHashId\": \"-1780503710981816722\", \"objectRawDataStr\": [\"\\r\\n                                    if ($_.FullyQualifiedErrorId -ne \\\"NativeCommandErrorMessage\\\" -and $ErrorView -ne \\\"CategoryView\\\")\\r\\n                                    {\\r\\n                                        $myinv = $_.InvocationInfo\\r\\n                                        if ($myinv -and $myinv.MyCommand)\\r\\n                                        {\\r\\n                                            switch -regex ( $myinv.MyCommand.CommandType )\\r\\n                                            {\\r\\n                                                ([System.Management.Automation.CommandTypes]::ExternalScript)\\r\\n                                                {\\r\\n                                                    if ($myinv.MyCommand.Path)\\r\\n                                                    {\\r\\n                                                        $myinv.MyCommand.Path + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                                ([System.Management.Automation.CommandTypes]::Script)\\r\\n                                                {\\r\\n                                                    if ($myinv.MyCommand.ScriptBlock)\\r\\n                                                    {\\r\\n                                                        $myinv.MyCommand.ScriptBlock.ToString() + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                                default\\r\\n                                                {\\r\\n                                                    if ($myinv.InvocationName -match '^[&\\\\.]?$')\\r\\n                                                    {\\r\\n                                                        if ($myinv.MyCommand.Name)\\r\\n                                                        {\\r\\n                                                            $myinv.MyCommand.Name + \\\" : \\\"\\r\\n                                                        }\\r\\n                                                    }\\r\\n                                                    else\\r\\n                                                    {\\r\\n                                                        $myinv.InvocationName + \\\" : \\\"\\r\\n                                                    }\\r\\n                                                    break\\r\\n                                                }\\r\\n                                            }\\r\\n                                        }\\r\\n                                        elseif ($myinv -and $myinv.InvocationName)\\r\\n                                        {\\r\\n                                            $myinv.InvocationName + \\\" : \\\"\\r\\n                                        }\\r\\n                                    }\\r\\n                                \", \"\\r\\n                                   if ($_.FullyQualifiedErrorId -eq \\\"NativeCommandErrorMessage\\\") {\\r\\n                                        $_.Exception.Message   \\r\\n                                   }\\r\\n                                   else\\r\\n                                   {\\r\\n                                        $myinv = $_.InvocationInfo\\r\\n                                        if ($myinv -and ($myinv.MyCommand -or ($_.CategoryInfo.Category -ne 'ParserError'))) {\\r\\n                                            $posmsg = $myinv.PositionMessage\\r\\n                                        } else {\\r\\n                                            $posmsg = \\\"\\\"\\r\\n                                        }\\r\\n                                        \\r\\n                                        if ($posmsg -ne \\\"\\\")\\r\\n                                        {\\r\\n                                            $posmsg = \\\"`n\\\" + $posmsg\\r\\n                                        }\\r\\n    \\t\\t\\t\\t    \\r\\n                                        if ( & { Set-StrictMode -Version 1; $_.PSMessageDetails } ) {\\r\\n                                            $posmsg = \\\" : \\\" +  $_.PSMessageDetails + $posmsg \\r\\n                                        }\\r\\n\\r\\n                                        $indent = 4\\r\\n                                        $width = $host.UI.RawUI.BufferSize.Width - $indent - 2\\r\\n\\r\\n                                        $errorCategoryMsg = & { Set-StrictMode -Version 1; $_.ErrorCategory_Message }\\r\\n                                        if ($errorCategoryMsg -ne $null)\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ CategoryInfo          : \\\" + $_.ErrorCategory_Message\\r\\n                                        }\\r\\n                                        else\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ CategoryInfo          : \\\" + $_.CategoryInfo\\r\\n                                        }\\r\\n                                        $posmsg += \\\"`n\\\"\\r\\n                                        foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n\\r\\n                                        $indentString = \\\"+ FullyQualifiedErrorId : \\\" + $_.FullyQualifiedErrorId\\r\\n                                        $posmsg += \\\"`n\\\"\\r\\n                                        foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n\\r\\n                                        $originInfo = & { Set-StrictMode -Version 1; $_.OriginInfo }\\r\\n                                        if (($originInfo -ne $null) -and ($originInfo.PSComputerName -ne $null))\\r\\n                                        {\\r\\n                                            $indentString = \\\"+ PSComputerName        : \\\" + $originInfo.PSComputerName\\r\\n                                            $posmsg += \\\"`n\\\"\\r\\n                                            foreach($line in @($indentString -split \\\"(.{$width})\\\")) { if($line) { $posmsg += (\\\" \\\" * $indent + $line) } }\\r\\n                                        }\\r\\n\\r\\n                                        if ($ErrorView -eq \\\"CategoryView\\\") {\\r\\n                                            $_.CategoryInfo.GetMessage()\\r\\n                                        }\\r\\n                                        elseif (! $_.ErrorDetails -or ! $_.ErrorDetails.Message) {\\r\\n                                            $_.Exception.Message + $posmsg + \\\"`n \\\"\\r\\n                                        } else {\\r\\n                                            $_.ErrorDetails.Message + $posmsg\\r\\n                                        }\\r\\n                                   }\\r\\n                                \", \"{ Set-StrictMode -Version 1; $_.PSMessageDetails }\", \"{ Set-StrictMode -Version 1; $_.ErrorCategory_Message }\", \"{ Set-StrictMode -Version 1; $_.OriginInfo }\", \"{\\n    Write-Host $_.FullName\\n  }\", \"\\r\\n                                                  $_.PSParentPath.Replace(\\\"Microsoft.PowerShell.Core\\\\FileSystem::\\\", \\\"\\\")\\r\\n                                              \", \"\\r\\n                                    [String]::Format(\\\"{0,10}  {1,8}\\\", $_.LastWriteTime.ToString(\\\"d\\\"), $_.LastWriteTime.ToString(\\\"t\\\"))\\r\\n                                \", \"if ($_ -is [System.IO.DirectoryInfo]) { return '' }\\r\\nif ($_.Attributes -band [System.IO.FileAttributes]::Offline)\\r\\n{\\r\\n    return '({0})' -f $_.Length\\r\\n}\\r\\nreturn $_.Length\", \"{\\n  if (Test-Path $_) {\\n    Write-Host \\\"$_ found.\\\"\\n  }\\n}\", \"{\\n  if (Test-Path $_ -ErrorAction SilentlyContinue) {\\n    Write-Host \\\"$_ Found!\\\" -ForegroundColor red\\n  }\\n}\", \"{\\n  $Drive = $_\\n  Get-ChildItem $Drive -Recurse -Include $fileExtensions -ErrorAction SilentlyContinue -Force | ForEach-Object {\\n    $path = $_\\n    #Exclude files/folders with 'lang' in the name\\n    if ($Path.FullName | select-string \\\"(?i).*lang.*\\\") {\\n      #Write-Host \\\"$($_.FullName) found!\\\" -ForegroundColor red\\n    }\\n    if($Path.FullName | Select-String \\\"(?i).:\\\\\\\\.*\\\\\\\\.*Pass.*\\\"){\\n      write-host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'pass'\\\"\\n    }\\n    if($Path.FullName | Select-String \\\".:\\\\\\\\.*\\\\\\\\.*user.*\\\" ){\\n      Write-Host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'user' -excluding the 'users' directory\\\"\\n    }\\n    # If path name ends with common excel extensions\\n    elseif ($Path.FullName | Select-String \\\".*\\\\.xls\\\",\\\".*\\\\.xlsm\\\",\\\".*\\\\.xlsx\\\") {\\n      if ($ReadExcel -and $Excel) {\\n        Search-Excel -Source $Path.FullName -SearchText \\\"user\\\"\\n        Search-Excel -Source $Path.FullName -SearchText \\\"pass\\\"\\n      }\\n    }\\n    else {\\n      if ($path.Length -gt 0) {\\n        # Write-Host -ForegroundColor Blue \\\"Path name matches extension search: $path\\\"\\n      }\\n      if ($path.FullName | Select-String \\\"(?i).*SiteList\\\\.xml\\\") {\\n        Write-Host \\\"Possible MCaffee Site List Found: $($_.FullName)\\\"\\n        Write-Host \\\"Just going to leave this here: https://github.com/funoverip/mcafee-sitelist-pwd-decryption\\\" -ForegroundColor Yellow\\n      }\\n      $regexSearch.keys | ForEach-Object {\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\\n    }  \\n  }\\n}\", \"{\\n    $path = $_\\n    #Exclude files/folders with 'lang' in the name\\n    if ($Path.FullName | select-string \\\"(?i).*lang.*\\\") {\\n      #Write-Host \\\"$($_.FullName) found!\\\" -ForegroundColor red\\n    }\\n    if($Path.FullName | Select-String \\\"(?i).:\\\\\\\\.*\\\\\\\\.*Pass.*\\\"){\\n      write-host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'pass'\\\"\\n    }\\n    if($Path.FullName | Select-String \\\".:\\\\\\\\.*\\\\\\\\.*user.*\\\" ){\\n      Write-Host -ForegroundColor Blue \\\"$($path.FullName) contains the word 'user' -excluding the 'users' directory\\\"\\n    }\\n    # If path name ends with common excel extensions\\n    elseif ($Path.FullName | Select-String \\\".*\\\\.xls\\\",\\\".*\\\\.xlsm\\\",\\\".*\\\\.xlsx\\\") {\\n      if ($ReadExcel -and $Excel) {\\n        Search-Excel -Source $Path.FullName -SearchText \\\"user\\\"\\n        Search-Excel -Source $Path.FullName -SearchText \\\"pass\\\"\\n      }\\n    }\\n    else {\\n      if ($path.Length -gt 0) {\\n        # Write-Host -ForegroundColor Blue \\\"Path name matches extension search: $path\\\"\\n      }\\n      if ($path.FullName | Select-String \\\"(?i).*SiteList\\\\.xml\\\") {\\n        Write-Host \\\"Possible MCaffee Site List Found: $($_.FullName)\\\"\\n        Write-Host \\\"Just going to leave this here: https://github.com/funoverip/mcafee-sitelist-pwd-decryption\\\" -ForegroundColor Yellow\\n      }\\n      $regexSearch.keys | ForEach-Object {\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\\n    }  \\n  }\", \"{\\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\\n        if ($passwordFound) {\\n          Write-Host \\\"Possible Password found: $_\\\" -ForegroundColor Yellow\\n          Write-Host $Path.FullName\\n          Write-Host -ForegroundColor Blue \\\"$_ triggered\\\"\\n          Write-Host $passwordFound -ForegroundColor Red\\n        }\\n      }\"], \"osDescription\": \"Windows 10 Pro (64 bit) build 19045\", \"parentCmd\": \"C:\\\\Windows\\\\Explorer.EXE\", \"parentFileHashId\": \"1767110345653159701\", \"parentFileHashMd5\": \"f8ad78f2ad64799786242d69ef77edd7\", \"parentFileHashSha1\": \"f021ca2dca81ee77aa80467096a804a26cd11364\", \"parentFileHashSha256\": \"f2e4604dfae18859b13a4efee601df6937e99dd96251c11205c30022b308868f\", \"parentFilePath\": \"C:\\\\Windows\\\\explorer.exe\", \"parentHashId\": \"999588025188847480\", \"parentIntegrityLevel\": 12288, \"parentLaunchTime\": \"1732638953785\", \"parentName\": \"C:\\\\Windows\\\\explorer.exe\", \"parentPid\": 9920, \"parentSigner\": [\"Microsoft Windows\"], \"parentSignerValid\": [true], \"parentTrueType\": 7, \"parentUser\": \"jdoe\", \"parentUserDomain\": \"Windows10\", \"pname\": \"751\", \"processCmd\": \"\\\"C:\\\\Windows\\\\system32\\\\WindowsPowerShell\\\\v1.0\\\\PowerShell_ISE.exe\\\" \", \"processFileHashId\": \"-4900073020808934214\", \"processFileHashMd5\": \"bd5cf4568d83088240e3b33f9f9838b1\", \"processFileHashSha1\": \"b1692a60d67dc55538f9a25ad3874a6a8f6bb089\", \"processFileHashSha256\": \"4388c298be8260741724ebf8b414ca063247d6a0d5d5aa5318f90edda3189cd2\", \"processFilePath\": \"C:\\\\Windows\\\\System32\\\\WindowsPowerShell\\\\v1.0\\\\powershell_ise.exe\", \"processHashId\": \"-5529997575794356190\", \"processLaunchTime\": \"1732639075967\", \"processName\": \"C:\\\\Windows\\\\System32\\\\WindowsPowerShell\\\\v1.0\\\\powershell_ise.exe\", \"processPid\": 5040, \"processSigner\": [\"Microsoft Windows\"], \"processSignerValid\": [true], \"processTrueType\": 7, \"processUser\": \"jdoe\", \"processUserDomain\": \"Windows10\", \"productCode\": \"xes\", \"tags\": [\"XSAE.F1971\", \"XSAE.F3367\", \"MITRE.T1005\", \"MITRE.T1070.006\", \"MITRE.T1070\"], \"uuid\": \"b2ece961-6eed-43f1-8890-a8d926840049\", \"plang\": 1, \"pver\": \"1.2.0.5608\", \"processSignerFlagsLibValid\": [false], \"eventHashId\": \"7588760429245659303\", \"processFileSize\": \"212992\", \"eventSourceType\": 1, \"processSignerFlagsAdhoc\": [false], \"objectFirstSeen\": \"1732639501774\", \"processFileModifiedTime\": \"1575651900000\", \"pplat\": 5889, \"processSignerFlagsRuntime\": [false], \"timezone\": \"UTC+00:00\", \"osVer\": \"10.0.19045\", \"authId\": \"1494147\", \"endpointMacAddress\": [\"8f:86:c0:d8:9d:ad\"], \"osType\": \"0x00000030\", \"processFileCreation\": \"1575712305614\", \"userDomain\": [\"Windows10\"], \"sessionId\": 2, \"osName\": \"Windows\", \"objectLastSeen\": \"1732639503446\", \"parentSignerFlagsLibValid\": [false], \"parentFileCreation\": \"1728117061706\", \"parentSessionId\": 2, \"parentFileModifiedTime\": \"1728117061831\", \"parentSignerFlagsAdhoc\": [false], \"parentAuthId\": \"1494147\", \"parentSignerFlagsRuntime\": [false], \"parentFileSize\": \"5845320\", \"objectSessionId\": \"19746\", \"objectRawDataSize\": [\"2995\", \"3802\", \"50\", \"55\", \"44\", \"32\", \"169\", \"169\", \"170\", \"56\", \"107\", \"1848\", \"1719\", \"411\"]}, \"ingestedDateTime\": \"2024-11-26T16:45:25Z\", \"entityType\": \"endpoint\", \"entityName\": \"Windows10(1802:d896:65fe:0b84:742d:0615:f69b:6600,193.103.164.106)\", \"endpoint\": {\"ips\": [\"1802:d896:65fe:0b84:742d:0615:f69b:6600\", \"193.103.164.106\"], \"agentGuid\": \"8e53268d-8348-4fd4-a314-b742448960c9\", \"endpointName\": \"Windows10\"}}",
    "event": {
        "category": [
            "intrusion_detection"
        ],
        "end": "2024-11-26T16:45:03.446000Z",
        "start": "2024-11-26T16:45:01.774000Z",
        "type": [
            "info"
        ]
    },
    "@timestamp": "2024-11-26T16:45:01Z",
    "action": {
        "properties": {
            "ScriptBlockText": [
                "\r\n                                                  $_.PSParentPath.Replace(\"Microsoft.PowerShell.Core\\FileSystem::\", \"\")\r\n                                              ",
                "\r\n                                    [String]::Format(\"{0,10}  {1,8}\", $_.LastWriteTime.ToString(\"d\"), $_.LastWriteTime.ToString(\"t\"))\r\n                                ",
                "\r\n                                    if ($_.FullyQualifiedErrorId -ne \"NativeCommandErrorMessage\" -and $ErrorView -ne \"CategoryView\")\r\n                                    {\r\n                                        $myinv = $_.InvocationInfo\r\n                                        if ($myinv -and $myinv.MyCommand)\r\n                                        {\r\n                                            switch -regex ( $myinv.MyCommand.CommandType )\r\n                                            {\r\n                                                ([System.Management.Automation.CommandTypes]::ExternalScript)\r\n                                                {\r\n                                                    if ($myinv.MyCommand.Path)\r\n                                                    {\r\n                                                        $myinv.MyCommand.Path + \" : \"\r\n                                                    }\r\n                                                    break\r\n                                                }\r\n                                                ([System.Management.Automation.CommandTypes]::Script)\r\n                                                {\r\n                                                    if ($myinv.MyCommand.ScriptBlock)\r\n                                                    {\r\n                                                        $myinv.MyCommand.ScriptBlock.ToString() + \" : \"\r\n                                                    }\r\n                                                    break\r\n                                                }\r\n                                                default\r\n                                                {\r\n                                                    if ($myinv.InvocationName -match '^[&\\.]?$')\r\n                                                    {\r\n                                                        if ($myinv.MyCommand.Name)\r\n                                                        {\r\n                                                            $myinv.MyCommand.Name + \" : \"\r\n                                                        }\r\n                                                    }\r\n                                                    else\r\n                                                    {\r\n                                                        $myinv.InvocationName + \" : \"\r\n                                                    }\r\n                                                    break\r\n                                                }\r\n                                            }\r\n                                        }\r\n                                        elseif ($myinv -and $myinv.InvocationName)\r\n                                        {\r\n                                            $myinv.InvocationName + \" : \"\r\n                                        }\r\n                                    }\r\n                                ",
                "\r\n                                   if ($_.FullyQualifiedErrorId -eq \"NativeCommandErrorMessage\") {\r\n                                        $_.Exception.Message   \r\n                                   }\r\n                                   else\r\n                                   {\r\n                                        $myinv = $_.InvocationInfo\r\n                                        if ($myinv -and ($myinv.MyCommand -or ($_.CategoryInfo.Category -ne 'ParserError'))) {\r\n                                            $posmsg = $myinv.PositionMessage\r\n                                        } else {\r\n                                            $posmsg = \"\"\r\n                                        }\r\n                                        \r\n                                        if ($posmsg -ne \"\")\r\n                                        {\r\n                                            $posmsg = \"`n\" + $posmsg\r\n                                        }\r\n    \t\t\t\t    \r\n                                        if ( & { Set-StrictMode -Version 1; $_.PSMessageDetails } ) {\r\n                                            $posmsg = \" : \" +  $_.PSMessageDetails + $posmsg \r\n                                        }\r\n\r\n                                        $indent = 4\r\n                                        $width = $host.UI.RawUI.BufferSize.Width - $indent - 2\r\n\r\n                                        $errorCategoryMsg = & { Set-StrictMode -Version 1; $_.ErrorCategory_Message }\r\n                                        if ($errorCategoryMsg -ne $null)\r\n                                        {\r\n                                            $indentString = \"+ CategoryInfo          : \" + $_.ErrorCategory_Message\r\n                                        }\r\n                                        else\r\n                                        {\r\n                                            $indentString = \"+ CategoryInfo          : \" + $_.CategoryInfo\r\n                                        }\r\n                                        $posmsg += \"`n\"\r\n                                        foreach($line in @($indentString -split \"(.{$width})\")) { if($line) { $posmsg += (\" \" * $indent + $line) } }\r\n\r\n                                        $indentString = \"+ FullyQualifiedErrorId : \" + $_.FullyQualifiedErrorId\r\n                                        $posmsg += \"`n\"\r\n                                        foreach($line in @($indentString -split \"(.{$width})\")) { if($line) { $posmsg += (\" \" * $indent + $line) } }\r\n\r\n                                        $originInfo = & { Set-StrictMode -Version 1; $_.OriginInfo }\r\n                                        if (($originInfo -ne $null) -and ($originInfo.PSComputerName -ne $null))\r\n                                        {\r\n                                            $indentString = \"+ PSComputerName        : \" + $originInfo.PSComputerName\r\n                                            $posmsg += \"`n\"\r\n                                            foreach($line in @($indentString -split \"(.{$width})\")) { if($line) { $posmsg += (\" \" * $indent + $line) } }\r\n                                        }\r\n\r\n                                        if ($ErrorView -eq \"CategoryView\") {\r\n                                            $_.CategoryInfo.GetMessage()\r\n                                        }\r\n                                        elseif (! $_.ErrorDetails -or ! $_.ErrorDetails.Message) {\r\n                                            $_.Exception.Message + $posmsg + \"`n \"\r\n                                        } else {\r\n                                            $_.ErrorDetails.Message + $posmsg\r\n                                        }\r\n                                   }\r\n                                ",
                "if ($_ -is [System.IO.DirectoryInfo]) { return '' }\r\nif ($_.Attributes -band [System.IO.FileAttributes]::Offline)\r\n{\r\n    return '({0})' -f $_.Length\r\n}\r\nreturn $_.Length",
                "{\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\n        if ($passwordFound) {\n          Write-Host \"Possible Password found: $_\" -ForegroundColor Yellow\n          Write-Host $Path.FullName\n          Write-Host -ForegroundColor Blue \"$_ triggered\"\n          Write-Host $passwordFound -ForegroundColor Red\n        }\n      }",
                "{\n    $path = $_\n    #Exclude files/folders with 'lang' in the name\n    if ($Path.FullName | select-string \"(?i).*lang.*\") {\n      #Write-Host \"$($_.FullName) found!\" -ForegroundColor red\n    }\n    if($Path.FullName | Select-String \"(?i).:\\\\.*\\\\.*Pass.*\"){\n      write-host -ForegroundColor Blue \"$($path.FullName) contains the word 'pass'\"\n    }\n    if($Path.FullName | Select-String \".:\\\\.*\\\\.*user.*\" ){\n      Write-Host -ForegroundColor Blue \"$($path.FullName) contains the word 'user' -excluding the 'users' directory\"\n    }\n    # If path name ends with common excel extensions\n    elseif ($Path.FullName | Select-String \".*\\.xls\",\".*\\.xlsm\",\".*\\.xlsx\") {\n      if ($ReadExcel -and $Excel) {\n        Search-Excel -Source $Path.FullName -SearchText \"user\"\n        Search-Excel -Source $Path.FullName -SearchText \"pass\"\n      }\n    }\n    else {\n      if ($path.Length -gt 0) {\n        # Write-Host -ForegroundColor Blue \"Path name matches extension search: $path\"\n      }\n      if ($path.FullName | Select-String \"(?i).*SiteList\\.xml\") {\n        Write-Host \"Possible MCaffee Site List Found: $($_.FullName)\"\n        Write-Host \"Just going to leave this here: https://github.com/funoverip/mcafee-sitelist-pwd-decryption\" -ForegroundColor Yellow\n      }\n      $regexSearch.keys | ForEach-Object {\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\n        if ($passwordFound) {\n          Write-Host \"Possible Password found: $_\" -ForegroundColor Yellow\n          Write-Host $Path.FullName\n          Write-Host -ForegroundColor Blue \"$_ triggered\"\n          Write-Host $passwordFound -ForegroundColor Red\n        }\n      }\n    }  \n  }",
                "{\n    Write-Host $_.FullName\n  }",
                "{\n  $Drive = $_\n  Get-ChildItem $Drive -Recurse -Include $fileExtensions -ErrorAction SilentlyContinue -Force | ForEach-Object {\n    $path = $_\n    #Exclude files/folders with 'lang' in the name\n    if ($Path.FullName | select-string \"(?i).*lang.*\") {\n      #Write-Host \"$($_.FullName) found!\" -ForegroundColor red\n    }\n    if($Path.FullName | Select-String \"(?i).:\\\\.*\\\\.*Pass.*\"){\n      write-host -ForegroundColor Blue \"$($path.FullName) contains the word 'pass'\"\n    }\n    if($Path.FullName | Select-String \".:\\\\.*\\\\.*user.*\" ){\n      Write-Host -ForegroundColor Blue \"$($path.FullName) contains the word 'user' -excluding the 'users' directory\"\n    }\n    # If path name ends with common excel extensions\n    elseif ($Path.FullName | Select-String \".*\\.xls\",\".*\\.xlsm\",\".*\\.xlsx\") {\n      if ($ReadExcel -and $Excel) {\n        Search-Excel -Source $Path.FullName -SearchText \"user\"\n        Search-Excel -Source $Path.FullName -SearchText \"pass\"\n      }\n    }\n    else {\n      if ($path.Length -gt 0) {\n        # Write-Host -ForegroundColor Blue \"Path name matches extension search: $path\"\n      }\n      if ($path.FullName | Select-String \"(?i).*SiteList\\.xml\") {\n        Write-Host \"Possible MCaffee Site List Found: $($_.FullName)\"\n        Write-Host \"Just going to leave this here: https://github.com/funoverip/mcafee-sitelist-pwd-decryption\" -ForegroundColor Yellow\n      }\n      $regexSearch.keys | ForEach-Object {\n        $passwordFound = Get-Content $path.FullName -ErrorAction SilentlyContinue -Force | Select-String $regexSearch[$_] -Context 1, 1\n        if ($passwordFound) {\n          Write-Host \"Possible Password found: $_\" -ForegroundColor Yellow\n          Write-Host $Path.FullName\n          Write-Host -ForegroundColor Blue \"$_ triggered\"\n          Write-Host $passwordFound -ForegroundColor Red\n        }\n      }\n    }  \n  }\n}",
                "{\n  if (Test-Path $_ -ErrorAction SilentlyContinue) {\n    Write-Host \"$_ Found!\" -ForegroundColor red\n  }\n}",
                "{\n  if (Test-Path $_) {\n    Write-Host \"$_ found.\"\n  }\n}",
                "{ Set-StrictMode -Version 1; $_.ErrorCategory_Message }",
                "{ Set-StrictMode -Version 1; $_.OriginInfo }",
                "{ Set-StrictMode -Version 1; $_.PSMessageDetails }"
            ]
        }
    },
    "agent": {
        "id": "8e53268d-8348-4fd4-a314-b742448960c9"
    },
    "group": {
        "id": "a1c0d757-0961-40a4-8a00-bf9b2922d5de"
    },
    "host": {
        "id": "9567d4bc-ce0b-45cf-b259-138beb4c80c3",
        "ip": [
            "1802:d896:65fe:b84:742d:615:f69b:6600",
            "193.103.164.106"
        ],
        "name": "Windows10",
        "os": {
            "full": "Windows 10 Pro (64 bit) build 19045",
            "name": "Windows",
            "version": "10.0.19045"
        }
    },
    "observer": {
        "product": "Vision One",
        "vendor": "TrendMicro"
    },
    "process": {
        "name": "powershell_ise.exe",
        "parent": {
            "command_line": "\"C:\\Windows\\system32\\WindowsPowerShell\\v1.0\\PowerShell_ISE.exe\" ",
            "executable": "C:\\Windows\\System32\\WindowsPowerShell\\v1.0\\powershell_ise.exe",
            "hash": {
                "md5": "bd5cf4568d83088240e3b33f9f9838b1",
                "sha1": "b1692a60d67dc55538f9a25ad3874a6a8f6bb089",
                "sha256": "4388c298be8260741724ebf8b414ca063247d6a0d5d5aa5318f90edda3189cd2"
            },
            "parent": {
                "command_line": "C:\\Windows\\Explorer.EXE",
                "executable": "C:\\Windows\\explorer.exe",
                "hash": {
                    "md5": "f8ad78f2ad64799786242d69ef77edd7",
                    "sha1": "f021ca2dca81ee77aa80467096a804a26cd11364",
                    "sha256": "f2e4604dfae18859b13a4efee601df6937e99dd96251c11205c30022b308868f"
                },
                "name": "explorer.exe",
                "pid": "9920",
                "start": "2024-11-26T16:35:53.785000Z",
                "user": {
                    "domain": "Windows10",
                    "name": "jdoe"
                }
            },
            "pid": 5040,
            "start": "2024-11-26T16:37:55.967000Z",
            "user": {
                "domain": "Windows10",
                "name": "jdoe"
            }
        }
    },
    "related": {
        "hash": [
            "4388c298be8260741724ebf8b414ca063247d6a0d5d5aa5318f90edda3189cd2",
            "b1692a60d67dc55538f9a25ad3874a6a8f6bb089",
            "bd5cf4568d83088240e3b33f9f9838b1"
        ],
        "ip": [
            "1802:d896:65fe:b84:742d:615:f69b:6600",
            "193.103.164.106"
        ]
    },
    "threat": {
        "tactic": {
            "id": [
                "TA0005",
                "TA0009"
            ]
        },
        "technique": {
            "id": [
                "T1005",
                "T1070"
            ],
            "subtechnique": {
                "id": [
                    "T1070.006"
                ]
            }
        }
    }
}

Extracted Fields

The following table lists the fields that are extracted, normalized under the ECS format, analyzed and indexed by the parser. It should be noted that infered fields are not listed.

Name Type Description
@timestamp date Date/time when the event originated.
action.properties.ScriptBlockText keyword
agent.id keyword Unique identifier of this agent.
event.category keyword Event category. The second categorization field in the hierarchy.
event.end date event.end contains the date when the event ended or when the activity was last observed.
event.start date event.start contains the date when the event started or when the activity was first observed.
event.type keyword Event type. The third categorization field in the hierarchy.
group.id keyword Unique identifier for the group on the system/platform.
host.id keyword Unique host id.
host.ip ip Host ip addresses.
host.name keyword Name of the host.
host.os.full keyword Operating system name, including the version or code name.
host.os.name keyword Operating system name, without the version.
host.os.version keyword Operating system version as a raw string.
observer.product keyword The product name of the observer.
observer.vendor keyword Vendor name of the observer.
process.command_line wildcard Full command line that started the process.
process.executable keyword Absolute path to the process executable.
process.hash.md5 keyword MD5 hash.
process.hash.sha1 keyword SHA1 hash.
process.hash.sha256 keyword SHA256 hash.
process.name keyword Process name.
process.parent.command_line wildcard Full command line that started the process.
process.parent.executable keyword Absolute path to the process executable.
process.parent.hash.md5 keyword MD5 hash.
process.parent.hash.sha1 keyword SHA1 hash.
process.parent.hash.sha256 keyword SHA256 hash.
process.parent.parent.command_line keyword
process.parent.parent.executable keyword
process.parent.parent.hash.md5 keyword
process.parent.parent.hash.sha1 keyword
process.parent.parent.hash.sha256 keyword
process.parent.parent.name keyword
process.parent.parent.pid keyword
process.parent.parent.start datetime
process.parent.parent.user.domain keyword
process.parent.parent.user.name keyword
process.parent.pid long Process id.
process.parent.start date The time the process started.
process.parent.user.domain keyword
process.pid long Process id.
threat.tactic.id keyword Threat tactic id.
threat.technique.id keyword Threat technique id.
threat.technique.subtechnique.id keyword Threat subtechnique id.
user.domain keyword Name of the directory the user is a member of.
user.name keyword Short name or login of the user.

For more information on the Intake Format, please find the code of the Parser, Smart Descriptions, and Supported Events here.