Illusive ADS solution files modified

This commit is contained in:
Devika Mehra 2022-05-19 14:42:52 +05:30
Родитель 9dde14a805
Коммит 3ce1baba2b
4 изменённых файлов: 140 добавлений и 137 удалений

Просмотреть файл

@ -1,134 +1,134 @@
{
"id": "illusiveAttackManagementSystem",
"title": "Illusive Attack Management System",
"publisher": "illusive",
"descriptionMarkdown": "The Illusive Attack Management System Connector allows you to share Illusive's attack surface analysis data and incident logs with Azure Sentinel and view this information in dedicated dashboards that offer insight into your organization's attack surface risk (ASM Dashboard) and track unauthorized lateral movement in your organization's network (ADS Dashboard).",
"graphQueries": [
{
"metricName": "Total data received",
"legend": "illusive",
"baseQuery": "\nCommonSecurityLog\n| where DeviceVendor == \"illusive\"\n| where DeviceProduct == \"illusive\"\n"
}
],
"sampleQueries": [
{
"description" : "Number of Incidents in in the last 30 days in which Trigger Type is found",
"query": "union CommonSecurityLog | where (DeviceEventClassID == \"illusive:login\" or DeviceEventClassID == \"illusive:access\" or DeviceEventClassID == \"illusive:suspicious\")| where Message !contains \"hasForensics\" | where TimeGenerated > ago(30d) | summarize by DestinationServiceName ,DeviceCustomNumber2 | summarize incident_count=count() by DestinationServiceName"
},
{
"description" : "Top 10 alerting hosts in the last 30 days",
"query": "union CommonSecurityLog | where (DeviceEventClassID == \"illusive:login\" or DeviceEventClassID == \"illusive:access\" or DeviceEventClassID == \"illusive:suspicious\")| where Message !contains \"hasForensics\" | where TimeGenerated > ago(30d) | summarize by AlertingHost=iff(SourceHostName != \"\" and SourceHostName != \"Failed to obtain\", SourceHostName, SourceIP) ,DeviceCustomNumber2 | where AlertingHost != \"\" and AlertingHost != \"Failed to obtain\" | summarize incident_count=count() by AlertingHost | order by incident_count | limit 10"
}
],
"dataTypes": [
{
"name": "CommonSecurityLog (illusive)",
"lastDataReceivedQuery": "\nCommonSecurityLog\n| where DeviceVendor == \"illusive\"\n| where DeviceProduct == \"illusive\"\n\n | summarize Time = max(TimeGenerated)\n | where isnotempty(Time)"
}
],
"connectivityCriterias": [
{
"type": "IsConnectedQuery",
"value": [
"\nCommonSecurityLog\n| where DeviceVendor == \"illusive\"\n| where DeviceProduct == \"illusive\"\n\n | summarize LastLogReceived = max(TimeGenerated)\n | project IsConnected = LastLogReceived > ago(30d)"
]
}
],
"availability": {
"status": 1,
"isPreview": true
},
"permissions": {
"resourceProvider": [
{
"provider": "Microsoft.OperationalInsights/workspaces",
"permissionsDisplayText": "read and write permissions are required.",
"providerDisplayName": "Workspace",
"scope": "Workspace",
"requiredPermissions": {
"read": true,
"write": true,
"delete": true
}
},
{
"provider": "Microsoft.OperationalInsights/workspaces/sharedKeys",
"permissionsDisplayText": "read permissions to shared keys for the workspace are required. [See the documentation to learn more about workspace keys](https://docs.microsoft.com/azure/azure-monitor/platform/agent-windows#obtain-workspace-id-and-key).",
"providerDisplayName": "Keys",
"scope": "Workspace",
"requiredPermissions": {
"action": true
}
}
]
},
"instructionSteps": [
{
"title": "1. Linux Syslog agent configuration",
"description": "Install and configure the Linux agent to collect your Common Event Format (CEF) Syslog messages and forward them to Azure Sentinel.\n\n> Notice that the data from all regions will be stored in the selected workspace",
"innerSteps": [
{
"title": "1.1 Select or create a Linux machine",
"description": "Select or create a Linux machine that Azure Sentinel will use as the proxy between your security solution and Azure Sentinel this machine can be on your on-prem environment, Azure or other clouds."
},
{
"title": "1.2 Install the CEF collector on the Linux machine",
"description": "Install the Microsoft Monitoring Agent on your Linux machine and configure the machine to listen on the necessary port and forward messages to your Azure Sentinel workspace. The CEF collector collects CEF messages on port 514 TCP.\n\n> 1. Make sure that you have Python on your machine using the following command: python -version.\n\n> 2. You must have elevated permissions (sudo) on your machine.",
"instructions": [
{
"parameters": {
"fillWith": [
"WorkspaceId",
"PrimaryKey"
],
"label": "Run the following command to install and apply the CEF collector:",
"value": "sudo wget -O cef_installer.py https://raw.githubusercontent.com/Azure/Azure-Sentinel/master/DataConnectors/CEF/cef_installer.py&&sudo python cef_installer.py {0} {1}"
},
"type": "CopyableLabel"
}
]
}
]
},
{
"title": "2. Forward Illusive Common Event Format (CEF) logs to Syslog agent",
"description": "1. Set your security solution to send Syslog messages in CEF format to the proxy machine. Make sure you to send the logs to port 514 TCP on the machine's IP address.\n> 2. Log onto the Illusive Console, and navigate to Settings->Reporting.\n> 3. Find Syslog Servers\n> 4. Supply the following information:\n>> 1. Host name: Linux Syslog agent IP address or FQDN host name\n>> 2. Port: 514\n>> 3. Protocol: TCP\n>> 4. Audit messages: Send audit messages to server\n> 5. To add the syslog server, click Add.\n> 6. For more information about how to add a new syslog server in the Illusive platform, please find the Illusive Networks Admin Guide in here: https://support.illusivenetworks.com/hc/en-us/sections/360002292119-Documentation-by-Version"
},
{
"title": "3. Validate connection",
"description": "Follow the instructions to validate your connectivity:\n\nOpen Log Analytics to check if the logs are received using the CommonSecurityLog schema.\n\n>It may take about 20 minutes until the connection streams data to your workspace.\n\nIf the logs are not received, run the following connectivity validation script:\n\n> 1. Make sure that you have Python on your machine using the following command: python -version\n\n>2. You must have elevated permissions (sudo) on your machine",
"instructions": [
{
"parameters": {
"fillWith": [
"WorkspaceId"
],
"label": "Run the following command to validate your connectivity:",
"value": "sudo wget O cef_troubleshoot.py https://raw.githubusercontent.com/Azure/Azure-Sentinel/master/DataConnectors/CEF/cef_troubleshoot.py&&sudo python cef_troubleshoot.py {0}"
},
"type": "CopyableLabel"
}
]
},
{
"title": "4. Secure your machine ",
"description": "Make sure to configure the machine's security according to your organization's security policy\n\n\n[Learn more >](https://aka.ms/SecureCEF)"
}
],
"metadata": {
"id": "aa770f1e-4d05-477a-8dc1-b893772f3a46",
"version": "1.0.0",
"kind": "dataConnector",
"source": {
"kind": "community"
},
"author": {
"name": "Illusive Networks"
},
"support": {
"name": "Illusive Networks",
"link": "https://www.illusivenetworks.com/technical-support/",
"tier": "developer"
}
"id": "illusiveAttackManagementSystem",
"title": "Illusive Attack Management System",
"publisher": "illusive",
"descriptionMarkdown": "The Illusive Attack Management System Connector allows you to share Illusive's attack surface analysis data and incident logs with Azure Sentinel and view this information in dedicated dashboards that offer insight into your organization's attack surface risk (ASM Dashboard) and track unauthorized lateral movement in your organization's network (ADS Dashboard).",
"graphQueries": [
{
"metricName": "Total data received",
"legend": "illusive",
"baseQuery": "\nCommonSecurityLog\n| where DeviceVendor == \"illusive\"\n| where DeviceProduct == \"illusive\"\n"
}
}
],
"sampleQueries": [
{
"description": "Number of Incidents in in the last 30 days in which Trigger Type is found",
"query": "union CommonSecurityLog\r\n| where (DeviceEventClassID == \"illusive:login\" or DeviceEventClassID == \"illusive:access\" or DeviceEventClassID == \"illusive:suspicious\")\r\n| where Message !contains \"hasForensics\" \r\n| where TimeGenerated > ago(30d) \r\n| extend DeviceCustomNumber2 = coalesce(column_ifexists(\"FieldDeviceCustomNumber2\", long(null)), DeviceCustomNumber2, long(null))\r\n| summarize by DestinationServiceName, DeviceCustomNumber2 \r\n| summarize incident_count=count() by DestinationServiceName"
},
{
"description": "Top 10 alerting hosts in the last 30 days",
"query": "union CommonSecurityLog \r\n| where (DeviceEventClassID == \"illusive:login\" or DeviceEventClassID == \"illusive:access\" or DeviceEventClassID == \"illusive:suspicious\")\r\n| where Message !contains \"hasForensics\" \r\n| where TimeGenerated > ago(30d) \r\n| extend DeviceCustomNumber2 = coalesce(column_ifexists(\"FieldDeviceCustomNumber2\", long(null)), DeviceCustomNumber2, long(null)) \r\n| summarize by AlertingHost=iff(SourceHostName != \"\" and SourceHostName != \"Failed to obtain\", SourceHostName, SourceIP) ,DeviceCustomNumber2 \r\n| where AlertingHost != \"\" and AlertingHost != \"Failed to obtain\" \r\n| summarize incident_count=count() by AlertingHost \r\n| order by incident_count \r\n| limit 10"
}
],
"dataTypes": [
{
"name": "CommonSecurityLog (illusive)",
"lastDataReceivedQuery": "\nCommonSecurityLog\n| where DeviceVendor == \"illusive\"\n| where DeviceProduct == \"illusive\"\n\n | summarize Time = max(TimeGenerated)\n | where isnotempty(Time)"
}
],
"connectivityCriterias": [
{
"type": "IsConnectedQuery",
"value": [
"\nCommonSecurityLog\n| where DeviceVendor == \"illusive\"\n| where DeviceProduct == \"illusive\"\n\n | summarize LastLogReceived = max(TimeGenerated)\n | project IsConnected = LastLogReceived > ago(30d)"
]
}
],
"availability": {
"status": 1,
"isPreview": true
},
"permissions": {
"resourceProvider": [
{
"provider": "Microsoft.OperationalInsights/workspaces",
"permissionsDisplayText": "read and write permissions are required.",
"providerDisplayName": "Workspace",
"scope": "Workspace",
"requiredPermissions": {
"read": true,
"write": true,
"delete": true
}
},
{
"provider": "Microsoft.OperationalInsights/workspaces/sharedKeys",
"permissionsDisplayText": "read permissions to shared keys for the workspace are required. [See the documentation to learn more about workspace keys](https://docs.microsoft.com/azure/azure-monitor/platform/agent-windows#obtain-workspace-id-and-key).",
"providerDisplayName": "Keys",
"scope": "Workspace",
"requiredPermissions": {
"action": true
}
}
]
},
"instructionSteps": [
{
"title": "1. Linux Syslog agent configuration",
"description": "Install and configure the Linux agent to collect your Common Event Format (CEF) Syslog messages and forward them to Azure Sentinel.\n\n> Notice that the data from all regions will be stored in the selected workspace",
"innerSteps": [
{
"title": "1.1 Select or create a Linux machine",
"description": "Select or create a Linux machine that Azure Sentinel will use as the proxy between your security solution and Azure Sentinel this machine can be on your on-prem environment, Azure or other clouds."
},
{
"title": "1.2 Install the CEF collector on the Linux machine",
"description": "Install the Microsoft Monitoring Agent on your Linux machine and configure the machine to listen on the necessary port and forward messages to your Azure Sentinel workspace. The CEF collector collects CEF messages on port 514 TCP.\n\n> 1. Make sure that you have Python on your machine using the following command: python -version.\n\n> 2. You must have elevated permissions (sudo) on your machine.",
"instructions": [
{
"parameters": {
"fillWith": [
"WorkspaceId",
"PrimaryKey"
],
"label": "Run the following command to install and apply the CEF collector:",
"value": "sudo wget -O cef_installer.py https://raw.githubusercontent.com/Azure/Azure-Sentinel/master/DataConnectors/CEF/cef_installer.py&&sudo python cef_installer.py {0} {1}"
},
"type": "CopyableLabel"
}
]
}
]
},
{
"title": "2. Forward Illusive Common Event Format (CEF) logs to Syslog agent",
"description": "1. Set your security solution to send Syslog messages in CEF format to the proxy machine. Make sure you to send the logs to port 514 TCP on the machine's IP address.\n> 2. Log onto the Illusive Console, and navigate to Settings->Reporting.\n> 3. Find Syslog Servers\n> 4. Supply the following information:\n>> 1. Host name: Linux Syslog agent IP address or FQDN host name\n>> 2. Port: 514\n>> 3. Protocol: TCP\n>> 4. Audit messages: Send audit messages to server\n> 5. To add the syslog server, click Add.\n> 6. For more information about how to add a new syslog server in the Illusive platform, please find the Illusive Networks Admin Guide in here: https://support.illusivenetworks.com/hc/en-us/sections/360002292119-Documentation-by-Version"
},
{
"title": "3. Validate connection",
"description": "Follow the instructions to validate your connectivity:\n\nOpen Log Analytics to check if the logs are received using the CommonSecurityLog schema.\n\n>It may take about 20 minutes until the connection streams data to your workspace.\n\nIf the logs are not received, run the following connectivity validation script:\n\n> 1. Make sure that you have Python on your machine using the following command: python -version\n\n>2. You must have elevated permissions (sudo) on your machine",
"instructions": [
{
"parameters": {
"fillWith": [
"WorkspaceId"
],
"label": "Run the following command to validate your connectivity:",
"value": "sudo wget O cef_troubleshoot.py https://raw.githubusercontent.com/Azure/Azure-Sentinel/master/DataConnectors/CEF/cef_troubleshoot.py&&sudo python cef_troubleshoot.py {0}"
},
"type": "CopyableLabel"
}
]
},
{
"title": "4. Secure your machine ",
"description": "Make sure to configure the machine's security according to your organization's security policy\n\n\n[Learn more >](https://aka.ms/SecureCEF)"
}
],
"metadata": {
"id": "aa770f1e-4d05-477a-8dc1-b893772f3a46",
"version": "1.0.0",
"kind": "dataConnector",
"source": {
"kind": "community"
},
"author": {
"name": "Illusive Networks"
},
"support": {
"name": "Illusive Networks",
"link": "https://www.illusivenetworks.com/technical-support/",
"tier": "developer"
}
}
}

