Customer-managed encryption keys
By default, Integration Connectors encrypts customer content at rest. Integration Connectors handles encryption for you without any additional actions on your part. This option is called Google default encryption.
If you want to control your encryption keys, then you can use customer-managed encryption keys (CMEKs) in Cloud KMS with CMEK-integrated services including Integration Connectors. Using Cloud KMS keys gives you control over their protection level, location, rotation schedule, usage and access permissions, and cryptographic boundaries. Using Cloud KMS also lets you view audit logs and control key lifecycles. Instead of Google owning and managing the symmetric key encryption keys (KEKs) that protect your data, you control and manage these keys in Cloud KMS.
After you set up your resources with CMEKs, the experience of accessing your Integration Connectors resources is similar to using Google default encryption. For more information about your encryption options, see Customer-managed encryption keys (CMEK).
Before you begin
Ensure that the following tasks are completed before using CMEK for Integration Connectors:
- Enable the Cloud KMS API for the project that will store your encryption keys.
- Assign the Cloud KMS Admin IAM role or grant the following IAM permissions for the project that will store your encryption keys:
      - cloudkms.cryptoKeys.setIamPolicy
- cloudkms.keyRings.create
- cloudkms.cryptoKeys.create
 For information about granting additional roles or permissions, see Granting, changing, and revoking access. 
- Create a key ring and a key.
Add service account to CMEK key
  In order to use a CMEK key in Integration Connectors, you must ensure that your default service account (having the format service-PROJECT_NUMBER@gcp-sa-connectors.iam.gserviceaccount.com) is added and assigned with the CryptoKey Encrypter/Decrypter IAM role for that CMEK key.
  
- In the Google Cloud console, go to the Key Inventory page.
- Select the checkbox for the desired CMEK key. 
      The Permissions tab in the right window pane becomes available. 
- Click Add principal, and enter the email address of the default service account.
- Click Select a role and select the Cloud KMS CryptoKey Encrypter/Decrypter role from the available dropdown list.
- Click Save.
Enable CMEK encryption for an existing Integration Connectors region
You can use CMEK to encrypt and decrypt the supported data stored in a region (also referred as location). To enable CMEK encryption for an existing Integration Connectors region, do the following steps:
- In the Google Cloud console, go to the Integration Connectors > Connections page.
      Go to all connections page. 
- Filter the connections for the required Location.
    You will get a list of all the connections for the specified location (region). 
- Suspend all the connections in the region.
- Go to the Integration Connectors > Regions page. This lists all the regions where Integration Connectors is available.
- For the region in which you want to enable CMEK, click Edit encryption in the Actions menu. This shows the Edit encryption pane.
- Select Customer-managed encryption key (CMEK), and then select the required key from the
    Customer-managed key drop-down list. 
   
    This may prompt you to grant to cloudkms.cryptoKeyEncrypterDecrypterrole to the service account. Click Grant.
- Click Done.
Enable CMEK encryption for a new Integration Connectors region
You can use CMEK to encrypt and decrypt the supported data stored in a region (also referred as location). To enable CMEK encryption for a new Integration Connectors region, do the following steps:
- In the Google Cloud console, go to the Integration Connectors > Regions page.
      Go to Regions page. 
- Click Provision new region. This displays the create region page.
- Select the required region from the Region drop-down list.
- In the Advanced settings section, select
       Customer-managed encryption key (CMEK), and then select the required key from the
       Customer-managed key drop-down list
    This may prompt you to grant to cloudkms.cryptoKeyEncrypterDecrypterrole to the service account. Click Grant.
- Click Done.
Cloud KMS quotas and Integration Connectors
When you use CMEK in Integration Connectors, your projects can consume Cloud KMS cryptographic requests quotas. For example, CMEK keys can consume these quotas for each encryption and decryption call.
Encryption and decryption operations using CMEK keys affect Cloud KMS quotas in these ways:
- For software CMEK keys generated in Cloud KMS, no Cloud KMS quota is consumed.
- For hardware CMEK keys—sometimes called Cloud HSM keys—encryption and decryption operations count against Cloud HSM quotas in the project that contains the key.
- For external CMEK keys—sometimes called Cloud EKM keys—encryption and decryption operations count against Cloud EKM quotas in the project that contains the key.
For more information, see Cloud KMS quotas.