New – Move Payment Processing to the Cloud with AWS Payment Cryptography

0
875
New – Move Payment Processing to the Cloud with AWS Payment Cryptography


Voiced by Polly

Cryptography is in every single place in our every day lives. If you’re studying this weblog, you’re utilizing HTTPS, an extension of HTTP that makes use of encryption to safe communications. On AWS, a number of companies and capabilities enable you to handle keys and encryption, equivalent to:

HSMs are bodily units that securely defend cryptographic operations and the keys utilized by these operations. HSMs can assist you meet your company, contractual, and regulatory compliance necessities. With CloudHSM, you might have entry to general-purpose HSMs. When funds are concerned, there are particular cost HSMs that provide capabilities equivalent to producing and validating the non-public identification quantity (PIN) and the safety code of a credit score or debit card.

Today, I’m joyful to share the provision of AWS Payment Cryptography, an elastic service that manages cost HSMs and keys for cost processing functions within the cloud.

Applications utilizing funds HSMs have difficult necessities as a result of cost processing is advanced, time delicate, and extremely regulated and requires the interplay of a number of monetary service suppliers and cost networks. Every time you make a cost, information is exchanged between two or extra monetary service suppliers and should be decrypted, remodeled, encrypted, or validated at every step.

This course of requires extremely performant cryptography capabilities and key administration procedures between every cost service supplier. These suppliers might need 1000’s of keys to guard, handle, rotate, and audit, making the general course of costly and troublesome to scale. To add to that, cost HSMs traditionally make use of advanced and error-prone processes, equivalent to exchanging keys utilizing key elements printed on paper, couriered to a number of key custodians individually who ultimately mix the elements beneath an elaborate key ceremony in a safe room.

Introducing AWS Payment Cryptography
AWS Payment Cryptography simplifies your implementation of cryptographic features and key administration used to safe information in cost processing in accordance with numerous cost card business (PCI) requirements.

With AWS Payment Cryptography, you possibly can get rid of the necessity to provision and handle on-premises cost HSMs and use the supplied instruments to keep away from error-prone key change processes. For instance, with AWS Payment Cryptography, cost and monetary service suppliers can start growth inside minutes and plan to change keys electronically, eliminating handbook processes.

To present its elastic cryptographic capabilities in a compliant method, AWS Payment Cryptography makes use of HSMs with PCI PTS HSM machine approval. These capabilities embody encryption and decryption of card information, key creation, and pin translation. AWS Payment Cryptography can also be designed in accordance with PCI safety requirements equivalent to PCI DSS, PCI PIN, and PCI P2PE, and it supplies proof and reporting to assist meet your compliance wants.

You can import and export symmetric keys between AWS Payment Cryptography and on-premises HSMs beneath key encryption key (KEKs) utilizing the ANSI X9 TR-31 protocol. You may import and export symmetric KEKs with different programs and units utilizing the ANSI X9 TR-34 protocol, which permits the service to change symmetric keys utilizing uneven methods.

To simplify shifting shopper cost processing to the cloud, current card cost functions can use AWS Payment Cryptography by means of the AWS SDKs. In this manner, you need to use your favourite programming language, equivalent to Java or Python, as an alternative of vendor-specific ASCII interfaces over TCP sockets, as is widespread with cost HSMs.

Access could be licensed utilizing AWS Identity and Access Management (IAM) identity-based insurance policies, the place you possibly can specify which actions and sources are allowed or denied and beneath which situations.

Monitoring is necessary to take care of the reliability, availability, and efficiency wanted by cost processing. With AWS Payment Cryptography, you need to use Amazon CloudWatch, AWS CloudPath, and Amazon EventBridge to grasp what is going on, report when one thing is incorrect, and take automated actions when acceptable.

Let’s see how this works in observe.

Using AWS Payment Cryptography
Using the AWS Command Line Interface (AWS CLI), I create a double-length 3DES key for use as a card verification key (CVK). A CVK is a key used for producing and verifying card safety codes equivalent to CVV, CVV2, and comparable values.

Note that there are two instructions for the CLI (and equally two endpoints for API and SDKs):

  • payment-cryptography for management airplane operation equivalent to itemizing and creating keys and aliases.
  • payment-cryptography-data for cryptographic operations that use keys, for instance, to generate PIN or card validation information.

