Class LedgerEncryptionDescription
- All Implemented Interfaces:
Serializable
,SdkPojo
,ToCopyableBuilder<LedgerEncryptionDescription.Builder,
LedgerEncryptionDescription>
Information about the encryption of data at rest in an Amazon QLDB ledger. This includes the current status, the key in Key Management Service (KMS), and when the key became inaccessible (in the case of an error).
For more information, see Encryption at rest in the Amazon QLDB Developer Guide.
- See Also:
-
Nested Class Summary
Nested Classes -
Method Summary
Modifier and TypeMethodDescriptionbuilder()
final EncryptionStatus
The current state of encryption at rest for the ledger.final String
The current state of encryption at rest for the ledger.final boolean
final boolean
equalsBySdkFields
(Object obj) Indicates whether some other object is "equal to" this one by SDK fields.final <T> Optional
<T> getValueForField
(String fieldName, Class<T> clazz) final int
hashCode()
final Instant
The date and time, in epoch time format, when the KMS key first became inaccessible, in the case of an error.final String
The Amazon Resource Name (ARN) of the customer managed KMS key that the ledger uses for encryption at rest.static Class
<? extends LedgerEncryptionDescription.Builder> Take this object and create a builder that contains all of the current property values of this object.final String
toString()
Returns a string representation of this object.Methods inherited from interface software.amazon.awssdk.utils.builder.ToCopyableBuilder
copy
-
Method Details
-
kmsKeyArn
The Amazon Resource Name (ARN) of the customer managed KMS key that the ledger uses for encryption at rest. If this parameter is undefined, the ledger uses an Amazon Web Services owned KMS key for encryption. It will display
AWS_OWNED_KMS_KEY
when updating the ledger's encryption configuration to the Amazon Web Services owned KMS key.- Returns:
- The Amazon Resource Name (ARN) of the customer managed KMS key that the ledger uses for encryption at
rest. If this parameter is undefined, the ledger uses an Amazon Web Services owned KMS key for
encryption. It will display
AWS_OWNED_KMS_KEY
when updating the ledger's encryption configuration to the Amazon Web Services owned KMS key.
-
encryptionStatus
The current state of encryption at rest for the ledger. This can be one of the following values:
-
ENABLED
: Encryption is fully enabled using the specified key. -
UPDATING
: The ledger is actively processing the specified key change.Key changes in QLDB are asynchronous. The ledger is fully accessible without any performance impact while the key change is being processed. The amount of time it takes to update a key varies depending on the ledger size.
-
KMS_KEY_INACCESSIBLE
: The specified customer managed KMS key is not accessible, and the ledger is impaired. Either the key was disabled or deleted, or the grants on the key were revoked. When a ledger is impaired, it is not accessible and does not accept any read or write requests.An impaired ledger automatically returns to an active state after you restore the grants on the key, or re-enable the key that was disabled. However, deleting a customer managed KMS key is irreversible. After a key is deleted, you can no longer access the ledgers that are protected with that key, and the data becomes unrecoverable permanently.
If the service returns an enum value that is not available in the current SDK version,
encryptionStatus
will returnEncryptionStatus.UNKNOWN_TO_SDK_VERSION
. The raw value returned by the service is available fromencryptionStatusAsString()
.- Returns:
- The current state of encryption at rest for the ledger. This can be one of the following values:
-
ENABLED
: Encryption is fully enabled using the specified key. -
UPDATING
: The ledger is actively processing the specified key change.Key changes in QLDB are asynchronous. The ledger is fully accessible without any performance impact while the key change is being processed. The amount of time it takes to update a key varies depending on the ledger size.
-
KMS_KEY_INACCESSIBLE
: The specified customer managed KMS key is not accessible, and the ledger is impaired. Either the key was disabled or deleted, or the grants on the key were revoked. When a ledger is impaired, it is not accessible and does not accept any read or write requests.An impaired ledger automatically returns to an active state after you restore the grants on the key, or re-enable the key that was disabled. However, deleting a customer managed KMS key is irreversible. After a key is deleted, you can no longer access the ledgers that are protected with that key, and the data becomes unrecoverable permanently.
-
- See Also:
-
-
encryptionStatusAsString
The current state of encryption at rest for the ledger. This can be one of the following values:
-
ENABLED
: Encryption is fully enabled using the specified key. -
UPDATING
: The ledger is actively processing the specified key change.Key changes in QLDB are asynchronous. The ledger is fully accessible without any performance impact while the key change is being processed. The amount of time it takes to update a key varies depending on the ledger size.
-
KMS_KEY_INACCESSIBLE
: The specified customer managed KMS key is not accessible, and the ledger is impaired. Either the key was disabled or deleted, or the grants on the key were revoked. When a ledger is impaired, it is not accessible and does not accept any read or write requests.An impaired ledger automatically returns to an active state after you restore the grants on the key, or re-enable the key that was disabled. However, deleting a customer managed KMS key is irreversible. After a key is deleted, you can no longer access the ledgers that are protected with that key, and the data becomes unrecoverable permanently.
If the service returns an enum value that is not available in the current SDK version,
encryptionStatus
will returnEncryptionStatus.UNKNOWN_TO_SDK_VERSION
. The raw value returned by the service is available fromencryptionStatusAsString()
.- Returns:
- The current state of encryption at rest for the ledger. This can be one of the following values:
-
ENABLED
: Encryption is fully enabled using the specified key. -
UPDATING
: The ledger is actively processing the specified key change.Key changes in QLDB are asynchronous. The ledger is fully accessible without any performance impact while the key change is being processed. The amount of time it takes to update a key varies depending on the ledger size.
-
KMS_KEY_INACCESSIBLE
: The specified customer managed KMS key is not accessible, and the ledger is impaired. Either the key was disabled or deleted, or the grants on the key were revoked. When a ledger is impaired, it is not accessible and does not accept any read or write requests.An impaired ledger automatically returns to an active state after you restore the grants on the key, or re-enable the key that was disabled. However, deleting a customer managed KMS key is irreversible. After a key is deleted, you can no longer access the ledgers that are protected with that key, and the data becomes unrecoverable permanently.
-
- See Also:
-
-
inaccessibleKmsKeyDateTime
The date and time, in epoch time format, when the KMS key first became inaccessible, in the case of an error. (Epoch time format is the number of seconds that have elapsed since 12:00:00 AM January 1, 1970 UTC.)
This parameter is undefined if the KMS key is accessible.
- Returns:
- The date and time, in epoch time format, when the KMS key first became inaccessible, in the case of an
error. (Epoch time format is the number of seconds that have elapsed since 12:00:00 AM January 1, 1970
UTC.)
This parameter is undefined if the KMS key is accessible.
-
toBuilder
Description copied from interface:ToCopyableBuilder
Take this object and create a builder that contains all of the current property values of this object.- Specified by:
toBuilder
in interfaceToCopyableBuilder<LedgerEncryptionDescription.Builder,
LedgerEncryptionDescription> - Returns:
- a builder for type T
-
builder
-
serializableBuilderClass
-
hashCode
-
equals
-
equalsBySdkFields
Description copied from interface:SdkPojo
Indicates whether some other object is "equal to" this one by SDK fields. An SDK field is a modeled, non-inherited field in anSdkPojo
class, and is generated based on a service model.If an
SdkPojo
class does not have any inherited fields,equalsBySdkFields
andequals
are essentially the same.- Specified by:
equalsBySdkFields
in interfaceSdkPojo
- Parameters:
obj
- the object to be compared with- Returns:
- true if the other object equals to this object by sdk fields, false otherwise.
-
toString
-
getValueForField
-
sdkFields
-