From a34858365be3be60e46b64466a0ce0b29b18cc78 Mon Sep 17 00:00:00 2001 From: v-rusraut Date: Wed, 13 Sep 2023 17:30:36 +0530 Subject: [PATCH 1/6] Repackaging - Illusive Platform (MMA to AMA Migration) --- .../Illusive_Detection_Query.yaml | 5 +- .../illusive Attack Management System.json | 2 +- .../template_IllusivePlatformAMA.json | 136 ++++++++++++++++++ ...lution_IllusiveAttackManagementSystem.json | 7 +- .../WorkbookMetadata/WorkbooksMetadata.json | 6 +- 5 files changed, 149 insertions(+), 7 deletions(-) create mode 100644 Solutions/Illusive Platform/Data Connectors/template_IllusivePlatformAMA.json diff --git a/Solutions/Illusive Platform/Analytic Rules/Illusive_Detection_Query.yaml b/Solutions/Illusive Platform/Analytic Rules/Illusive_Detection_Query.yaml index 2fc87d7084a..7a90597c631 100644 --- a/Solutions/Illusive Platform/Analytic Rules/Illusive_Detection_Query.yaml +++ b/Solutions/Illusive Platform/Analytic Rules/Illusive_Detection_Query.yaml @@ -8,6 +8,9 @@ requiredDataConnectors: - connectorId: Illusive dataTypes: - CommonSecurityLog + - connectorId: illusiveAttackManagementSystemAma + dataTypes: + - CommonSecurityLog queryFrequency: 5m queryPeriod: 5m triggerOperator: gt @@ -46,5 +49,5 @@ alertDetailsOverride: Illusive Incident: {{IncidentId}} alertDescriptionFormat: | Illusive Incident {{IncidentId}} generated at {{TimeGenerated}} -version: 1.0.2 +version: 1.0.3 kind: Scheduled \ No newline at end of file diff --git a/Solutions/Illusive Platform/Data Connectors/illusive Attack Management System.json b/Solutions/Illusive Platform/Data Connectors/illusive Attack Management System.json index bd849b0b355..be0e6005355 100644 --- a/Solutions/Illusive Platform/Data Connectors/illusive Attack Management System.json +++ b/Solutions/Illusive Platform/Data Connectors/illusive Attack Management System.json @@ -1,6 +1,6 @@ { "id": "illusiveAttackManagementSystem", - "title": "Illusive Platform", + "title": "[Deprecated] Illusive Platform via Legacy Agent", "publisher": "illusive", "descriptionMarkdown": "The Illusive Platform Connector allows you to share Illusive's attack surface analysis data and incident logs with Microsoft 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": [ diff --git a/Solutions/Illusive Platform/Data Connectors/template_IllusivePlatformAMA.json b/Solutions/Illusive Platform/Data Connectors/template_IllusivePlatformAMA.json new file mode 100644 index 00000000000..ead06ce10ad --- /dev/null +++ b/Solutions/Illusive Platform/Data Connectors/template_IllusivePlatformAMA.json @@ -0,0 +1,136 @@ +{ + "id": "illusiveAttackManagementSystemAma", + "title": "[Recommended] Illusive Platform via AMA", + "publisher": "illusive", + "descriptionMarkdown": "The Illusive Platform Connector allows you to share Illusive's attack surface analysis data and incident logs with Microsoft 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": "CommonSecurityLog\n |where DeviceVendor =~ 'illusive'\n |where DeviceProduct =~ 'illusive'\n |extend sent_by_ama = column_ifexists('CollectorHostName','')\n |where isnotempty(sent_by_ama)" + } + ], + "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": "CommonSecurityLog\n |where DeviceVendor =~ 'illusive'\n |where DeviceProduct =~ 'illusive'\n |extend sent_by_ama = column_ifexists('CollectorHostName','')\n |where isnotempty(sent_by_ama)\n | summarize Time = max(TimeGenerated)\n | where isnotempty(Time)" + } + ], + "connectivityCriterias": [ + { + "type": "IsConnectedQuery", + "value": [ + "CommonSecurityLog\n |where DeviceVendor =~ 'illusive'\n |where DeviceProduct =~ 'illusive'\n |extend sent_by_ama = column_ifexists('CollectorHostName','')\n |where isnotempty(sent_by_ama)\n | summarize LastLogReceived = max(TimeGenerated)\n | project IsConnected = LastLogReceived > ago(30d)" + ] + } + ], + "availability": { + "status": 1, + "isPreview": false + }, + "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 + } + } + ], + "customs": [ + { + "description": "To collect data from non-Azure VMs, they must have Azure Arc installed and enabled. [Learn more](https://docs.microsoft.com/azure/azure-monitor/agents/azure-monitor-agent-install?tabs=ARMAgentPowerShell,PowerShellWindows,PowerShellWindowsArc,CLIWindows,CLIWindowsArc)" + }, + { + "description": "Common Event Format (CEF) via AMA and Syslog via AMA data connectors must be installed [Learn more](https://learn.microsoft.com/azure/sentinel/connect-cef-ama#open-the-connector-page-and-create-the-dcr)" + } + ] + }, + "instructionSteps": [ + { + "title": "", + "description": "", + "instructions": [ + { + "parameters": { + "title": "1. Kindly follow the steps to configure the data connector", + "instructionSteps": [ + { + "title": "Step A. Configure the Common Event Format (CEF) via AMA data connector", + "description": "_Note:- CEF logs are collected only from Linux Agents_\n\n1. Navigate to Microsoft Sentinel workspace ---> configuration ---> Data connector blade .\n\n2. Search for 'Common Event Format (CEF) via AMA' data connector and open it.\n\n3. Check If there is no existing DCR configured to collect required facility of logs, Create a new DCR (Data Collection Rule)\n\n\t_Note:- It is recommended to install minimum 1.27 version of AMA agent [Learn more](https://learn.microsoft.com/azure/azure-monitor/agents/azure-monitor-agent-manage?tabs=azure-portal ) and ensure there is no duplicate DCR as it can cause log duplicacy_\n\n4. Run the command provided in the CEF via AMA data connector page to configure the CEF collector on the machine", + "instructions": [ + ] + }, + { + "title": "Step B. 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", + "instructions": [ + ] + }, + { + "title": "Step C. 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\nIt 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\n2. You must have elevated permissions (sudo) on your machine", + "instructions": [ + { + "parameters": { + "label": "Run the following command to validate your connectivity:", + "value": "sudo wget -O Sentinel_AMA_troubleshoot.py https://raw.githubusercontent.com/Azure/Azure-Sentinel/master/DataConnectors/Syslog/Sentinel_AMA_troubleshoot.py&&sudo python Sentinel_AMA_troubleshoot.py --cef" + }, + "type": "CopyableLabel" + } + ] + } + ] + }, + "type": "InstructionStepsGroup" + } + ] + }, + + + { + "title": "2. 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" + } + } +} \ No newline at end of file diff --git a/Solutions/Illusive Platform/Data/Solution_IllusiveAttackManagementSystem.json b/Solutions/Illusive Platform/Data/Solution_IllusiveAttackManagementSystem.json index 931d976db6a..2dc943d53d7 100644 --- a/Solutions/Illusive Platform/Data/Solution_IllusiveAttackManagementSystem.json +++ b/Solutions/Illusive Platform/Data/Solution_IllusiveAttackManagementSystem.json @@ -2,10 +2,11 @@ "Name": "Illusive Platform", "Author": "Illusive Networks", "Logo": "", - "Description": "The Illusive Platform solution for Microsoft Sentinel enables you to ingest Illusive Platform’s attack surface analysis data and incident logs into Microsoft 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). \r\n\r\n **Underlying Microsoft Technologies used:**\r\n\r\n This solution takes a dependency on the following technologies, and some of these dependencies either may be in [Preview](https://azure.microsoft.com/support/legal/preview-supplemental-terms/) state or might result in additional ingestion or operational costs:\r\n\n a. [Agent-based log collection (CEF over Syslog)](https://docs.microsoft.com/azure/sentinel/connect-common-event-format)\r\n\n", + "Description": "The Illusive Platform solution for Microsoft Sentinel enables you to ingest Illusive Platform’s attack surface analysis data and incident logs into Microsoft 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).\n\r\n1. **Illusive Platform via AMA** - This data connector helps in ingesting Illusive Platform logs into your Log Analytics Workspace using the new Azure Monitor Agent. Learn more about ingesting using the new Azure Monitor Agent [here](https://learn.microsoft.com/azure/sentinel/connect-cef-ama). **Microsoft recommends using this Data Connector**.\n\r\n2. **Illusive Platform via Legacy Agent** - This data connector helps in ingesting Illusive Platform logs into your Log Analytics Workspace using the legacy Log Analytics agent.\n\n**NOTE:** Microsoft recommends installation of Illusive Platform via AMA Connector. Legacy connector uses the Log Analytics agent which is about to be deprecated by **Aug 31, 2024,** and thus should only be installed where AMA is not supported. Using MMA and AMA on same machine can cause log duplication and extra ingestion cost [more details](https://learn.microsoft.com/en-us/azure/sentinel/ama-migrate).", "Data Connectors": [ - "Data Connectors/illusive Attack Management System.json" + "Data Connectors/illusive Attack Management System.json", + "Data Connectors/template_IllusivePlatformAMA.json" ], "Workbooks": [ "Workbooks/IllusiveADS.json", @@ -15,7 +16,7 @@ "Analytic Rules/Illusive_Detection_Query.yaml" ], "BasePath": "C:\\GitHub\\Azure-Sentinel\\Solutions\\Illusive Platform", - "Version": "2.0.1", + "Version": "3.0.0", "Metadata": "SolutionMetadata.json", "TemplateSpec": true, "Is1PConnector": false diff --git a/Tools/Create-Azure-Sentinel-Solution/V2/WorkbookMetadata/WorkbooksMetadata.json b/Tools/Create-Azure-Sentinel-Solution/V2/WorkbookMetadata/WorkbooksMetadata.json index c6959fa29d0..fe2981273e3 100644 --- a/Tools/Create-Azure-Sentinel-Solution/V2/WorkbookMetadata/WorkbooksMetadata.json +++ b/Tools/Create-Azure-Sentinel-Solution/V2/WorkbookMetadata/WorkbooksMetadata.json @@ -1190,7 +1190,8 @@ "CommonSecurityLog" ], "dataConnectorsDependencies": [ - "illusiveAttackManagementSystem" + "illusiveAttackManagementSystem", + "illusiveAttackManagementSystemAma" ], "previewImagesFileNames": [ "IllusiveASMWhite.png", @@ -1210,7 +1211,8 @@ "CommonSecurityLog" ], "dataConnectorsDependencies": [ - "illusiveAttackManagementSystem" + "illusiveAttackManagementSystem", + "illusiveAttackManagementSystemAma" ], "previewImagesFileNames": [ "IllusiveADSWhite.png", From c9c584a4291a0fa9d1e7e62e811040623c5af522 Mon Sep 17 00:00:00 2001 From: Github Bot Date: Wed, 13 Sep 2023 12:10:56 +0000 Subject: [PATCH 2/6] [skip ci] Github Bot Added package to Pull Request! --- .../Data/system_generated_metadata.json | 31 + Solutions/Illusive Platform/Package/3.0.0.zip | Bin 0 -> 13172 bytes .../Package/createUiDefinition.json | 39 +- .../Package/mainTemplate.json | 609 ++++++++++++++---- 4 files changed, 564 insertions(+), 115 deletions(-) create mode 100644 Solutions/Illusive Platform/Data/system_generated_metadata.json create mode 100644 Solutions/Illusive Platform/Package/3.0.0.zip diff --git a/Solutions/Illusive Platform/Data/system_generated_metadata.json b/Solutions/Illusive Platform/Data/system_generated_metadata.json new file mode 100644 index 00000000000..d4d8874e288 --- /dev/null +++ b/Solutions/Illusive Platform/Data/system_generated_metadata.json @@ -0,0 +1,31 @@ +{ + "Name": "Illusive Platform", + "Author": "Illusive Networks", + "Logo": "", + "Description": "The Illusive Platform solution for Microsoft Sentinel enables you to ingest Illusive Platform’s attack surface analysis data and incident logs into Microsoft 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).\n\r\n1. **Illusive Platform via AMA** - This data connector helps in ingesting Illusive Platform logs into your Log Analytics Workspace using the new Azure Monitor Agent. Learn more about ingesting using the new Azure Monitor Agent [here](https://learn.microsoft.com/azure/sentinel/connect-cef-ama). **Microsoft recommends using this Data Connector**.\n\r\n2. **Illusive Platform via Legacy Agent** - This data connector helps in ingesting Illusive Platform logs into your Log Analytics Workspace using the legacy Log Analytics agent.\n\n**NOTE:** Microsoft recommends installation of Illusive Platform via AMA Connector. Legacy connector uses the Log Analytics agent which is about to be deprecated by **Aug 31, 2024,** and thus should only be installed where AMA is not supported. Using MMA and AMA on same machine can cause log duplication and extra ingestion cost [more details](https://learn.microsoft.com/en-us/azure/sentinel/ama-migrate).", + "BasePath": "C:\\GitHub\\Azure-Sentinel\\Solutions\\Illusive Platform", + "Version": "3.0.0", + "Metadata": "SolutionMetadata.json", + "TemplateSpec": true, + "Is1PConnector": false, + "publisherId": "illusivenetworks", + "offerId": "illusive_platform_mss", + "providers": [ + "Illusive" + ], + "categories": { + "domains": [ + "Security - Threat Protection", + "Security - Others" + ] + }, + "firstPublishDate": "2022-05-25", + "support": { + "name": "Illusive Networks", + "tier": "Partner", + "link": "https://illusive.com/support" + }, + "Data Connectors": "[\n \"Data Connectors/illusive Attack Management System.json\",\n \"Data Connectors/template_IllusivePlatformAMA.json\"\n]", + "Workbooks": "[\n \"Workbooks/IllusiveADS.json\",\n \"Workbooks/IllusiveASM.json\"\n]", + "Analytic Rules": "[\n \"Illusive_Detection_Query.yaml\"\n]" +} diff --git a/Solutions/Illusive Platform/Package/3.0.0.zip b/Solutions/Illusive Platform/Package/3.0.0.zip new file mode 100644 index 0000000000000000000000000000000000000000..d6ca9741d026ffd22776d36a76291079703a8c71 GIT binary patch literal 13172 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 J4d(wj{Xa7xhXw!u literal 0 HcmV?d00001 diff --git a/Solutions/Illusive Platform/Package/createUiDefinition.json b/Solutions/Illusive Platform/Package/createUiDefinition.json index a31c4a98ebf..c49836ad5b2 100644 --- a/Solutions/Illusive Platform/Package/createUiDefinition.json +++ b/Solutions/Illusive Platform/Package/createUiDefinition.json @@ -6,7 +6,7 @@ "config": { "isWizard": false, "basics": { - "description": "\n\n**Note:** _There may be [known issues](https://aka.ms/sentinelsolutionsknownissues) pertaining to this Solution, please refer to them before installing._\n\nThe Illusive Platform solution for Microsoft Sentinel enables you to ingest Illusive Platform’s attack surface analysis data and incident logs into Microsoft 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). \r\n\r\n **Underlying Microsoft Technologies used:**\r\n\r\n This solution takes a dependency on the following technologies, and some of these dependencies either may be in [Preview](https://azure.microsoft.com/support/legal/preview-supplemental-terms/) state or might result in additional ingestion or operational costs:\r\n\n a. [Agent-based log collection (CEF over Syslog)](https://docs.microsoft.com/azure/sentinel/connect-common-event-format)\r\n\n\n\n**Data Connectors:** 1, **Workbooks:** 2, **Analytic Rules:** 1\n\n[Learn more about Microsoft Sentinel](https://aka.ms/azuresentinel) | [Learn more about Solutions](https://aka.ms/azuresentinelsolutionsdoc)", + "description": "\n\n**Note:** _There may be [known issues](https://aka.ms/sentinelsolutionsknownissues) pertaining to this Solution, please refer to them before installing._\n\nThe Illusive Platform solution for Microsoft Sentinel enables you to ingest Illusive Platform’s attack surface analysis data and incident logs into Microsoft 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).\n\r\n1. **Illusive Platform via AMA** - This data connector helps in ingesting Illusive Platform logs into your Log Analytics Workspace using the new Azure Monitor Agent. Learn more about ingesting using the new Azure Monitor Agent [here](https://learn.microsoft.com/azure/sentinel/connect-cef-ama). **Microsoft recommends using this Data Connector**.\n\r\n2. **Illusive Platform via Legacy Agent** - This data connector helps in ingesting Illusive Platform logs into your Log Analytics Workspace using the legacy Log Analytics agent.\n\n**NOTE:** Microsoft recommends installation of Illusive Platform via AMA Connector. Legacy connector uses the Log Analytics agent which is about to be deprecated by **Aug 31, 2024,** and thus should only be installed where AMA is not supported. Using MMA and AMA on same machine can cause log duplication and extra ingestion cost [more details](https://learn.microsoft.com/en-us/azure/sentinel/ama-migrate).\n\n**Data Connectors:** 2, **Workbooks:** 2, **Analytic Rules:** 1\n\n[Learn more about Microsoft Sentinel](https://aka.ms/azuresentinel) | [Learn more about Solutions](https://aka.ms/azuresentinelsolutionsdoc)", "subscription": { "resourceProviders": [ "Microsoft.OperationsManagement/solutions", @@ -60,7 +60,7 @@ "name": "dataconnectors1-text", "type": "Microsoft.Common.TextBlock", "options": { - "text": "This solution installs the data connector to ingest Illusive attack surface management and threat detection data in Common Event Format (CEF) into Microsoft Sentinel. After installing the solution, configure and enable this data connector by following guidance in Manage solution view." + "text": "This Solution installs the data connector for Illusive Platform. You can get Illusive Platform CommonSecurityLog data in your Microsoft Sentinel workspace. After installing the solution, configure and enable this data connector by following guidance in Manage solution view." } }, { @@ -72,6 +72,13 @@ "uri": "https://docs.microsoft.com/azure/sentinel/connect-data-sources" } } + }, + { + "name": "dataconnectors2-text", + "type": "Microsoft.Common.TextBlock", + "options": { + "text": "This Solution installs the data connector for Illusive Platform. You can get Illusive Platform CommonSecurityLog data in your Microsoft Sentinel workspace. After installing the solution, configure and enable this data connector by following guidance in Manage solution view." + } } ] }, @@ -100,6 +107,34 @@ "uri": "https://docs.microsoft.com/azure/sentinel/tutorial-monitor-your-data" } } + }, + { + "name": "workbook1", + "type": "Microsoft.Common.Section", + "label": "Illusive ADS Dashboard", + "elements": [ + { + "name": "workbook1-text", + "type": "Microsoft.Common.TextBlock", + "options": { + "text": "Gain insights into unauthorized lateral movement in your organization's network.\nIllusive ADS is designed to paralyzes attackers and eradicates in-network threats by creating a hostile environment for the attackers across all the layers of the attack surface." + } + } + ] + }, + { + "name": "workbook2", + "type": "Microsoft.Common.Section", + "label": "Illusive ASM Dashboard", + "elements": [ + { + "name": "workbook2-text", + "type": "Microsoft.Common.TextBlock", + "options": { + "text": "Gain insights into your organization's Cyber Hygiene and Attack Surface risk.\nIllusive ASM automates discovery and clean-up of credential violations, allows drill-down inspection of pathways to critical assets, and provides risk insights that inform intelligent decision-making to reduce attacker mobility." + } + } + ] } ] }, diff --git a/Solutions/Illusive Platform/Package/mainTemplate.json b/Solutions/Illusive Platform/Package/mainTemplate.json index bf30906db63..9b8f195ad20 100644 --- a/Solutions/Illusive Platform/Package/mainTemplate.json +++ b/Solutions/Illusive Platform/Package/mainTemplate.json @@ -48,62 +48,58 @@ "variables": { "solutionId": "illusivenetworks.illusive_platform_mss", "_solutionId": "[variables('solutionId')]", - "workspaceResourceId": "[resourceId('microsoft.OperationalInsights/Workspaces', parameters('workspace'))]", + "_solutionName": "Illusive Platform", + "_solutionVersion": "3.0.0", "uiConfigId1": "illusiveAttackManagementSystem", "_uiConfigId1": "[variables('uiConfigId1')]", "dataConnectorContentId1": "illusiveAttackManagementSystem", "_dataConnectorContentId1": "[variables('dataConnectorContentId1')]", "dataConnectorId1": "[extensionResourceId(resourceId('Microsoft.OperationalInsights/workspaces', parameters('workspace')), 'Microsoft.SecurityInsights/dataConnectors', variables('_dataConnectorContentId1'))]", "_dataConnectorId1": "[variables('dataConnectorId1')]", - "dataConnectorTemplateSpecName1": "[concat(parameters('workspace'),'-dc-',uniquestring(variables('_dataConnectorContentId1')))]", + "dataConnectorTemplateSpecName1": "[concat(parameters('workspace'),'/Microsoft.SecurityInsights/',concat(parameters('workspace'),'-dc-',uniquestring(variables('_dataConnectorContentId1'))))]", "dataConnectorVersion1": "1.0.0", + "_dataConnectorcontentProductId1": "[concat(take(variables('_solutionId'),50),'-','dc','-', uniqueString(concat(variables('_solutionId'),'-','DataConnector','-',variables('_dataConnectorContentId1'),'-', variables('dataConnectorVersion1'))))]", + "uiConfigId2": "illusiveAttackManagementSystemAma", + "_uiConfigId2": "[variables('uiConfigId2')]", + "dataConnectorContentId2": "illusiveAttackManagementSystemAma", + "_dataConnectorContentId2": "[variables('dataConnectorContentId2')]", + "dataConnectorId2": "[extensionResourceId(resourceId('Microsoft.OperationalInsights/workspaces', parameters('workspace')), 'Microsoft.SecurityInsights/dataConnectors', variables('_dataConnectorContentId2'))]", + "_dataConnectorId2": "[variables('dataConnectorId2')]", + "dataConnectorTemplateSpecName2": "[concat(parameters('workspace'),'/Microsoft.SecurityInsights/',concat(parameters('workspace'),'-dc-',uniquestring(variables('_dataConnectorContentId2'))))]", + "dataConnectorVersion2": "1.0.0", + "_dataConnectorcontentProductId2": "[concat(take(variables('_solutionId'),50),'-','dc','-', uniqueString(concat(variables('_solutionId'),'-','DataConnector','-',variables('_dataConnectorContentId2'),'-', variables('dataConnectorVersion2'))))]", "workbookVersion1": "1.0.0", "workbookContentId1": "IllusiveADSWorkbook", "workbookId1": "[resourceId('Microsoft.Insights/workbooks', variables('workbookContentId1'))]", - "workbookTemplateSpecName1": "[concat(parameters('workspace'),'-wb-',uniquestring(variables('_workbookContentId1')))]", + "workbookTemplateSpecName1": "[concat(parameters('workspace'),'/Microsoft.SecurityInsights/',concat(parameters('workspace'),'-wb-',uniquestring(variables('_workbookContentId1'))))]", "_workbookContentId1": "[variables('workbookContentId1')]", + "workspaceResourceId": "[resourceId('microsoft.OperationalInsights/Workspaces', parameters('workspace'))]", + "_workbookcontentProductId1": "[concat(take(variables('_solutionId'),50),'-','wb','-', uniqueString(concat(variables('_solutionId'),'-','Workbook','-',variables('_workbookContentId1'),'-', variables('workbookVersion1'))))]", "workbookVersion2": "1.0.0", "workbookContentId2": "IllusiveASMWorkbook", "workbookId2": "[resourceId('Microsoft.Insights/workbooks', variables('workbookContentId2'))]", - "workbookTemplateSpecName2": "[concat(parameters('workspace'),'-wb-',uniquestring(variables('_workbookContentId2')))]", + "workbookTemplateSpecName2": "[concat(parameters('workspace'),'/Microsoft.SecurityInsights/',concat(parameters('workspace'),'-wb-',uniquestring(variables('_workbookContentId2'))))]", "_workbookContentId2": "[variables('workbookContentId2')]", - "analyticRuleVersion1": "1.0.2", + "_workbookcontentProductId2": "[concat(take(variables('_solutionId'),50),'-','wb','-', uniqueString(concat(variables('_solutionId'),'-','Workbook','-',variables('_workbookContentId2'),'-', variables('workbookVersion2'))))]", + "analyticRuleVersion1": "1.0.3", "analyticRulecontentId1": "1a7dbcf6-21a2-4255-84b2-c8dbbdca4630", "_analyticRulecontentId1": "[variables('analyticRulecontentId1')]", "analyticRuleId1": "[resourceId('Microsoft.SecurityInsights/AlertRuleTemplates', variables('analyticRulecontentId1'))]", - "analyticRuleTemplateSpecName1": "[concat(parameters('workspace'),'-ar-',uniquestring(variables('_analyticRulecontentId1')))]", - "IllusiveIncident": "IncidentId", - "_IllusiveIncident": "[variables('IllusiveIncident')]" + "analyticRuleTemplateSpecName1": "[concat(parameters('workspace'),'/Microsoft.SecurityInsights/',concat(parameters('workspace'),'-ar-',uniquestring(variables('_analyticRulecontentId1'))))]", + "_analyticRulecontentProductId1": "[concat(take(variables('_solutionId'),50),'-','ar','-', uniqueString(concat(variables('_solutionId'),'-','AnalyticsRule','-',variables('_analyticRulecontentId1'),'-', variables('analyticRuleVersion1'))))]", + "_solutioncontentProductId": "[concat(take(variables('_solutionId'),50),'-','sl','-', uniqueString(concat(variables('_solutionId'),'-','Solution','-',variables('_solutionId'),'-', variables('_solutionVersion'))))]" }, "resources": [ { - "type": "Microsoft.Resources/templateSpecs", - "apiVersion": "2021-05-01", + "type": "Microsoft.OperationalInsights/workspaces/providers/contentTemplates", + "apiVersion": "2023-04-01-preview", "name": "[variables('dataConnectorTemplateSpecName1')]", "location": "[parameters('workspace-location')]", - "tags": { - "hidden-sentinelWorkspaceId": "[variables('workspaceResourceId')]", - "hidden-sentinelContentType": "DataConnector" - }, - "properties": { - "description": "Illusive Platform data connector with template", - "displayName": "Illusive Platform template" - } - }, - { - "type": "Microsoft.Resources/templateSpecs/versions", - "apiVersion": "2021-05-01", - "name": "[concat(variables('dataConnectorTemplateSpecName1'),'/',variables('dataConnectorVersion1'))]", - "location": "[parameters('workspace-location')]", - "tags": { - "hidden-sentinelWorkspaceId": "[variables('workspaceResourceId')]", - "hidden-sentinelContentType": "DataConnector" - }, "dependsOn": [ - "[resourceId('Microsoft.Resources/templateSpecs', variables('dataConnectorTemplateSpecName1'))]" + "[extensionResourceId(resourceId('Microsoft.OperationalInsights/workspaces', parameters('workspace')), 'Microsoft.SecurityInsights/contentPackages', variables('_solutionId'))]" ], "properties": { - "description": "Illusive Platform data connector with template version 2.0.1", + "description": "Illusive Platform data connector with template version 3.0.0", "mainTemplate": { "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#", "contentVersion": "[variables('dataConnectorVersion1')]", @@ -119,7 +115,7 @@ "properties": { "connectorUiConfig": { "id": "[variables('_uiConfigId1')]", - "title": "Illusive Platform", + "title": "[Deprecated] Illusive Platform via Legacy Agent", "publisher": "illusive", "descriptionMarkdown": "The Illusive Platform Connector allows you to share Illusive's attack surface analysis data and incident logs with Microsoft 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": [ @@ -255,7 +251,7 @@ }, { "type": "Microsoft.OperationalInsights/workspaces/providers/metadata", - "apiVersion": "2022-01-01-preview", + "apiVersion": "2023-04-01-preview", "name": "[concat(parameters('workspace'),'/Microsoft.SecurityInsights/',concat('DataConnector-', last(split(variables('_dataConnectorId1'),'/'))))]", "properties": { "parentId": "[extensionResourceId(resourceId('Microsoft.OperationalInsights/workspaces', parameters('workspace')), 'Microsoft.SecurityInsights/dataConnectors', variables('_dataConnectorContentId1'))]", @@ -278,12 +274,23 @@ } } ] - } + }, + "packageKind": "Solution", + "packageVersion": "[variables('_solutionVersion')]", + "packageName": "[variables('_solutionName')]", + "packageId": "[variables('_solutionId')]", + "contentSchemaVersion": "3.0.0", + "contentId": "[variables('_dataConnectorContentId1')]", + "contentKind": "DataConnector", + "displayName": "[Deprecated] Illusive Platform via Legacy Agent", + "contentProductId": "[variables('_dataConnectorcontentProductId1')]", + "id": "[variables('_dataConnectorcontentProductId1')]", + "version": "[variables('dataConnectorVersion1')]" } }, { "type": "Microsoft.OperationalInsights/workspaces/providers/metadata", - "apiVersion": "2022-01-01-preview", + "apiVersion": "2023-04-01-preview", "name": "[concat(parameters('workspace'),'/Microsoft.SecurityInsights/',concat('DataConnector-', last(split(variables('_dataConnectorId1'),'/'))))]", "dependsOn": [ "[variables('_dataConnectorId1')]" @@ -317,7 +324,7 @@ "kind": "GenericUI", "properties": { "connectorUiConfig": { - "title": "Illusive Platform", + "title": "[Deprecated] Illusive Platform via Legacy Agent", "publisher": "illusive", "descriptionMarkdown": "The Illusive Platform Connector allows you to share Illusive's attack surface analysis data and incident logs with Microsoft 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": [ @@ -437,33 +444,360 @@ } }, { - "type": "Microsoft.Resources/templateSpecs", - "apiVersion": "2021-05-01", - "name": "[variables('workbookTemplateSpecName1')]", + "type": "Microsoft.OperationalInsights/workspaces/providers/contentTemplates", + "apiVersion": "2023-04-01-preview", + "name": "[variables('dataConnectorTemplateSpecName2')]", "location": "[parameters('workspace-location')]", - "tags": { - "hidden-sentinelWorkspaceId": "[variables('workspaceResourceId')]", - "hidden-sentinelContentType": "Workbook" - }, + "dependsOn": [ + "[extensionResourceId(resourceId('Microsoft.OperationalInsights/workspaces', parameters('workspace')), 'Microsoft.SecurityInsights/contentPackages', variables('_solutionId'))]" + ], "properties": { - "description": "Illusive Platform Workbook with template", - "displayName": "Illusive Platform workbook template" + "description": "Illusive Platform data connector with template version 3.0.0", + "mainTemplate": { + "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#", + "contentVersion": "[variables('dataConnectorVersion2')]", + "parameters": {}, + "variables": {}, + "resources": [ + { + "name": "[concat(parameters('workspace'),'/Microsoft.SecurityInsights/',variables('_dataConnectorContentId2'))]", + "apiVersion": "2021-03-01-preview", + "type": "Microsoft.OperationalInsights/workspaces/providers/dataConnectors", + "location": "[parameters('workspace-location')]", + "kind": "GenericUI", + "properties": { + "connectorUiConfig": { + "id": "[variables('_uiConfigId2')]", + "title": "[Recommended] Illusive Platform via AMA (using Azure Functions)", + "publisher": "illusive", + "descriptionMarkdown": "The Illusive Platform Connector allows you to share Illusive's attack surface analysis data and incident logs with Microsoft 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": "CommonSecurityLog\n |where DeviceVendor =~ 'illusive'\n |where DeviceProduct =~ 'illusive'\n |extend sent_by_ama = column_ifexists('CollectorHostName','')\n |where isnotempty(sent_by_ama)" + } + ], + "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": "CommonSecurityLog\n |where DeviceVendor =~ 'illusive'\n |where DeviceProduct =~ 'illusive'\n |extend sent_by_ama = column_ifexists('CollectorHostName','')\n |where isnotempty(sent_by_ama)\n | summarize Time = max(TimeGenerated)\n | where isnotempty(Time)" + } + ], + "connectivityCriterias": [ + { + "type": "IsConnectedQuery", + "value": [ + "CommonSecurityLog\n |where DeviceVendor =~ 'illusive'\n |where DeviceProduct =~ 'illusive'\n |extend sent_by_ama = column_ifexists('CollectorHostName','')\n |where isnotempty(sent_by_ama)\n | summarize LastLogReceived = max(TimeGenerated)\n | project IsConnected = LastLogReceived > ago(30d)" + ] + } + ], + "availability": { + "status": 1, + "isPreview": false + }, + "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 + } + } + ], + "customs": [ + { + "description": "To collect data from non-Azure VMs, they must have Azure Arc installed and enabled. [Learn more](https://docs.microsoft.com/azure/azure-monitor/agents/azure-monitor-agent-install?tabs=ARMAgentPowerShell,PowerShellWindows,PowerShellWindowsArc,CLIWindows,CLIWindowsArc)" + }, + { + "description": "Common Event Format (CEF) via AMA and Syslog via AMA data connectors must be installed [Learn more](https://learn.microsoft.com/azure/sentinel/connect-cef-ama#open-the-connector-page-and-create-the-dcr)" + } + ] + }, + "instructionSteps": [ + { + "instructions": [ + { + "parameters": { + "title": "1. Kindly follow the steps to configure the data connector", + "instructionSteps": [ + { + "title": "Step A. Configure the Common Event Format (CEF) via AMA data connector", + "description": "_Note:- CEF logs are collected only from Linux Agents_\n\n1. Navigate to Microsoft Sentinel workspace ---> configuration ---> Data connector blade .\n\n2. Search for 'Common Event Format (CEF) via AMA' data connector and open it.\n\n3. Check If there is no existing DCR configured to collect required facility of logs, Create a new DCR (Data Collection Rule)\n\n\t_Note:- It is recommended to install minimum 1.27 version of AMA agent [Learn more](https://learn.microsoft.com/azure/azure-monitor/agents/azure-monitor-agent-manage?tabs=azure-portal ) and ensure there is no duplicate DCR as it can cause log duplicacy_\n\n4. Run the command provided in the CEF via AMA data connector page to configure the CEF collector on the machine", + "instructions": [] + }, + { + "title": "Step B. 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", + "instructions": [] + }, + { + "title": "Step C. 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\nIt 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\n2. You must have elevated permissions (sudo) on your machine", + "instructions": [ + { + "parameters": { + "label": "Run the following command to validate your connectivity:", + "value": "sudo wget -O Sentinel_AMA_troubleshoot.py https://raw.githubusercontent.com/Azure/Azure-Sentinel/master/DataConnectors/Syslog/Sentinel_AMA_troubleshoot.py&&sudo python Sentinel_AMA_troubleshoot.py --cef" + }, + "type": "CopyableLabel" + } + ] + } + ] + }, + "type": "InstructionStepsGroup" + } + ] + }, + { + "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)", + "title": "2. Secure your machine " + } + ], + "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" + } + } + } + } + }, + { + "type": "Microsoft.OperationalInsights/workspaces/providers/metadata", + "apiVersion": "2023-04-01-preview", + "name": "[concat(parameters('workspace'),'/Microsoft.SecurityInsights/',concat('DataConnector-', last(split(variables('_dataConnectorId2'),'/'))))]", + "properties": { + "parentId": "[extensionResourceId(resourceId('Microsoft.OperationalInsights/workspaces', parameters('workspace')), 'Microsoft.SecurityInsights/dataConnectors', variables('_dataConnectorContentId2'))]", + "contentId": "[variables('_dataConnectorContentId2')]", + "kind": "DataConnector", + "version": "[variables('dataConnectorVersion2')]", + "source": { + "kind": "Solution", + "name": "Illusive Platform", + "sourceId": "[variables('_solutionId')]" + }, + "author": { + "name": "Illusive Networks" + }, + "support": { + "name": "Illusive Networks", + "tier": "Partner", + "link": "https://illusive.com/support" + } + } + } + ] + }, + "packageKind": "Solution", + "packageVersion": "[variables('_solutionVersion')]", + "packageName": "[variables('_solutionName')]", + "packageId": "[variables('_solutionId')]", + "contentSchemaVersion": "3.0.0", + "contentId": "[variables('_dataConnectorContentId2')]", + "contentKind": "DataConnector", + "displayName": "[Recommended] Illusive Platform via AMA (using Azure Functions)", + "contentProductId": "[variables('_dataConnectorcontentProductId2')]", + "id": "[variables('_dataConnectorcontentProductId2')]", + "version": "[variables('dataConnectorVersion2')]" } }, { - "type": "Microsoft.Resources/templateSpecs/versions", - "apiVersion": "2021-05-01", - "name": "[concat(variables('workbookTemplateSpecName1'),'/',variables('workbookVersion1'))]", + "type": "Microsoft.OperationalInsights/workspaces/providers/metadata", + "apiVersion": "2023-04-01-preview", + "name": "[concat(parameters('workspace'),'/Microsoft.SecurityInsights/',concat('DataConnector-', last(split(variables('_dataConnectorId2'),'/'))))]", + "dependsOn": [ + "[variables('_dataConnectorId2')]" + ], + "location": "[parameters('workspace-location')]", + "properties": { + "parentId": "[extensionResourceId(resourceId('Microsoft.OperationalInsights/workspaces', parameters('workspace')), 'Microsoft.SecurityInsights/dataConnectors', variables('_dataConnectorContentId2'))]", + "contentId": "[variables('_dataConnectorContentId2')]", + "kind": "DataConnector", + "version": "[variables('dataConnectorVersion2')]", + "source": { + "kind": "Solution", + "name": "Illusive Platform", + "sourceId": "[variables('_solutionId')]" + }, + "author": { + "name": "Illusive Networks" + }, + "support": { + "name": "Illusive Networks", + "tier": "Partner", + "link": "https://illusive.com/support" + } + } + }, + { + "name": "[concat(parameters('workspace'),'/Microsoft.SecurityInsights/',variables('_dataConnectorContentId2'))]", + "apiVersion": "2021-03-01-preview", + "type": "Microsoft.OperationalInsights/workspaces/providers/dataConnectors", + "location": "[parameters('workspace-location')]", + "kind": "GenericUI", + "properties": { + "connectorUiConfig": { + "title": "[Recommended] Illusive Platform via AMA (using Azure Functions)", + "publisher": "illusive", + "descriptionMarkdown": "The Illusive Platform Connector allows you to share Illusive's attack surface analysis data and incident logs with Microsoft 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": "CommonSecurityLog\n |where DeviceVendor =~ 'illusive'\n |where DeviceProduct =~ 'illusive'\n |extend sent_by_ama = column_ifexists('CollectorHostName','')\n |where isnotempty(sent_by_ama)" + } + ], + "dataTypes": [ + { + "name": "CommonSecurityLog (illusive)", + "lastDataReceivedQuery": "CommonSecurityLog\n |where DeviceVendor =~ 'illusive'\n |where DeviceProduct =~ 'illusive'\n |extend sent_by_ama = column_ifexists('CollectorHostName','')\n |where isnotempty(sent_by_ama)\n | summarize Time = max(TimeGenerated)\n | where isnotempty(Time)" + } + ], + "connectivityCriterias": [ + { + "type": "IsConnectedQuery", + "value": [ + "CommonSecurityLog\n |where DeviceVendor =~ 'illusive'\n |where DeviceProduct =~ 'illusive'\n |extend sent_by_ama = column_ifexists('CollectorHostName','')\n |where isnotempty(sent_by_ama)\n | summarize LastLogReceived = max(TimeGenerated)\n | project IsConnected = LastLogReceived > ago(30d)" + ] + } + ], + "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" + } + ], + "availability": { + "status": 1, + "isPreview": false + }, + "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 + } + } + ], + "customs": [ + { + "description": "To collect data from non-Azure VMs, they must have Azure Arc installed and enabled. [Learn more](https://docs.microsoft.com/azure/azure-monitor/agents/azure-monitor-agent-install?tabs=ARMAgentPowerShell,PowerShellWindows,PowerShellWindowsArc,CLIWindows,CLIWindowsArc)" + }, + { + "description": "Common Event Format (CEF) via AMA and Syslog via AMA data connectors must be installed [Learn more](https://learn.microsoft.com/azure/sentinel/connect-cef-ama#open-the-connector-page-and-create-the-dcr)" + } + ] + }, + "instructionSteps": [ + { + "instructions": [ + { + "parameters": { + "title": "1. Kindly follow the steps to configure the data connector", + "instructionSteps": [ + { + "title": "Step A. Configure the Common Event Format (CEF) via AMA data connector", + "description": "_Note:- CEF logs are collected only from Linux Agents_\n\n1. Navigate to Microsoft Sentinel workspace ---> configuration ---> Data connector blade .\n\n2. Search for 'Common Event Format (CEF) via AMA' data connector and open it.\n\n3. Check If there is no existing DCR configured to collect required facility of logs, Create a new DCR (Data Collection Rule)\n\n\t_Note:- It is recommended to install minimum 1.27 version of AMA agent [Learn more](https://learn.microsoft.com/azure/azure-monitor/agents/azure-monitor-agent-manage?tabs=azure-portal ) and ensure there is no duplicate DCR as it can cause log duplicacy_\n\n4. Run the command provided in the CEF via AMA data connector page to configure the CEF collector on the machine", + "instructions": [] + }, + { + "title": "Step B. 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", + "instructions": [] + }, + { + "title": "Step C. 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\nIt 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\n2. You must have elevated permissions (sudo) on your machine", + "instructions": [ + { + "parameters": { + "label": "Run the following command to validate your connectivity:", + "value": "sudo wget -O Sentinel_AMA_troubleshoot.py https://raw.githubusercontent.com/Azure/Azure-Sentinel/master/DataConnectors/Syslog/Sentinel_AMA_troubleshoot.py&&sudo python Sentinel_AMA_troubleshoot.py --cef" + }, + "type": "CopyableLabel" + } + ] + } + ] + }, + "type": "InstructionStepsGroup" + } + ] + }, + { + "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)", + "title": "2. Secure your machine " + } + ], + "id": "[variables('_uiConfigId2')]" + } + } + }, + { + "type": "Microsoft.OperationalInsights/workspaces/providers/contentTemplates", + "apiVersion": "2023-04-01-preview", + "name": "[variables('workbookTemplateSpecName1')]", "location": "[parameters('workspace-location')]", - "tags": { - "hidden-sentinelWorkspaceId": "[variables('workspaceResourceId')]", - "hidden-sentinelContentType": "Workbook" - }, "dependsOn": [ - "[resourceId('Microsoft.Resources/templateSpecs', variables('workbookTemplateSpecName1'))]" + "[extensionResourceId(resourceId('Microsoft.OperationalInsights/workspaces', parameters('workspace')), 'Microsoft.SecurityInsights/contentPackages', variables('_solutionId'))]" ], "properties": { - "description": "IllusiveADSWorkbook Workbook with template version 2.0.1", + "description": "IllusiveADSWorkbook Workbook with template version 3.0.0", "mainTemplate": { "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#", "contentVersion": "[variables('workbookVersion1')]", @@ -481,7 +815,7 @@ }, "properties": { "displayName": "[parameters('workbook1-name')]", - "serializedData": "{\"version\":\"Notebook/1.0\",\"items\":[{\"type\":1,\"content\":{\"json\":\"## Illusive ADS Dashboard\\n\"},\"name\":\"text - 2\"},{\"type\":1,\"content\":{\"json\":\"\\n\"},\"customWidth\":\"65\",\"name\":\"text - 2 - Copy\"},{\"type\":9,\"content\":{\"version\":\"KqlParameterItem/1.0\",\"parameters\":[{\"id\":\"e5b79f84-7773-4162-9750-702cd0001041\",\"version\":\"KqlParameterItem/1.0\",\"name\":\"NumberOfDays\",\"label\":\"Number of Days \",\"type\":2,\"description\":\"Select range of days to query\",\"isRequired\":true,\"value\":\"30\",\"jsonData\":\"[1,7,14,21,30]\",\"resourceType\":\"microsoft.insights/components\"},{\"id\":\"ba9324e9-07f9-49dc-81b6-f87833a09afc\",\"version\":\"KqlParameterItem/1.0\",\"name\":\"ManagementIP\",\"label\":\"Management IP\",\"type\":2,\"description\":\"Filter managment ip\",\"isRequired\":true,\"multiSelect\":true,\"quote\":\"'\",\"delimiter\":\",\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:login\\\" or DeviceEventClassID == \\\"illusive:access\\\" or DeviceEventClassID == \\\"illusive:suspicious\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nwhere DeviceAddress != \\\"\\\" |\\r\\nsummarize count() by DeviceAddress | \\r\\nproject DeviceAddress\\r\\n\",\"value\":[\"value::all\"],\"typeSettings\":{\"additionalResourceOptions\":[\"value::all\"],\"selectAllValue\":\"All\"},\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\"}],\"style\":\"pills\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\"},\"customWidth\":\"35\",\"name\":\"parameters - 6\",\"styleSettings\":{\"margin\":\"0px\",\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"let binSize = iff({NumberOfDays} > 1, 1d, 1h);\\nunion CommonSecurityLog | \\nwhere (DeviceEventClassID == \\\"illusive:login\\\" or DeviceEventClassID == \\\"illusive:access\\\" or DeviceEventClassID == \\\"illusive:suspicious\\\")|\\nwhere Message !contains \\\"hasForensics\\\" |\\nwhere TimeGenerated > ago({NumberOfDays}d) | \\nwhere \\\"{ManagementIP}\\\" contains \\\"All\\\" or \\\"{ManagementIP}\\\" contains DeviceAddress |\\nextend DeviceCustomNumber2 = coalesce(column_ifexists(\\\"FieldDeviceCustomNumber2\\\", long(null)),DeviceCustomNumber2) |\\nsummarize by bin(TimeGenerated,binSize) ,DeviceCustomNumber2 |\\nmake-series event_count=count() default=0 on TimeGenerated in range (ago({NumberOfDays}d), now(), binSize) |\\nmvexpand TimeGenerated, event_count |\\nproject todatetime(TimeGenerated), toint(event_count)\",\"size\":0,\"aggregation\":3,\"title\":\"Incidents over time\",\"timeContext\":{\"durationMs\":2592000000},\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"linechart\",\"chartSettings\":{\"seriesLabelSettings\":[{\"seriesName\":\"event_count\",\"color\":\"red\"}]}},\"customWidth\":\"50\",\"name\":\"Incidents over time\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"let binSize = iff({NumberOfDays} > 1, 1d, 1h);\\nunion CommonSecurityLog | \\nwhere (DeviceEventClassID == \\\"illusive:login\\\" or DeviceEventClassID == \\\"illusive:access\\\" or DeviceEventClassID == \\\"illusive:suspicious\\\")|\\nwhere Message !contains \\\"hasForensics\\\" |\\nwhere TimeGenerated > ago({NumberOfDays}d) | \\nwhere \\\"{ManagementIP}\\\" contains \\\"All\\\" or \\\"{ManagementIP}\\\" contains DeviceAddress |\\nsummarize by bin(TimeGenerated,binSize) ,ExternalID |\\nmake-series event_count=count() default=0 on TimeGenerated in range (ago({NumberOfDays}d), now(), binSize) |\\nmvexpand TimeGenerated, event_count |\\nproject todatetime(TimeGenerated), toint(event_count)\",\"size\":0,\"aggregation\":3,\"title\":\"Events over time\",\"timeContext\":{\"durationMs\":2592000000},\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"linechart\",\"chartSettings\":{\"seriesLabelSettings\":[{\"seriesName\":\"event_count\",\"color\":\"yellow\"}]}},\"customWidth\":\"50\",\"name\":\"Events over time\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"let binSize = iff({NumberOfDays} > 1, 1d, 1h);\\r\\nunion CommonSecurityLog \\r\\n| extend DeviceCustomNumber2 = coalesce(column_ifexists(\\\"FieldDeviceCustomNumber2\\\", long(null)),DeviceCustomNumber2)\\r\\n | where (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,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"group\":\"DestinationServiceName\",\"createOtherGroup\":8}},\"customWidth\":\"33\",\"name\":\"TriggerType\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog \\r\\n| extend DeviceCustomNumber2 = coalesce(column_ifexists(\\\"FieldDeviceCustomNumber2\\\", long(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,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"group\":\"DeviceEventClassID\",\"createOtherGroup\":8}},\"customWidth\":\"33\",\"name\":\"EventType\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog| \\r\\nextend DeviceCustomNumber2 = coalesce(column_ifexists(\\\"FieldDeviceCustomNumber2\\\", long(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,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"table\",\"chartSettings\":{\"group\":\"DeviceEventClassID\",\"createOtherGroup\":8}},\"customWidth\":\"33\",\"name\":\"TopHosts\"}],\"fromTemplateId\":\"sentinel-IllusiveADS\",\"$schema\":\"https://github.com/Microsoft/Application-Insights-Workbooks/blob/master/schema/workbook.json\"}\r\n", + "serializedData": "{\"version\":\"Notebook/1.0\",\"items\":[{\"type\":1,\"content\":{\"json\":\"## Illusive ADS Dashboard\\n\"},\"name\":\"text - 2\"},{\"type\":1,\"content\":{\"json\":\"\\n\"},\"customWidth\":\"65\",\"name\":\"text - 2 - Copy\"},{\"type\":9,\"content\":{\"version\":\"KqlParameterItem/1.0\",\"parameters\":[{\"id\":\"e5b79f84-7773-4162-9750-702cd0001041\",\"version\":\"KqlParameterItem/1.0\",\"name\":\"NumberOfDays\",\"label\":\"Number of Days \",\"type\":2,\"description\":\"Select range of days to query\",\"isRequired\":true,\"value\":\"30\",\"typeSettings\":{\"additionalResourceOptions\":[]},\"jsonData\":\"[1,7,14,21,30]\",\"resourceType\":\"microsoft.insights/components\"},{\"id\":\"ba9324e9-07f9-49dc-81b6-f87833a09afc\",\"version\":\"KqlParameterItem/1.0\",\"name\":\"ManagementIP\",\"label\":\"Management IP\",\"type\":2,\"description\":\"Filter managment ip\",\"isRequired\":true,\"multiSelect\":true,\"quote\":\"'\",\"delimiter\":\",\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:login\\\" or DeviceEventClassID == \\\"illusive:access\\\" or DeviceEventClassID == \\\"illusive:suspicious\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nwhere DeviceAddress != \\\"\\\" |\\r\\nsummarize count() by DeviceAddress | \\r\\nproject DeviceAddress\\r\\n\",\"value\":[\"value::all\"],\"typeSettings\":{\"additionalResourceOptions\":[\"value::all\"],\"selectAllValue\":\"All\"},\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\"}],\"style\":\"pills\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\"},\"customWidth\":\"35\",\"name\":\"parameters - 6\",\"styleSettings\":{\"margin\":\"0px\",\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"let binSize = iff({NumberOfDays} > 1, 1d, 1h);\\nunion CommonSecurityLog | \\nwhere (DeviceEventClassID == \\\"illusive:login\\\" or DeviceEventClassID == \\\"illusive:access\\\" or DeviceEventClassID == \\\"illusive:suspicious\\\")|\\nwhere Message !contains \\\"hasForensics\\\" |\\nwhere TimeGenerated > ago({NumberOfDays}d) | \\nwhere \\\"{ManagementIP}\\\" contains \\\"All\\\" or \\\"{ManagementIP}\\\" contains DeviceAddress |\\nextend DeviceCustomNumber2 = coalesce(column_ifexists(\\\"FieldDeviceCustomNumber2\\\", long(null)),DeviceCustomNumber2) |\\nsummarize by bin(TimeGenerated,binSize) ,DeviceCustomNumber2 |\\nmake-series event_count=count() default=0 on TimeGenerated in range (ago({NumberOfDays}d), now(), binSize) |\\nmvexpand TimeGenerated, event_count |\\nproject todatetime(TimeGenerated), toint(event_count)\",\"size\":0,\"aggregation\":3,\"title\":\"Incidents over time\",\"timeContext\":{\"durationMs\":2592000000},\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"linechart\",\"chartSettings\":{\"seriesLabelSettings\":[{\"seriesName\":\"event_count\",\"color\":\"red\"}]}},\"customWidth\":\"50\",\"name\":\"Incidents over time\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"let binSize = iff({NumberOfDays} > 1, 1d, 1h);\\nunion CommonSecurityLog | \\nwhere (DeviceEventClassID == \\\"illusive:login\\\" or DeviceEventClassID == \\\"illusive:access\\\" or DeviceEventClassID == \\\"illusive:suspicious\\\")|\\nwhere Message !contains \\\"hasForensics\\\" |\\nwhere TimeGenerated > ago({NumberOfDays}d) | \\nwhere \\\"{ManagementIP}\\\" contains \\\"All\\\" or \\\"{ManagementIP}\\\" contains DeviceAddress |\\nsummarize by bin(TimeGenerated,binSize) ,ExternalID |\\nmake-series event_count=count() default=0 on TimeGenerated in range (ago({NumberOfDays}d), now(), binSize) |\\nmvexpand TimeGenerated, event_count |\\nproject todatetime(TimeGenerated), toint(event_count)\",\"size\":0,\"aggregation\":3,\"title\":\"Events over time\",\"timeContext\":{\"durationMs\":2592000000},\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"linechart\",\"chartSettings\":{\"seriesLabelSettings\":[{\"seriesName\":\"event_count\",\"color\":\"yellow\"}]}},\"customWidth\":\"50\",\"name\":\"Events over time\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"let binSize = iff({NumberOfDays} > 1, 1d, 1h);\\r\\nunion CommonSecurityLog \\r\\n| extend DeviceCustomNumber2 = coalesce(column_ifexists(\\\"FieldDeviceCustomNumber2\\\", long(null)),DeviceCustomNumber2)\\r\\n | where (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,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"group\":\"DestinationServiceName\",\"createOtherGroup\":8}},\"customWidth\":\"33\",\"name\":\"TriggerType\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog \\r\\n| extend DeviceCustomNumber2 = coalesce(column_ifexists(\\\"FieldDeviceCustomNumber2\\\", long(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,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"group\":\"DeviceEventClassID\",\"createOtherGroup\":8}},\"customWidth\":\"33\",\"name\":\"EventType\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog| \\r\\nextend DeviceCustomNumber2 = coalesce(column_ifexists(\\\"FieldDeviceCustomNumber2\\\", long(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,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"table\",\"chartSettings\":{\"group\":\"DeviceEventClassID\",\"createOtherGroup\":8}},\"customWidth\":\"33\",\"name\":\"TopHosts\"}],\"fromTemplateId\":\"sentinel-IllusiveADS\",\"$schema\":\"https://github.com/Microsoft/Application-Insights-Workbooks/blob/master/schema/workbook.json\"}\n", "version": "1.0", "sourceId": "[variables('workspaceResourceId')]", "category": "sentinel" @@ -509,41 +843,51 @@ "name": "Illusive Networks", "tier": "Partner", "link": "https://illusive.com/support" + }, + "dependencies": { + "operator": "AND", + "criteria": [ + { + "contentId": "CommonSecurityLog", + "kind": "DataType" + }, + { + "contentId": "illusiveAttackManagementSystem", + "kind": "DataConnector" + }, + { + "contentId": "illusiveAttackManagementSystemAma", + "kind": "DataConnector" + } + ] } } } ] - } + }, + "packageKind": "Solution", + "packageVersion": "[variables('_solutionVersion')]", + "packageName": "[variables('_solutionName')]", + "packageId": "[variables('_solutionId')]", + "contentSchemaVersion": "3.0.0", + "contentId": "[variables('_workbookContentId1')]", + "contentKind": "Workbook", + "displayName": "[parameters('workbook1-name')]", + "contentProductId": "[variables('_workbookcontentProductId1')]", + "id": "[variables('_workbookcontentProductId1')]", + "version": "[variables('workbookVersion1')]" } }, { - "type": "Microsoft.Resources/templateSpecs", - "apiVersion": "2021-05-01", + "type": "Microsoft.OperationalInsights/workspaces/providers/contentTemplates", + "apiVersion": "2023-04-01-preview", "name": "[variables('workbookTemplateSpecName2')]", "location": "[parameters('workspace-location')]", - "tags": { - "hidden-sentinelWorkspaceId": "[variables('workspaceResourceId')]", - "hidden-sentinelContentType": "Workbook" - }, - "properties": { - "description": "Illusive Platform Workbook with template", - "displayName": "Illusive Platform workbook template" - } - }, - { - "type": "Microsoft.Resources/templateSpecs/versions", - "apiVersion": "2021-05-01", - "name": "[concat(variables('workbookTemplateSpecName2'),'/',variables('workbookVersion2'))]", - "location": "[parameters('workspace-location')]", - "tags": { - "hidden-sentinelWorkspaceId": "[variables('workspaceResourceId')]", - "hidden-sentinelContentType": "Workbook" - }, "dependsOn": [ - "[resourceId('Microsoft.Resources/templateSpecs', variables('workbookTemplateSpecName2'))]" + "[extensionResourceId(resourceId('Microsoft.OperationalInsights/workspaces', parameters('workspace')), 'Microsoft.SecurityInsights/contentPackages', variables('_solutionId'))]" ], "properties": { - "description": "IllusiveASMWorkbook Workbook with template version 2.0.1", + "description": "IllusiveASMWorkbook Workbook with template version 3.0.0", "mainTemplate": { "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#", "contentVersion": "[variables('workbookVersion2')]", @@ -561,7 +905,7 @@ }, "properties": { "displayName": "[parameters('workbook2-name')]", - "serializedData": "{\"version\":\"Notebook/1.0\",\"items\":[{\"type\":1,\"content\":{\"json\":\"## Illusive ASM Dashboard\\n\"},\"name\":\"text - 2\"},{\"type\":1,\"content\":{\"json\":\"\\n\"},\"customWidth\":\"80\",\"name\":\"text - 2 - Copy\"},{\"type\":9,\"content\":{\"version\":\"KqlParameterItem/1.0\",\"parameters\":[{\"id\":\"e5b79f84-7773-4162-9750-702cd0001041\",\"version\":\"KqlParameterItem/1.0\",\"name\":\"NumberOfDays\",\"label\":\"Number of Days \",\"type\":2,\"description\":\"Select range of days to query\",\"isRequired\":true,\"value\":\"14\",\"jsonData\":\"[1,7,14,21,30]\"}],\"style\":\"pills\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\"},\"customWidth\":\"20\",\"name\":\"parameters - 6\",\"styleSettings\":{\"margin\":\"0px\",\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize count = count() by ViolationType = DeviceCustomString1 \\r\\n\\r\\n\",\"size\":0,\"title\":\"Violation Types\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"yAxis\":[\"count\"],\"group\":\"ViolationType\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Violation Types\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"let binSize = iff({NumberOfDays} > 1, 1d, 1h);\\nunion CommonSecurityLog | \\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\nwhere TimeGenerated > ago({NumberOfDays}d) | \\nmake-series event_count=count() default=0 on TimeGenerated in range (ago({NumberOfDays}d), now(), binSize) |\\nmvexpand TimeGenerated, event_count |\\nproject todatetime(TimeGenerated), toint(event_count)\",\"size\":0,\"aggregation\":3,\"title\":\"Violations Over Time\",\"timeContext\":{\"durationMs\":2592000000},\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"linechart\",\"chartSettings\":{\"seriesLabelSettings\":[{\"seriesName\":\"event_count\",\"color\":\"yellow\"}]}},\"customWidth\":\"50\",\"name\":\"Violations Trendline\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":1,\"content\":{\"json\":\"\\r\\n## Domain User Credentials\"},\"name\":\"text - 9\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"USER_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingHost = SourceHostName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Domain User Credentials - Top Violating Hosts\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingHost\",\"createOtherGroup\":6}},\"customWidth\":\"50\",\"name\":\"Domain User Credentials Top Violating Hosts\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"USER_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingUsers = SourceUserName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Domain User Credentials - Top Violating Users\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingUsers\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Domain User Credentials Top Violating Users\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":1,\"content\":{\"json\":\"\\r\\n## Crown Jewel Connections\"},\"name\":\"text - 9 - Copy\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"CROWN_JEWEL_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingHost = SourceHostName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Crown Jewel Connections - Top Violating Hosts\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingHost\",\"createOtherGroup\":6}},\"customWidth\":\"33\",\"name\":\"Crown Jewel Connections Top Violating Hosts\",\"styleSettings\":{\"maxWidth\":\"33\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"CROWN_JEWEL_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by CrownJewelType = DeviceCustomString6 |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Crown Jewel Connections - Crown Jewel Types\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"CrownJewelType\",\"createOtherGroup\":6}},\"customWidth\":\"33\",\"name\":\"Crown Jewel Connections - Crown Jewel Types\",\"styleSettings\":{\"maxWidth\":\"33\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"CROWN_JEWEL_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by ServiceType = DeviceCustomString4 |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Crown Jewel Connections - Service Types\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"ServiceType\",\"createOtherGroup\":8}},\"customWidth\":\"33\",\"name\":\"Crown Jewel Connections - Service Types\",\"styleSettings\":{\"maxWidth\":\"33\"}},{\"type\":1,\"content\":{\"json\":\"\\r\\n## Local User Administrators\"},\"name\":\"text - 9 - Copy - Copy\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"LOCAL_USER_ADMINISTRATORS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingHost = SourceHostName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Local User Administrators - Top Violating Hosts\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingHost\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Local User Administrators Top Violating Hosts\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"LOCAL_USER_ADMINISTRATORS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingUsers = SourceUserName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Local User Administrators - Top Violating Users\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingUsers\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Local User Administrators - Top Violating Users\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":1,\"content\":{\"json\":\"\\r\\n## Suspicious Files\"},\"name\":\"text - 9 - Copy - Copy - Copy\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"SUSPICIOUS_FILES\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopSuspiciousFilesHashes = DeviceCustomString3 |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Suspicious Files - Top Violating Processes\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"table\",\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingHost\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Suspicious Files Top Violating Hosts\",\"styleSettings\":{\"maxWidth\":\"50\"}}],\"fromTemplateId\":\"sentinel-IllusiveASM\",\"$schema\":\"https://github.com/Microsoft/Application-Insights-Workbooks/blob/master/schema/workbook.json\"}\r\n", + "serializedData": "{\"version\":\"Notebook/1.0\",\"items\":[{\"type\":1,\"content\":{\"json\":\"## Illusive ASM Dashboard\\n\"},\"name\":\"text - 2\"},{\"type\":1,\"content\":{\"json\":\"\\n\"},\"customWidth\":\"80\",\"name\":\"text - 2 - Copy\"},{\"type\":9,\"content\":{\"version\":\"KqlParameterItem/1.0\",\"parameters\":[{\"id\":\"e5b79f84-7773-4162-9750-702cd0001041\",\"version\":\"KqlParameterItem/1.0\",\"name\":\"NumberOfDays\",\"label\":\"Number of Days \",\"type\":2,\"description\":\"Select range of days to query\",\"isRequired\":true,\"value\":\"14\",\"typeSettings\":{\"additionalResourceOptions\":[]},\"jsonData\":\"[1,7,14,21,30]\"}],\"style\":\"pills\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\"},\"customWidth\":\"20\",\"name\":\"parameters - 6\",\"styleSettings\":{\"margin\":\"0px\",\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize count = count() by ViolationType = DeviceCustomString1 \\r\\n\\r\\n\",\"size\":0,\"title\":\"Violation Types\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"yAxis\":[\"count\"],\"group\":\"ViolationType\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Violation Types\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"let binSize = iff({NumberOfDays} > 1, 1d, 1h);\\nunion CommonSecurityLog | \\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\nwhere TimeGenerated > ago({NumberOfDays}d) | \\nmake-series event_count=count() default=0 on TimeGenerated in range (ago({NumberOfDays}d), now(), binSize) |\\nmvexpand TimeGenerated, event_count |\\nproject todatetime(TimeGenerated), toint(event_count)\",\"size\":0,\"aggregation\":3,\"title\":\"Violations Over Time\",\"timeContext\":{\"durationMs\":2592000000},\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"linechart\",\"chartSettings\":{\"seriesLabelSettings\":[{\"seriesName\":\"event_count\",\"color\":\"yellow\"}]}},\"customWidth\":\"50\",\"name\":\"Violations Trendline\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":1,\"content\":{\"json\":\"\\r\\n## Domain User Credentials\"},\"name\":\"text - 9\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"USER_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingHost = SourceHostName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Domain User Credentials - Top Violating Hosts\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingHost\",\"createOtherGroup\":6}},\"customWidth\":\"50\",\"name\":\"Domain User Credentials Top Violating Hosts\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"USER_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingUsers = SourceUserName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Domain User Credentials - Top Violating Users\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingUsers\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Domain User Credentials Top Violating Users\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":1,\"content\":{\"json\":\"\\r\\n## Crown Jewel Connections\"},\"name\":\"text - 9 - Copy\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"CROWN_JEWEL_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingHost = SourceHostName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Crown Jewel Connections - Top Violating Hosts\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingHost\",\"createOtherGroup\":6}},\"customWidth\":\"33\",\"name\":\"Crown Jewel Connections Top Violating Hosts\",\"styleSettings\":{\"maxWidth\":\"33\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"CROWN_JEWEL_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by CrownJewelType = DeviceCustomString6 |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Crown Jewel Connections - Crown Jewel Types\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"CrownJewelType\",\"createOtherGroup\":6}},\"customWidth\":\"33\",\"name\":\"Crown Jewel Connections - Crown Jewel Types\",\"styleSettings\":{\"maxWidth\":\"33\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"CROWN_JEWEL_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by ServiceType = DeviceCustomString4 |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Crown Jewel Connections - Service Types\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"ServiceType\",\"createOtherGroup\":8}},\"customWidth\":\"33\",\"name\":\"Crown Jewel Connections - Service Types\",\"styleSettings\":{\"maxWidth\":\"33\"}},{\"type\":1,\"content\":{\"json\":\"\\r\\n## Local User Administrators\"},\"name\":\"text - 9 - Copy - Copy\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"LOCAL_USER_ADMINISTRATORS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingHost = SourceHostName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Local User Administrators - Top Violating Hosts\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingHost\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Local User Administrators Top Violating Hosts\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"LOCAL_USER_ADMINISTRATORS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingUsers = SourceUserName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Local User Administrators - Top Violating Users\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingUsers\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Local User Administrators - Top Violating Users\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":1,\"content\":{\"json\":\"\\r\\n## Suspicious Files\"},\"name\":\"text - 9 - Copy - Copy - Copy\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"SUSPICIOUS_FILES\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopSuspiciousFilesHashes = DeviceCustomString3 |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Suspicious Files - Top Violating Processes\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"table\",\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingHost\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Suspicious Files Top Violating Hosts\",\"styleSettings\":{\"maxWidth\":\"50\"}}],\"fromTemplateId\":\"sentinel-IllusiveASM\",\"$schema\":\"https://github.com/Microsoft/Application-Insights-Workbooks/blob/master/schema/workbook.json\"}\n", "version": "1.0", "sourceId": "[variables('workspaceResourceId')]", "category": "sentinel" @@ -589,41 +933,51 @@ "name": "Illusive Networks", "tier": "Partner", "link": "https://illusive.com/support" + }, + "dependencies": { + "operator": "AND", + "criteria": [ + { + "contentId": "CommonSecurityLog", + "kind": "DataType" + }, + { + "contentId": "illusiveAttackManagementSystem", + "kind": "DataConnector" + }, + { + "contentId": "illusiveAttackManagementSystemAma", + "kind": "DataConnector" + } + ] } } } ] - } + }, + "packageKind": "Solution", + "packageVersion": "[variables('_solutionVersion')]", + "packageName": "[variables('_solutionName')]", + "packageId": "[variables('_solutionId')]", + "contentSchemaVersion": "3.0.0", + "contentId": "[variables('_workbookContentId2')]", + "contentKind": "Workbook", + "displayName": "[parameters('workbook2-name')]", + "contentProductId": "[variables('_workbookcontentProductId2')]", + "id": "[variables('_workbookcontentProductId2')]", + "version": "[variables('workbookVersion2')]" } }, { - "type": "Microsoft.Resources/templateSpecs", - "apiVersion": "2021-05-01", + "type": "Microsoft.OperationalInsights/workspaces/providers/contentTemplates", + "apiVersion": "2023-04-01-preview", "name": "[variables('analyticRuleTemplateSpecName1')]", "location": "[parameters('workspace-location')]", - "tags": { - "hidden-sentinelWorkspaceId": "[variables('workspaceResourceId')]", - "hidden-sentinelContentType": "AnalyticsRule" - }, - "properties": { - "description": "Illusive Platform Analytics Rule 1 with template", - "displayName": "Illusive Platform Analytics Rule template" - } - }, - { - "type": "Microsoft.Resources/templateSpecs/versions", - "apiVersion": "2021-05-01", - "name": "[concat(variables('analyticRuleTemplateSpecName1'),'/',variables('analyticRuleVersion1'))]", - "location": "[parameters('workspace-location')]", - "tags": { - "hidden-sentinelWorkspaceId": "[variables('workspaceResourceId')]", - "hidden-sentinelContentType": "AnalyticsRule" - }, "dependsOn": [ - "[resourceId('Microsoft.Resources/templateSpecs', variables('analyticRuleTemplateSpecName1'))]" + "[extensionResourceId(resourceId('Microsoft.OperationalInsights/workspaces', parameters('workspace')), 'Microsoft.SecurityInsights/contentPackages', variables('_solutionId'))]" ], "properties": { - "description": "Illusive_Detection_Query_AnalyticalRules Analytics Rule with template version 2.0.1", + "description": "Illusive_Detection_Query_AnalyticalRules Analytics Rule with template version 3.0.0", "mainTemplate": { "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#", "contentVersion": "[variables('analyticRuleVersion1')]", @@ -632,7 +986,7 @@ "resources": [ { "type": "Microsoft.SecurityInsights/AlertRuleTemplates", - "name": "[variables('AnalyticRulecontentId1')]", + "name": "[variables('analyticRulecontentId1')]", "apiVersion": "2022-04-01-preview", "kind": "Scheduled", "location": "[parameters('workspace-location')]", @@ -651,10 +1005,16 @@ "status": "Available", "requiredDataConnectors": [ { + "connectorId": "Illusive", "dataTypes": [ "CommonSecurityLog" - ], - "connectorId": "Illusive" + ] + }, + { + "connectorId": "illusiveAttackManagementSystemAma", + "dataTypes": [ + "CommonSecurityLog" + ] } ], "entityMappings": [ @@ -691,12 +1051,12 @@ }, "customDetails": { "Account": "SourceUserName", - "IllusiveIncidentId": "[variables('_IllusiveIncident')]", - "HasForensics": "HasForensics" + "HasForensics": "HasForensics", + "IllusiveIncidentId": "IncidentId" }, "alertDetailsOverride": { - "alertDescriptionFormat": "Illusive Incident {{IncidentId}} generated at {{TimeGenerated}}\n", - "alertDisplayNameFormat": "Illusive Incident: {{IncidentId}}\n" + "alertDisplayNameFormat": "Illusive Incident: {{IncidentId}}\n", + "alertDescriptionFormat": "Illusive Incident {{IncidentId}} generated at {{TimeGenerated}}\n" } } }, @@ -726,17 +1086,35 @@ } } ] - } + }, + "packageKind": "Solution", + "packageVersion": "[variables('_solutionVersion')]", + "packageName": "[variables('_solutionName')]", + "packageId": "[variables('_solutionId')]", + "contentSchemaVersion": "3.0.0", + "contentId": "[variables('_analyticRulecontentId1')]", + "contentKind": "AnalyticsRule", + "displayName": "Illusive Incidents Analytic Rule", + "contentProductId": "[variables('_analyticRulecontentProductId1')]", + "id": "[variables('_analyticRulecontentProductId1')]", + "version": "[variables('analyticRuleVersion1')]" } }, { - "type": "Microsoft.OperationalInsights/workspaces/providers/metadata", - "apiVersion": "2022-01-01-preview", + "type": "Microsoft.OperationalInsights/workspaces/providers/contentPackages", + "apiVersion": "2023-04-01-preview", "location": "[parameters('workspace-location')]", "properties": { - "version": "2.0.1", + "version": "3.0.0", "kind": "Solution", - "contentSchemaVersion": "2.0.0", + "contentSchemaVersion": "3.0.0", + "displayName": "Illusive Platform", + "publisherDisplayName": "Illusive Networks", + "descriptionHtml": "

Note: There may be known issues pertaining to this Solution, please refer to them before installing.

\n

The Illusive Platform solution for Microsoft Sentinel enables you to ingest Illusive Platform’s attack surface analysis data and incident logs into Microsoft 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).

