Collecting the CVV Code
While you can reuse a customer’s saved card information, you may still be required to pass a customer’s CVV code in an authorization or charge request. Since the CVV code is not part of the saved token, you will thus need to collect the CVV code from your customers before you can proceed with the payment flow.
You can collect the CVV code using either the Secure Code Form or the JavaScript API.
Using the Secure Code Form
API Reference
For an overview of all methods supported by the Secure Code Form, see the Secure CVV Form Reference.PaymentsOS allows you to securely collect a customer’s CVV code using a Secure Code Form that you embed in your web page. Similar to the Secure Fields Form, the Secure Code Form generates the CVV’s input field and handles the logic of grabbing the CVV submitted by the user.
Note
A CVV code is always related to customer’s card information, so make sure you have the card’s token at hand (recall that you fetch the token from a customer object). You will need the token when collecting the CVV code.Let’s take a look at how it all works. To get started, include the CVV Javascript SDK in your checkout page. You can find the SDK at https://js.paymentsos.com/cvv/latest/cvv-encryptor.min.js. Also provide your public key to authenticate yourself by calling POSC.setPublicKey()
.
Subresource Integrity (SRI)
For enhanced security, you can use Subresource Integrity (SRI) checks with versioned SDKs instead of the ‘latest’ version. Learn more in the Using SRI.<body>
<script language="JavaScript" type="text/javascript" src="https://js.paymentsos.com/cvv/latest/cvv-encryptor.min.js"></script>
<script>POSC.setPublicKey("99346d84-5186-4221-9c16-dc51a8de27fb");
</script>
...
</body>
Now embed the Secure Code Form form and set your environment (either “test” or “live”) by calling POSC.setEnvironment()
. The CVV code must always be related to the payment method that the customer chose to use, so the next step is to call POSC.setPaymentToken()
and pass it the token you fetched from the customer object. Then display the form’s CVV field by calling POSC.initCvvEncryptor()
. As a last step, attach a click event to the form that is invoked when the form is submitted and pass the event the POSC.createToken()
function. This function will send the CVV code to PaymentsOS, tokenize the CVV value and return an encrypted code to your site.
Let’s piece it all together:
<body>
...
<!-- Embed the form after loading the CVV Javascript SDK and setting your public key -->
<form id="cvv-form">
<div id="cvv-field">
<!-- The form will be displayed here -->
</div>
<button type=”submit”>Pass CVV Code</button>
</form>
<script>
// Set your environment. Values are either "test" or "live".
// If omitted, the test environment will be used.
POSC.setEnvironment("test");
// Pass us the token that belongs to the payment method that your customer chose to use
POSC.setPaymentToken(token);
// Initialize the form's fields
POSC.initCvvEncryptor('cvv-field');
// Attach a click event to the form that is invoked when the form is submitted.
document.getElementById('cvv-form').addEventListener('submit', function(event) {
event.preventDefault();
// On submit, pass the CVV code to PaymentsOS
POSC.createToken(function(result) {
// Grab the encrypted CVV code here
});
});
</script>
</body>
Styling the Secure Code Form
To customize the look and feel of the Secure Code Form, define the CSS of the CVV input field and call POSC.setStyle()
for your changes to take effect. Make sure to initialize the form after setting your styles.
<script>
// Make sure to use camelCase for the style attributes
const style = {
base: {
border: 'none',
backgroundColor: 'transparent',
height: 45,
fontSize: 14,
},
cvv: {
width: 40,
height: 45,
}
}
// Done styling? Let us know, so that we can apply your changes.
POSC.setStyle(style);
// Make sure to initialize the cvv field after setting your styles
POSC.initCvvEncryptor('cvv-fields');
...
</script>
Setting a CVV Field Placeholder
To set the CVV code’s input field placeholder text, call POSC.setSecurityNumberPlaceholder()
. The default placeholder text is “CVV”. Call this method before initializing the form’s fields.
<script>
...
// Set the field's placeholder
POSC.setSecurityNumberPlaceholder("CVD");
// Now initialize the fields
POSC.initCvvEncryptor('cvv-field');
</script>
Using the JavaScript API
API Reference
For an overview of all methods supported by the JavaScript API, see the Javascript API Reference.You can choose the use the JavaScript API to collect a user’s CVV code, instead of the Secure Code Form. Simply include the JavaScript API in your web page and then call POS.tokenize()
, passing in an object with the fields required for a token_type
of card_cvv_code
:
...
<!-- Add the JavaScript API Library -->
<script language="JavaScript" type="text/javascript" src="https://js.paymentsos.com/v2/0.0.1/token.min.js"></script>
<!-- Call POS.tokenize() -->
<script>
POS.tokenize({
"token_type": "card_cvv_code",
"credit_card_cvv": "123",
"payment_method_token": "d5c0d95d-55ef-476d-bea0-0354dfb03194"
},
function (result) {
console.log ("result obtained"+result);
// Check for errors, if all is good, then proceed!
}
);
</script>