bigquery/cloud-client/viewTableOrViewAccessPolicy.js (19 lines of code) (raw):
// Copyright 2025 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
'use strict';
async function main(projectId, datasetId, resourceName) {
// [START bigquery_view_table_or_view_access_policy]
/**
* TODO(developer): Update and un-comment below lines
*/
// const projectId = "YOUR_PROJECT_ID"
// const datasetId = "YOUR_DATASET_ID"
// const resourceName = "YOUR_RESOURCE_NAME";
const {BigQuery} = require('@google-cloud/bigquery');
// Instantiate a client.
const client = new BigQuery();
async function viewTableOrViewAccessPolicy() {
const dataset = client.dataset(datasetId);
const table = dataset.table(resourceName);
// Get the IAM access policy for the table or view.
const [policy] = await table.getIamPolicy();
// Initialize bindings if they don't exist
if (!policy.bindings) {
policy.bindings = [];
}
// Show policy details.
// Find more details for the Policy object here:
// https://cloud.google.com/bigquery/docs/reference/rest/v2/Policy
console.log(`Access Policy details for table or view '${resourceName}'.`);
console.log(`Bindings: ${JSON.stringify(policy.bindings, null, 2)}`);
console.log(`etag: ${policy.etag}`);
console.log(`Version: ${policy.version}`);
}
// [END bigquery_view_table_or_view_access_policy]
await viewTableOrViewAccessPolicy();
}
exports.viewTableOrViewAccessPolicy = main;