Detection rules › Panther

AWS RDS Instance or Cluster Deleted

Status
Experimental
Severity
high
Group by
awsRegion, recipientAccountId, requestParameters.dBInstanceIdentifier
Log types
AWS.CloudTrail
Tags
AWS, Impact, Data Destruction, RDS
Reference
https://docs.aws.amazon.com/AmazonRDS/latest/UserGuide/USER_DeleteInstance.html
Source
github.com/panther-labs/panther-analysis

Detects RDS database instance or cluster deletion. Deletions that skip final snapshots result in permanent data loss and may indicate ransomware, insider threats, or compromised credentials being used to destroy data.

MITRE ATT&CK coverage

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_rds_instance_deletion.py
RuleID: "AWS.RDS.InstanceDeletion"
DisplayName: "AWS RDS Instance or Cluster Deleted"
Enabled: true
Status: Experimental
LogTypes:
  - AWS.CloudTrail
Tags:
  - AWS
  - Impact
  - Data Destruction
  - RDS
Severity: High
Description: >
  Detects RDS database instance or cluster deletion. Deletions that skip final snapshots
  result in permanent data loss and may indicate ransomware, insider threats, or
  compromised credentials being used to destroy data.
Runbook: |
  1. Find all RDS API calls by the user ARN in the 48 hours before the alert to identify precursor activities
  2. Check if this user has deleted databases in the past 90 days to determine if this is unusual behavior
  3. Look for deletion protection changes from this user in the 24 hours before the deletion
Reference: https://docs.aws.amazon.com/AmazonRDS/latest/UserGuide/USER_DeleteInstance.html
Reports:
  MITRE ATT&CK:
    - TA0040:T1485  # Data Destruction
    - TA0040:T1531  # Account Access Removal
DedupPeriodMinutes: 60
SummaryAttributes:
  - eventName
  - userIdentity:principalId
  - requestParameters:dBInstanceIdentifier
  - requestParameters:dBClusterIdentifier
  - requestParameters:skipFinalSnapshot
  - p_any_aws_account_ids
