Interface PaymentCryptographyDataClient
- All Superinterfaces:
AutoCloseable
,AwsClient
,SdkAutoCloseable
,SdkClient
builder()
method.
You use the Amazon Web Services Payment Cryptography Data Plane to manage how encryption keys are used for payment-related transaction processing and associated cryptographic operations. You can encrypt, decrypt, generate, verify, and translate payment-related cryptographic operations in Amazon Web Services Payment Cryptography. For more information, see Data operations in the Amazon Web Services Payment Cryptography User Guide.
To manage your encryption keys, you use the Amazon Web Services Payment Cryptography Control Plane. You can create, import, export, share, manage, and delete keys. You can also manage Identity and Access Management (IAM) policies for keys.
-
Field Summary
Modifier and TypeFieldDescriptionstatic final String
Value for looking up the service's metadata from theServiceMetadataProvider
.static final String
-
Method Summary
Modifier and TypeMethodDescriptionbuilder()
Create a builder that can be used to configure and create aPaymentCryptographyDataClient
.create()
Create aPaymentCryptographyDataClient
with the region loaded from theDefaultAwsRegionProviderChain
and credentials loaded from theDefaultCredentialsProvider
.default DecryptDataResponse
decryptData
(Consumer<DecryptDataRequest.Builder> decryptDataRequest) Decrypts ciphertext data to plaintext using a symmetric (TDES, AES), asymmetric (RSA), or derived (DUKPT or EMV) encryption key scheme.default DecryptDataResponse
decryptData
(DecryptDataRequest decryptDataRequest) Decrypts ciphertext data to plaintext using a symmetric (TDES, AES), asymmetric (RSA), or derived (DUKPT or EMV) encryption key scheme.default EncryptDataResponse
encryptData
(Consumer<EncryptDataRequest.Builder> encryptDataRequest) Encrypts plaintext data to ciphertext using a symmetric (TDES, AES), asymmetric (RSA), or derived (DUKPT or EMV) encryption key scheme.default EncryptDataResponse
encryptData
(EncryptDataRequest encryptDataRequest) Encrypts plaintext data to ciphertext using a symmetric (TDES, AES), asymmetric (RSA), or derived (DUKPT or EMV) encryption key scheme.generateCardValidationData
(Consumer<GenerateCardValidationDataRequest.Builder> generateCardValidationDataRequest) Generates card-related validation data using algorithms such as Card Verification Values (CVV/CVV2), Dynamic Card Verification Values (dCVV/dCVV2), or Card Security Codes (CSC).generateCardValidationData
(GenerateCardValidationDataRequest generateCardValidationDataRequest) Generates card-related validation data using algorithms such as Card Verification Values (CVV/CVV2), Dynamic Card Verification Values (dCVV/dCVV2), or Card Security Codes (CSC).default GenerateMacResponse
generateMac
(Consumer<GenerateMacRequest.Builder> generateMacRequest) Generates a Message Authentication Code (MAC) cryptogram within Amazon Web Services Payment Cryptography.default GenerateMacResponse
generateMac
(GenerateMacRequest generateMacRequest) Generates a Message Authentication Code (MAC) cryptogram within Amazon Web Services Payment Cryptography.default GeneratePinDataResponse
generatePinData
(Consumer<GeneratePinDataRequest.Builder> generatePinDataRequest) Generates pin-related data such as PIN, PIN Verification Value (PVV), PIN Block, and PIN Offset during new card issuance or reissuance.default GeneratePinDataResponse
generatePinData
(GeneratePinDataRequest generatePinDataRequest) Generates pin-related data such as PIN, PIN Verification Value (PVV), PIN Block, and PIN Offset during new card issuance or reissuance.default ReEncryptDataResponse
reEncryptData
(Consumer<ReEncryptDataRequest.Builder> reEncryptDataRequest) Re-encrypt ciphertext using DUKPT, Symmetric and Asymmetric Data Encryption Keys.default ReEncryptDataResponse
reEncryptData
(ReEncryptDataRequest reEncryptDataRequest) Re-encrypt ciphertext using DUKPT, Symmetric and Asymmetric Data Encryption Keys.The SDK service client configuration exposes client settings to the user, e.g., ClientOverrideConfigurationstatic ServiceMetadata
default TranslatePinDataResponse
translatePinData
(Consumer<TranslatePinDataRequest.Builder> translatePinDataRequest) Translates encrypted PIN block from and to ISO 9564 formats 0,1,3,4.default TranslatePinDataResponse
translatePinData
(TranslatePinDataRequest translatePinDataRequest) Translates encrypted PIN block from and to ISO 9564 formats 0,1,3,4.verifyAuthRequestCryptogram
(Consumer<VerifyAuthRequestCryptogramRequest.Builder> verifyAuthRequestCryptogramRequest) Verifies Authorization Request Cryptogram (ARQC) for a EMV chip payment card authorization.verifyAuthRequestCryptogram
(VerifyAuthRequestCryptogramRequest verifyAuthRequestCryptogramRequest) Verifies Authorization Request Cryptogram (ARQC) for a EMV chip payment card authorization.default VerifyCardValidationDataResponse
verifyCardValidationData
(Consumer<VerifyCardValidationDataRequest.Builder> verifyCardValidationDataRequest) Verifies card-related validation data using algorithms such as Card Verification Values (CVV/CVV2), Dynamic Card Verification Values (dCVV/dCVV2) and Card Security Codes (CSC).default VerifyCardValidationDataResponse
verifyCardValidationData
(VerifyCardValidationDataRequest verifyCardValidationDataRequest) Verifies card-related validation data using algorithms such as Card Verification Values (CVV/CVV2), Dynamic Card Verification Values (dCVV/dCVV2) and Card Security Codes (CSC).default VerifyMacResponse
verifyMac
(Consumer<VerifyMacRequest.Builder> verifyMacRequest) Verifies a Message Authentication Code (MAC).default VerifyMacResponse
verifyMac
(VerifyMacRequest verifyMacRequest) Verifies a Message Authentication Code (MAC).default VerifyPinDataResponse
verifyPinData
(Consumer<VerifyPinDataRequest.Builder> verifyPinDataRequest) Verifies pin-related data such as PIN and PIN Offset using algorithms including VISA PVV and IBM3624.default VerifyPinDataResponse
verifyPinData
(VerifyPinDataRequest verifyPinDataRequest) Verifies pin-related data such as PIN and PIN Offset using algorithms including VISA PVV and IBM3624.Methods inherited from interface software.amazon.awssdk.utils.SdkAutoCloseable
close
Methods inherited from interface software.amazon.awssdk.core.SdkClient
serviceName
-
Field Details
-
SERVICE_NAME
- See Also:
-
SERVICE_METADATA_ID
Value for looking up the service's metadata from theServiceMetadataProvider
.- See Also:
-
-
Method Details
-
decryptData
default DecryptDataResponse decryptData(DecryptDataRequest decryptDataRequest) throws ValidationException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Decrypts ciphertext data to plaintext using a symmetric (TDES, AES), asymmetric (RSA), or derived (DUKPT or EMV) encryption key scheme. For more information, see Decrypt data in the Amazon Web Services Payment Cryptography User Guide.
You can use an encryption key generated within Amazon Web Services Payment Cryptography, or you can import your own encryption key by calling ImportKey. For this operation, the key must have
KeyModesOfUse
set toDecrypt
. In asymmetric decryption, Amazon Web Services Payment Cryptography decrypts the ciphertext using the private component of the asymmetric encryption key pair. For data encryption outside of Amazon Web Services Payment Cryptography, you can export the public component of the asymmetric key pair by calling GetPublicCertificate.For symmetric and DUKPT decryption, Amazon Web Services Payment Cryptography supports
TDES
andAES
algorithms. For EMV decryption, Amazon Web Services Payment Cryptography supportsTDES
algorithms. For asymmetric decryption, Amazon Web Services Payment Cryptography supportsRSA
.When you use TDES or TDES DUKPT, the ciphertext data length must be a multiple of 8 bytes. For AES or AES DUKPT, the ciphertext data length must be a multiple of 16 bytes. For RSA, it sould be equal to the key size unless padding is enabled.
For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
- Parameters:
decryptDataRequest
-- Returns:
- Result of the DecryptData operation returned by the service.
- See Also:
-
decryptData
default DecryptDataResponse decryptData(Consumer<DecryptDataRequest.Builder> decryptDataRequest) throws ValidationException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Decrypts ciphertext data to plaintext using a symmetric (TDES, AES), asymmetric (RSA), or derived (DUKPT or EMV) encryption key scheme. For more information, see Decrypt data in the Amazon Web Services Payment Cryptography User Guide.
You can use an encryption key generated within Amazon Web Services Payment Cryptography, or you can import your own encryption key by calling ImportKey. For this operation, the key must have
KeyModesOfUse
set toDecrypt
. In asymmetric decryption, Amazon Web Services Payment Cryptography decrypts the ciphertext using the private component of the asymmetric encryption key pair. For data encryption outside of Amazon Web Services Payment Cryptography, you can export the public component of the asymmetric key pair by calling GetPublicCertificate.For symmetric and DUKPT decryption, Amazon Web Services Payment Cryptography supports
TDES
andAES
algorithms. For EMV decryption, Amazon Web Services Payment Cryptography supportsTDES
algorithms. For asymmetric decryption, Amazon Web Services Payment Cryptography supportsRSA
.When you use TDES or TDES DUKPT, the ciphertext data length must be a multiple of 8 bytes. For AES or AES DUKPT, the ciphertext data length must be a multiple of 16 bytes. For RSA, it sould be equal to the key size unless padding is enabled.
For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
This is a convenience which creates an instance of the
DecryptDataRequest.Builder
avoiding the need to create one manually viaDecryptDataRequest.builder()
- Parameters:
decryptDataRequest
- AConsumer
that will call methods onDecryptDataRequest.Builder
to create a request.- Returns:
- Result of the DecryptData operation returned by the service.
- See Also:
-
encryptData
default EncryptDataResponse encryptData(EncryptDataRequest encryptDataRequest) throws ValidationException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Encrypts plaintext data to ciphertext using a symmetric (TDES, AES), asymmetric (RSA), or derived (DUKPT or EMV) encryption key scheme. For more information, see Encrypt data in the Amazon Web Services Payment Cryptography User Guide.
You can generate an encryption key within Amazon Web Services Payment Cryptography by calling CreateKey. You can import your own encryption key by calling ImportKey. For this operation, the key must have
KeyModesOfUse
set toEncrypt
. In asymmetric encryption, plaintext is encrypted using public component. You can import the public component of an asymmetric key pair created outside Amazon Web Services Payment Cryptography by calling ImportKey.For symmetric and DUKPT encryption, Amazon Web Services Payment Cryptography supports
TDES
andAES
algorithms. For EMV encryption, Amazon Web Services Payment Cryptography supportsTDES
algorithms.For asymmetric encryption, Amazon Web Services Payment Cryptography supportsRSA
.When you use TDES or TDES DUKPT, the plaintext data length must be a multiple of 8 bytes. For AES or AES DUKPT, the plaintext data length must be a multiple of 16 bytes. For RSA, it sould be equal to the key size unless padding is enabled.
To encrypt using DUKPT, you must already have a BDK (Base Derivation Key) key in your account with
KeyModesOfUse
set toDeriveKey
, or you can generate a new DUKPT key by calling CreateKey. To encrypt using EMV, you must already have an IMK (Issuer Master Key) key in your account withKeyModesOfUse
set toDeriveKey
.For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
- Parameters:
encryptDataRequest
-- Returns:
- Result of the EncryptData operation returned by the service.
- See Also:
-
encryptData
default EncryptDataResponse encryptData(Consumer<EncryptDataRequest.Builder> encryptDataRequest) throws ValidationException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Encrypts plaintext data to ciphertext using a symmetric (TDES, AES), asymmetric (RSA), or derived (DUKPT or EMV) encryption key scheme. For more information, see Encrypt data in the Amazon Web Services Payment Cryptography User Guide.
You can generate an encryption key within Amazon Web Services Payment Cryptography by calling CreateKey. You can import your own encryption key by calling ImportKey. For this operation, the key must have
KeyModesOfUse
set toEncrypt
. In asymmetric encryption, plaintext is encrypted using public component. You can import the public component of an asymmetric key pair created outside Amazon Web Services Payment Cryptography by calling ImportKey.For symmetric and DUKPT encryption, Amazon Web Services Payment Cryptography supports
TDES
andAES
algorithms. For EMV encryption, Amazon Web Services Payment Cryptography supportsTDES
algorithms.For asymmetric encryption, Amazon Web Services Payment Cryptography supportsRSA
.When you use TDES or TDES DUKPT, the plaintext data length must be a multiple of 8 bytes. For AES or AES DUKPT, the plaintext data length must be a multiple of 16 bytes. For RSA, it sould be equal to the key size unless padding is enabled.
To encrypt using DUKPT, you must already have a BDK (Base Derivation Key) key in your account with
KeyModesOfUse
set toDeriveKey
, or you can generate a new DUKPT key by calling CreateKey. To encrypt using EMV, you must already have an IMK (Issuer Master Key) key in your account withKeyModesOfUse
set toDeriveKey
.For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
This is a convenience which creates an instance of the
EncryptDataRequest.Builder
avoiding the need to create one manually viaEncryptDataRequest.builder()
- Parameters:
encryptDataRequest
- AConsumer
that will call methods onEncryptDataRequest.Builder
to create a request.- Returns:
- Result of the EncryptData operation returned by the service.
- See Also:
-
generateCardValidationData
default GenerateCardValidationDataResponse generateCardValidationData(GenerateCardValidationDataRequest generateCardValidationDataRequest) throws ValidationException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Generates card-related validation data using algorithms such as Card Verification Values (CVV/CVV2), Dynamic Card Verification Values (dCVV/dCVV2), or Card Security Codes (CSC). For more information, see Generate card data in the Amazon Web Services Payment Cryptography User Guide.
This operation generates a CVV or CSC value that is printed on a payment credit or debit card during card production. The CVV or CSC, PAN (Primary Account Number) and expiration date of the card are required to check its validity during transaction processing. To begin this operation, a CVK (Card Verification Key) encryption key is required. You can use CreateKey or ImportKey to establish a CVK within Amazon Web Services Payment Cryptography. The
KeyModesOfUse
should be set toGenerate
andVerify
for a CVK encryption key.For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
- Parameters:
generateCardValidationDataRequest
-- Returns:
- Result of the GenerateCardValidationData operation returned by the service.
- See Also:
-
generateCardValidationData
default GenerateCardValidationDataResponse generateCardValidationData(Consumer<GenerateCardValidationDataRequest.Builder> generateCardValidationDataRequest) throws ValidationException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Generates card-related validation data using algorithms such as Card Verification Values (CVV/CVV2), Dynamic Card Verification Values (dCVV/dCVV2), or Card Security Codes (CSC). For more information, see Generate card data in the Amazon Web Services Payment Cryptography User Guide.
This operation generates a CVV or CSC value that is printed on a payment credit or debit card during card production. The CVV or CSC, PAN (Primary Account Number) and expiration date of the card are required to check its validity during transaction processing. To begin this operation, a CVK (Card Verification Key) encryption key is required. You can use CreateKey or ImportKey to establish a CVK within Amazon Web Services Payment Cryptography. The
KeyModesOfUse
should be set toGenerate
andVerify
for a CVK encryption key.For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
This is a convenience which creates an instance of the
GenerateCardValidationDataRequest.Builder
avoiding the need to create one manually viaGenerateCardValidationDataRequest.builder()
- Parameters:
generateCardValidationDataRequest
- AConsumer
that will call methods onGenerateCardValidationDataRequest.Builder
to create a request.- Returns:
- Result of the GenerateCardValidationData operation returned by the service.
- See Also:
-
generateMac
default GenerateMacResponse generateMac(GenerateMacRequest generateMacRequest) throws ValidationException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Generates a Message Authentication Code (MAC) cryptogram within Amazon Web Services Payment Cryptography.
You can use this operation to authenticate card-related data by using known data values to generate MAC for data validation between the sending and receiving parties. This operation uses message data, a secret encryption key and MAC algorithm to generate a unique MAC value for transmission. The receiving party of the MAC must use the same message data, secret encryption key and MAC algorithm to reproduce another MAC value for comparision.
You can use this operation to generate a DUPKT, CMAC, HMAC or EMV MAC by setting generation attributes and algorithm to the associated values. The MAC generation encryption key must have valid values for
KeyUsage
such asTR31_M7_HMAC_KEY
for HMAC generation, and they key must haveKeyModesOfUse
set toGenerate
andVerify
.For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
- Parameters:
generateMacRequest
-- Returns:
- Result of the GenerateMac operation returned by the service.
- See Also:
-
generateMac
default GenerateMacResponse generateMac(Consumer<GenerateMacRequest.Builder> generateMacRequest) throws ValidationException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Generates a Message Authentication Code (MAC) cryptogram within Amazon Web Services Payment Cryptography.
You can use this operation to authenticate card-related data by using known data values to generate MAC for data validation between the sending and receiving parties. This operation uses message data, a secret encryption key and MAC algorithm to generate a unique MAC value for transmission. The receiving party of the MAC must use the same message data, secret encryption key and MAC algorithm to reproduce another MAC value for comparision.
You can use this operation to generate a DUPKT, CMAC, HMAC or EMV MAC by setting generation attributes and algorithm to the associated values. The MAC generation encryption key must have valid values for
KeyUsage
such asTR31_M7_HMAC_KEY
for HMAC generation, and they key must haveKeyModesOfUse
set toGenerate
andVerify
.For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
This is a convenience which creates an instance of the
GenerateMacRequest.Builder
avoiding the need to create one manually viaGenerateMacRequest.builder()
- Parameters:
generateMacRequest
- AConsumer
that will call methods onGenerateMacRequest.Builder
to create a request.- Returns:
- Result of the GenerateMac operation returned by the service.
- See Also:
-
generatePinData
default GeneratePinDataResponse generatePinData(GeneratePinDataRequest generatePinDataRequest) throws ValidationException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Generates pin-related data such as PIN, PIN Verification Value (PVV), PIN Block, and PIN Offset during new card issuance or reissuance. For more information, see Generate PIN data in the Amazon Web Services Payment Cryptography User Guide.
PIN data is never transmitted in clear to or from Amazon Web Services Payment Cryptography. This operation generates PIN, PVV, or PIN Offset and then encrypts it using Pin Encryption Key (PEK) to create an
EncryptedPinBlock
for transmission from Amazon Web Services Payment Cryptography. This operation uses a separate Pin Verification Key (PVK) for VISA PVV generation.For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
- Parameters:
generatePinDataRequest
-- Returns:
- Result of the GeneratePinData operation returned by the service.
- See Also:
-
generatePinData
default GeneratePinDataResponse generatePinData(Consumer<GeneratePinDataRequest.Builder> generatePinDataRequest) throws ValidationException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Generates pin-related data such as PIN, PIN Verification Value (PVV), PIN Block, and PIN Offset during new card issuance or reissuance. For more information, see Generate PIN data in the Amazon Web Services Payment Cryptography User Guide.
PIN data is never transmitted in clear to or from Amazon Web Services Payment Cryptography. This operation generates PIN, PVV, or PIN Offset and then encrypts it using Pin Encryption Key (PEK) to create an
EncryptedPinBlock
for transmission from Amazon Web Services Payment Cryptography. This operation uses a separate Pin Verification Key (PVK) for VISA PVV generation.For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
This is a convenience which creates an instance of the
GeneratePinDataRequest.Builder
avoiding the need to create one manually viaGeneratePinDataRequest.builder()
- Parameters:
generatePinDataRequest
- AConsumer
that will call methods onGeneratePinDataRequest.Builder
to create a request.- Returns:
- Result of the GeneratePinData operation returned by the service.
- See Also:
-
reEncryptData
default ReEncryptDataResponse reEncryptData(ReEncryptDataRequest reEncryptDataRequest) throws ValidationException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Re-encrypt ciphertext using DUKPT, Symmetric and Asymmetric Data Encryption Keys.
You can either generate an encryption key within Amazon Web Services Payment Cryptography by calling CreateKey or import your own encryption key by calling ImportKey. The
KeyArn
for use with this operation must be in a compatible key state withKeyModesOfUse
set toEncrypt
. In asymmetric encryption, ciphertext is encrypted using public component (imported by calling ImportKey) of the asymmetric key pair created outside of Amazon Web Services Payment Cryptography.For symmetric and DUKPT encryption, Amazon Web Services Payment Cryptography supports
TDES
andAES
algorithms. For asymmetric encryption, Amazon Web Services Payment Cryptography supportsRSA
. To encrypt using DUKPT, a DUKPT key must already exist within your account withKeyModesOfUse
set toDeriveKey
or a new DUKPT can be generated by calling CreateKey.For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
- Parameters:
reEncryptDataRequest
-- Returns:
- Result of the ReEncryptData operation returned by the service.
- See Also:
-
reEncryptData
default ReEncryptDataResponse reEncryptData(Consumer<ReEncryptDataRequest.Builder> reEncryptDataRequest) throws ValidationException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Re-encrypt ciphertext using DUKPT, Symmetric and Asymmetric Data Encryption Keys.
You can either generate an encryption key within Amazon Web Services Payment Cryptography by calling CreateKey or import your own encryption key by calling ImportKey. The
KeyArn
for use with this operation must be in a compatible key state withKeyModesOfUse
set toEncrypt
. In asymmetric encryption, ciphertext is encrypted using public component (imported by calling ImportKey) of the asymmetric key pair created outside of Amazon Web Services Payment Cryptography.For symmetric and DUKPT encryption, Amazon Web Services Payment Cryptography supports
TDES
andAES
algorithms. For asymmetric encryption, Amazon Web Services Payment Cryptography supportsRSA
. To encrypt using DUKPT, a DUKPT key must already exist within your account withKeyModesOfUse
set toDeriveKey
or a new DUKPT can be generated by calling CreateKey.For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
This is a convenience which creates an instance of the
ReEncryptDataRequest.Builder
avoiding the need to create one manually viaReEncryptDataRequest.builder()
- Parameters:
reEncryptDataRequest
- AConsumer
that will call methods onReEncryptDataRequest.Builder
to create a request.- Returns:
- Result of the ReEncryptData operation returned by the service.
- See Also:
-
translatePinData
default TranslatePinDataResponse translatePinData(TranslatePinDataRequest translatePinDataRequest) throws ValidationException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Translates encrypted PIN block from and to ISO 9564 formats 0,1,3,4. For more information, see Translate PIN data in the Amazon Web Services Payment Cryptography User Guide.
PIN block translation involves changing the encrytion of PIN block from one encryption key to another encryption key and changing PIN block format from one to another without PIN block data leaving Amazon Web Services Payment Cryptography. The encryption key transformation can be from PEK (Pin Encryption Key) to BDK (Base Derivation Key) for DUKPT or from BDK for DUKPT to PEK. Amazon Web Services Payment Cryptography supports
TDES
andAES
key derivation type for DUKPT translations.The allowed combinations of PIN block format translations are guided by PCI. It is important to note that not all encrypted PIN block formats (example, format 1) require PAN (Primary Account Number) as input. And as such, PIN block format that requires PAN (example, formats 0,3,4) cannot be translated to a format (format 1) that does not require a PAN for generation.
For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Amazon Web Services Payment Cryptography currently supports ISO PIN block 4 translation for PIN block built using legacy PAN length. That is, PAN is the right most 12 digits excluding the check digits.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
- Parameters:
translatePinDataRequest
-- Returns:
- Result of the TranslatePinData operation returned by the service.
- See Also:
-
translatePinData
default TranslatePinDataResponse translatePinData(Consumer<TranslatePinDataRequest.Builder> translatePinDataRequest) throws ValidationException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Translates encrypted PIN block from and to ISO 9564 formats 0,1,3,4. For more information, see Translate PIN data in the Amazon Web Services Payment Cryptography User Guide.
PIN block translation involves changing the encrytion of PIN block from one encryption key to another encryption key and changing PIN block format from one to another without PIN block data leaving Amazon Web Services Payment Cryptography. The encryption key transformation can be from PEK (Pin Encryption Key) to BDK (Base Derivation Key) for DUKPT or from BDK for DUKPT to PEK. Amazon Web Services Payment Cryptography supports
TDES
andAES
key derivation type for DUKPT translations.The allowed combinations of PIN block format translations are guided by PCI. It is important to note that not all encrypted PIN block formats (example, format 1) require PAN (Primary Account Number) as input. And as such, PIN block format that requires PAN (example, formats 0,3,4) cannot be translated to a format (format 1) that does not require a PAN for generation.
For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Amazon Web Services Payment Cryptography currently supports ISO PIN block 4 translation for PIN block built using legacy PAN length. That is, PAN is the right most 12 digits excluding the check digits.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
This is a convenience which creates an instance of the
TranslatePinDataRequest.Builder
avoiding the need to create one manually viaTranslatePinDataRequest.builder()
- Parameters:
translatePinDataRequest
- AConsumer
that will call methods onTranslatePinDataRequest.Builder
to create a request.- Returns:
- Result of the TranslatePinData operation returned by the service.
- See Also:
-
verifyAuthRequestCryptogram
default VerifyAuthRequestCryptogramResponse verifyAuthRequestCryptogram(VerifyAuthRequestCryptogramRequest verifyAuthRequestCryptogramRequest) throws ValidationException, VerificationFailedException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Verifies Authorization Request Cryptogram (ARQC) for a EMV chip payment card authorization. For more information, see Verify auth request cryptogram in the Amazon Web Services Payment Cryptography User Guide.
ARQC generation is done outside of Amazon Web Services Payment Cryptography and is typically generated on a point of sale terminal for an EMV chip card to obtain payment authorization during transaction time. For ARQC verification, you must first import the ARQC generated outside of Amazon Web Services Payment Cryptography by calling ImportKey. This operation uses the imported ARQC and an major encryption key (DUKPT) created by calling CreateKey to either provide a boolean ARQC verification result or provide an APRC (Authorization Response Cryptogram) response using Method 1 or Method 2. The
ARPC_METHOD_1
usesAuthResponseCode
to generate ARPC andARPC_METHOD_2
usesCardStatusUpdate
to generate ARPC.For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
- Parameters:
verifyAuthRequestCryptogramRequest
-- Returns:
- Result of the VerifyAuthRequestCryptogram operation returned by the service.
- See Also:
-
verifyAuthRequestCryptogram
default VerifyAuthRequestCryptogramResponse verifyAuthRequestCryptogram(Consumer<VerifyAuthRequestCryptogramRequest.Builder> verifyAuthRequestCryptogramRequest) throws ValidationException, VerificationFailedException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Verifies Authorization Request Cryptogram (ARQC) for a EMV chip payment card authorization. For more information, see Verify auth request cryptogram in the Amazon Web Services Payment Cryptography User Guide.
ARQC generation is done outside of Amazon Web Services Payment Cryptography and is typically generated on a point of sale terminal for an EMV chip card to obtain payment authorization during transaction time. For ARQC verification, you must first import the ARQC generated outside of Amazon Web Services Payment Cryptography by calling ImportKey. This operation uses the imported ARQC and an major encryption key (DUKPT) created by calling CreateKey to either provide a boolean ARQC verification result or provide an APRC (Authorization Response Cryptogram) response using Method 1 or Method 2. The
ARPC_METHOD_1
usesAuthResponseCode
to generate ARPC andARPC_METHOD_2
usesCardStatusUpdate
to generate ARPC.For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
This is a convenience which creates an instance of the
VerifyAuthRequestCryptogramRequest.Builder
avoiding the need to create one manually viaVerifyAuthRequestCryptogramRequest.builder()
- Parameters:
verifyAuthRequestCryptogramRequest
- AConsumer
that will call methods onVerifyAuthRequestCryptogramRequest.Builder
to create a request.- Returns:
- Result of the VerifyAuthRequestCryptogram operation returned by the service.
- See Also:
-
verifyCardValidationData
default VerifyCardValidationDataResponse verifyCardValidationData(VerifyCardValidationDataRequest verifyCardValidationDataRequest) throws ValidationException, VerificationFailedException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Verifies card-related validation data using algorithms such as Card Verification Values (CVV/CVV2), Dynamic Card Verification Values (dCVV/dCVV2) and Card Security Codes (CSC). For more information, see Verify card data in the Amazon Web Services Payment Cryptography User Guide.
This operation validates the CVV or CSC codes that is printed on a payment credit or debit card during card payment transaction. The input values are typically provided as part of an inbound transaction to an issuer or supporting platform partner. Amazon Web Services Payment Cryptography uses CVV or CSC, PAN (Primary Account Number) and expiration date of the card to check its validity during transaction processing. In this operation, the CVK (Card Verification Key) encryption key for use with card data verification is same as the one in used for GenerateCardValidationData.
For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
- Parameters:
verifyCardValidationDataRequest
-- Returns:
- Result of the VerifyCardValidationData operation returned by the service.
- See Also:
-
verifyCardValidationData
default VerifyCardValidationDataResponse verifyCardValidationData(Consumer<VerifyCardValidationDataRequest.Builder> verifyCardValidationDataRequest) throws ValidationException, VerificationFailedException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Verifies card-related validation data using algorithms such as Card Verification Values (CVV/CVV2), Dynamic Card Verification Values (dCVV/dCVV2) and Card Security Codes (CSC). For more information, see Verify card data in the Amazon Web Services Payment Cryptography User Guide.
This operation validates the CVV or CSC codes that is printed on a payment credit or debit card during card payment transaction. The input values are typically provided as part of an inbound transaction to an issuer or supporting platform partner. Amazon Web Services Payment Cryptography uses CVV or CSC, PAN (Primary Account Number) and expiration date of the card to check its validity during transaction processing. In this operation, the CVK (Card Verification Key) encryption key for use with card data verification is same as the one in used for GenerateCardValidationData.
For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
This is a convenience which creates an instance of the
VerifyCardValidationDataRequest.Builder
avoiding the need to create one manually viaVerifyCardValidationDataRequest.builder()
- Parameters:
verifyCardValidationDataRequest
- AConsumer
that will call methods onVerifyCardValidationDataRequest.Builder
to create a request.- Returns:
- Result of the VerifyCardValidationData operation returned by the service.
- See Also:
-
verifyMac
default VerifyMacResponse verifyMac(VerifyMacRequest verifyMacRequest) throws ValidationException, VerificationFailedException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Verifies a Message Authentication Code (MAC).
You can use this operation to verify MAC for message data authentication such as . In this operation, you must use the same message data, secret encryption key and MAC algorithm that was used to generate MAC. You can use this operation to verify a DUPKT, CMAC, HMAC or EMV MAC by setting generation attributes and algorithm to the associated values.
For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
- Parameters:
verifyMacRequest
-- Returns:
- Result of the VerifyMac operation returned by the service.
- See Also:
-
verifyMac
default VerifyMacResponse verifyMac(Consumer<VerifyMacRequest.Builder> verifyMacRequest) throws ValidationException, VerificationFailedException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Verifies a Message Authentication Code (MAC).
You can use this operation to verify MAC for message data authentication such as . In this operation, you must use the same message data, secret encryption key and MAC algorithm that was used to generate MAC. You can use this operation to verify a DUPKT, CMAC, HMAC or EMV MAC by setting generation attributes and algorithm to the associated values.
For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
This is a convenience which creates an instance of the
VerifyMacRequest.Builder
avoiding the need to create one manually viaVerifyMacRequest.builder()
- Parameters:
verifyMacRequest
- AConsumer
that will call methods onVerifyMacRequest.Builder
to create a request.- Returns:
- Result of the VerifyMac operation returned by the service.
- See Also:
-
verifyPinData
default VerifyPinDataResponse verifyPinData(VerifyPinDataRequest verifyPinDataRequest) throws ValidationException, VerificationFailedException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Verifies pin-related data such as PIN and PIN Offset using algorithms including VISA PVV and IBM3624. For more information, see Verify PIN data in the Amazon Web Services Payment Cryptography User Guide.
This operation verifies PIN data for user payment card. A card holder PIN data is never transmitted in clear to or from Amazon Web Services Payment Cryptography. This operation uses PIN Verification Key (PVK) for PIN or PIN Offset generation and then encrypts it using PIN Encryption Key (PEK) to create an
EncryptedPinBlock
for transmission from Amazon Web Services Payment Cryptography.For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
- Parameters:
verifyPinDataRequest
-- Returns:
- Result of the VerifyPinData operation returned by the service.
- See Also:
-
verifyPinData
default VerifyPinDataResponse verifyPinData(Consumer<VerifyPinDataRequest.Builder> verifyPinDataRequest) throws ValidationException, VerificationFailedException, AccessDeniedException, ResourceNotFoundException, ThrottlingException, InternalServerException, AwsServiceException, SdkClientException, PaymentCryptographyDataException Verifies pin-related data such as PIN and PIN Offset using algorithms including VISA PVV and IBM3624. For more information, see Verify PIN data in the Amazon Web Services Payment Cryptography User Guide.
This operation verifies PIN data for user payment card. A card holder PIN data is never transmitted in clear to or from Amazon Web Services Payment Cryptography. This operation uses PIN Verification Key (PVK) for PIN or PIN Offset generation and then encrypts it using PIN Encryption Key (PEK) to create an
EncryptedPinBlock
for transmission from Amazon Web Services Payment Cryptography.For information about valid keys for this operation, see Understanding key attributes and Key types for specific data operations in the Amazon Web Services Payment Cryptography User Guide.
Cross-account use: This operation can't be used across different Amazon Web Services accounts.
Related operations:
This is a convenience which creates an instance of the
VerifyPinDataRequest.Builder
avoiding the need to create one manually viaVerifyPinDataRequest.builder()
- Parameters:
verifyPinDataRequest
- AConsumer
that will call methods onVerifyPinDataRequest.Builder
to create a request.- Returns:
- Result of the VerifyPinData operation returned by the service.
- See Also:
-
create
Create aPaymentCryptographyDataClient
with the region loaded from theDefaultAwsRegionProviderChain
and credentials loaded from theDefaultCredentialsProvider
. -
builder
Create a builder that can be used to configure and create aPaymentCryptographyDataClient
. -
serviceMetadata
-
serviceClientConfiguration
Description copied from interface:SdkClient
The SDK service client configuration exposes client settings to the user, e.g., ClientOverrideConfiguration- Specified by:
serviceClientConfiguration
in interfaceAwsClient
- Specified by:
serviceClientConfiguration
in interfaceSdkClient
- Returns:
- SdkServiceClientConfiguration
-