KMS Encryption Keys Should Be Rotated
More Info:
Ensure KMS encryption keys are rotated within a period of 90 days.
Risk Level
High
Address
Security
Compliance Standards
GDPR, ISO27001, CISGCP, CBP
Triage and Remediation
Remediation
Sure, here are the step-by-step instructions to remediate the KMS Encryption Keys Rotation issue in GCP using the GCP console:
- Open the Google Cloud Console and select the project in which the KMS key is created.
- In the left navigation menu, click on the “Security” option and select “Encryption keys” from the drop-down menu.
- Select the KMS key for which you want to enable rotation.
- Click on the “Edit” button at the top of the page.
- In the “Edit key” dialog box, scroll down to the “Rotation” section.
- Toggle the switch for “Automatic key rotation” to “On”.
- Set the “Rotation period” to a desired value. It is recommended to rotate the key once a year.
- Click on the “Save” button to save the changes.
After completing these steps, the KMS key rotation will be enabled, and the key will be automatically rotated based on the rotation period set by you. This will help to ensure that your encryption keys are updated and secure.
To remediate the KMS Encryption Keys rotation issue in GCP using GCP CLI, you can follow the below steps:
-
Open the Google Cloud Console and select the project in which you want to remediate the issue.
-
Open the Cloud Shell by clicking on the icon located at the top right corner of the console.
-
Run the following command to list all the KMS encryption keys in your project:
gcloud kms keys list
-
Identify the key that needs to be rotated.
-
Run the following command to rotate the key:
gcloud kms keys rotate [KEY_NAME] --location [LOCATION] --keyring [KEYRING_NAME]
Replace [KEY_NAME], [LOCATION], and [KEYRING_NAME] with the actual values of the key that needs to be rotated.
- Confirm the rotation by running the following command:
gcloud kms keys describe [KEY_NAME] --location [LOCATION] --keyring [KEYRING_NAME]
This command will display the details of the key, including the rotation period.
- Repeat steps 5 and 6 for all the KMS encryption keys that need to be rotated.
By following these steps, you will be able to remediate the KMS Encryption Keys rotation issue in GCP using GCP CLI.
To remediate this issue in GCP using Python, you can follow these steps:
- Install the necessary libraries:
pip install google-cloud-kms google-auth
- Authenticate with the GCP project:
from google.oauth2 import service_account
credentials = service_account.Credentials.from_service_account_file('path/to/service_account.json')
- Retrieve the list of KMS keys in the project:
from google.cloud import kms_v1
client = kms_v1.KeyManagementServiceClient(credentials=credentials)
parent = client.key_ring_path(project_id, location_id, key_ring_id)
keys = client.list_crypto_keys(parent)
- For each key, check the creation time and determine if it needs to be rotated:
from datetime import datetime, timedelta
for key in keys:
create_time = datetime.strptime(key.create_time.strftime('%Y-%m-%d %H:%M:%S.%f'), '%Y-%m-%d %H:%M:%S.%f')
if datetime.now() - create_time > timedelta(days=365):
# Key needs to be rotated
# Generate a new key version
response = client.create_crypto_key_version(key.name)
- Finally, delete the old key versions:
for key in keys:
versions = client.list_crypto_key_versions(key.name)
for version in versions:
create_time = datetime.strptime(version.create_time.strftime('%Y-%m-%d %H:%M:%S.%f'), '%Y-%m-%d %H:%M:%S.%f')
if datetime.now() - create_time > timedelta(days=365):
# Delete the key version
client.destroy_crypto_key_version(version.name)
Note: Replace project_id
, location_id
, and key_ring_id
with the appropriate values for your GCP project. Also, make sure that the service account used for authentication has the necessary permissions to manage KMS keys.