Creating a key’s a management airplane operation:

aws payment-cryptography create-key 
    --no-exportable 
    --key-attributes KeyAlgorithm=TDES_2KEY,
                     KeyUtilization=TR31_C0_CARD_VERIFICATION_KEY,
                     KeyClass=SYMMETRIC_KEY,
                     KeyModesOfUse="{Generate=true,Verify=true}"

{
    "Key": {
        "KeyArn": "arn:aws:payment-cryptography:us-west-2:123412341234:key/42cdc4ocf45mg54h",
        "KeyAttributes": {
            "KeyUtilization": "TR31_C0_CARD_VERIFICATION_KEY",
            "KeyClass": "SYMMETRIC_KEY",
            "KeyAlgorithm": "TDES_2KEY",
            "KeyModesOfUse": {
                "Encrypt": false,
                "Decrypt": false,
                "Wrap": false,
                "Unwrap": false,
                "Generate": true,
                "Sign": false,
                "Verify": true,
                "DeriveKey": false,
                "NoRestrictions": false
            }
        },
        "KeyCheckValue": "B2DD4E",
        "KeyCheckValueAlgorithm": "ANSI_X9_24",
        "Enabled": true,
        "Exportable": false,
        "KeyState": "CREATE_COMPLETE",
        "KeyOrigin": "AWS_PAYMENT_CRYPTOGRAPHY",
        "CreateTimestamp": "2023-05-26T14:25:48.240000+01:00",
        "UsageStartTimestamp": "2023-05-26T14:25:48.220000+01:00"
    }
}

To reference this key within the subsequent steps, I can use the Amazon Resource Name (ARN) as discovered within the KeyARN property, or I can create an alias. An alias is a pleasant identify that lets me seek advice from a key with out having to make use of the complete ARN. I can replace an alias to seek advice from a distinct key. When I want to switch a key, I can simply replace the alias with out having to alter the configuration or the code of your functions. To be acknowledged simply, alias names begin with alias/. For instance, the next command creates the alias alias/my-key for the important thing I simply created:

aws payment-cryptography create-alias --alias-name alias/my-key 
    --key-arn arn:aws:payment-cryptography:us-west-2:123412341234:key/42cdc4ocf45mg54h

{
    "Alias": {
        "AliasName": "alias/my-key",
        "KeyArn": "arn:aws:payment-cryptography:us-west-2:123412341234:key/42cdc4ocf45mg54h"
    }
}

Before I begin utilizing the brand new key, I record all my keys to examine their standing:

aws payment-cryptography list-keys

{
    "Keys": [
        {
            "KeyArn": "arn:aws:payment-cryptography:us-west-2:123421341234:key/42cdc4ocf45mg54h",
            "KeyAttributes": {
                "KeyUsage": "TR31_C0_CARD_VERIFICATION_KEY",
                "KeyClass": "SYMMETRIC_KEY",
                "KeyAlgorithm": "TDES_2KEY",
                "KeyModesOfUse": {
                    "Encrypt": false,
                    "Decrypt": false,
                    "Wrap": false,
                    "Unwrap": false,
                    "Generate": true,
                    "Sign": false,
                    "Verify": true,
                    "DeriveKey": false,
                    "NoRestrictions": false
                }
            },
            "KeyCheckValue": "B2DD4E",
            "Enabled": true,
            "Exportable": false,
            "KeyState": "CREATE_COMPLETE"
        },
        {
            "KeyArn": "arn:aws:payment-cryptography:us-west-2:123412341234:key/ok4oliaxyxbjuibp",
            "KeyAttributes": {
                "KeyUsage": "TR31_C0_CARD_VERIFICATION_KEY",
                "KeyClass": "SYMMETRIC_KEY",
                "KeyAlgorithm": "TDES_2KEY",
                "KeyModesOfUse": {
                    "Encrypt": false,
                    "Decrypt": false,
                    "Wrap": false,
                    "Unwrap": false,
                    "Generate": true,
                    "Sign": false,
                    "Verify": true,
                    "DeriveKey": false,
                    "NoRestrictions": false
                }
            },
            "KeyCheckValue": "905848",
            "Enabled": true,
            "Exportable": false,
            "KeyState": "DELETE_PENDING"
        }
    ]
}

