Key version
Key versions are the cryptographic material that you can use for encrypting and decrypting data.
The following operations with key versions are supported:
-
Creating versions when rotating keys.
The algorithm and size of a new version's cryptographic material are determined by the current key encryption algorithm.
-
Using versions to encrypt and decrypt data.
A key always has the primary version that is used by default in key operations. You can specify the version explicitly. In this case, the cryptographic material of the specified version is used. Directly or indirectly, any encryption and decryption operations in KMS use the cryptographic material contained in one of the versions.
-
Destroying versions.
You can't destroy the primary version of a key.
Versions can have one of the following statuses:
Active
: The version is active and can be used for data encryption and decryption.Scheduled For Destruction
: The version is scheduled for destruction. This means that it's already inactive, but you can still restore it if necessary.Destroyed
: The version is destroyed and cannot be restored.
Rotating keys
Rotation limits the lifetime of cryptographic material. When a key is rotated, a new version is created: cryptographic material is generated again (its parameters are determined by the algorithm specified in the key). The version of the key created during its rotation becomes the primary one. If necessary, you can specify any other active version of the key as the primary one.
After key rotation:
- Encryption operations use the new version of the key, unless you explicitly specify a different version.
- The previous key versions are only used to decrypt data encrypted with them before the key is rotated.
Rotation can be manual or automatic. This depends on the Rotation period key parameter.
Destroying key versions
Alert
Destroying any version of a key means destroying all data encrypted with it. Before you destroy a version, make sure that there is no data encrypted with this version or that you really need to delete all the encrypted data.
To destroy previous key versions without negative consequences, use the reEncrypt method. This operation decrypts the transmitted ciphertext and then re-encrypts it with the primary version of the key.
For safety reasons, destruction isn't immediate. You can schedule a version for destruction by setting the time after which the destruction occurs. The status for this version switches to Scheduled For Destruction
: it can't be used for encryption or decryption, but it can still be restored. When it's time to destroy it, the version status changes to Destroyed
and it is permanently deleted.