createCustomKeyStore method
Creates a custom key store that is associated with an AWS CloudHSM cluster that you own and manage.
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.
Before you create the custom key store, you must assemble the required elements, including an AWS CloudHSM cluster that fulfills the requirements for a custom key store. For details about the required elements, see Assemble the Prerequisites in the AWS Key Management Service Developer Guide.
When the operation completes successfully, it returns the ID of the new custom key store. Before you can use your new custom key store, you need to use the ConnectCustomKeyStore operation to connect the new key store to its AWS CloudHSM cluster. Even if you are not going to use your custom key store immediately, you might want to connect it to verify that all settings are correct and then disconnect it until you are ready to use it.
For help with failures, see Troubleshooting a Custom Key Store in the AWS Key Management Service Developer Guide.
Cross-account use: No. You cannot perform this operation on a custom key store in a different AWS account.
Required permissions: kms:CreateCustomKeyStore (IAM policy).
Related operations:
- ConnectCustomKeyStore
- DeleteCustomKeyStore
- DescribeCustomKeyStores
- DisconnectCustomKeyStore
- UpdateCustomKeyStore
May throw CloudHsmClusterInUseException. May throw CustomKeyStoreNameInUseException. May throw CloudHsmClusterNotFoundException. May throw KMSInternalException. May throw CloudHsmClusterNotActiveException. May throw IncorrectTrustAnchorException. May throw CloudHsmClusterInvalidConfigurationException.
Parameter cloudHsmClusterId
:
Identifies the AWS CloudHSM cluster for the custom key store. Enter the
cluster ID of any active AWS CloudHSM cluster that is not already
associated with a custom key store. To find the cluster ID, use the DescribeClusters
operation.
Parameter customKeyStoreName
:
Specifies a friendly name for the custom key store. The name must be
unique in your AWS account.
Parameter keyStorePassword
:
Enter the password of the
kmsuser
crypto user (CU) account in the specified AWS
CloudHSM cluster. AWS KMS logs into the cluster as this user to manage key
material on your behalf.
The password must be a string of 7 to 32 characters. Its value is case sensitive.
This parameter tells AWS KMS the kmsuser
account password; it
does not change the password in the AWS CloudHSM cluster.
Parameter trustAnchorCertificate
:
Enter the content of the trust anchor certificate for the cluster. This is
the content of the customerCA.crt
file that you created when
you initialized
the cluster.
Implementation
Future<CreateCustomKeyStoreResponse> createCustomKeyStore({
required String cloudHsmClusterId,
required String customKeyStoreName,
required String keyStorePassword,
required String trustAnchorCertificate,
}) async {
ArgumentError.checkNotNull(cloudHsmClusterId, 'cloudHsmClusterId');
_s.validateStringLength(
'cloudHsmClusterId',
cloudHsmClusterId,
19,
24,
isRequired: true,
);
ArgumentError.checkNotNull(customKeyStoreName, 'customKeyStoreName');
_s.validateStringLength(
'customKeyStoreName',
customKeyStoreName,
1,
256,
isRequired: true,
);
ArgumentError.checkNotNull(keyStorePassword, 'keyStorePassword');
_s.validateStringLength(
'keyStorePassword',
keyStorePassword,
7,
32,
isRequired: true,
);
ArgumentError.checkNotNull(
trustAnchorCertificate, 'trustAnchorCertificate');
_s.validateStringLength(
'trustAnchorCertificate',
trustAnchorCertificate,
1,
5000,
isRequired: true,
);
final headers = <String, String>{
'Content-Type': 'application/x-amz-json-1.1',
'X-Amz-Target': 'TrentService.CreateCustomKeyStore'
};
final jsonResponse = await _protocol.send(
method: 'POST',
requestUri: '/',
exceptionFnMap: _exceptionFns,
// TODO queryParams
headers: headers,
payload: {
'CloudHsmClusterId': cloudHsmClusterId,
'CustomKeyStoreName': customKeyStoreName,
'KeyStorePassword': keyStorePassword,
'TrustAnchorCertificate': trustAnchorCertificate,
},
);
return CreateCustomKeyStoreResponse.fromJson(jsonResponse.body);
}