As you possibly can see, there may be one other key I created earlier than, which has since been deleted. When a key’s deleted, it’s marked for deletion (DELETE_PENDING). The precise deletion occurs after a configurable interval (by default, 7 days). This is a security mechanism to stop the unintended or malicious deletion of a key. Keys marked for deletion usually are not out there to be used however could be restored.

In an analogous approach, I record all my aliases to see to which keys they’re they referring:

aws payment-cryptography list-aliases

{
    "Aliases": [
        {
            "AliasName": "alias/my-key",
            "KeyArn": "arn:aws:payment-cryptography:us-west-2:123412341234:key/42cdc4ocf45mg54h"
        }
    ]
}

Now, I take advantage of the important thing to generate a card safety code with the CVV2 authentication system. You could be accustomed to CVV2 numbers which are often written on the again of a bank card. This is the way in which they’re computed. I present as enter the first account variety of the bank card, the cardboard expiration date, and the important thing from the earlier step. To specify the important thing, I take advantage of its alias. This is an information airplane operation:

aws payment-cryptography-data generate-card-validation-data 
    --key-identifier alias/my-key 
    --primary-account-number=171234567890123 
    --generation-attributes CardVerificationValue2={CardExpiryDate=0124}

{
    "KeyArn": "arn:aws:payment-cryptography:us-west-2:123412341234:key/42cdc4ocf45mg54h",
    "KeyCheckValue": "B2DD4E",
    "ValidationData": "343"
}

I be aware of the three digits within the ValidationData property. When processing a cost, I can confirm that the cardboard information worth is right:

aws payment-cryptography-data verify-card-validation-data 
    --key-identifier alias/my-key 
    --primary-account-number=171234567890123 
    --verification-attributes CardVerificationValue2={CardExpiryDate=0124} 
    --validation-data 343

{
    "KeyArn": "arn:aws:payment-cryptography:us-west-2:123412341234:key/42cdc4ocf45mg54h",
    "KeyCheckValue": "B2DD4E"
}

The verification is profitable, and in return I get again the identical KeyCheckValue as after I generated the validation information.

As you may count on, if I take advantage of the incorrect validation information, the verification isn’t profitable, and I get again an error:

aws payment-cryptography-data verify-card-validation-data 
    --key-identifier alias/my-key 
    --primary-account-number=171234567890123 
    --verification-attributes CardVerificationValue2={CardExpiryDate=0124} 
    --validation-data 999

An error occurred (com.amazonaws.paymentcryptography.exception#VerificationFailedException)
when calling the VerifyCardValidationData operation:
Card validation information verification failed

In the AWS Payment Cryptography console, I select View Keys to see the record of keys.

Console screenshot.

Optionally, I can allow extra columns, for instance, to see the important thing kind (symmetric/uneven) and the algorithm used.

Console screenshot.

I select the important thing I used within the earlier instance to get extra particulars. Here, I see the cryptographic configuration, the tags assigned to the important thing, and the aliases that seek advice from this key.

Console screenshot.

AWS Payment Cryptography helps many extra operations than those I confirmed right here. For this walkthrough, I used the AWS CLI. In your functions, you need to use AWS Payment Cryptography by means of any of the AWS SDKs.

Availability and Pricing
AWS Payment Cryptography is obtainable as we speak within the following AWS Regions: US East (N. Virginia) and US West (Oregon).

With AWS Payment Cryptography, you solely pay for what you utilize based mostly on the variety of lively keys and API calls with no up-front dedication or minimal charge. For extra info, see AWS Payment Cryptography pricing.

AWS Payment Cryptography removes your dependencies on devoted cost HSMs and legacy key administration programs, simplifying your integration with AWS native APIs. In addition, by working all the cost software within the cloud, you possibly can decrease round-trip communications and latency.

Move your cost processing functions to the cloud with AWS Payment Cryptography.

Danilo

LEAVE A REPLY

Please enter your comment!
Please enter your name here