let threshold = 100;
PulseConnectSecure
| where Messages startswith "Login failed"
| summarize dcount(User) by Computer, bin(TimeGenerated, 15m)
| where dcount_User > threshold
name: PulseConnectSecure - Large Number of Distinct Failed User Logins
kind: Scheduled
tactics:
- CredentialAccess
triggerThreshold: 0
triggerOperator: gt
version: 1.0.4
status: Available
queryFrequency: 1h
id: 1fa1528e-f746-4794-8a41-14827f4cb798
requiredDataConnectors:
- connectorId: SyslogAma
datatypes:
- Syslog
relevantTechniques:
- T1110
description: |
'This query identifies evidence of failed login attempts from a large number of distinct users on a Pulse Connect Secure VPN server'
entityMappings:
- entityType: Host
fieldMappings:
- columnName: Computer
identifier: FullName
OriginalUri: https://github.com/Azure/Azure-Sentinel/blob/master/Solutions/Pulse Connect Secure/Analytic Rules/PulseConnectSecureVPN-DistinctFailedUserLogin.yaml
queryPeriod: 1h
severity: Medium
query: |
let threshold = 100;
PulseConnectSecure
| where Messages startswith "Login failed"
| summarize dcount(User) by Computer, bin(TimeGenerated, 15m)
| where dcount_User > threshold