Group Policy Abuse for Privilege Addition

Detects the first occurrence of a modification to Group Policy Object Attributes to add privileges to user accounts or use them to add users as local admins.

Elastic rule (View on GitHub)

 1[metadata]
 2creation_date = "2021/11/08"
 3integration = ["system", "windows"]
 4maturity = "production"
 5updated_date = "2024/08/09"
 6
 7[rule]
 8author = ["Elastic"]
 9description = """
10Detects the first occurrence of a modification to Group Policy Object Attributes to add privileges to user accounts or
11use them to add users as local admins.
12"""
13index = ["winlogbeat-*", "logs-system.*", "logs-windows.*"]
14language = "eql"
15license = "Elastic License v2"
16name = "Group Policy Abuse for Privilege Addition"
17note = """## Triage and analysis
18
19### Investigating Group Policy Abuse for Privilege Addition
20
21Group Policy Objects (GPOs) can be used to add rights and/or modify Group Membership on GPOs by changing the contents of an INF file named GptTmpl.inf, which is responsible for storing every setting under the Security Settings container in the GPO. This file is unique for each GPO, and only exists if the GPO contains security settings. Example Path: "\\\\DC.com\\SysVol\\DC.com\\Policies\\{PolicyGUID}\\Machine\\Microsoft\\Windows NT\\SecEdit\\GptTmpl.inf"
22
23#### Possible investigation steps
24
25- This attack abuses a legitimate mechanism of Active Directory, so it is important to determine whether the activity is legitimate and the administrator is authorized to perform this operation.
26- Retrieve the contents of the `GptTmpl.inf` file, and under the `Privilege Rights` section, look for potentially dangerous high privileges, for example: SeTakeOwnershipPrivilege, SeEnableDelegationPrivilege, etc.
27- Inspect the user security identifiers (SIDs) associated with these privileges, and if they should have these privileges.
28
29### False positive analysis
30
31- Inspect whether the user that has done the modifications should be allowed to. The user name can be found in the `winlog.event_data.SubjectUserName` field.
32
33### Related rules
34
35- Scheduled Task Execution at Scale via GPO - 15a8ba77-1c13-4274-88fe-6bd14133861e
36- Startup/Logon Script added to Group Policy Object - 16fac1a1-21ee-4ca6-b720-458e3855d046
37
38### Response and remediation
39
40- Initiate the incident response process based on the outcome of the triage.
41- The investigation and containment must be performed in every computer controlled by the GPO, where necessary.
42- Remove the script from the GPO.
43- Check if other GPOs have suspicious scripts attached.
44"""
45references = [
46    "https://github.com/atc-project/atc-data/blob/master/docs/Logging_Policies/LP_0025_windows_audit_directory_service_changes.md",
47    "https://labs.f-secure.com/tools/sharpgpoabuse",
48]
49risk_score = 73
50rule_id = "b9554892-5e0e-424b-83a0-5aef95aa43bf"
51setup = """## Setup
52
53The 'Audit Directory Service Changes' audit policy must be configured (Success Failure).
54Steps to implement the logging policy with Advanced Audit Configuration:

Computer Configuration > Policies > Windows Settings > Security Settings > Advanced Audit Policies Configuration > Audit Policies > DS Access > Audit Directory Service Changes (Success,Failure)

 1"""
 2severity = "high"
 3tags = [
 4    "Domain: Endpoint",
 5    "OS: Windows",
 6    "Use Case: Threat Detection",
 7    "Tactic: Privilege Escalation",
 8    "Data Source: Active Directory",
 9    "Resources: Investigation Guide",
10    "Use Case: Active Directory Monitoring",
11    "Data Source: System",
12]
13timestamp_override = "event.ingested"
14type = "eql"
15
16query = '''
17any where host.os.type == "windows" and event.code: "5136" and
18  winlog.event_data.AttributeLDAPDisplayName: "gPCMachineExtensionNames" and
19  winlog.event_data.AttributeValue: "*827D319E-6EAC-11D2-A4EA-00C04F79F83A*" and
20  winlog.event_data.AttributeValue: "*803E14A0-B4FB-11D0-A0D0-00A0C90F574B*"
21'''
22
23
24[[rule.threat]]
25framework = "MITRE ATT&CK"
26[[rule.threat.technique]]
27id = "T1484"
28name = "Domain or Tenant Policy Modification"
29reference = "https://attack.mitre.org/techniques/T1484/"
30[[rule.threat.technique.subtechnique]]
31id = "T1484.001"
32name = "Group Policy Modification"
33reference = "https://attack.mitre.org/techniques/T1484/001/"
34
35
36
37[rule.threat.tactic]
38id = "TA0004"
39name = "Privilege Escalation"
40reference = "https://attack.mitre.org/tactics/TA0004/"

Triage and analysis

Investigating Group Policy Abuse for Privilege Addition

Group Policy Objects (GPOs) can be used to add rights and/or modify Group Membership on GPOs by changing the contents of an INF file named GptTmpl.inf, which is responsible for storing every setting under the Security Settings container in the GPO. This file is unique for each GPO, and only exists if the GPO contains security settings. Example Path: "\DC.com\SysVol\DC.com\Policies{PolicyGUID}\Machine\Microsoft\Windows NT\SecEdit\GptTmpl.inf"

Possible investigation steps

  • This attack abuses a legitimate mechanism of Active Directory, so it is important to determine whether the activity is legitimate and the administrator is authorized to perform this operation.
  • Retrieve the contents of the GptTmpl.inf file, and under the Privilege Rights section, look for potentially dangerous high privileges, for example: SeTakeOwnershipPrivilege, SeEnableDelegationPrivilege, etc.
  • Inspect the user security identifiers (SIDs) associated with these privileges, and if they should have these privileges.

False positive analysis

  • Inspect whether the user that has done the modifications should be allowed to. The user name can be found in the winlog.event_data.SubjectUserName field.
  • Scheduled Task Execution at Scale via GPO - 15a8ba77-1c13-4274-88fe-6bd14133861e
  • Startup/Logon Script added to Group Policy Object - 16fac1a1-21ee-4ca6-b720-458e3855d046

Response and remediation

  • Initiate the incident response process based on the outcome of the triage.
  • The investigation and containment must be performed in every computer controlled by the GPO, where necessary.
  • Remove the script from the GPO.
  • Check if other GPOs have suspicious scripts attached.

References

Related rules

to-top