updateCustomKeyStore method
Changes the properties of a custom key store. Use the
CustomKeyStoreId
parameter to identify the custom key store
you want to edit. Use the remaining parameters to change the properties of
the custom key store.
You can only update a custom key store that is disconnected. To disconnect the custom key store, use DisconnectCustomKeyStore. To reconnect the custom key store after the update completes, use ConnectCustomKeyStore. To find the connection state of a custom key store, use the DescribeCustomKeyStores operation.
Use the parameters of UpdateCustomKeyStore
to edit your
keystore settings.
- Use the NewCustomKeyStoreName parameter to change the friendly name of the custom key store to the value that you specify.
-
Use the KeyStorePassword parameter tell AWS KMS the current
password of the
kmsuser
crypto user (CU) in the associated AWS CloudHSM cluster. You can use this parameter to fix connection failures that occur when AWS KMS cannot log into the associated cluster because thekmsuser
password has changed. This value does not change the password in the AWS CloudHSM cluster. - Use the CloudHsmClusterId parameter to associate the custom key store with a different, but related, AWS CloudHSM cluster. You can use this parameter to repair a custom key store if its AWS CloudHSM cluster becomes corrupted or is deleted, or when you need to create or restore a cluster from a backup.
This operation is part of the Custom Key Store feature feature in AWS KMS, which combines the convenience and extensive integration of AWS KMS with the isolation and control of a single-tenant key store.
Cross-account use: No. You cannot perform this operation on a custom key store in a different AWS account.
Required permissions: kms:UpdateCustomKeyStore (IAM policy)
Related operations:
- ConnectCustomKeyStore
- CreateCustomKeyStore
- DeleteCustomKeyStore
- DescribeCustomKeyStores
- DisconnectCustomKeyStore
May throw CustomKeyStoreNotFoundException. May throw CustomKeyStoreNameInUseException. May throw CloudHsmClusterNotFoundException. May throw CloudHsmClusterNotRelatedException. May throw CustomKeyStoreInvalidStateException. May throw KMSInternalException. May throw CloudHsmClusterNotActiveException. May throw CloudHsmClusterInvalidConfigurationException.
Parameter customKeyStoreId
:
Identifies the custom key store that you want to update. Enter the ID of
the custom key store. To find the ID of a custom key store, use the
DescribeCustomKeyStores operation.
Parameter cloudHsmClusterId
:
Associates the custom key store with a related AWS CloudHSM cluster.
Enter the cluster ID of the cluster that you used to create the custom key store or a cluster that shares a backup history and has the same cluster certificate as the original cluster. You cannot use this parameter to associate a custom key store with an unrelated cluster. In addition, the replacement cluster must fulfill the requirements for a cluster associated with a custom key store. To view the cluster certificate of a cluster, use the DescribeClusters operation.
Parameter keyStorePassword
:
Enter the current password of the kmsuser
crypto user (CU) in
the AWS CloudHSM cluster that is associated with the custom key store.
This parameter tells AWS KMS the current password of the
kmsuser
crypto user (CU). It does not set or change the
password of any users in the AWS CloudHSM cluster.
Parameter newCustomKeyStoreName
:
Changes the friendly name of the custom key store to the value that you
specify. The custom key store name must be unique in the AWS account.
Implementation
Future<void> updateCustomKeyStore({
required String customKeyStoreId,
String? cloudHsmClusterId,
String? keyStorePassword,
String? newCustomKeyStoreName,
}) async {
ArgumentError.checkNotNull(customKeyStoreId, 'customKeyStoreId');
_s.validateStringLength(
'customKeyStoreId',
customKeyStoreId,
1,
64,
isRequired: true,
);
_s.validateStringLength(
'cloudHsmClusterId',
cloudHsmClusterId,
19,
24,
);
_s.validateStringLength(
'keyStorePassword',
keyStorePassword,
7,
32,
);
_s.validateStringLength(
'newCustomKeyStoreName',
newCustomKeyStoreName,
1,
256,
);
final headers = <String, String>{
'Content-Type': 'application/x-amz-json-1.1',
'X-Amz-Target': 'TrentService.UpdateCustomKeyStore'
};
await _protocol.send(
method: 'POST',
requestUri: '/',
exceptionFnMap: _exceptionFns,
// TODO queryParams
headers: headers,
payload: {
'CustomKeyStoreId': customKeyStoreId,
if (cloudHsmClusterId != null) 'CloudHsmClusterId': cloudHsmClusterId,
if (keyStorePassword != null) 'KeyStorePassword': keyStorePassword,
if (newCustomKeyStoreName != null)
'NewCustomKeyStoreName': newCustomKeyStoreName,
},
);
}