Detection rules › Panther

GCP Destructive Queries

Severity
informational
Entities
emails, ip_addresses
Log types
GCP.AuditLog
Reference
https://cloud.google.com/bigquery/docs/managing-tables
Source
github.com/panther-labs/panther-analysis

Detect any destructive BigQuery queries or jobs such as update, delete, drop, alter or truncate.

Rule body yaml

AnalysisType: rule
Description: Detect any destructive BigQuery queries or jobs such as update, delete, drop, alter or truncate.
DisplayName: "GCP Destructive Queries"
Enabled: true
Filename: gcp_destructive_queries.py
Reference: https://cloud.google.com/bigquery/docs/managing-tables
Severity: Info
SummaryAttributes:
  - p_alert_context.table
Tests:
  - ExpectedResult: true
    Log:
      insertid: abcdefghijklmn
      logname: projects/gcp-project1/logs/cloudaudit.googleapis.com%2Fdata_access
      operation:
        id: 1234567890123-gcp-project1:abcdefghijklmnopqrstuvwz
        last: true
        producer: bigquery.googleapis.com
      p_any_emails:
        - user@company.io
      p_any_ip_addresses:
        - 1.2.3.4
      p_event_time: "2023-03-28 18:37:06.079"
      p_log_type: GCP.AuditLog
      p_parse_time: "2023-03-28 18:38:14.478"
      p_row_id: 06bf03d9d5dfbadba981899e1787bf05
      p_schema_version: 0
      p_source_id: 964c7894-9a0d-4ddf-864f-0193438221d6
      p_source_label: gcp-logsource
      protopayload:
        at_sign_type: type.googleapis.com/google.cloud.audit.AuditLog
        authenticationInfo:
          principalEmail: user@company.io
        authorizationInfo:
          - granted: true
            permission: bigquery.jobs.create
            resource: projects/gcp-project1
        metadata:
          "@type": type.googleapis.com/google.cloud.audit.BigQueryAuditMetadata
          jobChange:
            after: DONE
            job:
              jobConfig:
                queryConfig:
                  createDisposition: CREATE_IF_NEEDED
                  destinationTable: projects/gcp-project1/datasets/test1/tables/newtable
                  priority: QUERY_INTERACTIVE
                  query: DROP TABLE test1.newtable
                  statementType: DROP_TABLE
                  writeDisposition: WRITE_EMPTY
                type: QUERY
              jobName: projects/gcp-project1/jobs/abcdefghijklmnopqrstuvwz
              jobStats:
                createTime: "2023-03-28T18:37:05.842Z"
                endTime: "2023-03-28T18:37:06.073Z"
                queryStats: {}
                startTime: "2023-03-28T18:37:05.934Z"
              jobStatus:
                jobState: DONE
        methodName: google.cloud.bigquery.v2.JobService.InsertJob
        requestMetadata:
          callerIP: 1.2.3.4
          callerSuppliedUserAgent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/111.0.0.0 Safari/537.36,gzip(gfe),gzip(gfe)
        resourceName: projects/gcp-project1/jobs/abcdefghijklmnopqrstuvwz
        serviceName: bigquery.googleapis.com
        status: {}
      receivetimestamp: "2023-03-28 18:37:06.745"
      resource:
        labels:
          location: US
          project_id: gcp-project1
        type: bigquery_project
      severity: INFO
      timestamp: "2023-03-28 18:37:06.079"
    Name: Drop Table Event
  - ExpectedResult: true
    Log:
      insertid: abcdefghijklmn
      logname: projects/gcp-project1/logs/cloudaudit.googleapis.com%2Factivity
      operation:
        id: 1234567890123-gcp-project1:abcdefghijklmnopqrstuvwz
        last: true
        producer: bigquery.googleapis.com
      p_any_emails:
        - user@company.io
      p_any_ip_addresses:
        - 1.2.3.4
      p_event_time: "2023-03-28 18:37:06.079"
      p_log_type: GCP.AuditLog
      p_parse_time: "2023-03-28 18:38:14.478"
      p_row_id: 06bf03d9d5dfbadba981899e1787bf05
      p_schema_version: 0
      p_source_id: 964c7894-9a0d-4ddf-864f-0193438221d6
      p_source_label: gcp-logsource
      protopayload:
        at_sign_type: type.googleapis.com/google.cloud.audit.AuditLog
        authenticationInfo:
          principalEmail: user@company.io
        authorizationInfo:
          - granted: true
            permission: bigquery.tables.delete
            resource: projects/gcp-project1/datasets/test1/tables/newtable
        metadata:
          "@type": type.googleapis.com/google.cloud.audit.BigQueryAuditMetadata
          methodName: google.cloud.bigquery.v2.JobService.InsertJob
          requestMetadata:
            callerIP: 1.2.3.4
            callerSuppliedUserAgent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/111.0.0.0 Safari/537.36,gzip(gfe),gzip(gfe)
          resourceName: projects/gcp-project1/datasets/test1/tables/newtable
          serviceName: bigquery.googleapis.com
          status: {}
          tableDeletion:
            jobName: projects/gcp-project1/jobs/bquxjob_5e4a0679_18729a639d7
            reason: QUERY
        receivetimestamp: "2023-03-28 18:37:06.745"
        resource:
          labels:
            dataset_id: test1
            project_id: gcp-project1
          type: bigquery_dataset
        severity: NOTICE
        timestamp: "2023-03-28 18:37:06.079"
    Name: TableDeletion
  - ExpectedResult: true
    Log:
      insertid: abcdefghijklmn
      logname: projects/gcp-project1/logs/cloudaudit.googleapis.com%2Fdata_access
      operation:
        id: 1234567890123-gcp-project1:abcdefghijklmnopqrstuvwz
        last: true
        producer: bigquery.googleapis.com
      p_any_emails:
        - user@company.io
      p_any_ip_addresses:
        - 1.2.3.4
      p_event_time: "2023-03-28 18:37:06.079"
      p_log_type: GCP.AuditLog
      p_parse_time: "2023-03-28 18:38:14.478"
      p_row_id: 06bf03d9d5dfbadba981899e1787bf05
      p_schema_version: 0
      p_source_id: 964c7894-9a0d-4ddf-864f-0193438221d6
      p_source_label: gcp-logsource
      protopayload:
        at_sign_type: type.googleapis.com/google.cloud.audit.AuditLog
        authenticationInfo:
          principalEmail: user@company.io
        authorizationInfo:
          - granted: true
            permission: bigquery.jobs.create
            resource: projects/gcp-project1
        metadata:
          "@type": type.googleapis.com/google.cloud.audit.BigQueryAuditMetadata
          jobChange:
            after: DONE
            job:
              jobConfig:
                queryConfig:
                  createDisposition: CREATE_IF_NEEDED
                  destinationTable: projects/gcp-project1/datasets/test1/tables/newtable
                  priority: QUERY_INTERACTIVE
                  query: DELETE from test1.newtable WHERE foo = bar
                  statementType: DELETE
                  writeDisposition: WRITE_EMPTY
                type: QUERY
              jobName: projects/gcp-project1/jobs/abcdefghijklmnopqrstuvwz
              jobStats:
                createTime: "2023-03-28T18:37:05.842Z"
                endTime: "2023-03-28T18:37:06.073Z"
                queryStats: {}
                startTime: "2023-03-28T18:37:05.934Z"
              jobStatus:
                jobState: DONE
        methodName: google.cloud.bigquery.v2.JobService.InsertJob
        requestMetadata:
          callerIP: 1.2.3.4
          callerSuppliedUserAgent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/111.0.0.0 Safari/537.36,gzip(gfe),gzip(gfe)
        resourceName: projects/gcp-project1/jobs/abcdefghijklmnopqrstuvwz
        serviceName: bigquery.googleapis.com
        status: {}
      receivetimestamp: "2023-03-28 18:37:06.745"
      resource:
        labels:
          location: US
          project_id: gcp-project1
        type: bigquery_project
      severity: INFO
      timestamp: "2023-03-28 18:37:06.079"
    Name: DataDeletion
