dlp/deIdentifyTableConditionInfoTypes.js (96 lines of code) (raw):

// Copyright 2023 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'; // sample-metadata: // title: De-identify table data using conditional logic // description: Redact PERSON_NAME findings when specific conditions are met. // usage: node deIdentifyTableConditionInfoTypes.js my-project function main(projectId) { // [START dlp_deidentify_table_condition_infotypes] // Imports the Google Cloud Data Loss Prevention library const DLP = require('@google-cloud/dlp'); // Initialize google DLP Client const dlp = new DLP.DlpServiceClient(); // The project ID to run the API call under // const projectId = 'my-project'; // Construct the tabular data const tablularData = { headers: [ {name: 'AGE'}, {name: 'PATIENT'}, {name: 'HAPPINESS SCORE'}, {name: 'FACTOID'}, ], rows: [ { values: [ {integerValue: 101}, {stringValue: 'Charles Dickens'}, {integerValue: 95}, { stringValue: 'Charles Dickens name was a curse invented by Shakespeare.', }, ], }, { values: [ {integerValue: 22}, {stringValue: 'Jane Austen'}, {integerValue: 21}, {stringValue: "There are 14 kisses in Jane Austen's novels."}, ], }, { values: [ {integerValue: 55}, {stringValue: 'Mark Twain'}, {integerValue: 75}, {stringValue: 'Mark Twain loved cats.'}, ], }, ], }; async function deIdentifyTableConditionalInfoType() { // Specify fields to be de-identified. const fieldIds = [{name: 'PATIENT'}, {name: 'FACTOID'}]; // Associate info type with the replacement strategy const infoTypeTransformations = { transformations: [ { infoTypes: [{name: 'PERSON_NAME'}], primitiveTransformation: { replaceWithInfoTypeConfig: {}, }, }, ], }; // Specify when the above fields should be de-identified. const condition = { expressions: { conditions: { conditions: [ { field: {name: 'AGE'}, operator: 'GREATER_THAN', value: {integerValue: 89}, }, ], }, }, }; // Apply the condition to records. const recordTransformations = { fieldTransformations: [ { infoTypeTransformations, fields: fieldIds, condition: condition, }, ], }; // Combine configurations into a request for the service. const request = { parent: `projects/${projectId}/locations/global`, item: { table: tablularData, }, deidentifyConfig: { recordTransformations, }, }; // Send the request and receive response from the service. const [response] = await dlp.deidentifyContent(request); // Print the results. console.log( `Table after de-identification: ${JSON.stringify(response.item.table)}` ); } deIdentifyTableConditionalInfoType(); // [END dlp_deidentify_table_condition_infotypes] } process.on('unhandledRejection', err => { console.error(err.message); process.exitCode = 1; }); main(...process.argv.slice(2));