AWS Key Management Service
Learn how to manage encryption using AWS KMS
To enhance the security of your Infisical projects, you can now encrypt your secrets using an external Key Management Service (KMS). When external KMS is configured for your project, all encryption and decryption operations will be handled by the chosen KMS. This guide will walk you through the steps needed to configure external KMS support with AWS KMS.
Prerequisites
Before you begin, you’ll first need to choose a method of authentication with AWS from below.
Create the Managing User IAM Role
-
Navigate to the Create IAM Role page in your AWS Console.
-
Select AWS Account as the Trusted Entity Type.
-
Choose Another AWS Account and enter 381492033652 (Infisical AWS Account ID). This restricts the role to be assumed only by Infisical. If you are self-hosting, provide the AWS account number where Infisical is hosted.
-
Optionally, enable Require external ID and enter your Infisical project ID to further enhance security.
Add Required Permissions for the IAM Role
Use the following custom policy to grant the minimum permissions required by Infisical to integrate with AWS KMS
Setup AWS KMS in the Organization Settings
Next, you will need to follow the steps listed below to add AWS KMS for your organization.
Navigate to the organization settings and select the 'Encryption' tab.
Click on the 'Add' button
Click the ‘Add’ button to begin adding a new external KMS.
Select 'AWS KMS'
Choose ‘AWS KMS’ from the list of encryption providers.
Provide the inputs for AWS KMS
Selecting AWS as the provider will require you input the following fields.
Name for referencing the AWS KMS key within the organization.
Short description of the AWS KMS key.
Authentication mode for AWS, either “AWS Assume Role” or “Access Key”.
ARN of the AWS role to assume for providing Infisical access to the AWS KMS Key (required if Authentication Mode is “AWS Assume Role”)
Custom identifier for additional validation during role assumption.
AWS IAM Access Key ID for authentication (required if Authentication Mode is “Access Key”).
AWS IAM Secret Access Key for authentication (required if Authentication Mode is “Access Key”).
AWS region where the AWS KMS Key is located.
Key ID of the AWS KMS Key. If left blank, Infisical will generate and use a new AWS KMS Key in the specified region.
Click Save
Save your configuration to apply the settings.
You now have an AWS KMS Key configured at the organization level. You can assign these AWS KMS keys to existing Infisical projects by visiting the ‘Project Settings’ page.
Assign AWS KMS Key to an Existing Project
To assign the AWS KMS key you added to your organization, follow the steps below.
Open Project Settings and select to the Encryption Tab
Under the Key Management section, select your newly added AWS KMS key from the dropdown
Choose the AWS KMS key you configured earlier.
Click Save
Once you have selected the KMS of choice, click save.