\n
    \n
  1. Illusive Platform via AMA - This data connector helps in ingesting Illusive Platform logs into your Log Analytics Workspace using the new Azure Monitor Agent. Learn more about ingesting using the new Azure Monitor Agent here. Microsoft recommends using this Data Connector.

    \n
  2. \n
  3. Illusive Platform via Legacy Agent - This data connector helps in ingesting Illusive Platform logs into your Log Analytics Workspace using the legacy Log Analytics agent.

    \n
  4. \n
\n

NOTE: Microsoft recommends installation of Illusive Platform via AMA Connector. Legacy connector uses the Log Analytics agent which is about to be deprecated by Aug 31, 2024, and thus should only be installed where AMA is not supported. Using MMA and AMA on same machine can cause log duplication and extra ingestion cost more details.

\n

Data Connectors: 2, Workbooks: 2, Analytic Rules: 1

\n

Learn more about Microsoft Sentinel | Learn more about Solutions

\n", + "contentKind": "Solution", + "contentProductId": "[variables('_solutioncontentProductId')]", + "id": "[variables('_solutioncontentProductId')]", + "icon": "", "contentId": "[variables('_solutionId')]", "parentId": "[variables('_solutionId')]", "source": { @@ -760,6 +1138,11 @@ "contentId": "[variables('_dataConnectorContentId1')]", "version": "[variables('dataConnectorVersion1')]" }, + { + "kind": "DataConnector", + "contentId": "[variables('_dataConnectorContentId2')]", + "version": "[variables('dataConnectorVersion2')]" + }, { "kind": "Workbook", "contentId": "[variables('_workbookContentId1')]", From c1306d6e107b72e35a1881e4ec91335a5ca9450c Mon Sep 17 00:00:00 2001 From: v-rusraut Date: Thu, 14 Sep 2023 11:50:29 +0530 Subject: [PATCH 3/6] update CreateUi and added Release Notes --- Solutions/Illusive Platform/Package/3.0.0.zip | Bin 13172 -> 13817 bytes .../Package/createUiDefinition.json | 14 +++------- .../Package/mainTemplate.json | 26 +++++++++--------- Solutions/Illusive Platform/ReleaseNotes.md | 5 ++++ 4 files changed, 22 insertions(+), 23 deletions(-) create mode 100644 Solutions/Illusive Platform/ReleaseNotes.md diff --git a/Solutions/Illusive Platform/Package/3.0.0.zip b/Solutions/Illusive Platform/Package/3.0.0.zip index d6ca9741d026ffd22776d36a76291079703a8c71..3e24b55c5fe1baa50b24577b0fed4cad78b93d3b 100644 GIT binary patch literal 13817 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 literal 13172 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 J4d(wj{Xa7xhXw!u diff --git a/Solutions/Illusive Platform/Package/createUiDefinition.json b/Solutions/Illusive Platform/Package/createUiDefinition.json index c49836ad5b2..34b0bf9b3de 100644 --- a/Solutions/Illusive Platform/Package/createUiDefinition.json +++ b/Solutions/Illusive Platform/Package/createUiDefinition.json @@ -6,7 +6,7 @@ "config": { "isWizard": false, "basics": { - "description": "\n\n**Note:** _There may be [known issues](https://aka.ms/sentinelsolutionsknownissues) pertaining to this Solution, please refer to them before installing._\n\nThe Illusive Platform solution for Microsoft Sentinel enables you to ingest Illusive Platform’s attack surface analysis data and incident logs into Microsoft 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).\n\r\n1. **Illusive Platform via AMA** - This data connector helps in ingesting Illusive Platform logs into your Log Analytics Workspace using the new Azure Monitor Agent. Learn more about ingesting using the new Azure Monitor Agent [here](https://learn.microsoft.com/azure/sentinel/connect-cef-ama). **Microsoft recommends using this Data Connector**.\n\r\n2. **Illusive Platform via Legacy Agent** - This data connector helps in ingesting Illusive Platform logs into your Log Analytics Workspace using the legacy Log Analytics agent.\n\n**NOTE:** Microsoft recommends installation of Illusive Platform via AMA Connector. Legacy connector uses the Log Analytics agent which is about to be deprecated by **Aug 31, 2024,** and thus should only be installed where AMA is not supported. Using MMA and AMA on same machine can cause log duplication and extra ingestion cost [more details](https://learn.microsoft.com/en-us/azure/sentinel/ama-migrate).\n\n**Data Connectors:** 2, **Workbooks:** 2, **Analytic Rules:** 1\n\n[Learn more about Microsoft Sentinel](https://aka.ms/azuresentinel) | [Learn more about Solutions](https://aka.ms/azuresentinelsolutionsdoc)", + "description": "\n\n**Note:** Please refer to the following before installing the solution: \r \n • Review the solution [Release Notes](https://github.com/Azure/Azure-Sentinel/tree/master/Solutions/OSSEC/ReleaseNotes.md)\r \n • There may be [known issues](https://aka.ms/sentinelsolutionsknownissues) pertaining to this Solution, please refer to them before installing.\n\nThe Illusive Platform solution for Microsoft Sentinel enables you to ingest Illusive Platform’s attack surface analysis data and incident logs into Microsoft 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).\n\r\n1. **Illusive Platform via AMA** - This data connector helps in ingesting Illusive Platform logs into your Log Analytics Workspace using the new Azure Monitor Agent. Learn more about ingesting using the new Azure Monitor Agent [here](https://learn.microsoft.com/azure/sentinel/connect-cef-ama). **Microsoft recommends using this Data Connector**.\n\r\n2. **Illusive Platform via Legacy Agent** - This data connector helps in ingesting Illusive Platform logs into your Log Analytics Workspace using the legacy Log Analytics agent.\n\n**NOTE:** Microsoft recommends installation of Illusive Platform via AMA Connector. Legacy connector uses the Log Analytics agent which is about to be deprecated by **Aug 31, 2024,** and thus should only be installed where AMA is not supported. Using MMA and AMA on same machine can cause log duplication and extra ingestion cost [more details](https://learn.microsoft.com/en-us/azure/sentinel/ama-migrate).\n\n**Data Connectors:** 2, **Workbooks:** 2, **Analytic Rules:** 1\n\n[Learn more about Microsoft Sentinel](https://aka.ms/azuresentinel) | [Learn more about Solutions](https://aka.ms/azuresentinelsolutionsdoc)", "subscription": { "resourceProviders": [ "Microsoft.OperationsManagement/solutions", @@ -60,7 +60,7 @@ "name": "dataconnectors1-text", "type": "Microsoft.Common.TextBlock", "options": { - "text": "This Solution installs the data connector for Illusive Platform. You can get Illusive Platform CommonSecurityLog data in your Microsoft Sentinel workspace. After installing the solution, configure and enable this data connector by following guidance in Manage solution view." + "text": "This solution installs the data connector to ingest Illusive attack surface management and threat detection data in Common Event Format (CEF) into Microsoft Sentinel. After installing the solution, configure and enable this data connector by following guidance in Manage solution view." } }, { @@ -72,21 +72,15 @@ "uri": "https://docs.microsoft.com/azure/sentinel/connect-data-sources" } } - }, - { - "name": "dataconnectors2-text", - "type": "Microsoft.Common.TextBlock", - "options": { - "text": "This Solution installs the data connector for Illusive Platform. You can get Illusive Platform CommonSecurityLog data in your Microsoft Sentinel workspace. After installing the solution, configure and enable this data connector by following guidance in Manage solution view." - } } + ] }, { "name": "workbooks", "label": "Workbooks", "subLabel": { - "preValidation": "Configure the workbooks", + "preValidation": "Configure the This Solution installs the data connector for Illusive Platform. You can get Illusive Platform CommonSecurityLog data in your Microsoft Sentinel workspace. After installing the solution, configure and enable this data connector by following guidance in Manage solution view.", "postValidation": "Done" }, "bladeTitle": "Workbooks", diff --git a/Solutions/Illusive Platform/Package/mainTemplate.json b/Solutions/Illusive Platform/Package/mainTemplate.json index 9b8f195ad20..d5afaeb49ad 100644 --- a/Solutions/Illusive Platform/Package/mainTemplate.json +++ b/Solutions/Illusive Platform/Package/mainTemplate.json @@ -468,7 +468,7 @@ "properties": { "connectorUiConfig": { "id": "[variables('_uiConfigId2')]", - "title": "[Recommended] Illusive Platform via AMA (using Azure Functions)", + "title": "[Recommended] Illusive Platform via AMA", "publisher": "illusive", "descriptionMarkdown": "The Illusive Platform Connector allows you to share Illusive's attack surface analysis data and incident logs with Microsoft 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": [ @@ -547,13 +547,13 @@ "instructionSteps": [ { "title": "Step A. Configure the Common Event Format (CEF) via AMA data connector", - "description": "_Note:- CEF logs are collected only from Linux Agents_\n\n1. Navigate to Microsoft Sentinel workspace ---> configuration ---> Data connector blade .\n\n2. Search for 'Common Event Format (CEF) via AMA' data connector and open it.\n\n3. Check If there is no existing DCR configured to collect required facility of logs, Create a new DCR (Data Collection Rule)\n\n\t_Note:- It is recommended to install minimum 1.27 version of AMA agent [Learn more](https://learn.microsoft.com/azure/azure-monitor/agents/azure-monitor-agent-manage?tabs=azure-portal ) and ensure there is no duplicate DCR as it can cause log duplicacy_\n\n4. Run the command provided in the CEF via AMA data connector page to configure the CEF collector on the machine", - "instructions": [] + "description": "_Note:- CEF logs are collected only from Linux Agents_\n\n1. Navigate to Microsoft Sentinel workspace ---> configuration ---> Data connector blade .\n\n2. Search for 'Common Event Format (CEF) via AMA' data connector and open it.\n\n3. Check If there is no existing DCR configured to collect required facility of logs, Create a new DCR (Data Collection Rule)\n\n\t_Note:- It is recommended to install minimum 1.27 version of AMA agent [Learn more](https://learn.microsoft.com/azure/azure-monitor/agents/azure-monitor-agent-manage?tabs=azure-portal ) and ensure there is no duplicate DCR as it can cause log duplicacy_\n\n4. Run the command provided in the CEF via AMA data connector page to configure the CEF collector on the machine" + }, { "title": "Step B. 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", - "instructions": [] + "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": "Step C. Validate connection", @@ -631,7 +631,7 @@ "contentSchemaVersion": "3.0.0", "contentId": "[variables('_dataConnectorContentId2')]", "contentKind": "DataConnector", - "displayName": "[Recommended] Illusive Platform via AMA (using Azure Functions)", + "displayName": "[Recommended] Illusive Platform via AMA", "contentProductId": "[variables('_dataConnectorcontentProductId2')]", "id": "[variables('_dataConnectorcontentProductId2')]", "version": "[variables('dataConnectorVersion2')]" @@ -673,7 +673,7 @@ "kind": "GenericUI", "properties": { "connectorUiConfig": { - "title": "[Recommended] Illusive Platform via AMA (using Azure Functions)", + "title": "[Recommended] Illusive Platform via AMA", "publisher": "illusive", "descriptionMarkdown": "The Illusive Platform Connector allows you to share Illusive's attack surface analysis data and incident logs with Microsoft 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": [ @@ -752,13 +752,13 @@ "instructionSteps": [ { "title": "Step A. Configure the Common Event Format (CEF) via AMA data connector", - "description": "_Note:- CEF logs are collected only from Linux Agents_\n\n1. Navigate to Microsoft Sentinel workspace ---> configuration ---> Data connector blade .\n\n2. Search for 'Common Event Format (CEF) via AMA' data connector and open it.\n\n3. Check If there is no existing DCR configured to collect required facility of logs, Create a new DCR (Data Collection Rule)\n\n\t_Note:- It is recommended to install minimum 1.27 version of AMA agent [Learn more](https://learn.microsoft.com/azure/azure-monitor/agents/azure-monitor-agent-manage?tabs=azure-portal ) and ensure there is no duplicate DCR as it can cause log duplicacy_\n\n4. Run the command provided in the CEF via AMA data connector page to configure the CEF collector on the machine", - "instructions": [] + "description": "_Note:- CEF logs are collected only from Linux Agents_\n\n1. Navigate to Microsoft Sentinel workspace ---> configuration ---> Data connector blade .\n\n2. Search for 'Common Event Format (CEF) via AMA' data connector and open it.\n\n3. Check If there is no existing DCR configured to collect required facility of logs, Create a new DCR (Data Collection Rule)\n\n\t_Note:- It is recommended to install minimum 1.27 version of AMA agent [Learn more](https://learn.microsoft.com/azure/azure-monitor/agents/azure-monitor-agent-manage?tabs=azure-portal ) and ensure there is no duplicate DCR as it can cause log duplicacy_\n\n4. Run the command provided in the CEF via AMA data connector page to configure the CEF collector on the machine" + }, { "title": "Step B. 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", - "instructions": [] + "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": "Step C. Validate connection", @@ -815,7 +815,7 @@ }, "properties": { "displayName": "[parameters('workbook1-name')]", - "serializedData": "{\"version\":\"Notebook/1.0\",\"items\":[{\"type\":1,\"content\":{\"json\":\"## Illusive ADS Dashboard\\n\"},\"name\":\"text - 2\"},{\"type\":1,\"content\":{\"json\":\"\\n\"},\"customWidth\":\"65\",\"name\":\"text - 2 - Copy\"},{\"type\":9,\"content\":{\"version\":\"KqlParameterItem/1.0\",\"parameters\":[{\"id\":\"e5b79f84-7773-4162-9750-702cd0001041\",\"version\":\"KqlParameterItem/1.0\",\"name\":\"NumberOfDays\",\"label\":\"Number of Days \",\"type\":2,\"description\":\"Select range of days to query\",\"isRequired\":true,\"value\":\"30\",\"typeSettings\":{\"additionalResourceOptions\":[]},\"jsonData\":\"[1,7,14,21,30]\",\"resourceType\":\"microsoft.insights/components\"},{\"id\":\"ba9324e9-07f9-49dc-81b6-f87833a09afc\",\"version\":\"KqlParameterItem/1.0\",\"name\":\"ManagementIP\",\"label\":\"Management IP\",\"type\":2,\"description\":\"Filter managment ip\",\"isRequired\":true,\"multiSelect\":true,\"quote\":\"'\",\"delimiter\":\",\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:login\\\" or DeviceEventClassID == \\\"illusive:access\\\" or DeviceEventClassID == \\\"illusive:suspicious\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nwhere DeviceAddress != \\\"\\\" |\\r\\nsummarize count() by DeviceAddress | \\r\\nproject DeviceAddress\\r\\n\",\"value\":[\"value::all\"],\"typeSettings\":{\"additionalResourceOptions\":[\"value::all\"],\"selectAllValue\":\"All\"},\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\"}],\"style\":\"pills\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\"},\"customWidth\":\"35\",\"name\":\"parameters - 6\",\"styleSettings\":{\"margin\":\"0px\",\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"let binSize = iff({NumberOfDays} > 1, 1d, 1h);\\nunion CommonSecurityLog | \\nwhere (DeviceEventClassID == \\\"illusive:login\\\" or DeviceEventClassID == \\\"illusive:access\\\" or DeviceEventClassID == \\\"illusive:suspicious\\\")|\\nwhere Message !contains \\\"hasForensics\\\" |\\nwhere TimeGenerated > ago({NumberOfDays}d) | \\nwhere \\\"{ManagementIP}\\\" contains \\\"All\\\" or \\\"{ManagementIP}\\\" contains DeviceAddress |\\nextend DeviceCustomNumber2 = coalesce(column_ifexists(\\\"FieldDeviceCustomNumber2\\\", long(null)),DeviceCustomNumber2) |\\nsummarize by bin(TimeGenerated,binSize) ,DeviceCustomNumber2 |\\nmake-series event_count=count() default=0 on TimeGenerated in range (ago({NumberOfDays}d), now(), binSize) |\\nmvexpand TimeGenerated, event_count |\\nproject todatetime(TimeGenerated), toint(event_count)\",\"size\":0,\"aggregation\":3,\"title\":\"Incidents over time\",\"timeContext\":{\"durationMs\":2592000000},\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"linechart\",\"chartSettings\":{\"seriesLabelSettings\":[{\"seriesName\":\"event_count\",\"color\":\"red\"}]}},\"customWidth\":\"50\",\"name\":\"Incidents over time\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"let binSize = iff({NumberOfDays} > 1, 1d, 1h);\\nunion CommonSecurityLog | \\nwhere (DeviceEventClassID == \\\"illusive:login\\\" or DeviceEventClassID == \\\"illusive:access\\\" or DeviceEventClassID == \\\"illusive:suspicious\\\")|\\nwhere Message !contains \\\"hasForensics\\\" |\\nwhere TimeGenerated > ago({NumberOfDays}d) | \\nwhere \\\"{ManagementIP}\\\" contains \\\"All\\\" or \\\"{ManagementIP}\\\" contains DeviceAddress |\\nsummarize by bin(TimeGenerated,binSize) ,ExternalID |\\nmake-series event_count=count() default=0 on TimeGenerated in range (ago({NumberOfDays}d), now(), binSize) |\\nmvexpand TimeGenerated, event_count |\\nproject todatetime(TimeGenerated), toint(event_count)\",\"size\":0,\"aggregation\":3,\"title\":\"Events over time\",\"timeContext\":{\"durationMs\":2592000000},\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"linechart\",\"chartSettings\":{\"seriesLabelSettings\":[{\"seriesName\":\"event_count\",\"color\":\"yellow\"}]}},\"customWidth\":\"50\",\"name\":\"Events over time\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"let binSize = iff({NumberOfDays} > 1, 1d, 1h);\\r\\nunion CommonSecurityLog \\r\\n| extend DeviceCustomNumber2 = coalesce(column_ifexists(\\\"FieldDeviceCustomNumber2\\\", long(null)),DeviceCustomNumber2)\\r\\n | where (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,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"group\":\"DestinationServiceName\",\"createOtherGroup\":8}},\"customWidth\":\"33\",\"name\":\"TriggerType\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog \\r\\n| extend DeviceCustomNumber2 = coalesce(column_ifexists(\\\"FieldDeviceCustomNumber2\\\", long(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,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"group\":\"DeviceEventClassID\",\"createOtherGroup\":8}},\"customWidth\":\"33\",\"name\":\"EventType\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog| \\r\\nextend DeviceCustomNumber2 = coalesce(column_ifexists(\\\"FieldDeviceCustomNumber2\\\", long(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,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"table\",\"chartSettings\":{\"group\":\"DeviceEventClassID\",\"createOtherGroup\":8}},\"customWidth\":\"33\",\"name\":\"TopHosts\"}],\"fromTemplateId\":\"sentinel-IllusiveADS\",\"$schema\":\"https://github.com/Microsoft/Application-Insights-Workbooks/blob/master/schema/workbook.json\"}\n", + "serializedData": "{\"version\":\"Notebook/1.0\",\"items\":[{\"type\":1,\"content\":{\"json\":\"## Illusive ADS Dashboard\\n\"},\"name\":\"text - 2\"},{\"type\":1,\"content\":{\"json\":\"\\n\"},\"customWidth\":\"65\",\"name\":\"text - 2 - Copy\"},{\"type\":9,\"content\":{\"version\":\"KqlParameterItem/1.0\",\"parameters\":[{\"id\":\"e5b79f84-7773-4162-9750-702cd0001041\",\"version\":\"KqlParameterItem/1.0\",\"name\":\"NumberOfDays\",\"label\":\"Number of Days \",\"type\":2,\"description\":\"Select range of days to query\",\"isRequired\":true,\"value\":\"30\",\"jsonData\":\"[1,7,14,21,30]\",\"resourceType\":\"microsoft.insights/components\"},{\"id\":\"ba9324e9-07f9-49dc-81b6-f87833a09afc\",\"version\":\"KqlParameterItem/1.0\",\"name\":\"ManagementIP\",\"label\":\"Management IP\",\"type\":2,\"description\":\"Filter managment ip\",\"isRequired\":true,\"multiSelect\":true,\"quote\":\"'\",\"delimiter\":\",\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:login\\\" or DeviceEventClassID == \\\"illusive:access\\\" or DeviceEventClassID == \\\"illusive:suspicious\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nwhere DeviceAddress != \\\"\\\" |\\r\\nsummarize count() by DeviceAddress | \\r\\nproject DeviceAddress\\r\\n\",\"value\":[\"value::all\"],\"typeSettings\":{\"additionalResourceOptions\":[\"value::all\"],\"selectAllValue\":\"All\"},\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\"}],\"style\":\"pills\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\"},\"customWidth\":\"35\",\"name\":\"parameters - 6\",\"styleSettings\":{\"margin\":\"0px\",\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"let binSize = iff({NumberOfDays} > 1, 1d, 1h);\\nunion CommonSecurityLog | \\nwhere (DeviceEventClassID == \\\"illusive:login\\\" or DeviceEventClassID == \\\"illusive:access\\\" or DeviceEventClassID == \\\"illusive:suspicious\\\")|\\nwhere Message !contains \\\"hasForensics\\\" |\\nwhere TimeGenerated > ago({NumberOfDays}d) | \\nwhere \\\"{ManagementIP}\\\" contains \\\"All\\\" or \\\"{ManagementIP}\\\" contains DeviceAddress |\\nextend DeviceCustomNumber2 = coalesce(column_ifexists(\\\"FieldDeviceCustomNumber2\\\", long(null)),DeviceCustomNumber2) |\\nsummarize by bin(TimeGenerated,binSize) ,DeviceCustomNumber2 |\\nmake-series event_count=count() default=0 on TimeGenerated in range (ago({NumberOfDays}d), now(), binSize) |\\nmvexpand TimeGenerated, event_count |\\nproject todatetime(TimeGenerated), toint(event_count)\",\"size\":0,\"aggregation\":3,\"title\":\"Incidents over time\",\"timeContext\":{\"durationMs\":2592000000},\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"linechart\",\"chartSettings\":{\"seriesLabelSettings\":[{\"seriesName\":\"event_count\",\"color\":\"red\"}]}},\"customWidth\":\"50\",\"name\":\"Incidents over time\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"let binSize = iff({NumberOfDays} > 1, 1d, 1h);\\nunion CommonSecurityLog | \\nwhere (DeviceEventClassID == \\\"illusive:login\\\" or DeviceEventClassID == \\\"illusive:access\\\" or DeviceEventClassID == \\\"illusive:suspicious\\\")|\\nwhere Message !contains \\\"hasForensics\\\" |\\nwhere TimeGenerated > ago({NumberOfDays}d) | \\nwhere \\\"{ManagementIP}\\\" contains \\\"All\\\" or \\\"{ManagementIP}\\\" contains DeviceAddress |\\nsummarize by bin(TimeGenerated,binSize) ,ExternalID |\\nmake-series event_count=count() default=0 on TimeGenerated in range (ago({NumberOfDays}d), now(), binSize) |\\nmvexpand TimeGenerated, event_count |\\nproject todatetime(TimeGenerated), toint(event_count)\",\"size\":0,\"aggregation\":3,\"title\":\"Events over time\",\"timeContext\":{\"durationMs\":2592000000},\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"linechart\",\"chartSettings\":{\"seriesLabelSettings\":[{\"seriesName\":\"event_count\",\"color\":\"yellow\"}]}},\"customWidth\":\"50\",\"name\":\"Events over time\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"let binSize = iff({NumberOfDays} > 1, 1d, 1h);\\r\\nunion CommonSecurityLog \\r\\n| extend DeviceCustomNumber2 = coalesce(column_ifexists(\\\"FieldDeviceCustomNumber2\\\", long(null)),DeviceCustomNumber2)\\r\\n | where (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,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"group\":\"DestinationServiceName\",\"createOtherGroup\":8}},\"customWidth\":\"33\",\"name\":\"TriggerType\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog \\r\\n| extend DeviceCustomNumber2 = coalesce(column_ifexists(\\\"FieldDeviceCustomNumber2\\\", long(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,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"group\":\"DeviceEventClassID\",\"createOtherGroup\":8}},\"customWidth\":\"33\",\"name\":\"EventType\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog| \\r\\nextend DeviceCustomNumber2 = coalesce(column_ifexists(\\\"FieldDeviceCustomNumber2\\\", long(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,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"table\",\"chartSettings\":{\"group\":\"DeviceEventClassID\",\"createOtherGroup\":8}},\"customWidth\":\"33\",\"name\":\"TopHosts\"}],\"fromTemplateId\":\"sentinel-IllusiveADS\",\"$schema\":\"https://github.com/Microsoft/Application-Insights-Workbooks/blob/master/schema/workbook.json\"}\n", "version": "1.0", "sourceId": "[variables('workspaceResourceId')]", "category": "sentinel" @@ -905,7 +905,7 @@ }, "properties": { "displayName": "[parameters('workbook2-name')]", - "serializedData": "{\"version\":\"Notebook/1.0\",\"items\":[{\"type\":1,\"content\":{\"json\":\"## Illusive ASM Dashboard\\n\"},\"name\":\"text - 2\"},{\"type\":1,\"content\":{\"json\":\"\\n\"},\"customWidth\":\"80\",\"name\":\"text - 2 - Copy\"},{\"type\":9,\"content\":{\"version\":\"KqlParameterItem/1.0\",\"parameters\":[{\"id\":\"e5b79f84-7773-4162-9750-702cd0001041\",\"version\":\"KqlParameterItem/1.0\",\"name\":\"NumberOfDays\",\"label\":\"Number of Days \",\"type\":2,\"description\":\"Select range of days to query\",\"isRequired\":true,\"value\":\"14\",\"typeSettings\":{\"additionalResourceOptions\":[]},\"jsonData\":\"[1,7,14,21,30]\"}],\"style\":\"pills\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\"},\"customWidth\":\"20\",\"name\":\"parameters - 6\",\"styleSettings\":{\"margin\":\"0px\",\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize count = count() by ViolationType = DeviceCustomString1 \\r\\n\\r\\n\",\"size\":0,\"title\":\"Violation Types\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"yAxis\":[\"count\"],\"group\":\"ViolationType\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Violation Types\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"let binSize = iff({NumberOfDays} > 1, 1d, 1h);\\nunion CommonSecurityLog | \\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\nwhere TimeGenerated > ago({NumberOfDays}d) | \\nmake-series event_count=count() default=0 on TimeGenerated in range (ago({NumberOfDays}d), now(), binSize) |\\nmvexpand TimeGenerated, event_count |\\nproject todatetime(TimeGenerated), toint(event_count)\",\"size\":0,\"aggregation\":3,\"title\":\"Violations Over Time\",\"timeContext\":{\"durationMs\":2592000000},\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"linechart\",\"chartSettings\":{\"seriesLabelSettings\":[{\"seriesName\":\"event_count\",\"color\":\"yellow\"}]}},\"customWidth\":\"50\",\"name\":\"Violations Trendline\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":1,\"content\":{\"json\":\"\\r\\n## Domain User Credentials\"},\"name\":\"text - 9\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"USER_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingHost = SourceHostName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Domain User Credentials - Top Violating Hosts\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingHost\",\"createOtherGroup\":6}},\"customWidth\":\"50\",\"name\":\"Domain User Credentials Top Violating Hosts\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"USER_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingUsers = SourceUserName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Domain User Credentials - Top Violating Users\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingUsers\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Domain User Credentials Top Violating Users\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":1,\"content\":{\"json\":\"\\r\\n## Crown Jewel Connections\"},\"name\":\"text - 9 - Copy\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"CROWN_JEWEL_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingHost = SourceHostName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Crown Jewel Connections - Top Violating Hosts\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingHost\",\"createOtherGroup\":6}},\"customWidth\":\"33\",\"name\":\"Crown Jewel Connections Top Violating Hosts\",\"styleSettings\":{\"maxWidth\":\"33\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"CROWN_JEWEL_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by CrownJewelType = DeviceCustomString6 |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Crown Jewel Connections - Crown Jewel Types\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"CrownJewelType\",\"createOtherGroup\":6}},\"customWidth\":\"33\",\"name\":\"Crown Jewel Connections - Crown Jewel Types\",\"styleSettings\":{\"maxWidth\":\"33\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"CROWN_JEWEL_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by ServiceType = DeviceCustomString4 |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Crown Jewel Connections - Service Types\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"ServiceType\",\"createOtherGroup\":8}},\"customWidth\":\"33\",\"name\":\"Crown Jewel Connections - Service Types\",\"styleSettings\":{\"maxWidth\":\"33\"}},{\"type\":1,\"content\":{\"json\":\"\\r\\n## Local User Administrators\"},\"name\":\"text - 9 - Copy - Copy\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"LOCAL_USER_ADMINISTRATORS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingHost = SourceHostName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Local User Administrators - Top Violating Hosts\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingHost\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Local User Administrators Top Violating Hosts\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"LOCAL_USER_ADMINISTRATORS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingUsers = SourceUserName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Local User Administrators - Top Violating Users\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingUsers\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Local User Administrators - Top Violating Users\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":1,\"content\":{\"json\":\"\\r\\n## Suspicious Files\"},\"name\":\"text - 9 - Copy - Copy - Copy\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"SUSPICIOUS_FILES\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopSuspiciousFilesHashes = DeviceCustomString3 |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Suspicious Files - Top Violating Processes\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"table\",\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingHost\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Suspicious Files Top Violating Hosts\",\"styleSettings\":{\"maxWidth\":\"50\"}}],\"fromTemplateId\":\"sentinel-IllusiveASM\",\"$schema\":\"https://github.com/Microsoft/Application-Insights-Workbooks/blob/master/schema/workbook.json\"}\n", + "serializedData": "{\"version\":\"Notebook/1.0\",\"items\":[{\"type\":1,\"content\":{\"json\":\"## Illusive ASM Dashboard\\n\"},\"name\":\"text - 2\"},{\"type\":1,\"content\":{\"json\":\"\\n\"},\"customWidth\":\"80\",\"name\":\"text - 2 - Copy\"},{\"type\":9,\"content\":{\"version\":\"KqlParameterItem/1.0\",\"parameters\":[{\"id\":\"e5b79f84-7773-4162-9750-702cd0001041\",\"version\":\"KqlParameterItem/1.0\",\"name\":\"NumberOfDays\",\"label\":\"Number of Days \",\"type\":2,\"description\":\"Select range of days to query\",\"isRequired\":true,\"value\":\"14\",\"jsonData\":\"[1,7,14,21,30]\"}],\"style\":\"pills\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\"},\"customWidth\":\"20\",\"name\":\"parameters - 6\",\"styleSettings\":{\"margin\":\"0px\",\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize count = count() by ViolationType = DeviceCustomString1 \\r\\n\\r\\n\",\"size\":0,\"title\":\"Violation Types\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"yAxis\":[\"count\"],\"group\":\"ViolationType\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Violation Types\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"let binSize = iff({NumberOfDays} > 1, 1d, 1h);\\nunion CommonSecurityLog | \\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\nwhere TimeGenerated > ago({NumberOfDays}d) | \\nmake-series event_count=count() default=0 on TimeGenerated in range (ago({NumberOfDays}d), now(), binSize) |\\nmvexpand TimeGenerated, event_count |\\nproject todatetime(TimeGenerated), toint(event_count)\",\"size\":0,\"aggregation\":3,\"title\":\"Violations Over Time\",\"timeContext\":{\"durationMs\":2592000000},\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"linechart\",\"chartSettings\":{\"seriesLabelSettings\":[{\"seriesName\":\"event_count\",\"color\":\"yellow\"}]}},\"customWidth\":\"50\",\"name\":\"Violations Trendline\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":1,\"content\":{\"json\":\"\\r\\n## Domain User Credentials\"},\"name\":\"text - 9\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"USER_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingHost = SourceHostName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Domain User Credentials - Top Violating Hosts\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingHost\",\"createOtherGroup\":6}},\"customWidth\":\"50\",\"name\":\"Domain User Credentials Top Violating Hosts\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"USER_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingUsers = SourceUserName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Domain User Credentials - Top Violating Users\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingUsers\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Domain User Credentials Top Violating Users\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":1,\"content\":{\"json\":\"\\r\\n## Crown Jewel Connections\"},\"name\":\"text - 9 - Copy\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"CROWN_JEWEL_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingHost = SourceHostName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Crown Jewel Connections - Top Violating Hosts\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingHost\",\"createOtherGroup\":6}},\"customWidth\":\"33\",\"name\":\"Crown Jewel Connections Top Violating Hosts\",\"styleSettings\":{\"maxWidth\":\"33\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"CROWN_JEWEL_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by CrownJewelType = DeviceCustomString6 |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Crown Jewel Connections - Crown Jewel Types\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"CrownJewelType\",\"createOtherGroup\":6}},\"customWidth\":\"33\",\"name\":\"Crown Jewel Connections - Crown Jewel Types\",\"styleSettings\":{\"maxWidth\":\"33\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"CROWN_JEWEL_CREDENTIALS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by ServiceType = DeviceCustomString4 |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Crown Jewel Connections - Service Types\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"gridSettings\":{\"rowLimit\":10},\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"ServiceType\",\"createOtherGroup\":8}},\"customWidth\":\"33\",\"name\":\"Crown Jewel Connections - Service Types\",\"styleSettings\":{\"maxWidth\":\"33\"}},{\"type\":1,\"content\":{\"json\":\"\\r\\n## Local User Administrators\"},\"name\":\"text - 9 - Copy - Copy\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"LOCAL_USER_ADMINISTRATORS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingHost = SourceHostName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Local User Administrators - Top Violating Hosts\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingHost\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Local User Administrators Top Violating Hosts\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"LOCAL_USER_ADMINISTRATORS\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopViolatingUsers = SourceUserName |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Local User Administrators - Top Violating Users\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"piechart\",\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingUsers\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Local User Administrators - Top Violating Users\",\"styleSettings\":{\"maxWidth\":\"50\"}},{\"type\":1,\"content\":{\"json\":\"\\r\\n## Suspicious Files\"},\"name\":\"text - 9 - Copy - Copy - Copy\"},{\"type\":3,\"content\":{\"version\":\"KqlItem/1.0\",\"query\":\"union CommonSecurityLog | \\r\\nwhere (DeviceEventClassID == \\\"illusive:violation\\\") |\\r\\nwhere (DeviceCustomString1 == \\\"SUSPICIOUS_FILES\\\") |\\r\\nwhere TimeGenerated > ago({NumberOfDays}d) |\\r\\nsummarize NumberOfViolations = count() by TopSuspiciousFilesHashes = DeviceCustomString3 |\\r\\ntop 5 by NumberOfViolations desc\\r\\n\\r\\n\",\"size\":0,\"title\":\"Suspicious Files - Top Violating Processes\",\"queryType\":0,\"resourceType\":\"microsoft.operationalinsights/workspaces\",\"visualization\":\"table\",\"chartSettings\":{\"yAxis\":[\"NumberOfViolations\"],\"group\":\"TopViolatingHost\",\"createOtherGroup\":7}},\"customWidth\":\"50\",\"name\":\"Suspicious Files Top Violating Hosts\",\"styleSettings\":{\"maxWidth\":\"50\"}}],\"fromTemplateId\":\"sentinel-IllusiveASM\",\"$schema\":\"https://github.com/Microsoft/Application-Insights-Workbooks/blob/master/schema/workbook.json\"}\n", "version": "1.0", "sourceId": "[variables('workspaceResourceId')]", "category": "sentinel" diff --git a/Solutions/Illusive Platform/ReleaseNotes.md b/Solutions/Illusive Platform/ReleaseNotes.md new file mode 100644 index 00000000000..07f9b231e3b --- /dev/null +++ b/Solutions/Illusive Platform/ReleaseNotes.md @@ -0,0 +1,5 @@ +| **Version** | **Date Modified (DD-MM-YYYY)** | **Change History** | +|-------------|--------------------------------|--------------------------------------------------------------------| +| 3.0.0 | 13-09-2023 | Addition of new Illusive Platform AMA **Data Connector** | | + + From bc1ded5e20acbf3acec40de68232d8a0e1f74ede Mon Sep 17 00:00:00 2001 From: v-rusraut Date: Thu, 14 Sep 2023 12:04:08 +0530 Subject: [PATCH 4/6] Update ValidConnectorIds.json --- .../detectionTemplateSchemaValidation/ValidConnectorIds.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.script/tests/detectionTemplateSchemaValidation/ValidConnectorIds.json b/.script/tests/detectionTemplateSchemaValidation/ValidConnectorIds.json index 3d424823fac..11277d07f63 100644 --- a/.script/tests/detectionTemplateSchemaValidation/ValidConnectorIds.json +++ b/.script/tests/detectionTemplateSchemaValidation/ValidConnectorIds.json @@ -202,5 +202,6 @@ "PingFederateAma", "vArmourACAma", "ContrastProtectAma", - "ClarotyAma" + "ClarotyAma", + "illusiveAttackManagementSystemAma" ] From a7e82b6c195fd0cf0d418adca97fa75965468b21 Mon Sep 17 00:00:00 2001 From: v-atulyadav <104008048+v-atulyadav@users.noreply.github.com> Date: Fri, 15 Sep 2023 19:00:34 +0530 Subject: [PATCH 5/6] Update zip for branding validation --- Solutions/Illusive Platform/Package/3.0.0.zip | Bin 13817 -> 13818 bytes .../Package/mainTemplate.json | 2 +- 2 files changed, 1 insertion(+), 1 deletion(-) diff --git a/Solutions/Illusive Platform/Package/3.0.0.zip b/Solutions/Illusive Platform/Package/3.0.0.zip index 3e24b55c5fe1baa50b24577b0fed4cad78b93d3b..6dfa3741c8f75ffba650f6a2ea74c15a2bccabf7 100644 GIT binary patch delta 1965 zcmV;e2U7U?Yx-*qP)h>@6aWAK2msHPFR=}L3JrIcFIQIQ*%q=Y005@5mI{F*e-kwM zDz?0ii$oLPUH)Cx*iU7bZIN}^hJSe(wwj)4Gk}f*TSbQjDC0hqU+ycus_V0_R|0s& z&>{-x`vMB?M8#$nLxT8cJVfs6!CmFXC1=~>&dJ4yQkt1CD`8L< zxds<>XgC2?HDN)@mdahl%RqT3f0svAg&AWZ;Mh&OXw7kFsQ%u-8n*`GxJlgD@UJe% z#+Te}-{fCXH&AA}xAB|5;xi?$rJV@c*{F4DY6l|N2J?Yme8UXa|7{I;{N?(m|9bKH zUpLk-E?)fkPaB}(duq^ND&D5<2+YC>cI(4YBUM7=^f7?wz~ZDAt&O()e_`VyOqM$V zn_lTX#_mC8!6h#qS-JRoOl8^Pw-3k45d9N`ChK%^i^tF2j!p~r2Lh{3B9JlCR^C^d zp>sQXf(Jwu-(;12#hr+4lD@7uxvDVrV*(?YcV>o~a4-|GH~86m*q}05J3W7LqHlT% z+QYL-+XbMdP)wPXp_Uyfe|K+eV~>*q9pTAp8p%g^$3M}Z<(Ze1NNN} zp((ATg8tzs_WtB-ACEnbH1SK(DN8eHFc(9ux&n+wnVlTN?Byx1+Tn-RsWMv`@?m=< zFov*wkDS_}V17Cce>-8Y8~Wk)O_o%UFqAazYO1!5Te1?EIgsQkP5?3RUB=2*JWH!Yv$txqc|f1t5|YtzHV2H_BrL^m>& zRJPPaW@|;61c=qiW9E4TCy!N{DgEc_D5&mHP%RP89|vhAc%Haf^{J2o*G9KcHtOF{ z2g#myctRvkG7>bK91zVKH`bqn+>~)#nSyP=xH^7P>EYHS8aQ?^qW+<#mr8%7ZS31{ z>|lqVC$D}Ee?s4LuU_GuZhJp(ioeLubo}a^#p%Yzlnf~O*&rjI4qqnOj>fgo9S55- zDNu@UaP4}xt{nssrj)*7e-ZxY&zr_8f;2X4SL9HI7}l1wYm{ltiDlW{8 zZIJzwfBl5lI{a{h5i^c4kr8z!?6XXKWim$_F|35#3|&l5PdvqsQs7C%PDb#g1rKia z@tBaDc&?4(uzhZq98<%0fdKHv7ajL;J5i8laA4}r*uKJTI50O8EsF;j7?a2PTM{M9%t2~J`|X%=GDAo6I^%Vv z+w_v*be4>vFR=%V3o4+(J7W7*YU5KHii+YD%u`{o`BX7PF&+HS`JMUUMf9?z% z%?`Wn&boX@-E=3N!K^H2w>($3BuBRx4OAzEwhQg_JeR2jIH<_E(QMi>FjTuX{!|Ay z?`k@lYt9=?r$5hhROy|fiGC)9B+_PUl1sCkYdIE!f3rm>OB3Z!ef%pTqWVeHirxqy zGX^yHQ!BbQwEZAF<(u$Bo~i-xMbm-N^M!}syD?^ zUrWaInd6RG5?CxMvNiLhN;hWpm)Uq~dh+t02^AJ~>QJ4l$_D3@X@QqCi9((^`H%kq z|Ns91P)h*<6aW+e000O8&z3KfZZ$#;cb6|$R_ECkvMK-orjxxjHU?ld00000`*y>~ delta 1973 zcmV;m2TJ(*Yx!#pP)h>@6aWAK2mm2nF0l=K3KCjfE>|Nm)y|2O_Wr^MPM{!wlE|Z4LPO z<@%@pdhz*RH`XsMUi|q_8=%g6YS3U7-lpyY%)$wF>%&naRYK%+$X|3|G0}_GMqB={ zaeome%bkEtuk;>c_aL+2k{6GxT&z8&vTX6&hht?p{s}^pH95J(+`{yG=O$yQFeB|S2VI2g&r9>n&!U!!vYyZZu9YjS5&li=h+3(gC?J<8e+fDQ$ zcu(&0OI54eRkq@Ip>817s<_uzH*N4y*_soWdB41rnH7KhtXf*Mvf=c^m`v~_sDJ5_ z^4{md={h>q&UlC>sA?2^w6O|;`#l_QC_-F9qv(cYJ-C{d#$9SU?RSjl{~mEYLZRMU zCaKjT0KRMgSBaS0YtWtE!(o7o6#ZarR0HaZ6r^GOOd7`U!?xA(6 zq*jJ^*nS9%A#Bwnr*_zvpG3p17k})Aez<*;B@iSGC5^k9s;#t7!InM!x4MfoBZ;%X zR8jI*%?UBTOUwr=ihby>CnIZ|Y#ji}u@R=NTI{d@h_4AY-!uo;2?Futl&BBDQ3EPvqI^kA_; z=z}DYj0`1}Ej3ZtS`j4yVs*-xc^<(jW0ht~|G7H$se9~GON8@BKUxW%CvH}K0;IsT z(T$Uh`Zv@;vgaM12FX*41kEOgL9@n)^=BS8WgJ(gU>h*5j-OO|xHX9ejvb7sf2irD z(qCyC`!*aq*x~2NtDl3=_kY~0S9pKh-p`xjFY+@TzdC1ey0I}O14@22$jGO|mq})$ zacy+R!KO?Al;Rs)yWXv92SJ4Cqp#Rsg#Y>Trtyj(jSbrs`BEWH?o_LBMrNEPj zos8i53Le+&X0suA8J;qs?bWk+HmN zim7%?I_wyjHT(+Y4P~TDB=r&|@pK^MCx9q;f$vVJ&K|$T4h- z%_*PH{Va{cF~~MF*y?1bv&s1^rMuprzfS2cCDDZT;Npf~`O@)aLe8!vN;2~(paDZx zfu;CX7?6uI5X>C(rbWR-ak(B$<8|GSuE=(;O~8`vv=hvkc#fig1S2nUEaJHiQ@#Ru zfFZt11ZcuIu74L2;Yd=eOMYXdJb`yC)fWC2rW$~403B|Qfai#5xbPpC1g;LTqBskk ze~bf%%<;F~G3_{MFQS4034`T`K+Af{INe|IExWeo%fn-|3U zC-r#)CaGVv$Ssy|z<|3?@RCl@RA@8fzhBkdEa1s8Tsa6a7pI38T%{B$rY-*K#Zd|7MF&mJ-UJ`uJBw zMD>%X6}=HaW(;WXr&e@rX!}8U$~WPMJTp;*>SdpF`cJaJ{{R02P)h*<6aW+e000O8Azdz$Z#6; Date: Fri, 15 Sep 2023 19:09:54 +0530 Subject: [PATCH 6/6] update zip for branding --- Solutions/Illusive Platform/Package/3.0.0.zip | Bin 13818 -> 13818 bytes .../Package/createUiDefinition.json | 2 +- 2 files changed, 1 insertion(+), 1 deletion(-) diff --git a/Solutions/Illusive Platform/Package/3.0.0.zip b/Solutions/Illusive Platform/Package/3.0.0.zip index 6dfa3741c8f75ffba650f6a2ea74c15a2bccabf7..ee16748d6d1128fb198bc04821e309f63437ac71 100644 GIT binary patch delta 226 zcmeyB{VQ8Mz?+#xgn@y9gF$zuet7@!`{rI;3=9W1itp#FU&pnjW|_ZmRc7(|J)zG# z;u0hFFE}Z8TF`QezO3^TU-O$@>DiLG@mb+@<%nZMwgc8x}DKE`&X9T%T(I!R#4dHCcNXiMdZhe`4d9kRxNsYV{Juk Yfz{FYAAjRF*K@tq;zjYn<0KXJ#J^%m! delta 226 zcmeyB{VQ8Mz?+#xgn@y9gW>!%{qR5G`a8Y27#P-W6yMKTzv`Wi{PW8#_paZ0oOe}! z(RT4``Wc(li;i$V^*+uP*(0{FT0`f0$JWaUaU6+JYbs;vpR3P{3u_3LV#|M_6?*;4 znK@0}&if3OedMyfD^;c3X~1{b%wITQll&>SrCzy{%x3QowXO-N7I_t`yTokUf9>i6 z7RCRCe;siC7<|e(c#T#;@13OIzFR;09ll{&+ih$jwQujSlU@CF%}cV*3i}?<0Ng=n`2YX_ diff --git a/Solutions/Illusive Platform/Package/createUiDefinition.json b/Solutions/Illusive Platform/Package/createUiDefinition.json index 34b0bf9b3de..1d4c6798c6b 100644 --- a/Solutions/Illusive Platform/Package/createUiDefinition.json +++ b/Solutions/Illusive Platform/Package/createUiDefinition.json @@ -167,7 +167,7 @@ "name": "analytic1-text", "type": "Microsoft.Common.TextBlock", "options": { - "text": "Create a Sentinel incident upon a new Illusive alert (incident) and associate all related Illusive events to the relevant Sentinel alert. This is done by filtering and processing Illusive Syslog messages." + "text": "Create a Microsoft Sentinel incident upon a new Illusive alert (incident) and associate all related Illusive events to the relevant Microsoft Sentinel alert. This is done by filtering and processing Illusive Syslog messages." } } ]