HashiCorp Cloud Platform
MongoDB Atlas automatic secret rotation
MongoDB Atlas allows developers to programmatically integrate user accounts with their applications. These accounts use usernames and passwords for secure authentication and authorization, controlling access to developers' databases.
HCP Vault Secrets can automatically rotate MongoDB Atlas Database username and passwords.
Prerequisites
Note
During the private beta, auto-rotating secrets can be read using the HCP API and the HCP UI.
If you'd like to use the CLI you can download the beta vlt CLI here
- Project level HCP service principal with a service principal key and the HCP viewer role or higher.
- Environment variables set for the HCP organization ID, project ID, application name, secret name, service principal client ID, and service principal client secret.
- Access to a MongoDB Atlas Project and database.
- A MongoDB Atlas API Key created in your Project with the permissions set to Project Owner. (Refer to the MongoDB Atlas API Key documentation).
- Granted private beta access to the automated secret rotation capability.
Create a rotating secret
Navigate to an application you would like to add a rotated secret to.
Click Create new secret and select Auto-rotating secret.
Select the MongoDB Atlas username and password from the Integration Provider pulldown menu.
Enter a unique name for the auto-rotating secret in the Secret Name field.
Click + Add new integration next to the Integration pulldown menu and enter the following:
- Integration Name: Provide a unique name for the connection.
- Mongo DB Atlas public API key: Enter the Project Public key found from the Access Manager section inside your desired Project in the MongoDB Atlas Console.
- Mongo DB Atlas private API key: The Project Private API Key Secret.
Click Save to return to the new secret form.
Enter the MongoDB Project ID found under the settings tab inside Project Settings.
Enter the Mongo DB Database/Cluster Name for the database you'd like to provision the credentials for.
Click the MongoDB Roles pulldown menu and select the desired roles to be attached to the credentials to be rotated. You can add roles that are not in the list by simply typing one in and hitting enter on your keyboard.
Click the Rotation frequency pulldown menu and select the desired rotation frequency from the 3 options available - 30 days, 60 days, and 90 days.
Click Save.
The setup is complete and your rotating secret has been created.
Read a rotating secret's value
Generate an OAuth token to authenticate with the HCP API.
Read the HCP Vault Secrets auto-rotating secret value.
$ curl \ --location "https://api.cloud.hashicorp.com/secrets/2023-11-28/organizations/${HCP_ORG_ID}/projects/${HCP_PROJ_ID}/apps/${APP_NAME}/secrets/${SECRET_NAME}:open" \ --request GET \ --header "Authorization: Bearer ${HCP_API_TOKEN}" | jq
Retrieve all of the application's secrets
Generate an OAuth token to authenticate with the HCP API.
Read all secrets in the HCP Vault secrets application.
$ curl \ --location "https://api.cloud.hashicorp.com/secrets/2023-11-28/organizations/${HCP_ORG_ID}/projects/${HCP_PROJ_ID}/apps/${APP_NAME}/secrets:open" \ --request GET \ --header "Authorization: Bearer ${HCP_API_TOKEN}" | jq
Delete a MongoDB Atlas rotation integration
Generate an OAuth token to authenticate with the HCP API.
Delete an existing MongoDB Atlas rotation integration.
$ curl \ --location "https://api.cloud.hashicorp.com/secrets/2023-11-28/organizations/${HCP_ORG_ID}/projects/${HCP_PROJ_ID}/integrations/rotation/mongodb-atlas/${INTEGRATION_NAME}" \ --request DELETE \ --header "Authorization: Bearer ${HCP_API_TOKEN}" | jq