Просмотреть файл

@ -14,8 +14,10 @@ triggerThreshold: 0
query: |
CommonSecurityLog
| where DeviceProduct == "illusive"
| extend DeviceCustomNumber2 = coalesce(column_ifexists("FieldDeviceCustomNumber2", int(null)),DeviceCustomNumber2)
| summarize arg_max(TimeGenerated, *) by DeviceCustomNumber2, AdditionalExtensions, TimeGenerated
| extend Category = extract(@'cat=([^;]+)(\;|$)', 1, AdditionalExtensions), HasForensics = extract(@'cs7=([^;]+)(\;|$)', 1, AdditionalExtensions)
| extend Category = coalesce(column_ifexists("DeviceEventCategory",""),Category)
| where Category == "illusive:alerts"
| extend IncidentId = DeviceCustomNumber2, IncidentURL = DeviceCustomString5
| project TimeGenerated, SourceIP, SourceHostName,Computer , DeviceEventClassID ,HasForensics ,SourceUserName, Activity, DeviceAddress, DestinationHostName, DestinationUserName, IncidentId, IncidentURL

Просмотреть файл

@ -396,8 +396,9 @@ The analytic rule instructs Azure Sentinel to search for information of interest
```markdown
CommonSecurityLog
| where DeviceProduct == "illusive"
| extend DeviceCustomNumber2 = coalesce(column_ifexists("FieldDeviceCustomNumber2", long(null)), DeviceCustomNumber2, long(null)),
| summarize arg_max(TimeGenerated, *) by DeviceCustomNumber2, AdditionalExtensions, TimeGenerated
| extend Category = extract(@'cat=([^;]+)(\;|$)', 1, AdditionalExtensions), HasForensics = extract(@'cs7=([^;]+)(\;|$)', 1, AdditionalExtensions)
| extend Category = coalesce(column_ifexists("DeviceEventCategory", ""), extract(@'cat=([^;]+)(\;|$)', 1, AdditionalExtensions), ""), HasForensics = extract(@'cs7=([^;]+)(\;|$)', 1, AdditionalExtensions)
| where Category == "illusive:alerts"
| extend isHostIsolated = false
| extend isProcessIsolated = false
@ -481,4 +482,4 @@ You can view and manage Illusive playbooks as well as review playbook run histor
Sample playbook history (incident response):
<p align="center">
<img src="./Images/playbook-history-incident-response.PNG"> </a>
</p>
</p>

Просмотреть файл

@ -134,7 +134,7 @@
"type": 3,
"content": {
"version": "KqlItem/1.0",
"query": "let binSize = iff({NumberOfDays} > 1, 1d, 1h);\r\nunion CommonSecurityLog | \r\nwhere (DeviceEventClassID == \"illusive:login\" or DeviceEventClassID == \"illusive:access\" or DeviceEventClassID == \"illusive:suspicious\")|\r\nwhere Message !contains \"hasForensics\" |\r\nwhere TimeGenerated > ago({NumberOfDays}d) | \r\nwhere \"{ManagementIP}\" contains \"All\" or \"{ManagementIP}\" contains DeviceAddress |\r\nsummarize by DestinationServiceName ,DeviceCustomNumber2 |\r\nsummarize incident_count=count() by DestinationServiceName",
"query": "let binSize = iff({NumberOfDays} > 1, 1d, 1h);\r\nunion CommonSecurityLog \r\n| extend DeviceCustomNumber2 = coalesce(column_ifexists(\"FieldDeviceCustomNumber2\", int(null)),DeviceCustomNumber2)\r\nwhere (DeviceEventClassID == \"illusive:login\" or DeviceEventClassID == \"illusive:access\" or DeviceEventClassID == \"illusive:suspicious\")|\r\nwhere Message !contains \"hasForensics\" |\r\nwhere TimeGenerated > ago({NumberOfDays}d) | \r\nwhere \"{ManagementIP}\" contains \"All\" or \"{ManagementIP}\" contains DeviceAddress |\r\nsummarize by DestinationServiceName ,DeviceCustomNumber2 |\r\nsummarize incident_count=count() by DestinationServiceName",
"size": 0,
"title": "Number of Incidents in which Trigger Type is found",
"queryType": 0,
@ -152,7 +152,7 @@
"type": 3,
"content": {
"version": "KqlItem/1.0",
"query": "union CommonSecurityLog | \r\nwhere (DeviceEventClassID == \"illusive:login\" or DeviceEventClassID == \"illusive:access\" or DeviceEventClassID == \"illusive:suspicious\")|\r\nwhere Message !contains \"hasForensics\" |\r\nwhere TimeGenerated > ago({NumberOfDays}d) | \r\nwhere \"{ManagementIP}\" contains \"All\" or \"{ManagementIP}\" contains DeviceAddress |\r\nsummarize by DeviceEventClassID ,DeviceCustomNumber2 |\r\nsummarize incident_count=count() by DeviceEventClassID",
"query": "union CommonSecurityLog \r\n| extend DeviceCustomNumber2 = coalesce(column_ifexists(\"FieldDeviceCustomNumber2\", int(null)),DeviceCustomNumber2)|\r\nwhere (DeviceEventClassID == \"illusive:login\" or DeviceEventClassID == \"illusive:access\" or DeviceEventClassID == \"illusive:suspicious\")|\r\nwhere Message !contains \"hasForensics\" |\r\nwhere TimeGenerated > ago({NumberOfDays}d) | \r\nwhere \"{ManagementIP}\" contains \"All\" or \"{ManagementIP}\" contains DeviceAddress |\r\nsummarize by DeviceEventClassID ,DeviceCustomNumber2 |\r\nsummarize incident_count=count() by DeviceEventClassID",
"size": 0,
"title": "Number of Incidents in which Event Type is found",
"queryType": 0,
@ -170,7 +170,7 @@
"type": 3,
"content": {
"version": "KqlItem/1.0",
"query": "union CommonSecurityLog | \r\nwhere (DeviceEventClassID == \"illusive:login\" or DeviceEventClassID == \"illusive:access\" or DeviceEventClassID == \"illusive:suspicious\")|\r\nwhere Message !contains \"hasForensics\" |\r\nwhere TimeGenerated > ago({NumberOfDays}d) | \r\nwhere \"{ManagementIP}\" contains \"All\" or \"{ManagementIP}\" contains DeviceAddress |\r\nsummarize by AlertingHost=iff(SourceHostName != \"\" and SourceHostName != \"Failed to obtain\", SourceHostName, SourceIP) ,DeviceCustomNumber2 |\r\nwhere AlertingHost != \"\" and AlertingHost != \"Failed to obtain\" |\r\nsummarize incident_count=count() by AlertingHost |\r\norder by incident_count |\r\nlimit 10",
"query": "union CommonSecurityLog| \r\nextend DeviceCustomNumber2 = coalesce(column_ifexists(\"FieldDeviceCustomNumber2\", int(null)),DeviceCustomNumber2)|\r\nwhere (DeviceEventClassID == \"illusive:login\" or DeviceEventClassID == \"illusive:access\" or DeviceEventClassID == \"illusive:suspicious\")|\r\nwhere Message !contains \"hasForensics\" |\r\nwhere TimeGenerated > ago({NumberOfDays}d) | \r\nwhere \"{ManagementIP}\" contains \"All\" or \"{ManagementIP}\" contains DeviceAddress |\r\nsummarize by AlertingHost=iff(SourceHostName != \"\" and SourceHostName != \"Failed to obtain\", SourceHostName, SourceIP) ,DeviceCustomNumber2 |\r\nwhere AlertingHost != \"\" and AlertingHost != \"Failed to obtain\" |\r\nsummarize incident_count=count() by AlertingHost |\r\norder by incident_count |\r\nlimit 10",
"size": 0,
"title": "Top 10 alerting hosts",
"queryType": 0,