BigQuery Reservation API audit logging

This document describes audit logging for BigQuery Reservation API, including which methods generate audit logs, details about the audit logs each method produces, and which methods do not produce audit logs, if any. Google Cloud generates audit logs that record administrative and access activities within your Google Cloud resources. For more information, see Cloud Audit Logs overview.

Service name

BigQuery Reservation API audit logs use the service name bigqueryreservation.googleapis.com.

Methods by permission type

Each IAM permission has a type property, whose value is an enum that can be one of four values: ADMIN_READ, ADMIN_WRITE, DATA_READ, and DATA_WRITE. When you call a method, an audit log whose category is dependent on the type property of the permission required to perform the method. Methods that require an IAM permission with the type property value of DATA_READ, DATA_WRITE, or ADMIN_READ generate Data Access audit logs. Methods that require an IAM permission with the type property value of ADMIN_WRITE generate Admin Activity audit logs.

Permission type Methods
ADMIN_READ google.cloud.bigquery.reservation.v1.ReservationService.GetBiReservation
google.cloud.bigquery.reservation.v1.ReservationService.GetCapacityCommitment
google.cloud.bigquery.reservation.v1.ReservationService.GetReservation
google.cloud.bigquery.reservation.v1.ReservationService.ListAssignments
google.cloud.bigquery.reservation.v1.ReservationService.ListCapacityCommitments
google.cloud.bigquery.reservation.v1.ReservationService.ListReservations
google.cloud.bigquery.reservation.v1.ReservationService.SearchAllAssignments
google.cloud.bigquery.reservation.v1.ReservationService.SearchAssignments
ADMIN_WRITE google.cloud.bigquery.reservation.v1.ReservationService.CreateAssignment
google.cloud.bigquery.reservation.v1.ReservationService.CreateCapacityCommitment
google.cloud.bigquery.reservation.v1.ReservationService.CreateReservation
google.cloud.bigquery.reservation.v1.ReservationService.DeleteAssignment
google.cloud.bigquery.reservation.v1.ReservationService.DeleteCapacityCommitment
google.cloud.bigquery.reservation.v1.ReservationService.DeleteReservation
google.cloud.bigquery.reservation.v1.ReservationService.FailoverReservation
google.cloud.bigquery.reservation.v1.ReservationService.MergeCapacityCommitments
google.cloud.bigquery.reservation.v1.ReservationService.MoveAssignment
google.cloud.bigquery.reservation.v1.ReservationService.SplitCapacityCommitment
google.cloud.bigquery.reservation.v1.ReservationService.UpdateAssignment
google.cloud.bigquery.reservation.v1.ReservationService.UpdateBiReservation
google.cloud.bigquery.reservation.v1.ReservationService.UpdateCapacityCommitment
google.cloud.bigquery.reservation.v1.ReservationService.UpdateReservation

API interface audit logs

For information about how and which permissions are evaluated for each method, see the Identity and Access Management documentation for BigQuery Reservation API.

google.cloud.bigquery.reservation.v1.ReservationService

The following section contains details about audit logs associated with methods belonging to google.cloud.bigquery.reservation.v1.ReservationService.

CreateAssignment

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.CreateAssignment
  • Audit log type: Admin activity
  • Permissions:
    • bigquery.reservationAssignments.create - ADMIN_WRITE
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.CreateAssignment"

CreateCapacityCommitment

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.CreateCapacityCommitment
  • Audit log type: Admin activity
  • Permissions:
    • bigquery.capacityCommitments.create - ADMIN_WRITE
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.CreateCapacityCommitment"

CreateReservation

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.CreateReservation
  • Audit log type: Admin activity
  • Permissions:
    • bigquery.reservations.create - ADMIN_WRITE
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.CreateReservation"

DeleteAssignment

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.DeleteAssignment
  • Audit log type: Admin activity
  • Permissions:
    • bigquery.reservationAssignments.delete - ADMIN_WRITE
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.DeleteAssignment"

DeleteCapacityCommitment

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.DeleteCapacityCommitment
  • Audit log type: Admin activity
  • Permissions:
    • bigquery.capacityCommitments.delete - ADMIN_WRITE
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.DeleteCapacityCommitment"

DeleteReservation

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.DeleteReservation
  • Audit log type: Admin activity
  • Permissions:
    • bigquery.reservations.delete - ADMIN_WRITE
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.DeleteReservation"

FailoverReservation

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.FailoverReservation
  • Audit log type: Admin activity
  • Permissions:
    • bigquery.reservations.update - ADMIN_WRITE
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.FailoverReservation"

GetBiReservation

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.GetBiReservation
  • Audit log type: Data access
  • Permissions:
    • bigquery.bireservations.get - ADMIN_READ
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.GetBiReservation"

