Detection rules › Panther

EC2 Secrets Manager Retrieve Secrets

Status
Experimental
Severity
informational
Log types
AWS.CloudTrail
Tags
AWS, Credential Access, Stratus Red Team
Reference
https://stratus-red-team.cloud/attack-techniques/AWS/aws.credential-access.secretsmanager-retrieve-secrets/
Source
github.com/panther-labs/panther-analysis

An attacker attempted to retrieve a high number of Secrets Manager secrets, through secretsmanager:GetSecretValue.

MITRE ATT&CK coverage

TacticTechniques
Credential AccessT1552 Unsecured Credentials

Rules detecting the same action

Other rules on this platform that filter on the same API call or operation.

Rule body yaml

AnalysisType: rule
Filename: aws_secretsmanager_retrieve_secrets.py
RuleID: "AWS.SecretsManager.RetrieveSecrets"
DisplayName: "EC2 Secrets Manager Retrieve Secrets"
Enabled: true
LogTypes:
  - AWS.CloudTrail
Tags:
  - AWS
  - Credential Access
  - Stratus Red Team
Status: Experimental
Reports:
  MITRE ATT&CK:
    - TA0006:T1552 # Credentials from Password Stores 
Severity: Info
Description: An attacker attempted to retrieve a high number of Secrets Manager secrets, through secretsmanager:GetSecretValue.
Runbook: https://permiso.io/blog/lucr-3-scattered-spider-getting-saas-y-in-the-cloud
Reference: https://stratus-red-team.cloud/attack-techniques/AWS/aws.credential-access.secretsmanager-retrieve-secrets/
Threshold: 20
DedupPeriodMinutes: 1440
SummaryAttributes:
  - eventName
  - userAgent
  - sourceIpAddress
  - recipientAccountId
  - p_any_aws_arns
Tests:
  - Name: GetSecretValue Denied
    ExpectedResult: true
    Log: {
      "awsRegion": "us-west-2",
      "eventCategory": "Management",
      "eventID": "dfd6d93a-2ce6-4dbe-8939-86b8ba67c868",
      "eventName": "GetSecretValue",
      "errorCode": "AccessDenied",
      "eventSource": "secretsmanager.amazonaws.com",
      "eventTime": "2024-10-17 21:48:45.000000000",
      "eventType": "AwsApiCall",
      "eventVersion": "1.09",
      "managementEvent": true,
      "readOnly": true,
      "recipientAccountId": "123123123123",
      "requestID": "5128b35f-0daf-4c5e-948a-21a1c507968c",
      "requestParameters": {
        "secretId": "arn:aws:secretsmanager:us-west-2:123123123123:secret:stratus-red-team-retrieve-secret-3-gscOm8",
        "versionId": "7DC59E8B-63AE-454D-B7A4-8A7D64AB05E7"
      },
      "sourceIPAddress": "123.123.123.123",
      "tlsDetails": {
        "cipherSuite": "TLS_AES_128_GCM_SHA256",
        "clientProvidedHostHeader": "secretsmanager.us-west-2.amazonaws.com",
        "tlsVersion": "TLSv1.3"
      },
      "userAgent": "APN/1.0 HashiCorp/1.0 Terraform/1.1.2 (+https://www.terraform.io) terraform-provider-aws/3.76.1 (+https://registry.terraform.io/providers/hashicorp/aws) aws-sdk-go/1.44.157 (go1.19.3; darwin; arm64) HashiCorp-terraform-exec/0.17.3",
      "userIdentity": {
        "accessKeyId": "ASIASXP6SDP2LKLKYYC4",
        "accountId": "123123123123",
        "arn": "arn:aws:sts::123123123123:assumed-role/AWSReservedSSO_DevAdmin_635426549a280cc6/evil.genius",
        "principalId": "AROASXP6SDP2F4WLQVARB:evil.genius",
        "sessionContext": {
          "attributes": {
            "creationDate": "2024-10-17T21:48:13Z",
            "mfaAuthenticated": "false"
          },
          "sessionIssuer": {
            "accountId": "123123123123",
            "arn": "arn:aws:iam::123123123123:role/aws-reserved/sso.amazonaws.com/us-west-2/AWSReservedSSO_DevAdmin_635426549a280cc6",
            "principalId": "AROASXP6SDP2F4WLQVARB",
            "type": "Role",
            "userName": "AWSReservedSSO_DevAdmin_635426549a280cc6"
          }
        },
        "type": "AssumedRole"
      }
    }

Detection logic

Condition

eventName eq "GetSecretValue"
errorCode is_not_null or errorMessage is_not_null
errorCode eq "AccessDenied"

Indicators

Each row is a field, operator, and value that the rule matches. The corpus column counts how many other rules in the catalog look for the same combination: high numbers point to widely-used, community-vetted indicators. Blank or 1 shows that the indicator is specific to this rule.

FieldKindValues
errorCodeeq
  • AccessDenied
errorCodeis_not_null
  • (no value, null check)
errorMessageis_not_null
  • (no value, null check)
eventNameeq
  • GetSecretValue

Output fields

Fields the rule emits when it matches. Chronicle authors list these in the outcome block; they appear on the detection and $risk_score drives alerting. Sentinel / Defender XDR rules build them up through project / summarize / extend stages. Sentinel maps these into alert fields via entityMappings and customDetails; Defender XDR custom detections surface them as alert fields directly.

Field
actor_user