Encryption at rest - Amazon Inspector
Services or capabilities described in Amazon Web Services documentation might vary by Region. To see the differences applicable to the China Regions, see Getting Started with Amazon Web Services in China (PDF).

Encryption at rest

By default, Amazon Inspector stores data at rest using Amazon encryption solutions. Amazon Inspector encrypts data, such as the following:

  • Resource inventory collected with Amazon Systems Manager.

  • Resource inventory parsed from Amazon Elastic Container Registry images

  • Generated security findings using Amazon owned encryption keys from Amazon Key Management Service

You cannot manage, use, or view Amazon owned keys. However, you don't need to take action or change programs to protect keys that encrypt your data. For more information, see Amazon owned keys.

If you disable Amazon Inspector, it permanently deletes all resources it stores or maintains for you, such as collected inventory and security findings.

Encryption at rest for code in your findings

For Amazon Inspector Lambda code scanning, Amazon Inspector partners with CodeGuru to scan your code for vulnerabilities. When a vulnerability is detected CodeGuru extracts a snippet of your code containing the vulnerability and stores that code until Amazon Inspector requests access. By default CodeGuru uses an Amazon owned key to encrypt the extracted code, however, you can configure Amazon Inspector to use your own customer managed Amazon KMS key for encryption.

The following work flow explains how Amazon Inspector uses the key you configure to encrypt your code:

  1. You supply a Amazon KMS key to Amazon Inspector using the Amazon Inspector UpdateEncryptionKey API.

  2. Amazon Inspector forwards the information about your Amazon KMS key to CodeGuru. CodeGuru stores the information for future use.

  3. CodeGuru requests a grant from Amazon KMS for the key you configured in Amazon Inspector.

  4. CodeGuru creates an encrypted data key from your Amazon KMS key and stores it. This data key is used to encrypt your code data stored by CodeGuru.

  5. Whenever Amazon Inspector requests data from code scans CodeGuru uses the grant to decrypt the encrypted data key, then uses that key to decrypt the data so it can be retrieved.

When you disable Lambda code scanning CodeGuru retires the grant and deletes the associated data key.

Permissions for code encryption with a customer managed key

To use encryption you need to have a policy that allows access to Amazon KMS actions, as well as a statement that grants Amazon Inspector and CodeGuru permissions to use those actions through condition keys.

If you are setting, updating, or resetting the encryption key for your account you will need to use an Amazon Inspector administrator policy, such as Amazon managed policy: AmazonInspector2FullAccess. You will also need to grant the following permissions to read-only users who need to retrieve code snippets from findings or data about the key chosen for encryption.

For KMS, the policy must allow you to perform the following actions:

  • kms:CreateGrant

  • kms:Decrypt

  • kms:DescribeKey

  • kms:GenerateDataKeyWithoutPlainText

  • kms:Encrypt

  • kms:RetireGrant

Once you've verified that you have the correct Amazon KMS permissions in your policy, you must attach a statement that allows Amazon Inspector and CodeGuru to use your key for encryption. Attach the following policy statement:

Note

Replace Region with the Amazon Region you have Amazon Inspector Lambda code scanning enabled in.

{ "Sid": "allow CodeGuru Security to request a grant for a Amazon KMS key", "Effect": "Allow", "Action": "kms:CreateGrant", "Resource": "*", "Condition": { "ForAllValues:StringEquals": { "kms:GrantOperations": [ "GenerateDataKey", "GenerateDataKeyWithoutPlaintext", "Encrypt", "Decrypt", "RetireGrant", "DescribeKey" ] }, "StringEquals": { "kms:ViaService": [ "codeguru-security.Region.amazonaws.com" ] } } }, { "Sid": "allow Amazon Inspector and CodeGuru Security to use your Amazon KMS key", "Effect": "Allow", "Action": [ "kms:Encrypt", "kms:Decrypt", "kms:RetireGrant", "kms:DescribeKey", "kms:GenerateDataKeyWithoutPlaintext" ], "Resource": "*", "Condition": { "StringEquals": { "kms:ViaService": [ "inspector2.Region.amazonaws.com", "codeguru-security.Region.amazonaws.com" ] } } }
Note

When you add the statement, ensure that the syntax is valid. Policies use JSON format. This means that you need to add a comma before or after the statement, depending on where you add the statement to the policy. If you add the statement as the last statement, add a comma after the closing brace for the preceding statement. If you add it as the first statement or between two existing statements, add a comma after the closing brace for the statement.

Configuring encryption with a customer managed key

To configure encryption for your account using a customer managed key you must be an Amazon Inspector administrator with the permissions outlined in Permissions for code encryption with a customer managed key. Additionally you will need a Amazon KMS key in the same Amazon Region as your findings, or a multi-region key. You can use an existing symmetric key in your account or create a symmetric customer managed key by using the Amazon Management Console, or the Amazon KMS APIs. For more information see Creating symmetric encryption Amazon KMS keys in the Amazon KMS user guide.

Using the Amazon Inspector API to configure encryption

To set a key for encryption the UpdateEncryptionKey operation of the Amazon Inspector API while signed in as an Amazon Inspector administrator. In the API request, use the kmsKeyId field to specify the ARN of the Amazon KMS key you want to use. For scanType enter CODE and for resourceType enter AWS_LAMBDA_FUNCTION.

You can use UpdateEncryptionKey API to check view which Amazon KMS key Amazon Inspector is using for encryption.

Note

If you attempt to use GetEncryptionKey when you haven't set a customer managed key the operation returns a ResourceNotFoundException error which means that an Amazon owned key is being used for encryption.

If you delete or the key or change it's policy to deny access to Amazon Inspector or CodeGuru you will be unable to access your code vulnerability findings and Lambda code scanning will fail for your account.

You can use ResetEncryptionKey to resume using an Amazon owned key to encrypt code extracted as part of your Amazon Inspector findings.