GetCapacityCommitment

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.GetCapacityCommitment
  • Audit log type: Data access
  • Permissions:
    • bigquery.capacityCommitments.get - ADMIN_READ
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.GetCapacityCommitment"

GetReservation

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.GetReservation
  • Audit log type: Data access
  • Permissions:
    • bigquery.reservations.get - ADMIN_READ
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.GetReservation"

ListAssignments

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.ListAssignments
  • Audit log type: Data access
  • Permissions:
    • bigquery.reservationAssignments.list - ADMIN_READ
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.ListAssignments"

ListCapacityCommitments

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.ListCapacityCommitments
  • Audit log type: Data access
  • Permissions:
    • bigquery.capacityCommitments.list - ADMIN_READ
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.ListCapacityCommitments"

ListReservations

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.ListReservations
  • Audit log type: Data access
  • Permissions:
    • bigquery.reservations.list - ADMIN_READ
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.ListReservations"

MergeCapacityCommitments

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.MergeCapacityCommitments
  • Audit log type: Admin activity
  • Permissions:
    • bigquery.capacityCommitments.update - ADMIN_WRITE
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.MergeCapacityCommitments"

MoveAssignment

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.MoveAssignment
  • Audit log type: Admin activity
  • Permissions:
    • bigquery.reservationAssignments.create - ADMIN_WRITE
    • bigquery.reservationAssignments.delete - ADMIN_WRITE
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.MoveAssignment"

SearchAllAssignments

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.SearchAllAssignments
  • Audit log type: Data access
  • Permissions:
    • bigquery.reservationAssignments.search - ADMIN_READ
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.SearchAllAssignments"

SearchAssignments

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.SearchAssignments
  • Audit log type: Data access
  • Permissions:
    • bigquery.reservationAssignments.search - ADMIN_READ
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.SearchAssignments"

SplitCapacityCommitment

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.SplitCapacityCommitment
  • Audit log type: Admin activity
  • Permissions:
    • bigquery.capacityCommitments.update - ADMIN_WRITE
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.SplitCapacityCommitment"

UpdateAssignment

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.UpdateAssignment
  • Audit log type: Admin activity
  • Permissions:
    • bigquery.reservationAssignments.update - ADMIN_WRITE
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.UpdateAssignment"

UpdateBiReservation

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.UpdateBiReservation
  • Audit log type: Admin activity
  • Permissions:
    • bigquery.bireservations.update - ADMIN_WRITE
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.UpdateBiReservation"

UpdateCapacityCommitment

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.UpdateCapacityCommitment
  • Audit log type: Admin activity
  • Permissions:
    • bigquery.capacityCommitments.update - ADMIN_WRITE
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.UpdateCapacityCommitment"

UpdateReservation

  • Method: google.cloud.bigquery.reservation.v1.ReservationService.UpdateReservation
  • Audit log type: Admin activity
  • Permissions:
    • bigquery.reservations.update - ADMIN_WRITE
  • Method is a long-running or streaming operation: No.
  • Filter for this method: protoPayload.methodName="google.cloud.bigquery.reservation.v1.ReservationService.UpdateReservation"

Audit Log examples for BigQuery Reservations usage

The following examples use AuditLog messages to analyze BigQuery Reservations usage.

Example: Find users who purchased slots

This query shows the email address of the users who purchased slots.

  #standardSQL
  SELECT
    protopayload_auditlog.requestMetadata.requestAttributes.time request_time,
    protopayload_auditlog.methodName,
    protopayload_auditlog.authenticationInfo.principalEmail,
    JSON_QUERY(protopayload_auditlog.requestJson , "$.capacityCommitment.slotCount") slots,
  FROM
    `my-project-id.auditlog_dataset.cloudaudit_googleapis_com_activity`
  WHERE
    protopayload_auditlog.methodName like "%CreateCapacityCommitment%"
  ORDER by request_time

Example: History of a project assignment

This query shows the history of a project's reservation assignments.

  #standardSQL
  SELECT
    protopayload_auditlog.requestMetadata.requestAttributes.time request_time,
    protopayload_auditlog.methodName,
    protopayload_auditlog.authenticationInfo.principalEmail,
    JSON_QUERY(protopayload_auditlog.requestJson , "$.assignment.assignee") assignee,
    JSON_QUERY(protopayload_auditlog.requestJson , "$.assignment.jobType") job_type,
  FROM
    `my-project-id.auditlog_dataset.cloudaudit_googleapis_com_activity`
  WHERE
    protopayload_auditlog.methodName like "%Assignment%"
    AND JSON_QUERY(protopayload_auditlog.requestJson , "$.assignment.assignee") like "%OTHERPROJECTID%"
  ORDER by request_time