-
Notifications
You must be signed in to change notification settings - Fork 673
[New] Protected Storage Service Access via SMB #6333
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Open
Samirbous
wants to merge
3
commits into
main
Choose a base branch
from
prtected_storage
base: main
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from all commits
Commits
File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
121 changes: 121 additions & 0 deletions
121
rules/windows/credential_access_protected_storage_service_access.toml
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,121 @@ | ||
| [metadata] | ||
| creation_date = "2026/06/26" | ||
| integration = ["system", "windows"] | ||
| maturity = "production" | ||
| updated_date = "2026/06/26" | ||
|
|
||
| [rule] | ||
| author = ["Elastic"] | ||
| description = """ | ||
| Identifies remote access to the Windows Protected Storage Service through the IPC$ share. Attackers may abuse this | ||
| named pipe to interact with the Protected Storage Service and extract sensitive credentials, certificates, or DPAPI | ||
| backup keys. | ||
| """ | ||
| from = "now-9m" | ||
| index = ["logs-system.security*", "logs-windows.forwarded*", "winlogbeat-*"] | ||
| language = "kuery" | ||
| license = "Elastic License v2" | ||
| name = "Protected Storage Service Access via SMB" | ||
| note = """## Triage and analysis | ||
|
|
||
| ### Investigating Protected Storage Service Access via SMB | ||
|
|
||
| The Protected Storage Service manages sensitive user data such as passwords, certificates, and private keys. Remote | ||
| access to the `protected_storage` named pipe over the IPC$ share is unusual and may indicate an attempt to extract | ||
| credentials or abuse DPAPI to retrieve domain backup keys from domain controllers. | ||
|
|
||
| #### Possible investigation steps | ||
|
|
||
| - Identify the source system and user account that initiated the access by reviewing `source.ip`, `user.name`, and | ||
| `winlog.event_data.SubjectUserName`. | ||
| - Determine whether the target host is a domain controller or other high-value system that stores DPAPI backup keys. | ||
| - Review authentication events (4624, 4625) around the alert time to identify how the source authenticated to the | ||
| target. | ||
| - Investigate other alerts associated with the source host or user during the past 48 hours. | ||
| - Check for follow-on credential access activity such as registry hive access, LSASS access, or lateral movement. | ||
|
|
||
| ### False positive analysis | ||
|
|
||
| - This activity is rarely expected in most environments. If legitimate administrative tooling accesses this pipe, | ||
| confirm the source, account, and target system before adding an exception. | ||
|
|
||
| ### Response and remediation | ||
|
|
||
| - Initiate the incident response process based on the outcome of the triage. | ||
| - Isolate the source host if unauthorized access is confirmed. | ||
| - Investigate credential exposure and reset passwords for potentially compromised accounts. | ||
| - Review domain controller DPAPI backup key exposure if the target is a domain controller. | ||
| """ | ||
| references = [ | ||
| "https://threathunterplaybook.com/hunts/windows/190620-DomainDPAPIBackupKeyExtraction/notebook.html", | ||
| "https://www.elastic.co/security-labs/detect-credential-access", | ||
| ] | ||
| setup = """## Setup | ||
|
|
||
| Audit Detailed File Share must be enabled to generate the events used by this rule. | ||
| Setup instructions: https://ela.st/audit-detailed-file-share | ||
| """ | ||
| risk_score = 73 | ||
| rule_id = "9bed06f5-0c32-488a-9353-d565fc9d1573" | ||
| severity = "high" | ||
| tags = [ | ||
| "Domain: Endpoint", | ||
| "OS: Windows", | ||
| "Use Case: Threat Detection", | ||
| "Tactic: Credential Access", | ||
| "Tactic: Lateral Movement", | ||
| "Resources: Investigation Guide", | ||
| "Use Case: Active Directory Monitoring", | ||
| "Data Source: Active Directory", | ||
| "Data Source: Windows Security Event Logs", | ||
| ] | ||
| timestamp_override = "event.ingested" | ||
| type = "query" | ||
|
|
||
| query = ''' | ||
| host.os.type:windows and event.category:file and event.code:5145 and | ||
| winlog.event_data.ShareName:"\\\\*\\IPC$" and | ||
| winlog.event_data.RelativeTargetName:"protected_storage" and | ||
| not source.ip:("::" or "::1" or "0.0.0.0" or "127.0.0.1") | ||
| ''' | ||
|
|
||
|
|
||
| [[rule.threat]] | ||
| framework = "MITRE ATT&CK" | ||
|
|
||
| [[rule.threat.technique]] | ||
| id = "T1555" | ||
| name = "Credentials from Password Stores" | ||
| reference = "https://attack.mitre.org/techniques/T1555/" | ||
|
|
||
| [[rule.threat.technique]] | ||
| id = "T1552" | ||
| name = "Unsecured Credentials" | ||
| reference = "https://attack.mitre.org/techniques/T1552/" | ||
|
|
||
|
Copilot marked this conversation as resolved.
|
||
| [[rule.threat.technique.subtechnique]] | ||
| id = "T1552.004" | ||
| name = "Private Keys" | ||
| reference = "https://attack.mitre.org/techniques/T1552/004/" | ||
| [rule.threat.tactic] | ||
| id = "TA0006" | ||
| name = "Credential Access" | ||
| reference = "https://attack.mitre.org/tactics/TA0006/" | ||
|
|
||
| [[rule.threat]] | ||
| framework = "MITRE ATT&CK" | ||
|
|
||
| [[rule.threat.technique]] | ||
| id = "T1021" | ||
| name = "Remote Services" | ||
| reference = "https://attack.mitre.org/techniques/T1021/" | ||
|
|
||
| [[rule.threat.technique.subtechnique]] | ||
| id = "T1021.002" | ||
| name = "SMB/Windows Admin Shares" | ||
| reference = "https://attack.mitre.org/techniques/T1021/002/" | ||
|
|
||
| [rule.threat.tactic] | ||
| id = "TA0008" | ||
| name = "Lateral Movement" | ||
| reference = "https://attack.mitre.org/tactics/TA0008/" | ||
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Uh oh!
There was an error while loading. Please reload this page.