Okta Brute Force or Password Spraying Attack

Identifies a high number of failed Okta user authentication attempts from a single IP address, which could be indicative of a brute force or password spraying attack. An adversary may attempt a brute force or password spraying attack to obtain unauthorized access to user accounts.

Elastic rule (View on GitHub)

 1[metadata]
 2creation_date = "2020/07/16"
 3integration = ["okta"]
 4maturity = "production"
 5updated_date = "2024/07/23"
 6
 7[rule]
 8author = ["Elastic"]
 9description = """
10Identifies a high number of failed Okta user authentication attempts from a single IP address, which could be indicative
11of a brute force or password spraying attack. An adversary may attempt a brute force or password spraying attack to
12obtain unauthorized access to user accounts.
13"""
14false_positives = [
15    """
16    Automated processes that attempt to authenticate using expired credentials and unbounded retries may lead to false
17    positives.
18    """,
19]
20index = ["filebeat-*", "logs-okta*"]
21language = "kuery"
22license = "Elastic License v2"
23name = "Okta Brute Force or Password Spraying Attack"
24note = """## Triage and analysis
25
26### Investigating Okta Brute Force or Password Spraying Attack
27
28This rule alerts when a high number of failed Okta user authentication attempts occur from a single IP address. This could be indicative of a brute force or password spraying attack, where an adversary may attempt to gain unauthorized access to user accounts by guessing the passwords.
29
30#### Possible investigation steps:
31
32- Review the `source.ip` field to identify the IP address from which the high volume of failed login attempts originated.
33- Look into the `event.outcome` field to verify that these are indeed failed authentication attempts.
34- Determine the `user.name` or `user.email` related to these failed login attempts. If the attempts are spread across multiple accounts, it might indicate a password spraying attack.
35- Check the timeline of the events. Are the failed attempts spread out evenly, or are there burst periods, which might indicate an automated tool?
36- Determine the geographical location of the source IP. Is this location consistent with the user's typical login location?
37- Analyze any previous successful logins from this IP. Was this IP previously associated with successful logins?
38
39### False positive analysis:
40
41- A single user or automated process that attempts to authenticate using expired or wrong credentials multiple times may trigger a false positive.
42- Analyze the behavior of the source IP. If the IP is associated with legitimate users or services, it may be a false positive.
43
44### Response and remediation:
45
46- If you identify unauthorized access attempts, consider blocking the source IP at the firewall level.
47- Notify the users who are targeted by the attack. Ask them to change their passwords and ensure they use unique, complex passwords.
48- Enhance monitoring on the affected user accounts for any suspicious activity.
49- If the attack is persistent, consider implementing CAPTCHA or account lockouts after a certain number of failed login attempts.
50- If the attack is persistent, consider implementing multi-factor authentication (MFA) for the affected user accounts.
51- Review and update your security policies based on the findings from the incident.
52
53## Setup
54
55The Okta Fleet integration, Filebeat module, or similarly structured data is required to be compatible with this rule."""
56references = [
57    "https://developer.okta.com/docs/reference/api/system-log/",
58    "https://developer.okta.com/docs/reference/api/event-types/",
59    "https://www.elastic.co/security-labs/testing-okta-visibility-and-detection-dorothy",
60]
61risk_score = 47
62rule_id = "42bf698b-4738-445b-8231-c834ddefd8a0"
63severity = "medium"
64tags = ["Use Case: Identity and Access Audit", "Tactic: Credential Access", "Data Source: Okta"]
65timestamp_override = "event.ingested"
66type = "threshold"
67
68query = '''
69event.dataset:okta.system and event.category:authentication and event.outcome:failure
70'''
71
72
73[[rule.threat]]
74framework = "MITRE ATT&CK"
75[[rule.threat.technique]]
76id = "T1110"
77name = "Brute Force"
78reference = "https://attack.mitre.org/techniques/T1110/"
79
80
81[rule.threat.tactic]
82id = "TA0006"
83name = "Credential Access"
84reference = "https://attack.mitre.org/tactics/TA0006/"
85
86[rule.threshold]
87field = ["source.ip"]
88value = 25

Triage and analysis

Investigating Okta Brute Force or Password Spraying Attack

This rule alerts when a high number of failed Okta user authentication attempts occur from a single IP address. This could be indicative of a brute force or password spraying attack, where an adversary may attempt to gain unauthorized access to user accounts by guessing the passwords.

Possible investigation steps:

  • Review the source.ip field to identify the IP address from which the high volume of failed login attempts originated.
  • Look into the event.outcome field to verify that these are indeed failed authentication attempts.
  • Determine the user.name or user.email related to these failed login attempts. If the attempts are spread across multiple accounts, it might indicate a password spraying attack.
  • Check the timeline of the events. Are the failed attempts spread out evenly, or are there burst periods, which might indicate an automated tool?
  • Determine the geographical location of the source IP. Is this location consistent with the user's typical login location?
  • Analyze any previous successful logins from this IP. Was this IP previously associated with successful logins?

False positive analysis:

  • A single user or automated process that attempts to authenticate using expired or wrong credentials multiple times may trigger a false positive.
  • Analyze the behavior of the source IP. If the IP is associated with legitimate users or services, it may be a false positive.

Response and remediation:

  • If you identify unauthorized access attempts, consider blocking the source IP at the firewall level.
  • Notify the users who are targeted by the attack. Ask them to change their passwords and ensure they use unique, complex passwords.
  • Enhance monitoring on the affected user accounts for any suspicious activity.
  • If the attack is persistent, consider implementing CAPTCHA or account lockouts after a certain number of failed login attempts.
  • If the attack is persistent, consider implementing multi-factor authentication (MFA) for the affected user accounts.
  • Review and update your security policies based on the findings from the incident.

Setup

The Okta Fleet integration, Filebeat module, or similarly structured data is required to be compatible with this rule.

References

Related rules

to-top