From 49c6adcc0a1ebe9a5867427cab1f890f274af464 Mon Sep 17 00:00:00 2001 From: v-rusraut Date: Fri, 22 Sep 2023 11:41:00 +0530 Subject: [PATCH 1/3] Repackaging - Aruba ClearPass (MMA to AMA Migration) --- .../Connector_Syslog_ArubaClearPass.json | 2 +- .../template_ArubaClearPassAMA.json | 108 ++++++++++++++++++ .../Aruba ClearPass/Data/Solution_Aruba.json | 9 +- .../Parsers/ArubaClearPass.txt | 104 ----------------- Solutions/Aruba ClearPass/ReleaseNotes.md | 5 + 5 files changed, 119 insertions(+), 109 deletions(-) create mode 100644 Solutions/Aruba ClearPass/Data Connectors/template_ArubaClearPassAMA.json delete mode 100644 Solutions/Aruba ClearPass/Parsers/ArubaClearPass.txt create mode 100644 Solutions/Aruba ClearPass/ReleaseNotes.md diff --git a/Solutions/Aruba ClearPass/Data Connectors/Connector_Syslog_ArubaClearPass.json b/Solutions/Aruba ClearPass/Data Connectors/Connector_Syslog_ArubaClearPass.json index 7bcd8068372..a2dd3e953ee 100644 --- a/Solutions/Aruba ClearPass/Data Connectors/Connector_Syslog_ArubaClearPass.json +++ b/Solutions/Aruba ClearPass/Data Connectors/Connector_Syslog_ArubaClearPass.json @@ -1,6 +1,6 @@ { "id": "ArubaClearPass", - "title": "Aruba ClearPass", + "title": "[Deprecated] Aruba ClearPass via Legacy Agent", "publisher": "Aruba Networks", "descriptionMarkdown": "The [Aruba ClearPass](https://www.arubanetworks.com/products/security/network-access-control/secure-access/) connector allows you to easily connect your Aruba ClearPass with Microsoft Sentinel, to create custom dashboards, alerts, and improve investigation. This gives you more insight into your organization’s network and improves your security operation capabilities.", "additionalRequirementBanner":"These queries are dependent on a parser based on a Kusto Function deployed as part of the solution.", diff --git a/Solutions/Aruba ClearPass/Data Connectors/template_ArubaClearPassAMA.json b/Solutions/Aruba ClearPass/Data Connectors/template_ArubaClearPassAMA.json new file mode 100644 index 00000000000..63a6974c595 --- /dev/null +++ b/Solutions/Aruba ClearPass/Data Connectors/template_ArubaClearPassAMA.json @@ -0,0 +1,108 @@ +{ + "id": "ArubaClearPassAma", + "title": "[Recommended] Aruba ClearPass via AMA", + "publisher": "Aruba Networks", + "descriptionMarkdown": "The [Aruba ClearPass](https://www.arubanetworks.com/products/security/network-access-control/secure-access/) connector allows you to easily connect your Aruba ClearPass with Microsoft Sentinel, to create custom dashboards, alerts, and improve investigation. This gives you more insight into your organization’s network and improves your security operation capabilities.", + "additionalRequirementBanner":"These queries are dependent on a parser based on a Kusto Function deployed as part of the solution.", + "graphQueries": [{ + "metricName": "Total data received", + "legend": "ArubaClearPass", + "baseQuery": "CommonSecurityLog\n |where DeviceVendor =~ 'Aruba Networks'\n |where DeviceProduct =~ 'ClearPass'\n |extend sent_by_ama = column_ifexists('CollectorHostName','')\n |where isnotempty(sent_by_ama)" + }], + "sampleQueries": [{ + "description": "Top 10 Events by Username", + "query": "ArubaClearPass \n | summarize count() by UserName \n| top 10 by count_" + }, { + "description": "Top 10 Error Codes", + "query": "ArubaClearPass \n | summarize count() by ErrorCode \n| top 10 by count_" + }], + "connectivityCriterias": [{ + "type": "IsConnectedQuery", + "value": [ + "CommonSecurityLog\n |where DeviceVendor =~ 'Aruba Networks'\n |where DeviceProduct =~ 'ClearPass'\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)" + ] + }], + "dataTypes": [{ + "name": "CommonSecurityLog (ArubaClearPass)", + "lastDataReceivedQuery": "CommonSecurityLog\n |where DeviceVendor =~ 'Aruba Networks'\n |where DeviceProduct =~ 'ClearPass'\n |extend sent_by_ama = column_ifexists('CollectorHostName','')\n |where isnotempty(sent_by_ama)\n | summarize Time = max(TimeGenerated)\n | where isnotempty(Time)" + }], + "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": "**NOTE:** This data connector depends on a parser based on a Kusto Function to work as expected which is deployed as part of the solution. To view the function code in Log Analytics, open Log Analytics/Microsoft Sentinel Logs blade, click Functions and search for the alias ArubaClearPass and load the function code or click [here](https://github.com/Azure/Azure-Sentinel/blob/master/Solutions/Aruba%20ClearPass/Parsers/ArubaClearPass.txt).The function usually takes 10-15 minutes to activate after solution installation/update.", + "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 Aruba ClearPass logs to a Syslog agent", + "description": "Configure Aruba ClearPass to forward Syslog messages in CEF format to your Microsoft Sentinel workspace via the Syslog agent.\n1. [Follow these instructions](https://www.arubanetworks.com/techdocs/ClearPass/6.7/PolicyManager/Content/CPPM_UserGuide/Admin/syslogExportFilters_add_syslog_filter_general.htm) to configure the Aruba ClearPass to forward syslog.\n2. Use the IP address or hostname for the Linux device with the Linux agent installed as the Destination IP address.", + "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)" + } + + ] +} diff --git a/Solutions/Aruba ClearPass/Data/Solution_Aruba.json b/Solutions/Aruba ClearPass/Data/Solution_Aruba.json index f3f5bdbce47..2e56770a67a 100644 --- a/Solutions/Aruba ClearPass/Data/Solution_Aruba.json +++ b/Solutions/Aruba ClearPass/Data/Solution_Aruba.json @@ -2,15 +2,16 @@ "Name": "Aruba ClearPass", "Author": "Aruba Networks", "Logo": "", - "Description": "The [Aruba ClearPass](https://www.arubanetworks.com/products/security/network-access-control/secure-access/) solution allows you to easily connect your Aruba ClearPass with Microsoft Sentinel. solution for Microsoft Sentinel enables you to ingest Symantec VIP's authentication logs into Microsoft Sentinel.\n\n**Underlying Microsoft Technologies used:**\n\nThis 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\n\n- [Agent-based log collection (CEF)](https://docs.microsoft.com/azure/sentinel/connect-common-event-format)", + "Description": "The [Aruba ClearPass](https://www.arubanetworks.com/products/security/network-access-control/secure-access/) solution allows you to easily connect your Aruba ClearPass with Microsoft Sentinel. \n\r\n1. **Aruba ClearPass via AMA** - This data connector helps in ingesting Aruba ClearPass 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. **Aruba ClearPass via Legacy Agent** - This data connector helps in ingesting Aruba ClearPass logs into your Log Analytics Workspace using the legacy Log Analytics agent.\n\n**NOTE:** Microsoft recommends installation of Aruba ClearPass 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": [ - "Solutions/Aruba ClearPass/Data Connectors/Connector_Syslog_ArubaClearPass.json" + "Solutions/Aruba ClearPass/Data Connectors/Connector_Syslog_ArubaClearPass.json", + "Solutions/Aruba ClearPass/Data Connectors/template_ArubaClearPassAMA.json" ], "Parsers": [ - "Solutions/Aruba ClearPass/Parsers/ArubaClearPass.txt" + "Solutions/Aruba ClearPass/Parsers/ArubaClearPass.yaml" ], "BasePath": "C:\\GitHub\\Azure-Sentinel", - "Version": "2.0.2", + "Version": "3.0.0", "Metadata": "SolutionMetadata.json", "TemplateSpec": true, "Is1PConnector": false diff --git a/Solutions/Aruba ClearPass/Parsers/ArubaClearPass.txt b/Solutions/Aruba ClearPass/Parsers/ArubaClearPass.txt deleted file mode 100644 index 04530bf446b..00000000000 --- a/Solutions/Aruba ClearPass/Parsers/ArubaClearPass.txt +++ /dev/null @@ -1,104 +0,0 @@ -// Title: Aruba ClearPass Parser -// Author: Microsoft -// Version: 1.1 -// Last Updated: 01/23/2020 -// Comment: Added Supported for Version 6.6+ -// -// DESCRIPTION: -// This parser takes raw Aruba ClearPass logs from a Syslog (CEF) stream and parses the logs into a normalized schema. -// -// -// REFERENCES: -// Using functions in Azure monitor log queries: https://docs.microsoft.com/azure/azure-monitor/log-query/functions -// -// LOG SAMPLES: -// This parser assumes the raw log are formatted as follows: -// -// Dec 03 2017 16:31:28.861 IST 10.17.4.208 CEF:0|Aruba Networks|ClearPass|6.5.0.69058|0-1-0|Insight Logs|0|Auth.Username=host/Asif-Test-PC2 Auth.Authorization-Sources=null Auth.Login-Status=216 Auth.Request-Timestamp=2017-12-03 16:28:20+05:30 Auth.Protocol=RADIUS Auth.Source=null Auth.Enforcement-Profiles=[Allow Access Profile] Auth.NAS-Port=null Auth.SSID=cppm-dot1x-test TimestampFormat=MMM dd yyyy HH:mm:ss.SSS zzz Auth.NAS-Port-Type=19 Auth.Error-Code=216 Auth.Roles=null Auth.Service=Test Wireless Auth.Host-MAC-Address=6817294b0636 Auth.Unhealthy=null Auth.NAS-IP-Address=10.17.4.7 src=10.17.4.208 Auth.CalledStationId=000B8661CD70 Auth.NAS-Identifier=ClearPassLab3600 -// -// Nov 19 2017 18:22:40.700 IST 10.17.4.221 CEF:0|Aruba Networks|ClearPass|6.5.0.68754|13-1-0|Audit Records|5|cat=Role timeFormat=MMM dd yyyy HH:mm:ss.SSS zzz rt=Nov 19, 2014 18:21:13 IST src=Test Role 10 act=ADD usrName=admin -// -// Dec 01 2017 15:28:40.540 IST 10.17.4.206 CEF:0Aruba Networks|ClearPass|6.5.0.68878|1604-1-0|Session Logs|0|RADIUS.Acct-Calling-Station-Id=00:32:b6:2c:28:95 RADIUS.Acct-Framed-IP-Address=192.167.230.129 RADIUS.Auth-Source=AD:10.17.4.130 RADIUS.Acct-Timestamp=2014-12-01 15:26:43+05:30 RADIUS.Auth-Method=PAP RADIUS.Acct-Service-Name=Authenticate-Only RADIUS.Acct-Session-Time=3155 TimestampFormat=MMM dd yyyy HH:mm:ss.SSS zzz RADIUS.Acct-NAS-Port=0 RADIUS.Acct-Session-Id=R00001316-01-547c3b5a RADIUS.Acct-NAS-Port-Type=Wireless-802.11 RADIUS.Acct-Output-Octets=578470212 RADIUS.Acct-Username=A_user2 RADIUS.Acct-NAS-IP-Address=10.17.6.124 RADIUS.Acct-Input-Octets=786315664 -// -// <143>Aug 10 2016 15:18:04 172.20.21.100 CEF:0|Aruba Networks|ClearPass|6.6.1.84176|2006|Guest Access|1|duser=bob dmac=784b877a4155 dpriv=[User Authenticated] cs2=UNKNOWN cs2Label=System Posture Token outcome=[Allow Access Profile] rt=Aug 10 2016 15:16:51 dvc=172.20.21.100 cat=Session Logs -// -let LogHeader = -CommonSecurityLog -| where DeviceVendor == "Aruba Networks" and DeviceProduct == "ClearPass" -| extend Category = coalesce( - extract(@'cat=([^;]+)(\;|$)',1, AdditionalExtensions), - column_ifexists("DeviceEventCategory", "") - ), - Outcome = coalesce( - extract(@'outcome=([^;]+)\;',1, AdditionalExtensions), - column_ifexists("EventOutcome", "") - ) -| project-rename DvcIpAddr = DeviceAddress, - DvcVersion = DeviceVersion, - SrcIpAddr = SourceIP; -let InsightLogs = LogHeader -| where Activity == "Insight Logs" or Category == "Insight Logs" -// Version 6.5 -| extend UserName = extract(@'Auth.Username=([^;]+)\;',1, AdditionalExtensions), - AuthorizationSources = extract(@'Auth.Authorization-Sources=([^;]+)\;',1, AdditionalExtensions), - NetworkProtocol = extract(@'Auth.Protocol=([^;]+)\;',1, AdditionalExtensions), - RequestTimestamp = extract(@'Auth.Request-Timestamp=([^;]+)\;',1, AdditionalExtensions), - LoginStatus = extract(@'Auth.Login-Status=([^;]+)\;',1, AdditionalExtensions), - Source = extract(@'Auth.Source=([^;]+)\;',1, AdditionalExtensions), - EnforcementProfiles = extract(@'Auth.Enforcement-Profiles=([^;]+)\;',1, AdditionalExtensions), - NasPort = extract(@'Auth.NAS-Port=([^;]+)\;',1, AdditionalExtensions), - TimestampFormat = extract(@'TimestampFormat=([^;]+)\;',1, AdditionalExtensions), - Ssid = extract(@'Auth.SSID=([^;]+)\;',1, AdditionalExtensions), - NasPortType = extract(@'Auth.NAS-Port-Type=([^;]+)\;',1, AdditionalExtensions), - ErrorCode = extract(@'Auth.Error-Code=([^;]+)\;',1, AdditionalExtensions), - Roles = extract(@'Auth.Roles=([^;]+)\;',1, AdditionalExtensions), - Service = extract(@'Auth.Service=([^;]+)\;',1, AdditionalExtensions), - SrcMacAddr = extract(@'Auth.Host-MAC-Address=([^;]+)\;',1, AdditionalExtensions), - Unhealthy = extract(@'Auth.Unhealthy=([^;]+)\;',1, AdditionalExtensions), - NasIpAddr = extract(@'Auth.NAS-IP-Address=([^;]+)\;',1, AdditionalExtensions), - CalledStationId = extract(@'Auth.CalledStationId=([^;]+)\;',1, AdditionalExtensions), - NasIdentifier = extract(@'Auth.NAS-Identifier=([^;]+)\;',1, AdditionalExtensions) -// Version 6.6+ -| extend EndpointStatus = extract(@'ArubaClearpassEndpointStatus=([^;]+)\;',1, AdditionalExtensions), - EndpointConflict = extract(@'ArubaClearpassEndpointConflict=([^;]+)\;',1, AdditionalExtensions), - EndpointDvcCategory = iif(DeviceCustomString3Label == "Endpoint.Device-Category", DeviceCustomString3, ""), - EndpointDvcFamily = iif(DeviceCustomString4Label == "Endpoint.Device-Family", DeviceCustomString4, ""), - EndpointDvcName = iif(DeviceCustomString5Label == "Endpoint.Device-Name", DeviceCustomString5, ""), - EndpointMacVendor = iif(DeviceCustomString6Label == "Endpoint.MAC-Vendor", DeviceCustomString6, ""), - EndpointAddedDate= iif(DeviceCustomDate1Label == "Endpoint.Added-At", todatetime(DeviceCustomDate1), todatetime("")) -| extend Category = iif(isempty(Category), "Insight Logs", Category); -let AuditRecords = LogHeader -| where Activity == "Audit Records" or Category == "Audit Records" -| extend TimestampFormat = extract(@'timeFormat=([^;]+)\;',1, AdditionalExtensions), - UserName = extract(@'usrName=([^;]+)(\;|$)',1, AdditionalExtensions) -| extend Category = iif(isempty(Category), "Audit Records", Category); -let SessionLogs = LogHeader -| where Activity == "Session Logs" or Category == "Session Logs" -| extend Timestamp = extract(@'RADIUS.Acct-Timestamp=([^;]+)\;',1, AdditionalExtensions), - CallingStationId = extract(@'RADIUS.Acct-Calling-Station-Id=([^;]+)\;',1, AdditionalExtensions), - InputOctets = extract(@'RADIUS.Acct-Input-Octets=([^;]+)\;',1, AdditionalExtensions), - TimestampFormat = extract(@'TimestampFormat=([^;]+)\;',1, AdditionalExtensions), - SessionTime = extract(@'RADIUS.Acct-Session-Time=([^;]+)\;',1, AdditionalExtensions), - FramedIpAddr = extract(@'RADIUS.Acct-Framed-IP-Address=([^;]+)\;',1, AdditionalExtensions), - Source = extract(@'RADIUS.Auth-Source=([^;]+)\;',1, AdditionalExtensions), - Method = extract(@'RADIUS.Auth-Method=([^;]+)\;',1, AdditionalExtensions), - SessionId = extract(@'RADIUS.Acct-Session-Id=([^;]+)\;',1, AdditionalExtensions), - ServiceName = extract(@'RADIUS.Acct-Service-Name=([^;]+)\;',1, AdditionalExtensions), - NasPortNumber = extract(@'RADIUS.Acct-NAS-Port=([^;]+)\;',1, AdditionalExtensions), - NasPortType = extract(@'RADIUS.Acct-NAS-Port-Type=([^;]+)\;',1, AdditionalExtensions), - OutputOctets = extract(@'RADIUS.Acct-Output-Octets=([^;]+)\;',1, AdditionalExtensions), - UserName = extract(@'RADIUS.Acct-Username=([^;]+)\;',1, AdditionalExtensions), - NasIpAddr = extract(@'RADIUS.Acct-NAS-IP-Address=([^;]+)\;',1, AdditionalExtensions) -| project-rename DstServiceName = DestinationServiceName, - DstUserPriviledges = DestinationUserPrivileges, - DstUserName = DestinationUserName, - DstMacAddr = DestinationMACAddress -| extend Category = iif(isempty(Category), "Sessions Logs", Category); -let SystemLogs = LogHeader -| where Activity == "System Logs" or Category == "ClearPass System Events" -| extend Description = extract(@'description=([^;]+)\;',1, AdditionalExtensions), - Action = extract(@'daction=([^;]+)\;',1, AdditionalExtensions), - InputOctets = extract(@'RADIUS.Acct-Input-Octets=([^;]+)\;',1, AdditionalExtensions), - TimeFormat = extract(@'devTimeFormat=([^;]+)\;',1, AdditionalExtensions) -| extend Category = iif(isempty(Category), "System Logs", "System Logs"); -union SessionLogs, InsightLogs, AuditRecords, SystemLogs \ No newline at end of file diff --git a/Solutions/Aruba ClearPass/ReleaseNotes.md b/Solutions/Aruba ClearPass/ReleaseNotes.md new file mode 100644 index 00000000000..ebe1ea7cfaa --- /dev/null +++ b/Solutions/Aruba ClearPass/ReleaseNotes.md @@ -0,0 +1,5 @@ +| **Version** | **Date Modified (DD-MM-YYYY)** | **Change History** | +|-------------|--------------------------------|--------------------------------------------------------------------| +| 3.0.0 | 21-09-2023 | Addition of new Aruba ClearPass AMA **Data Connector** | | + + From a553297addf7181395c6c69a6ab7b93307cdcb38 Mon Sep 17 00:00:00 2001 From: Github Bot Date: Fri, 22 Sep 2023 06:22:00 +0000 Subject: [PATCH 2/3] [skip ci] Github Bot Added package to Pull Request! --- .../Data/system_generated_metadata.json | 31 ++ Solutions/Aruba ClearPass/Package/3.0.0.zip | Bin 0 -> 9769 bytes .../Package/createUiDefinition.json | 13 +- .../Aruba ClearPass/Package/mainTemplate.json | 486 +++++++++++++++--- 4 files changed, 461 insertions(+), 69 deletions(-) create mode 100644 Solutions/Aruba ClearPass/Data/system_generated_metadata.json create mode 100644 Solutions/Aruba ClearPass/Package/3.0.0.zip diff --git a/Solutions/Aruba ClearPass/Data/system_generated_metadata.json b/Solutions/Aruba ClearPass/Data/system_generated_metadata.json new file mode 100644 index 00000000000..34d058d2ea1 --- /dev/null +++ b/Solutions/Aruba ClearPass/Data/system_generated_metadata.json @@ -0,0 +1,31 @@ +{ + "Name": "Aruba ClearPass", + "Author": "Aruba Networks", + "Logo": "", + "Description": "The [Aruba ClearPass](https://www.arubanetworks.com/products/security/network-access-control/secure-access/) solution allows you to easily connect your Aruba ClearPass with Microsoft Sentinel. \n\r\n1. **Aruba ClearPass via AMA** - This data connector helps in ingesting Aruba ClearPass 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. **Aruba ClearPass via Legacy Agent** - This data connector helps in ingesting Aruba ClearPass logs into your Log Analytics Workspace using the legacy Log Analytics agent.\n\n**NOTE:** Microsoft recommends installation of Aruba ClearPass 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", + "Version": "3.0.0", + "Metadata": "SolutionMetadata.json", + "TemplateSpec": true, + "Is1PConnector": false, + "publisherId": "azuresentinel", + "offerId": "azure-sentinel-solution-arubaclearpass", + "providers": [ + "Aruba" + ], + "categories": { + "domains": [ + "Security - Threat Protection" + ], + "verticals": [] + }, + "firstPublishDate": "2022-05-23", + "support": { + "tier": "Microsoft", + "name": "Microsoft Corporation", + "email": "support@microsoft.com", + "link": "https://support.microsoft.com/" + }, + "Data Connectors": "[\n \"Connector_Syslog_ArubaClearPass.json\",\n \"template_ArubaClearPassAMA.json\"\n]", + "Parsers": "[\n \"ArubaClearPass.yaml\"\n]" +} diff --git a/Solutions/Aruba ClearPass/Package/3.0.0.zip b/Solutions/Aruba ClearPass/Package/3.0.0.zip new file mode 100644 index 0000000000000000000000000000000000000000..685dd1dc9bcdcb4cdca146102564ab8bb850898c GIT binary patch literal 9769 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\n\n**Note:** _There may be [known issues](https://aka.ms/sentinelsolutionsknownissues) pertaining to this Solution, please refer to them before installing._\n\nThe [Aruba ClearPass](https://www.arubanetworks.com/products/security/network-access-control/secure-access/) solution allows you to easily connect your Aruba ClearPass with Microsoft Sentinel.\n\n**Underlying Microsoft Technologies used:**\n\nThis 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\n\n- [Agent-based log collection (CEF)](https://docs.microsoft.com/azure/sentinel/connect-common-event-format)\n\n**Data Connectors:** 1, **Parsers:** 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 [Aruba ClearPass](https://www.arubanetworks.com/products/security/network-access-control/secure-access/) solution allows you to easily connect your Aruba ClearPass with Microsoft Sentinel. \n\r\n1. **Aruba ClearPass via AMA** - This data connector helps in ingesting Aruba ClearPass 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. **Aruba ClearPass via Legacy Agent** - This data connector helps in ingesting Aruba ClearPass logs into your Log Analytics Workspace using the legacy Log Analytics agent.\n\n**NOTE:** Microsoft recommends installation of Aruba ClearPass 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, **Parsers:** 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,14 +60,14 @@ "name": "dataconnectors1-text", "type": "Microsoft.Common.TextBlock", "options": { - "text": "The solution installs the data connector ingesting Aruba ClearPass to create custom dashboards, alerts, and improve investigation. This gives you more insight into your organization’s network and improves your security operation capabilities. 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 Aruba ClearPass. You can get Aruba ClearPass 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": "dataconnectors-parser-text", "type": "Microsoft.Common.TextBlock", "options": { - "text": "The solution installs a parser that transforms ingested data. The transformed logs can be accessed using the ArubaClearPass Kusto Function alias." + "text": "The Solution installs a parser that transforms the ingested data into Microsoft Sentinel normalized format. The normalized format enables better correlation of different types of data from different data sources to drive end-to-end outcomes seamlessly in security monitoring, hunting, incident investigation and response scenarios in Microsoft Sentinel." } }, { @@ -79,6 +79,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 Aruba ClearPass. You can get Aruba ClearPass CommonSecurityLog data in your Microsoft Sentinel workspace. After installing the solution, configure and enable this data connector by following guidance in Manage solution view." + } } ] } diff --git a/Solutions/Aruba ClearPass/Package/mainTemplate.json b/Solutions/Aruba ClearPass/Package/mainTemplate.json index 3a2d4d9b15b..6baf32f55f1 100644 --- a/Solutions/Aruba ClearPass/Package/mainTemplate.json +++ b/Solutions/Aruba ClearPass/Package/mainTemplate.json @@ -32,53 +32,48 @@ "variables": { "solutionId": "azuresentinel.azure-sentinel-solution-arubaclearpass", "_solutionId": "[variables('solutionId')]", - "workspaceResourceId": "[resourceId('microsoft.OperationalInsights/Workspaces', parameters('workspace'))]", + "_solutionName": "Aruba ClearPass", + "_solutionVersion": "3.0.0", "uiConfigId1": "ArubaClearPass", "_uiConfigId1": "[variables('uiConfigId1')]", "dataConnectorContentId1": "ArubaClearPass", "_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", - "parserVersion1": "1.0.0", - "parserContentId1": "ArubaClearPass-Parser", - "_parserContentId1": "[variables('parserContentId1')]", + "_dataConnectorcontentProductId1": "[concat(take(variables('_solutionId'),50),'-','dc','-', uniqueString(concat(variables('_solutionId'),'-','DataConnector','-',variables('_dataConnectorContentId1'),'-', variables('dataConnectorVersion1'))))]", + "uiConfigId2": "ArubaClearPassAma", + "_uiConfigId2": "[variables('uiConfigId2')]", + "dataConnectorContentId2": "ArubaClearPassAma", + "_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'))))]", "parserName1": "ArubaClearPass", "_parserName1": "[concat(parameters('workspace'),'/',variables('parserName1'))]", "parserId1": "[resourceId('Microsoft.OperationalInsights/workspaces/savedSearches', parameters('workspace'), variables('parserName1'))]", "_parserId1": "[variables('parserId1')]", - "parserTemplateSpecName1": "[concat(parameters('workspace'),'-pr-',uniquestring(variables('_parserContentId1')))]" + "parserTemplateSpecName1": "[concat(parameters('workspace'),'/Microsoft.SecurityInsights/',concat(parameters('workspace'),'-pr-',uniquestring(variables('_parserContentId1'))))]", + "parserVersion1": "1.0.0", + "parserContentId1": "ArubaClearPass-Parser", + "_parserContentId1": "[variables('parserContentId1')]", + "_parsercontentProductId1": "[concat(take(variables('_solutionId'),50),'-','pr','-', uniqueString(concat(variables('_solutionId'),'-','Parser','-',variables('_parserContentId1'),'-', variables('parserVersion1'))))]", + "_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": "Aruba ClearPass data connector with template", - "displayName": "Aruba ClearPass 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": "Aruba ClearPass data connector with template version 2.0.2", + "description": "Aruba ClearPass data connector with template version 3.0.0", "mainTemplate": { "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#", "contentVersion": "[variables('dataConnectorVersion1')]", @@ -94,7 +89,7 @@ "properties": { "connectorUiConfig": { "id": "[variables('_uiConfigId1')]", - "title": "Aruba ClearPass", + "title": "[Deprecated] Aruba ClearPass via Legacy Agent", "publisher": "Aruba Networks", "descriptionMarkdown": "The [Aruba ClearPass](https://www.arubanetworks.com/products/security/network-access-control/secure-access/) connector allows you to easily connect your Aruba ClearPass with Microsoft Sentinel, to create custom dashboards, alerts, and improve investigation. This gives you more insight into your organization’s network and improves your security operation capabilities.", "additionalRequirementBanner": "These queries are dependent on a parser based on a Kusto Function deployed as part of the solution.", @@ -218,7 +213,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'))]", @@ -242,12 +237,23 @@ } } ] - } + }, + "packageKind": "Solution", + "packageVersion": "[variables('_solutionVersion')]", + "packageName": "[variables('_solutionName')]", + "packageId": "[variables('_solutionId')]", + "contentSchemaVersion": "3.0.0", + "contentId": "[variables('_dataConnectorContentId1')]", + "contentKind": "DataConnector", + "displayName": "[Deprecated] Aruba ClearPass 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')]" @@ -282,7 +288,7 @@ "kind": "GenericUI", "properties": { "connectorUiConfig": { - "title": "Aruba ClearPass", + "title": "[Deprecated] Aruba ClearPass via Legacy Agent", "publisher": "Aruba Networks", "descriptionMarkdown": "The [Aruba ClearPass](https://www.arubanetworks.com/products/security/network-access-control/secure-access/) connector allows you to easily connect your Aruba ClearPass with Microsoft Sentinel, to create custom dashboards, alerts, and improve investigation. This gives you more insight into your organization’s network and improves your security operation capabilities.", "graphQueries": [ @@ -406,33 +412,350 @@ } }, { - "type": "Microsoft.Resources/templateSpecs", - "apiVersion": "2021-05-01", - "name": "[variables('parserTemplateSpecName1')]", + "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": "Parser" - }, + "dependsOn": [ + "[extensionResourceId(resourceId('Microsoft.OperationalInsights/workspaces', parameters('workspace')), 'Microsoft.SecurityInsights/contentPackages', variables('_solutionId'))]" + ], "properties": { - "description": "ArubaClearPass Data Parser with template", - "displayName": "ArubaClearPass Data Parser template" + "description": "Aruba ClearPass 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] Aruba ClearPass via AMA", + "publisher": "Aruba Networks", + "descriptionMarkdown": "The [Aruba ClearPass](https://www.arubanetworks.com/products/security/network-access-control/secure-access/) connector allows you to easily connect your Aruba ClearPass with Microsoft Sentinel, to create custom dashboards, alerts, and improve investigation. This gives you more insight into your organization’s network and improves your security operation capabilities.", + "additionalRequirementBanner": "These queries are dependent on a parser based on a Kusto Function deployed as part of the solution.", + "graphQueries": [ + { + "metricName": "Total data received", + "legend": "ArubaClearPass", + "baseQuery": "CommonSecurityLog\n |where DeviceVendor =~ 'Aruba Networks'\n |where DeviceProduct =~ 'ClearPass'\n |extend sent_by_ama = column_ifexists('CollectorHostName','')\n |where isnotempty(sent_by_ama)" + } + ], + "sampleQueries": [ + { + "description": "Top 10 Events by Username", + "query": "ArubaClearPass \n | summarize count() by UserName \n| top 10 by count_" + }, + { + "description": "Top 10 Error Codes", + "query": "ArubaClearPass \n | summarize count() by ErrorCode \n| top 10 by count_" + } + ], + "connectivityCriterias": [ + { + "type": "IsConnectedQuery", + "value": [ + "CommonSecurityLog\n |where DeviceVendor =~ 'Aruba Networks'\n |where DeviceProduct =~ 'ClearPass'\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)" + ] + } + ], + "dataTypes": [ + { + "name": "CommonSecurityLog (ArubaClearPass)", + "lastDataReceivedQuery": "CommonSecurityLog\n |where DeviceVendor =~ 'Aruba Networks'\n |where DeviceProduct =~ 'ClearPass'\n |extend sent_by_ama = column_ifexists('CollectorHostName','')\n |where isnotempty(sent_by_ama)\n | summarize Time = max(TimeGenerated)\n | where isnotempty(Time)" + } + ], + "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": [ + { + "description": "**NOTE:** This data connector depends on a parser based on a Kusto Function to work as expected which is deployed as part of the solution. To view the function code in Log Analytics, open Log Analytics/Microsoft Sentinel Logs blade, click Functions and search for the alias ArubaClearPass and load the function code or click [here](https://github.com/Azure/Azure-Sentinel/blob/master/Solutions/Aruba%20ClearPass/Parsers/ArubaClearPass.txt).The function usually takes 10-15 minutes to activate after solution installation/update.", + "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 Aruba ClearPass logs to a Syslog agent", + "description": "Configure Aruba ClearPass to forward Syslog messages in CEF format to your Microsoft Sentinel workspace via the Syslog agent.\n1. [Follow these instructions](https://www.arubanetworks.com/techdocs/ClearPass/6.7/PolicyManager/Content/CPPM_UserGuide/Admin/syslogExportFilters_add_syslog_filter_general.htm) to configure the Aruba ClearPass to forward syslog.\n2. Use the IP address or hostname for the Linux device with the Linux agent installed as the Destination IP address.", + "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 " + } + ] + } + } + }, + { + "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": "Aruba ClearPass", + "sourceId": "[variables('_solutionId')]" + }, + "author": { + "name": "Aruba Networks" + }, + "support": { + "tier": "Microsoft", + "name": "Microsoft Corporation", + "email": "support@microsoft.com", + "link": "https://support.microsoft.com/" + } + } + } + ] + }, + "packageKind": "Solution", + "packageVersion": "[variables('_solutionVersion')]", + "packageName": "[variables('_solutionName')]", + "packageId": "[variables('_solutionId')]", + "contentSchemaVersion": "3.0.0", + "contentId": "[variables('_dataConnectorContentId2')]", + "contentKind": "DataConnector", + "displayName": "[Recommended] Aruba ClearPass via AMA", + "contentProductId": "[variables('_dataConnectorcontentProductId2')]", + "id": "[variables('_dataConnectorcontentProductId2')]", + "version": "[variables('dataConnectorVersion2')]" } }, { - "type": "Microsoft.Resources/templateSpecs/versions", - "apiVersion": "2021-05-01", - "name": "[concat(variables('parserTemplateSpecName1'),'/',variables('parserVersion1'))]", + "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": "Aruba ClearPass", + "sourceId": "[variables('_solutionId')]" + }, + "author": { + "name": "Aruba Networks" + }, + "support": { + "tier": "Microsoft", + "name": "Microsoft Corporation", + "email": "support@microsoft.com", + "link": "https://support.microsoft.com/" + } + } + }, + { + "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] Aruba ClearPass via AMA", + "publisher": "Aruba Networks", + "descriptionMarkdown": "The [Aruba ClearPass](https://www.arubanetworks.com/products/security/network-access-control/secure-access/) connector allows you to easily connect your Aruba ClearPass with Microsoft Sentinel, to create custom dashboards, alerts, and improve investigation. This gives you more insight into your organization’s network and improves your security operation capabilities.", + "graphQueries": [ + { + "metricName": "Total data received", + "legend": "ArubaClearPass", + "baseQuery": "CommonSecurityLog\n |where DeviceVendor =~ 'Aruba Networks'\n |where DeviceProduct =~ 'ClearPass'\n |extend sent_by_ama = column_ifexists('CollectorHostName','')\n |where isnotempty(sent_by_ama)" + } + ], + "dataTypes": [ + { + "name": "CommonSecurityLog (ArubaClearPass)", + "lastDataReceivedQuery": "CommonSecurityLog\n |where DeviceVendor =~ 'Aruba Networks'\n |where DeviceProduct =~ 'ClearPass'\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 =~ 'Aruba Networks'\n |where DeviceProduct =~ 'ClearPass'\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": "Top 10 Events by Username", + "query": "ArubaClearPass \n | summarize count() by UserName \n| top 10 by count_" + }, + { + "description": "Top 10 Error Codes", + "query": "ArubaClearPass \n | summarize count() by ErrorCode \n| top 10 by count_" + } + ], + "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": [ + { + "description": "**NOTE:** This data connector depends on a parser based on a Kusto Function to work as expected which is deployed as part of the solution. To view the function code in Log Analytics, open Log Analytics/Microsoft Sentinel Logs blade, click Functions and search for the alias ArubaClearPass and load the function code or click [here](https://github.com/Azure/Azure-Sentinel/blob/master/Solutions/Aruba%20ClearPass/Parsers/ArubaClearPass.txt).The function usually takes 10-15 minutes to activate after solution installation/update.", + "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 Aruba ClearPass logs to a Syslog agent", + "description": "Configure Aruba ClearPass to forward Syslog messages in CEF format to your Microsoft Sentinel workspace via the Syslog agent.\n1. [Follow these instructions](https://www.arubanetworks.com/techdocs/ClearPass/6.7/PolicyManager/Content/CPPM_UserGuide/Admin/syslogExportFilters_add_syslog_filter_general.htm) to configure the Aruba ClearPass to forward syslog.\n2. Use the IP address or hostname for the Linux device with the Linux agent installed as the Destination IP address.", + "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')]", + "additionalRequirementBanner": "These queries are dependent on a parser based on a Kusto Function deployed as part of the solution." + } + } + }, + { + "type": "Microsoft.OperationalInsights/workspaces/providers/contentTemplates", + "apiVersion": "2023-04-01-preview", + "name": "[variables('parserTemplateSpecName1')]", "location": "[parameters('workspace-location')]", - "tags": { - "hidden-sentinelWorkspaceId": "[variables('workspaceResourceId')]", - "hidden-sentinelContentType": "Parser" - }, "dependsOn": [ - "[resourceId('Microsoft.Resources/templateSpecs', variables('parserTemplateSpecName1'))]" + "[extensionResourceId(resourceId('Microsoft.OperationalInsights/workspaces', parameters('workspace')), 'Microsoft.SecurityInsights/contentPackages', variables('_solutionId'))]" ], "properties": { - "description": "ArubaClearPass Data Parser with template version 2.0.2", + "description": "ArubaClearPass Data Parser with template version 3.0.0", "mainTemplate": { "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#", "contentVersion": "[variables('parserVersion1')]", @@ -441,20 +764,21 @@ "resources": [ { "name": "[variables('_parserName1')]", - "apiVersion": "2020-08-01", + "apiVersion": "2022-10-01", "type": "Microsoft.OperationalInsights/workspaces/savedSearches", "location": "[parameters('workspace-location')]", "properties": { "eTag": "*", "displayName": "ArubaClearPass", - "category": "Samples", + "category": "Microsoft Sentinel Parser", "functionAlias": "ArubaClearPass", - "query": "\nlet LogHeader =\r\nCommonSecurityLog\r\n| where DeviceVendor == \"Aruba Networks\" and DeviceProduct == \"ClearPass\"\r\n| extend Category = coalesce(\r\n extract(@'cat=([^;]+)(\\;|$)',1, AdditionalExtensions), \r\n column_ifexists(\"DeviceEventCategory\", \"\")\r\n ),\r\n Outcome = coalesce(\r\n extract(@'outcome=([^;]+)\\;',1, AdditionalExtensions), \r\n column_ifexists(\"EventOutcome\", \"\")\r\n )\r\n| project-rename DvcIpAddr = DeviceAddress,\r\n DvcVersion = DeviceVersion,\r\n SrcIpAddr = SourceIP;\r\nlet InsightLogs = LogHeader\r\n| where Activity == \"Insight Logs\" or Category == \"Insight Logs\"\r\n| extend UserName = extract(@'Auth.Username=([^;]+)\\;',1, AdditionalExtensions),\r\n AuthorizationSources = extract(@'Auth.Authorization-Sources=([^;]+)\\;',1, AdditionalExtensions),\r\n NetworkProtocol = extract(@'Auth.Protocol=([^;]+)\\;',1, AdditionalExtensions),\r\n RequestTimestamp = extract(@'Auth.Request-Timestamp=([^;]+)\\;',1, AdditionalExtensions),\r\n LoginStatus = extract(@'Auth.Login-Status=([^;]+)\\;',1, AdditionalExtensions),\r\n Source = extract(@'Auth.Source=([^;]+)\\;',1, AdditionalExtensions),\r\n EnforcementProfiles = extract(@'Auth.Enforcement-Profiles=([^;]+)\\;',1, AdditionalExtensions),\r\n NasPort = extract(@'Auth.NAS-Port=([^;]+)\\;',1, AdditionalExtensions),\r\n TimestampFormat = extract(@'TimestampFormat=([^;]+)\\;',1, AdditionalExtensions),\r\n Ssid = extract(@'Auth.SSID=([^;]+)\\;',1, AdditionalExtensions),\r\n NasPortType = extract(@'Auth.NAS-Port-Type=([^;]+)\\;',1, AdditionalExtensions),\r\n ErrorCode = extract(@'Auth.Error-Code=([^;]+)\\;',1, AdditionalExtensions),\r\n Roles = extract(@'Auth.Roles=([^;]+)\\;',1, AdditionalExtensions),\r\n Service = extract(@'Auth.Service=([^;]+)\\;',1, AdditionalExtensions),\r\n SrcMacAddr = extract(@'Auth.Host-MAC-Address=([^;]+)\\;',1, AdditionalExtensions),\r\n Unhealthy = extract(@'Auth.Unhealthy=([^;]+)\\;',1, AdditionalExtensions),\r\n NasIpAddr = extract(@'Auth.NAS-IP-Address=([^;]+)\\;',1, AdditionalExtensions),\r\n CalledStationId = extract(@'Auth.CalledStationId=([^;]+)\\;',1, AdditionalExtensions),\r\n NasIdentifier = extract(@'Auth.NAS-Identifier=([^;]+)\\;',1, AdditionalExtensions)\r\n| extend EndpointStatus = extract(@'ArubaClearpassEndpointStatus=([^;]+)\\;',1, AdditionalExtensions),\r\n EndpointConflict = extract(@'ArubaClearpassEndpointConflict=([^;]+)\\;',1, AdditionalExtensions),\r\n EndpointDvcCategory = iif(DeviceCustomString3Label == \"Endpoint.Device-Category\", DeviceCustomString3, \"\"),\r\n EndpointDvcFamily = iif(DeviceCustomString4Label == \"Endpoint.Device-Family\", DeviceCustomString4, \"\"),\r\n EndpointDvcName = iif(DeviceCustomString5Label == \"Endpoint.Device-Name\", DeviceCustomString5, \"\"),\r\n EndpointMacVendor = iif(DeviceCustomString6Label == \"Endpoint.MAC-Vendor\", DeviceCustomString6, \"\"), \r\n EndpointAddedDate= iif(DeviceCustomDate1Label == \"Endpoint.Added-At\", todatetime(DeviceCustomDate1), todatetime(\"\"))\r\n| extend Category = iif(isempty(Category), \"Insight Logs\", Category); \r\nlet AuditRecords = LogHeader\r\n| where Activity == \"Audit Records\" or Category == \"Audit Records\"\r\n| extend TimestampFormat = extract(@'timeFormat=([^;]+)\\;',1, AdditionalExtensions),\r\n UserName = extract(@'usrName=([^;]+)(\\;|$)',1, AdditionalExtensions)\r\n| extend Category = iif(isempty(Category), \"Audit Records\", Category);\r\nlet SessionLogs = LogHeader\r\n| where Activity == \"Session Logs\" or Category == \"Session Logs\"\r\n| extend Timestamp = extract(@'RADIUS.Acct-Timestamp=([^;]+)\\;',1, AdditionalExtensions),\r\n CallingStationId = extract(@'RADIUS.Acct-Calling-Station-Id=([^;]+)\\;',1, AdditionalExtensions),\r\n InputOctets = extract(@'RADIUS.Acct-Input-Octets=([^;]+)\\;',1, AdditionalExtensions),\r\n TimestampFormat = extract(@'TimestampFormat=([^;]+)\\;',1, AdditionalExtensions),\r\n SessionTime = extract(@'RADIUS.Acct-Session-Time=([^;]+)\\;',1, AdditionalExtensions),\r\n FramedIpAddr = extract(@'RADIUS.Acct-Framed-IP-Address=([^;]+)\\;',1, AdditionalExtensions),\r\n Source = extract(@'RADIUS.Auth-Source=([^;]+)\\;',1, AdditionalExtensions),\r\n Method = extract(@'RADIUS.Auth-Method=([^;]+)\\;',1, AdditionalExtensions),\r\n SessionId = extract(@'RADIUS.Acct-Session-Id=([^;]+)\\;',1, AdditionalExtensions),\r\n ServiceName = extract(@'RADIUS.Acct-Service-Name=([^;]+)\\;',1, AdditionalExtensions),\r\n NasPortNumber = extract(@'RADIUS.Acct-NAS-Port=([^;]+)\\;',1, AdditionalExtensions),\r\n NasPortType = extract(@'RADIUS.Acct-NAS-Port-Type=([^;]+)\\;',1, AdditionalExtensions),\r\n OutputOctets = extract(@'RADIUS.Acct-Output-Octets=([^;]+)\\;',1, AdditionalExtensions),\r\n UserName = extract(@'RADIUS.Acct-Username=([^;]+)\\;',1, AdditionalExtensions),\r\n NasIpAddr = extract(@'RADIUS.Acct-NAS-IP-Address=([^;]+)\\;',1, AdditionalExtensions)\r\n| project-rename DstServiceName = DestinationServiceName,\r\n DstUserPriviledges = DestinationUserPrivileges,\r\n DstUserName = DestinationUserName,\r\n DstMacAddr = DestinationMACAddress\r\n| extend Category = iif(isempty(Category), \"Sessions Logs\", Category);\r\nlet SystemLogs = LogHeader\r\n| where Activity == \"System Logs\" or Category == \"ClearPass System Events\"\r\n| extend Description = extract(@'description=([^;]+)\\;',1, AdditionalExtensions),\r\n Action = extract(@'daction=([^;]+)\\;',1, AdditionalExtensions),\r\n InputOctets = extract(@'RADIUS.Acct-Input-Octets=([^;]+)\\;',1, AdditionalExtensions),\r\n TimeFormat = extract(@'devTimeFormat=([^;]+)\\;',1, AdditionalExtensions)\r\n| extend Category = iif(isempty(Category), \"System Logs\", \"System Logs\");\r\nunion SessionLogs, InsightLogs, AuditRecords, SystemLogs", - "version": 1, + "query": "let LogHeader =\nCommonSecurityLog\n| where DeviceVendor == \"Aruba Networks\" and DeviceProduct == \"ClearPass\"\n| extend Category = coalesce(\n extract(@'cat=([^;]+)(\\;|$)',1, AdditionalExtensions), \n column_ifexists(\"DeviceEventCategory\", \"\")\n ),\n Outcome = coalesce(\n extract(@'outcome=([^;]+)\\;',1, AdditionalExtensions), \n column_ifexists(\"EventOutcome\", \"\")\n )\n| project-rename DvcIpAddr = DeviceAddress,\n DvcVersion = DeviceVersion,\n SrcIpAddr = SourceIP;\nlet InsightLogs = LogHeader\n| where Activity == \"Insight Logs\" or Category == \"Insight Logs\"\n// Version 6.5\n| extend UserName = extract(@'Auth.Username=([^;]+)\\;',1, AdditionalExtensions),\n AuthorizationSources = extract(@'Auth.Authorization-Sources=([^;]+)\\;',1, AdditionalExtensions),\n NetworkProtocol = extract(@'Auth.Protocol=([^;]+)\\;',1, AdditionalExtensions),\n RequestTimestamp = extract(@'Auth.Request-Timestamp=([^;]+)\\;',1, AdditionalExtensions),\n LoginStatus = extract(@'Auth.Login-Status=([^;]+)\\;',1, AdditionalExtensions),\n Source = extract(@'Auth.Source=([^;]+)\\;',1, AdditionalExtensions),\n EnforcementProfiles = extract(@'Auth.Enforcement-Profiles=([^;]+)\\;',1, AdditionalExtensions),\n NasPort = extract(@'Auth.NAS-Port=([^;]+)\\;',1, AdditionalExtensions),\n TimestampFormat = extract(@'TimestampFormat=([^;]+)\\;',1, AdditionalExtensions),\n Ssid = extract(@'Auth.SSID=([^;]+)\\;',1, AdditionalExtensions),\n NasPortType = extract(@'Auth.NAS-Port-Type=([^;]+)\\;',1, AdditionalExtensions),\n ErrorCode = extract(@'Auth.Error-Code=([^;]+)\\;',1, AdditionalExtensions),\n Roles = extract(@'Auth.Roles=([^;]+)\\;',1, AdditionalExtensions),\n Service = extract(@'Auth.Service=([^;]+)\\;',1, AdditionalExtensions),\n SrcMacAddr = extract(@'Auth.Host-MAC-Address=([^;]+)\\;',1, AdditionalExtensions),\n Unhealthy = extract(@'Auth.Unhealthy=([^;]+)\\;',1, AdditionalExtensions),\n NasIpAddr = extract(@'Auth.NAS-IP-Address=([^;]+)\\;',1, AdditionalExtensions),\n CalledStationId = extract(@'Auth.CalledStationId=([^;]+)\\;',1, AdditionalExtensions),\n NasIdentifier = extract(@'Auth.NAS-Identifier=([^;]+)\\;',1, AdditionalExtensions)\n// Version 6.6+\n| extend EndpointStatus = extract(@'ArubaClearpassEndpointStatus=([^;]+)\\;',1, AdditionalExtensions),\n EndpointConflict = extract(@'ArubaClearpassEndpointConflict=([^;]+)\\;',1, AdditionalExtensions),\n EndpointDvcCategory = iif(DeviceCustomString3Label == \"Endpoint.Device-Category\", DeviceCustomString3, \"\"),\n EndpointDvcFamily = iif(DeviceCustomString4Label == \"Endpoint.Device-Family\", DeviceCustomString4, \"\"),\n EndpointDvcName = iif(DeviceCustomString5Label == \"Endpoint.Device-Name\", DeviceCustomString5, \"\"),\n EndpointMacVendor = iif(DeviceCustomString6Label == \"Endpoint.MAC-Vendor\", DeviceCustomString6, \"\"), \n EndpointAddedDate= iif(DeviceCustomDate1Label == \"Endpoint.Added-At\", todatetime(DeviceCustomDate1), todatetime(\"\"))\n| extend Category = iif(isempty(Category), \"Insight Logs\", Category); \nlet AuditRecords = LogHeader\n| where Activity == \"Audit Records\" or Category == \"Audit Records\"\n| extend TimestampFormat = extract(@'timeFormat=([^;]+)\\;',1, AdditionalExtensions),\n UserName = extract(@'usrName=([^;]+)(\\;|$)',1, AdditionalExtensions)\n| extend Category = iif(isempty(Category), \"Audit Records\", Category);\nlet SessionLogs = LogHeader\n| where Activity == \"Session Logs\" or Category == \"Session Logs\"\n| extend Timestamp = extract(@'RADIUS.Acct-Timestamp=([^;]+)\\;',1, AdditionalExtensions),\n CallingStationId = extract(@'RADIUS.Acct-Calling-Station-Id=([^;]+)\\;',1, AdditionalExtensions),\n InputOctets = extract(@'RADIUS.Acct-Input-Octets=([^;]+)\\;',1, AdditionalExtensions),\n TimestampFormat = extract(@'TimestampFormat=([^;]+)\\;',1, AdditionalExtensions),\n SessionTime = extract(@'RADIUS.Acct-Session-Time=([^;]+)\\;',1, AdditionalExtensions),\n FramedIpAddr = extract(@'RADIUS.Acct-Framed-IP-Address=([^;]+)\\;',1, AdditionalExtensions),\n Source = extract(@'RADIUS.Auth-Source=([^;]+)\\;',1, AdditionalExtensions),\n Method = extract(@'RADIUS.Auth-Method=([^;]+)\\;',1, AdditionalExtensions),\n SessionId = extract(@'RADIUS.Acct-Session-Id=([^;]+)\\;',1, AdditionalExtensions),\n ServiceName = extract(@'RADIUS.Acct-Service-Name=([^;]+)\\;',1, AdditionalExtensions),\n NasPortNumber = extract(@'RADIUS.Acct-NAS-Port=([^;]+)\\;',1, AdditionalExtensions),\n NasPortType = extract(@'RADIUS.Acct-NAS-Port-Type=([^;]+)\\;',1, AdditionalExtensions),\n OutputOctets = extract(@'RADIUS.Acct-Output-Octets=([^;]+)\\;',1, AdditionalExtensions),\n UserName = extract(@'RADIUS.Acct-Username=([^;]+)\\;',1, AdditionalExtensions),\n NasIpAddr = extract(@'RADIUS.Acct-NAS-IP-Address=([^;]+)\\;',1, AdditionalExtensions)\n| project-rename DstServiceName = DestinationServiceName,\n DstUserPriviledges = DestinationUserPrivileges,\n DstUserName = DestinationUserName,\n DstMacAddr = DestinationMACAddress\n| extend Category = iif(isempty(Category), \"Sessions Logs\", Category);\nlet SystemLogs = LogHeader\n| where Activity == \"System Logs\" or Category == \"ClearPass System Events\"\n| extend Description = extract(@'description=([^;]+)\\;',1, AdditionalExtensions),\n Action = extract(@'daction=([^;]+)\\;',1, AdditionalExtensions),\n InputOctets = extract(@'RADIUS.Acct-Input-Octets=([^;]+)\\;',1, AdditionalExtensions),\n TimeFormat = extract(@'devTimeFormat=([^;]+)\\;',1, AdditionalExtensions)\n| extend Category = iif(isempty(Category), \"System Logs\", \"System Logs\");\nunion SessionLogs, InsightLogs, AuditRecords, SystemLogs\n", + "functionParameters": "", + "version": 2, "tags": [ { "name": "description", - "value": "ArubaClearPass" + "value": "" } ] } @@ -464,7 +788,7 @@ "apiVersion": "2022-01-01-preview", "name": "[concat(parameters('workspace'),'/Microsoft.SecurityInsights/',concat('Parser-', last(split(variables('_parserId1'),'/'))))]", "dependsOn": [ - "[variables('_parserName1')]" + "[variables('_parserId1')]" ], "properties": { "parentId": "[resourceId('Microsoft.OperationalInsights/workspaces/savedSearches', parameters('workspace'), variables('parserName1'))]", @@ -488,21 +812,39 @@ } } ] - } + }, + "packageKind": "Solution", + "packageVersion": "[variables('_solutionVersion')]", + "packageName": "[variables('_solutionName')]", + "packageId": "[variables('_solutionId')]", + "contentSchemaVersion": "3.0.0", + "contentId": "[variables('_parserContentId1')]", + "contentKind": "Parser", + "displayName": "ArubaClearPass", + "contentProductId": "[variables('_parsercontentProductId1')]", + "id": "[variables('_parsercontentProductId1')]", + "version": "[variables('parserVersion1')]" } }, { "type": "Microsoft.OperationalInsights/workspaces/savedSearches", - "apiVersion": "2021-06-01", + "apiVersion": "2022-10-01", "name": "[variables('_parserName1')]", "location": "[parameters('workspace-location')]", "properties": { "eTag": "*", "displayName": "ArubaClearPass", - "category": "Samples", + "category": "Microsoft Sentinel Parser", "functionAlias": "ArubaClearPass", - "query": "\nlet LogHeader =\r\nCommonSecurityLog\r\n| where DeviceVendor == \"Aruba Networks\" and DeviceProduct == \"ClearPass\"\r\n| extend Category = coalesce(\r\n extract(@'cat=([^;]+)(\\;|$)',1, AdditionalExtensions), \r\n column_ifexists(\"DeviceEventCategory\", \"\")\r\n ),\r\n Outcome = coalesce(\r\n extract(@'outcome=([^;]+)\\;',1, AdditionalExtensions), \r\n column_ifexists(\"EventOutcome\", \"\")\r\n )\r\n| project-rename DvcIpAddr = DeviceAddress,\r\n DvcVersion = DeviceVersion,\r\n SrcIpAddr = SourceIP;\r\nlet InsightLogs = LogHeader\r\n| where Activity == \"Insight Logs\" or Category == \"Insight Logs\"\r\n| extend UserName = extract(@'Auth.Username=([^;]+)\\;',1, AdditionalExtensions),\r\n AuthorizationSources = extract(@'Auth.Authorization-Sources=([^;]+)\\;',1, AdditionalExtensions),\r\n NetworkProtocol = extract(@'Auth.Protocol=([^;]+)\\;',1, AdditionalExtensions),\r\n RequestTimestamp = extract(@'Auth.Request-Timestamp=([^;]+)\\;',1, AdditionalExtensions),\r\n LoginStatus = extract(@'Auth.Login-Status=([^;]+)\\;',1, AdditionalExtensions),\r\n Source = extract(@'Auth.Source=([^;]+)\\;',1, AdditionalExtensions),\r\n EnforcementProfiles = extract(@'Auth.Enforcement-Profiles=([^;]+)\\;',1, AdditionalExtensions),\r\n NasPort = extract(@'Auth.NAS-Port=([^;]+)\\;',1, AdditionalExtensions),\r\n TimestampFormat = extract(@'TimestampFormat=([^;]+)\\;',1, AdditionalExtensions),\r\n Ssid = extract(@'Auth.SSID=([^;]+)\\;',1, AdditionalExtensions),\r\n NasPortType = extract(@'Auth.NAS-Port-Type=([^;]+)\\;',1, AdditionalExtensions),\r\n ErrorCode = extract(@'Auth.Error-Code=([^;]+)\\;',1, AdditionalExtensions),\r\n Roles = extract(@'Auth.Roles=([^;]+)\\;',1, AdditionalExtensions),\r\n Service = extract(@'Auth.Service=([^;]+)\\;',1, AdditionalExtensions),\r\n SrcMacAddr = extract(@'Auth.Host-MAC-Address=([^;]+)\\;',1, AdditionalExtensions),\r\n Unhealthy = extract(@'Auth.Unhealthy=([^;]+)\\;',1, AdditionalExtensions),\r\n NasIpAddr = extract(@'Auth.NAS-IP-Address=([^;]+)\\;',1, AdditionalExtensions),\r\n CalledStationId = extract(@'Auth.CalledStationId=([^;]+)\\;',1, AdditionalExtensions),\r\n NasIdentifier = extract(@'Auth.NAS-Identifier=([^;]+)\\;',1, AdditionalExtensions)\r\n| extend EndpointStatus = extract(@'ArubaClearpassEndpointStatus=([^;]+)\\;',1, AdditionalExtensions),\r\n EndpointConflict = extract(@'ArubaClearpassEndpointConflict=([^;]+)\\;',1, AdditionalExtensions),\r\n EndpointDvcCategory = iif(DeviceCustomString3Label == \"Endpoint.Device-Category\", DeviceCustomString3, \"\"),\r\n EndpointDvcFamily = iif(DeviceCustomString4Label == \"Endpoint.Device-Family\", DeviceCustomString4, \"\"),\r\n EndpointDvcName = iif(DeviceCustomString5Label == \"Endpoint.Device-Name\", DeviceCustomString5, \"\"),\r\n EndpointMacVendor = iif(DeviceCustomString6Label == \"Endpoint.MAC-Vendor\", DeviceCustomString6, \"\"), \r\n EndpointAddedDate= iif(DeviceCustomDate1Label == \"Endpoint.Added-At\", todatetime(DeviceCustomDate1), todatetime(\"\"))\r\n| extend Category = iif(isempty(Category), \"Insight Logs\", Category); \r\nlet AuditRecords = LogHeader\r\n| where Activity == \"Audit Records\" or Category == \"Audit Records\"\r\n| extend TimestampFormat = extract(@'timeFormat=([^;]+)\\;',1, AdditionalExtensions),\r\n UserName = extract(@'usrName=([^;]+)(\\;|$)',1, AdditionalExtensions)\r\n| extend Category = iif(isempty(Category), \"Audit Records\", Category);\r\nlet SessionLogs = LogHeader\r\n| where Activity == \"Session Logs\" or Category == \"Session Logs\"\r\n| extend Timestamp = extract(@'RADIUS.Acct-Timestamp=([^;]+)\\;',1, AdditionalExtensions),\r\n CallingStationId = extract(@'RADIUS.Acct-Calling-Station-Id=([^;]+)\\;',1, AdditionalExtensions),\r\n InputOctets = extract(@'RADIUS.Acct-Input-Octets=([^;]+)\\;',1, AdditionalExtensions),\r\n TimestampFormat = extract(@'TimestampFormat=([^;]+)\\;',1, AdditionalExtensions),\r\n SessionTime = extract(@'RADIUS.Acct-Session-Time=([^;]+)\\;',1, AdditionalExtensions),\r\n FramedIpAddr = extract(@'RADIUS.Acct-Framed-IP-Address=([^;]+)\\;',1, AdditionalExtensions),\r\n Source = extract(@'RADIUS.Auth-Source=([^;]+)\\;',1, AdditionalExtensions),\r\n Method = extract(@'RADIUS.Auth-Method=([^;]+)\\;',1, AdditionalExtensions),\r\n SessionId = extract(@'RADIUS.Acct-Session-Id=([^;]+)\\;',1, AdditionalExtensions),\r\n ServiceName = extract(@'RADIUS.Acct-Service-Name=([^;]+)\\;',1, AdditionalExtensions),\r\n NasPortNumber = extract(@'RADIUS.Acct-NAS-Port=([^;]+)\\;',1, AdditionalExtensions),\r\n NasPortType = extract(@'RADIUS.Acct-NAS-Port-Type=([^;]+)\\;',1, AdditionalExtensions),\r\n OutputOctets = extract(@'RADIUS.Acct-Output-Octets=([^;]+)\\;',1, AdditionalExtensions),\r\n UserName = extract(@'RADIUS.Acct-Username=([^;]+)\\;',1, AdditionalExtensions),\r\n NasIpAddr = extract(@'RADIUS.Acct-NAS-IP-Address=([^;]+)\\;',1, AdditionalExtensions)\r\n| project-rename DstServiceName = DestinationServiceName,\r\n DstUserPriviledges = DestinationUserPrivileges,\r\n DstUserName = DestinationUserName,\r\n DstMacAddr = DestinationMACAddress\r\n| extend Category = iif(isempty(Category), \"Sessions Logs\", Category);\r\nlet SystemLogs = LogHeader\r\n| where Activity == \"System Logs\" or Category == \"ClearPass System Events\"\r\n| extend Description = extract(@'description=([^;]+)\\;',1, AdditionalExtensions),\r\n Action = extract(@'daction=([^;]+)\\;',1, AdditionalExtensions),\r\n InputOctets = extract(@'RADIUS.Acct-Input-Octets=([^;]+)\\;',1, AdditionalExtensions),\r\n TimeFormat = extract(@'devTimeFormat=([^;]+)\\;',1, AdditionalExtensions)\r\n| extend Category = iif(isempty(Category), \"System Logs\", \"System Logs\");\r\nunion SessionLogs, InsightLogs, AuditRecords, SystemLogs", - "version": 1 + "query": "let LogHeader =\nCommonSecurityLog\n| where DeviceVendor == \"Aruba Networks\" and DeviceProduct == \"ClearPass\"\n| extend Category = coalesce(\n extract(@'cat=([^;]+)(\\;|$)',1, AdditionalExtensions), \n column_ifexists(\"DeviceEventCategory\", \"\")\n ),\n Outcome = coalesce(\n extract(@'outcome=([^;]+)\\;',1, AdditionalExtensions), \n column_ifexists(\"EventOutcome\", \"\")\n )\n| project-rename DvcIpAddr = DeviceAddress,\n DvcVersion = DeviceVersion,\n SrcIpAddr = SourceIP;\nlet InsightLogs = LogHeader\n| where Activity == \"Insight Logs\" or Category == \"Insight Logs\"\n// Version 6.5\n| extend UserName = extract(@'Auth.Username=([^;]+)\\;',1, AdditionalExtensions),\n AuthorizationSources = extract(@'Auth.Authorization-Sources=([^;]+)\\;',1, AdditionalExtensions),\n NetworkProtocol = extract(@'Auth.Protocol=([^;]+)\\;',1, AdditionalExtensions),\n RequestTimestamp = extract(@'Auth.Request-Timestamp=([^;]+)\\;',1, AdditionalExtensions),\n LoginStatus = extract(@'Auth.Login-Status=([^;]+)\\;',1, AdditionalExtensions),\n Source = extract(@'Auth.Source=([^;]+)\\;',1, AdditionalExtensions),\n EnforcementProfiles = extract(@'Auth.Enforcement-Profiles=([^;]+)\\;',1, AdditionalExtensions),\n NasPort = extract(@'Auth.NAS-Port=([^;]+)\\;',1, AdditionalExtensions),\n TimestampFormat = extract(@'TimestampFormat=([^;]+)\\;',1, AdditionalExtensions),\n Ssid = extract(@'Auth.SSID=([^;]+)\\;',1, AdditionalExtensions),\n NasPortType = extract(@'Auth.NAS-Port-Type=([^;]+)\\;',1, AdditionalExtensions),\n ErrorCode = extract(@'Auth.Error-Code=([^;]+)\\;',1, AdditionalExtensions),\n Roles = extract(@'Auth.Roles=([^;]+)\\;',1, AdditionalExtensions),\n Service = extract(@'Auth.Service=([^;]+)\\;',1, AdditionalExtensions),\n SrcMacAddr = extract(@'Auth.Host-MAC-Address=([^;]+)\\;',1, AdditionalExtensions),\n Unhealthy = extract(@'Auth.Unhealthy=([^;]+)\\;',1, AdditionalExtensions),\n NasIpAddr = extract(@'Auth.NAS-IP-Address=([^;]+)\\;',1, AdditionalExtensions),\n CalledStationId = extract(@'Auth.CalledStationId=([^;]+)\\;',1, AdditionalExtensions),\n NasIdentifier = extract(@'Auth.NAS-Identifier=([^;]+)\\;',1, AdditionalExtensions)\n// Version 6.6+\n| extend EndpointStatus = extract(@'ArubaClearpassEndpointStatus=([^;]+)\\;',1, AdditionalExtensions),\n EndpointConflict = extract(@'ArubaClearpassEndpointConflict=([^;]+)\\;',1, AdditionalExtensions),\n EndpointDvcCategory = iif(DeviceCustomString3Label == \"Endpoint.Device-Category\", DeviceCustomString3, \"\"),\n EndpointDvcFamily = iif(DeviceCustomString4Label == \"Endpoint.Device-Family\", DeviceCustomString4, \"\"),\n EndpointDvcName = iif(DeviceCustomString5Label == \"Endpoint.Device-Name\", DeviceCustomString5, \"\"),\n EndpointMacVendor = iif(DeviceCustomString6Label == \"Endpoint.MAC-Vendor\", DeviceCustomString6, \"\"), \n EndpointAddedDate= iif(DeviceCustomDate1Label == \"Endpoint.Added-At\", todatetime(DeviceCustomDate1), todatetime(\"\"))\n| extend Category = iif(isempty(Category), \"Insight Logs\", Category); \nlet AuditRecords = LogHeader\n| where Activity == \"Audit Records\" or Category == \"Audit Records\"\n| extend TimestampFormat = extract(@'timeFormat=([^;]+)\\;',1, AdditionalExtensions),\n UserName = extract(@'usrName=([^;]+)(\\;|$)',1, AdditionalExtensions)\n| extend Category = iif(isempty(Category), \"Audit Records\", Category);\nlet SessionLogs = LogHeader\n| where Activity == \"Session Logs\" or Category == \"Session Logs\"\n| extend Timestamp = extract(@'RADIUS.Acct-Timestamp=([^;]+)\\;',1, AdditionalExtensions),\n CallingStationId = extract(@'RADIUS.Acct-Calling-Station-Id=([^;]+)\\;',1, AdditionalExtensions),\n InputOctets = extract(@'RADIUS.Acct-Input-Octets=([^;]+)\\;',1, AdditionalExtensions),\n TimestampFormat = extract(@'TimestampFormat=([^;]+)\\;',1, AdditionalExtensions),\n SessionTime = extract(@'RADIUS.Acct-Session-Time=([^;]+)\\;',1, AdditionalExtensions),\n FramedIpAddr = extract(@'RADIUS.Acct-Framed-IP-Address=([^;]+)\\;',1, AdditionalExtensions),\n Source = extract(@'RADIUS.Auth-Source=([^;]+)\\;',1, AdditionalExtensions),\n Method = extract(@'RADIUS.Auth-Method=([^;]+)\\;',1, AdditionalExtensions),\n SessionId = extract(@'RADIUS.Acct-Session-Id=([^;]+)\\;',1, AdditionalExtensions),\n ServiceName = extract(@'RADIUS.Acct-Service-Name=([^;]+)\\;',1, AdditionalExtensions),\n NasPortNumber = extract(@'RADIUS.Acct-NAS-Port=([^;]+)\\;',1, AdditionalExtensions),\n NasPortType = extract(@'RADIUS.Acct-NAS-Port-Type=([^;]+)\\;',1, AdditionalExtensions),\n OutputOctets = extract(@'RADIUS.Acct-Output-Octets=([^;]+)\\;',1, AdditionalExtensions),\n UserName = extract(@'RADIUS.Acct-Username=([^;]+)\\;',1, AdditionalExtensions),\n NasIpAddr = extract(@'RADIUS.Acct-NAS-IP-Address=([^;]+)\\;',1, AdditionalExtensions)\n| project-rename DstServiceName = DestinationServiceName,\n DstUserPriviledges = DestinationUserPrivileges,\n DstUserName = DestinationUserName,\n DstMacAddr = DestinationMACAddress\n| extend Category = iif(isempty(Category), \"Sessions Logs\", Category);\nlet SystemLogs = LogHeader\n| where Activity == \"System Logs\" or Category == \"ClearPass System Events\"\n| extend Description = extract(@'description=([^;]+)\\;',1, AdditionalExtensions),\n Action = extract(@'daction=([^;]+)\\;',1, AdditionalExtensions),\n InputOctets = extract(@'RADIUS.Acct-Input-Octets=([^;]+)\\;',1, AdditionalExtensions),\n TimeFormat = extract(@'devTimeFormat=([^;]+)\\;',1, AdditionalExtensions)\n| extend Category = iif(isempty(Category), \"System Logs\", \"System Logs\");\nunion SessionLogs, InsightLogs, AuditRecords, SystemLogs\n", + "functionParameters": "", + "version": 2, + "tags": [ + { + "name": "description", + "value": "" + } + ] } }, { @@ -535,13 +877,20 @@ } }, { - "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.2", + "version": "3.0.0", "kind": "Solution", - "contentSchemaVersion": "2.0.0", + "contentSchemaVersion": "3.0.0", + "displayName": "Aruba ClearPass", + "publisherDisplayName": "Microsoft Sentinel, Microsoft Corporation", + "descriptionHtml": "

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