Threshold: 1
Tests:
  - Name: RDS Instance Deleted With Final Snapshot
    ExpectedResult: true
    Log:
      eventVersion: "1.08"
      userIdentity:
        type: AssumedRole
        principalId: "AIDAI23HXS3EXAMPLE:admin"
        arn: "arn:aws:sts::123456789012:assumed-role/DBARole/admin"
        accountId: "123456789012"
        accessKeyId: "ASIAIOSFODNN7EXAMPLE"
        sessionContext:
          sessionIssuer:
            type: Role
            principalId: "AIDAI23HXS3EXAMPLE"
            arn: "arn:aws:iam::123456789012:role/DBARole"
            accountId: "123456789012"
            userName: DBARole
      eventTime: "2024-01-15T14:30:00Z"
      eventSource: rds.amazonaws.com
      eventName: DeleteDBInstance
      awsRegion: us-east-1
      sourceIPAddress: "10.0.1.100"
      userAgent: "aws-cli/2.13.0"
      requestParameters:
        dBInstanceIdentifier: "production-mysql-db"
        skipFinalSnapshot: false
        finalDBSnapshotIdentifier: "production-mysql-db-final-snapshot-2024-01-15"
        deleteAutomatedBackups: false
      responseElements:
        dBInstanceIdentifier: "production-mysql-db"
        dBInstanceStatus: "deleting"
        dBInstanceArn: "arn:aws:rds:us-east-1:123456789012:db:production-mysql-db"
      requestID: "a1b2c3d4-e5f6-7890-abcd-ef1234567890"
      eventID: "f1e2d3c4-b5a6-7890-1234-567890abcdef"
      readOnly: false
      eventType: AwsApiCall
      managementEvent: true
      recipientAccountId: "123456789012"
      eventCategory: Management

  - Name: RDS Instance Deleted Without Final Snapshot - Critical
    ExpectedResult: true
    Log:
      eventVersion: "1.08"
      userIdentity:
        type: IAMUser
        principalId: "AIDAI23HXS3EXAMPLE"
        arn: "arn:aws:iam::123456789012:user/contractor"
        accountId: "123456789012"
        accessKeyId: "AKIAIOSFODNN7EXAMPLE"
        userName: contractor
      eventTime: "2024-01-15T14:30:00Z"
      eventSource: rds.amazonaws.com
      eventName: DeleteDBInstance
      awsRegion: us-west-2
      sourceIPAddress: "203.0.113.45"
      userAgent: "Boto3/1.26.0"
      requestParameters:
        dBInstanceIdentifier: "customer-data-db"
        skipFinalSnapshot: true
        deleteAutomatedBackups: true
      responseElements:
        dBInstanceIdentifier: "customer-data-db"
        dBInstanceStatus: "deleting"
      requestID: "b2c3d4e5-f6a7-8901-bcde-f1234567890a"
      eventID: "g2f3e4d5-c6b7-8901-2345-678901bcdefg"
      readOnly: false
      eventType: AwsApiCall
      managementEvent: true
      recipientAccountId: "123456789012"
      eventCategory: Management

  - Name: RDS Cluster Deleted
    ExpectedResult: true
    Log:
      eventVersion: "1.08"
      userIdentity:
        type: AssumedRole
        principalId: "AIDAI23HXS3EXAMPLE:user"
        arn: "arn:aws:sts::123456789012:assumed-role/Admin/user"
        accountId: "123456789012"
        accessKeyId: "ASIAIOSFODNN7EXAMPLE"
      eventTime: "2024-01-15T15:00:00Z"
      eventSource: rds.amazonaws.com
      eventName: DeleteDBCluster
      awsRegion: us-east-1
      sourceIPAddress: "10.0.1.50"
      userAgent: "console.amazonaws.com"
      requestParameters:
        dBClusterIdentifier: "aurora-cluster-prod"
        skipFinalSnapshot: false
        finalDBClusterSnapshotIdentifier: "aurora-cluster-prod-final-2024-01-15"
      responseElements:
        dBClusterIdentifier: "aurora-cluster-prod"
        status: "deleting"
        dBClusterArn: "arn:aws:rds:us-east-1:123456789012:cluster:aurora-cluster-prod"
      requestID: "c3d4e5f6-a7b8-9012-cdef-1234567890ab"
      eventID: "h3g4f5e6-d7c8-9012-3456-789012cdefgh"
      readOnly: false
      eventType: AwsApiCall
      managementEvent: true
      recipientAccountId: "123456789012"
      eventCategory: Management

  - Name: RDS Deletion Failed - Access Denied
    ExpectedResult: false
    Log:
      eventVersion: "1.08"
      userIdentity:
        type: IAMUser
        principalId: "AIDAI23HXS3EXAMPLE"
        arn: "arn:aws:iam::123456789012:user/developer"
        accountId: "123456789012"
        accessKeyId: "AKIAIOSFODNN7EXAMPLE"
        userName: developer
      eventTime: "2024-01-15T14:30:00Z"
      eventSource: rds.amazonaws.com
      eventName: DeleteDBInstance
      awsRegion: us-east-1
      sourceIPAddress: "10.0.2.100"
      userAgent: "aws-cli/2.13.0"
      requestParameters:
        dBInstanceIdentifier: "production-db"
        skipFinalSnapshot: true
      errorCode: AccessDenied
      errorMessage: "User: arn:aws:iam::123456789012:user/developer is not authorized to perform: rds:DeleteDBInstance"
      requestID: "d4e5f6a7-b8c9-0123-def0-1234567890bc"
      eventID: "i4h5g6f7-e8d9-0123-4567-890123defghi"
      readOnly: false
      eventType: AwsApiCall
      managementEvent: true
      recipientAccountId: "123456789012"
      eventCategory: Management

  - Name: Different RDS Event
    ExpectedResult: false
    Log:
      eventVersion: "1.08"
      userIdentity:
        type: AssumedRole
        principalId: "AIDAI23HXS3EXAMPLE:user"
        arn: "arn:aws:sts::123456789012:assumed-role/Admin/user"
        accountId: "123456789012"
      eventTime: "2024-01-15T14:30:00Z"
      eventSource: rds.amazonaws.com
      eventName: ModifyDBInstance
      awsRegion: us-east-1
      sourceIPAddress: "10.0.1.100"
      requestParameters:
        dBInstanceIdentifier: "my-db"
        allocatedStorage: 100
      requestID: "e5f6a7b8-c9d0-1234-ef01-234567890bcd"
      eventID: "j5i6h7g8-f9e0-1234-5678-901234efghij"
      readOnly: false
      eventType: AwsApiCall
      managementEvent: true
      recipientAccountId: "123456789012"
      eventCategory: Management

Detection logic

Condition

eventSource eq "rds.amazonaws.com"
eventName in ["DeleteDBInstance", "DeleteDBCluster"]
errorCode is_null

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
errorCodeis_null
  • (no value, null check)
eventNamein
  • DeleteDBCluster
  • DeleteDBInstance
eventSourceeq
  • rds.amazonaws.com

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.

FieldSource
eventName
eventSource
awsRegion
recipientAccountId
sourceIPAddress
userAgent
userIdentity
dBInstanceIdentifierrequestParameters.dBInstanceIdentifier
userNameuserIdentity.userName