DedupPeriodMinutes: 60
LogTypes:
  - GCP.AuditLog
RuleID: "GCP.Destructive.Queries"
Threshold: 1

Detection logic

Condition

(resource.type starts_with "bigquery" and protoPayload.metadata.jobChange.job.jobConfig.type eq "QUERY" and protoPayload.metadata.jobChange.job.jobConfig.queryConfig.statementType in ["UPDATE", "DELETE", "DROP_TABLE", "ALTER_TABLE", "TRUNCATE_TABLE"]) or protoPayload.metadata.tableDeletion is_not_null or protoPayload.metadata.datasetDeletion is_not_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
protoPayload.metadata.datasetDeletionis_not_null
  • (no value, null check)
protoPayload.metadata.jobChange.job.jobConfig.queryConfig.statementTypein
  • ALTER_TABLE
  • DELETE
  • DROP_TABLE
  • TRUNCATE_TABLE
  • UPDATE
protoPayload.metadata.jobChange.job.jobConfig.typeeq
  • QUERY
protoPayload.metadata.tableDeletionis_not_null
  • (no value, null check)
resource.typestarts_with
  • bigquery

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
queryprotoPayload.metadata.jobChange.job.jobConfig.queryConfig.query
actorprotoPayload.authenticationInfo.principalEmail
statementprotoPayload.metadata.jobChange.job.jobConfig.queryConfig.statementType
tableprotoPayload.metadata.jobChange.job.jobConfig.queryConfig.destinationTable