\n

The Aruba ClearPass solution allows you to easily connect your Aruba ClearPass with Microsoft Sentinel.

\n
    \n
  1. Aruba ClearPass via AMA - This data connector helps in ingesting Aruba ClearPass 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. Aruba ClearPass via Legacy Agent - This data connector helps in ingesting Aruba ClearPass logs into your Log Analytics Workspace using the legacy Log Analytics agent.

    \n
  4. \n
\n

NOTE: Microsoft recommends installation of Aruba ClearPass 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, Parsers: 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": { @@ -566,6 +915,11 @@ "contentId": "[variables('_dataConnectorContentId1')]", "version": "[variables('dataConnectorVersion1')]" }, + { + "kind": "DataConnector", + "contentId": "[variables('_dataConnectorContentId2')]", + "version": "[variables('dataConnectorVersion2')]" + }, { "kind": "Parser", "contentId": "[variables('_parserContentId1')]", From 80b8a4b00b70c9484c27d22d49f890c8bc1fa3f3 Mon Sep 17 00:00:00 2001 From: v-rusraut Date: Fri, 22 Sep 2023 12:10:26 +0530 Subject: [PATCH 3/3] update zip --- Solutions/Aruba ClearPass/Package/3.0.0.zip | Bin 9769 -> 10269 bytes .../Package/createUiDefinition.json | 14 ++++-------- .../Aruba ClearPass/Package/mainTemplate.json | 20 +++++++++--------- 3 files changed, 14 insertions(+), 20 deletions(-) diff --git a/Solutions/Aruba ClearPass/Package/3.0.0.zip b/Solutions/Aruba ClearPass/Package/3.0.0.zip index 685dd1dc9bcdcb4cdca146102564ab8bb850898c..088fd756d983529117e5c984e4875a7fc858d5aa 100644 GIT binary patch literal 10269 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 Z_y0Hq6lI~H{{w;eHv|900P6qj{uh3a0|fv8 literal 9769 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\n\n**Note:** _There may be [known issues](https://aka.ms/sentinelsolutionsknownissues) pertaining to this Solution, please refer to them before installing._\n\nThe [Aruba ClearPass](https://www.arubanetworks.com/products/security/network-access-control/secure-access/) solution allows you to easily connect your Aruba ClearPass with Microsoft Sentinel. \n\r\n1. **Aruba ClearPass via AMA** - This data connector helps in ingesting Aruba ClearPass 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. **Aruba ClearPass via Legacy Agent** - This data connector helps in ingesting Aruba ClearPass logs into your Log Analytics Workspace using the legacy Log Analytics agent.\n\n**NOTE:** Microsoft recommends installation of Aruba ClearPass 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, **Parsers:** 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/Aruba%20ClearPass/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 [Aruba ClearPass](https://www.arubanetworks.com/products/security/network-access-control/secure-access/) solution allows you to easily connect your Aruba ClearPass with Microsoft Sentinel. \n\r\n1. **Aruba ClearPass via AMA** - This data connector helps in ingesting Aruba ClearPass 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. **Aruba ClearPass via Legacy Agent** - This data connector helps in ingesting Aruba ClearPass logs into your Log Analytics Workspace using the legacy Log Analytics agent.\n\n**NOTE:** Microsoft recommends installation of Aruba ClearPass 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, **Parsers:** 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,14 +60,15 @@ "name": "dataconnectors1-text", "type": "Microsoft.Common.TextBlock", "options": { - "text": "This Solution installs the data connector for Aruba ClearPass. You can get Aruba ClearPass 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": "The solution installs the data connector ingesting Aruba ClearPass to create custom dashboards, alerts, and improve investigation. This gives you more insight into your organization’s network and improves your security operation capabilities. After installing the solution, configure and enable this data connector by following guidance in Manage solution view." } }, + { "name": "dataconnectors-parser-text", "type": "Microsoft.Common.TextBlock", "options": { - "text": "The Solution installs a parser that transforms the ingested data into Microsoft Sentinel normalized format. The normalized format enables better correlation of different types of data from different data sources to drive end-to-end outcomes seamlessly in security monitoring, hunting, incident investigation and response scenarios in Microsoft Sentinel." + "text": "The solution installs a parser that transforms ingested data. The transformed logs can be accessed using the ArubaClearPass Kusto Function alias." } }, { @@ -79,13 +80,6 @@ "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 Aruba ClearPass. You can get Aruba ClearPass CommonSecurityLog data in your Microsoft Sentinel workspace. After installing the solution, configure and enable this data connector by following guidance in Manage solution view." - } } ] } diff --git a/Solutions/Aruba ClearPass/Package/mainTemplate.json b/Solutions/Aruba ClearPass/Package/mainTemplate.json index 6baf32f55f1..77a4c7e474b 100644 --- a/Solutions/Aruba ClearPass/Package/mainTemplate.json +++ b/Solutions/Aruba ClearPass/Package/mainTemplate.json @@ -30,10 +30,10 @@ } }, "variables": { - "solutionId": "azuresentinel.azure-sentinel-solution-arubaclearpass", - "_solutionId": "[variables('solutionId')]", "_solutionName": "Aruba ClearPass", "_solutionVersion": "3.0.0", + "solutionId": "azuresentinel.azure-sentinel-solution-arubaclearpass", + "_solutionId": "[variables('solutionId')]", "uiConfigId1": "ArubaClearPass", "_uiConfigId1": "[variables('uiConfigId1')]", "dataConnectorContentId1": "ArubaClearPass", @@ -517,13 +517,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 Aruba ClearPass logs to a Syslog agent", - "description": "Configure Aruba ClearPass to forward Syslog messages in CEF format to your Microsoft Sentinel workspace via the Syslog agent.\n1. [Follow these instructions](https://www.arubanetworks.com/techdocs/ClearPass/6.7/PolicyManager/Content/CPPM_UserGuide/Admin/syslogExportFilters_add_syslog_filter_general.htm) to configure the Aruba ClearPass to forward syslog.\n2. Use the IP address or hostname for the Linux device with the Linux agent installed as the Destination IP address.", - "instructions": [] + "description": "Configure Aruba ClearPass to forward Syslog messages in CEF format to your Microsoft Sentinel workspace via the Syslog agent.\n1. [Follow these instructions](https://www.arubanetworks.com/techdocs/ClearPass/6.7/PolicyManager/Content/CPPM_UserGuide/Admin/syslogExportFilters_add_syslog_filter_general.htm) to configure the Aruba ClearPass to forward syslog.\n2. Use the IP address or hostname for the Linux device with the Linux agent installed as the Destination IP address." + }, { "title": "Step C. Validate connection", @@ -709,13 +709,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 Aruba ClearPass logs to a Syslog agent", - "description": "Configure Aruba ClearPass to forward Syslog messages in CEF format to your Microsoft Sentinel workspace via the Syslog agent.\n1. [Follow these instructions](https://www.arubanetworks.com/techdocs/ClearPass/6.7/PolicyManager/Content/CPPM_UserGuide/Admin/syslogExportFilters_add_syslog_filter_general.htm) to configure the Aruba ClearPass to forward syslog.\n2. Use the IP address or hostname for the Linux device with the Linux agent installed as the Destination IP address.", - "instructions": [] + "description": "Configure Aruba ClearPass to forward Syslog messages in CEF format to your Microsoft Sentinel workspace via the Syslog agent.\n1. [Follow these instructions](https://www.arubanetworks.com/techdocs/ClearPass/6.7/PolicyManager/Content/CPPM_UserGuide/Admin/syslogExportFilters_add_syslog_filter_general.htm) to configure the Aruba ClearPass to forward syslog.\n2. Use the IP address or hostname for the Linux device with the Linux agent installed as the Destination IP address." + }, { "title": "Step C. Validate connection",