You can use templates to create and persist configuration information to use with Sensitive Data Protection. Templates are useful for decoupling configuration such as what you inspect for and how you de-identify it from the implementation of your requests. Templates provide a robust way to re-use configuration and enable consistency across users and data sets.
The Sensitive Data Protection supports two types of templates:
- De-identification templates: Templates for saving configuration information for de-identification jobs, including both infoType and record (structured dataset) transformations.
- Inspection templates: Templates for persisting configuration information for inspection scan jobs, including what predefined or custom detectors to use. For more information about inspection templates, see Creating Sensitive Data Protection inspection templates.
For conceptual information about templates in Sensitive Data Protection, see Templates.
The remainder of this topic shows you how to create de-identification templates for use with the Sensitive Data Protection.
Create a de-identification template
Console
In the Google Cloud console, go to the Create template page.
The following sections describe how to fill in the Create template page.
Define template
In the Define template section, fill in the fields as follows:
- For Template type, select De-identify (remove sensitive data).
- For Data transformation type, select the type of transformation to apply: - InfoType. Sensitive Data Protection applies each transformation to only the value that was identified as the specific infoType. This transformation type is useful for unstructured text. 
- Record. Sensitive Data Protection considers the structured format of the data when it applies a transformation. This transformation type is useful for tabular data. 
- Image. Sensitive Data Protection redacts all detected text in an image or only text that matches a specific infoType. 
 
- For Template ID, enter a unique identifier for the template. 
- For Display name, enter a name for the template. 
- For Description, describe the template. 
- For Resource location, select Global or the location of the data that you want to de-identify. 
- Click Continue. 
Configure de-identification
The selection of fields that appear in Configure de-identification is based on your chosen data transformation type.
InfoType
If you selected InfoType as the data transformation type, do the following:
- In the Transformation field, select a transformation method to apply to findings. - More fields appear according to your selection. Fill in the fields as needed. For more information, see Transformation reference. 
- In the InfoTypes to transform section, specify whether you want to apply the transformation to all detected infoTypes that are defined in your inspection configuration. - If you select Specify infoTypes, select the infoTypes that you want to apply the transformation method to. 
- If you want to add transformation rules for infoTypes that aren't covered by your transformation rule, click Add transformation rule. Then, fill in the fields as needed. Repeat this step until you've configured a transformation rule for all infoTypes that you want to transform. 
- Click Create. 
Record
If you selected Record as the data transformation type, do the following:
- For Field(s) or column(s) to transform, type the name of the table
column containing the data that you want to transform. Then, press ENTER. Repeat this step for each column containing data that you want to transform.
- Specify the transformation type: - Match on infoType. Sensitive Data Protection treats each cell as unstructured text and applies the transformation to only the infoTypes that it finds in the cell. Sensitive Data Protection doesn't transform any data surrounding an infoType. - If you select this option, do the following: - Click Add transformation. In the Transformation field, select a transformation method to apply to findings.
- Specify whether you want to apply the transformation to all detected infoTypes that are defined in your inspection configuration. - If you select Specify infoTypes, select the infoTypes that you want to apply the transformation rule to. 
 - If you want to assign certain transformation rules to certain infoTypes, you can add more transformations as needed. 
- Primitive field transformation. Sensitive Data Protection always transforms the entire cell according to a transformation method that you choose. This option is useful if you want to transform entire columns of data, regardless of whether cells in those columns have detected infoTypes. - If you select this option, in the Transformation field, select a transformation method to apply to the columns that you specified. 
 - In both cases, more fields appear according to your selected transformation method. Fill in the fields as needed. For more information, see Transformation reference. 
- Click Create. 
Image
If you selected Image as the data transformation type, do the following:
- Optional: To change the color of the box that covers the redacted text, click the black box in the Redaction color field, and choose a different color. 
- In the InfoTypes to transform section, specify what you want to redact: all detected text, all infoTypes defined in your inspection configuration, or only specific infoTypes. - If you select Specify infoTypes, select the infoTypes that you want to apply the transformation rule to. 
- If you want to add transformation rules for infoTypes that aren't covered by your transformation rule, click Add transformation rule. Then, fill in the fields as needed. Repeat this step until you've configured a transformation rule for all infoTypes that you want to transform. 
- Click Create. 
Protocol
It's useful to note that a de-identification template is simply a reusable
de-identification configuration plus some metadata. In API terms, the
DeidentifyTemplate
object is effectively a
DeidentifyConfig
object that includes a few more fields of metadata, such as a display name and
a description. Therefore, to create a new de-identification template, the basic
steps are:
- Start with a
 DeidentifyConfigobject.
- Call or POST the createmethod of theprojects.deidentifyTemplatesresource, including in your request aDeidentifyTemplateobject that contains a display name, a description, and thatDeidentifyConfigobject.
The returned DeidentifyTemplate will be usable immediately. You can
reference it in other calls or jobs by its name. You can list the existing
templates by calling the *.deidentifyTemplates.list method. To view a
specific template, call the *.deidentifyTemplates.get method. Note that the
limit for the number of templates you can create is 1000.
If you've already had some experience de-identifying sensitive data from text,
images, or structured content using Sensitive Data Protection, you've already
created a
DeidentifyConfig
object. One additional step turns it into a
DeidentifyTemplate
object.
REST example
The following JSON is an example of what you could send to the
projects.deidentifyTemplates.create
method. This JSON creates a new template with the given display name and
description, and scans for matches on the infoTypes EMAIL_ADDRESS and
GENERIC_ID. When it finds content matching those infoTypes, it will mask the
first three characters with an asterisk (*) character.
HTTP method and URL
POST https://dlp.googleapis.com/v2/projects/PROJECT_ID/deidentifyTemplates
Replace PROJECT_ID with the project ID.
JSON input
{
  "deidentifyTemplate":{
    "displayName":"Email and id masker",
    "description":"De-identifies emails and ids with a series of asterisks.",
    "deidentifyConfig":{
      "infoTypeTransformations":{
        "transformations":[
          {
            "infoTypes":[
              {
                "name":"GENERIC_ID"
              }
            ],
            "primitiveTransformation":{
              "replaceWithInfoTypeConfig":{
              }
            }
          },
          {
            "infoTypes":[
              {
                "name":"EMAIL_ADDRESS"
              }
            ],
            "primitiveTransformation":{
              "characterMaskConfig":{
                "charactersToIgnore":[
                  {
                    "charactersToSkip":"@"
                  }
                ],
                "maskingCharacter":"*"
              }
            }
          }
        ]
      }
    }
  }
}
JSON output
{ "name":"projects/PROJECT_ID/deidentifyTemplates/JOB-ID", "displayName":"Email and id masker", "description":"De-identifies emails and ids with a series of asterisks.", "createTime":"2018-11-30T07:17:59.536022Z", "updateTime":"2018-11-30T07:17:59.536022Z", "deidentifyConfig":{ "infoTypeTransformations":{ "transformations":[ { "infoTypes":[ { "name":"GENERIC_ID" } ], "primitiveTransformation":{ "replaceWithInfoTypeConfig":{ } } }, { "infoTypes":[ { "name":"EMAIL_ADDRESS" } ], "primitiveTransformation":{ "characterMaskConfig":{ "maskingCharacter":"*", "charactersToIgnore":[ { "charactersToSkip":"@" } ] } } } ] } } }
To quickly try this out, you can use the APIs Explorer that's embedded below. For general information about using JSON to send requests to the DLP API, see the JSON quickstart.
Using de-identification templates
Once you've created a new template, you can use its name identifier anywhere
deidentifyTemplateName is accepted, such as:
- projects.content.deidentify: De-identifies potentially sensitive data in content using the template as its configuration. Be aware that this method can use either an inspection template or a de-identification template.
Listing de-identification templates
To list all de-identification templates that have been created, use one of the
*.*.list methods:
This section demonstrates how to use Sensitive Data Protection to list inspection templates. The process is identical to the one for listing de-identification templates.
C#
To learn how to install and use the client library for Sensitive Data Protection, see Sensitive Data Protection client libraries.
To authenticate to Sensitive Data Protection, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.
Go
To learn how to install and use the client library for Sensitive Data Protection, see Sensitive Data Protection client libraries.
To authenticate to Sensitive Data Protection, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.
Java
To learn how to install and use the client library for Sensitive Data Protection, see Sensitive Data Protection client libraries.
To authenticate to Sensitive Data Protection, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.
Node.js
To learn how to install and use the client library for Sensitive Data Protection, see Sensitive Data Protection client libraries.
To authenticate to Sensitive Data Protection, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.
PHP
To learn how to install and use the client library for Sensitive Data Protection, see Sensitive Data Protection client libraries.
To authenticate to Sensitive Data Protection, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.
Python
To learn how to install and use the client library for Sensitive Data Protection, see Sensitive Data Protection client libraries.
To authenticate to Sensitive Data Protection, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.
Deleting de-identification templates
To delete a specific de-identification template, use one of the *.*.delete
methods:
With each *.*.delete method, you include the resource name of the template to
be deleted.
C#
To learn how to install and use the client library for Sensitive Data Protection, see Sensitive Data Protection client libraries.
To authenticate to Sensitive Data Protection, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.
Go
To learn how to install and use the client library for Sensitive Data Protection, see Sensitive Data Protection client libraries.
To authenticate to Sensitive Data Protection, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.
Java
To learn how to install and use the client library for Sensitive Data Protection, see Sensitive Data Protection client libraries.
To authenticate to Sensitive Data Protection, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.
Node.js
To learn how to install and use the client library for Sensitive Data Protection, see Sensitive Data Protection client libraries.
To authenticate to Sensitive Data Protection, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.
PHP
To learn how to install and use the client library for Sensitive Data Protection, see Sensitive Data Protection client libraries.
To authenticate to Sensitive Data Protection, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.
Python
To learn how to install and use the client library for Sensitive Data Protection, see Sensitive Data Protection client libraries.
To authenticate to Sensitive Data Protection, set up Application Default Credentials. For more information, see Set up authentication for a local development environment.