On This Page
Samsung Pay Developer Guide
Audience and Purpose
This document is written for merchants who want to enable customers to use Samsung Pay to
pay for in-app purchases. This document provides an overview for integrating the Samsung Pay
SDK and describes how to request the
Cybersource
API to process an
authorization. Merchants must use the Samsung Pay SDK to receive the customer's encrypted
payment data before requesting the Cybersource
API to process the
transaction.Conventions
The following special statements are used in this document:
An
Important
statement contains information essential to successfully completing a task or learning a concept.A
Warning
contains information or instructions, which, if not heeded, can result in a security risk, irreversible loss of data, or significant cost in time or revenue or both.Related Documentation
Refer to the Support Center for complete technical documentation:
Customer Support
For support information about any service, visit the Support Center:
Recent Revisions to This Document
24.02
This revision contains only editorial changes and no technical updates.
24.01
This revision contains only editorial changes and no technical updates.
23.01
Removed American Express
and Discover as supported card types.
22.03
This revision contains only editorial changes and no technical updates.
22.02
This revision contains only editorial changes and no technical updates.
Requirements for Using Samsung Pay
In order to use the
Cybersource
platform to process Samsung Pay
transactions, you must have:- ACybersourceaccount. If you do not already have aCybersourceaccount, contact your localCybersourcesales representative.
- A merchant account with a supported processor.
- A profile on the Samsung Pay Partner Portal and an associated partner ID.
Samsung Pay relies on authorizations with payment network tokens. You
can sign up for Samsung Pay only when both of the following statements are true:
- Your processor supports payment network tokens.
- Cybersourcesupports payment network tokens with your processor.
If one or both of the preceding statements are not true, you must take one of
the following actions before you can sign up for Samsung Pay:
- Obtain a new merchant account with a processor that supports payment network tokens.
- Wait until your processor supports payment network tokens.
Supported Card Types and Optional Features
Processor | Card Types | Optional Features |
---|---|---|
FDC Compass |
|
|
Related Information
Transaction Endpoints
Test transactions:
- Akamai endpoint: http://ics2testa.ic3.com/
- Non-Akamai endpoint: http://ics2test.ic3.com/
Production transactions:
- Akamai endpoint: http://ics2a.ic3.com/
- Non-Akamai endpoint: http://ics2.ic3.com/
Getting Started
Follow these steps to set up Samsung Pay with
Cybersource
:- Registering with Samsung andCybersource:
- Integrating the Samsung SDK, which includes the following tasks:
- Using the Samsung SDK to:
Registering with Samsung Pay
- Create a profile by completing the merchant application on the Samsung Pay Partner Portal.
ADDITIONAL INFORMATION
After your merchant application is approved, you receive a unique partner ID. Include this ID in your application.You need the partner ID in order to generate a Certificate Signing Request (CSR) in theBusiness Center. Samsung requires the CSR file in order to encrypt sensitive payment data; it contains an identifier and public key. - Using the Samsung Pay Partner Portal, upload the CSR file.
- Enter an application name and a package name. When you associate the CSR file with the application, Samsung generates a product ID.
- Create login details for application developers on the Samsung Pay Partner Portal.
- Download and integrate the Samsung Pay SDK into your application.
ADDITIONAL INFORMATION
The SDK contains:- A Javadoc
- The Samsung Pay SDK filessamsungpay.jarandsdk-v1.0.0.jar
- A sample app
- The branding guide
- Image files
- Register a Samsung account ID and request adebug-api-keyfile using the Samsung Pay Partner Portal. The Samsung account ID, thedebug-api-key, and the product ID are used to validate your application so that you can use the Samsung Pay SDK for testing.
- Submit your application for approval using the Samsung Pay Partner Portal. Upload the final version of the Android Application Package (APK) file using the Samsung Pay Partner Portal, and include screenshots of your checkout page displaying the Samsung Pay logo.
Registering with Cybersource
Cybersource
- Log in to theBusiness Center:
ADDITIONAL INFORMATION
- Create a CSR file for test transactions:https://businesscentertest.cybersource.com
- Create a CSR file for production transactions:https://businesscentertest.cybersource.com
- On the left navigation pane, click thePayment Configurationicon.
- ClickDigital Payment Solutions. The Digital Payments page opens.
- ClickConfigure. The Samsung Pay Registration panel opens.
- Enter your Samsung partner ID.
- ClickGenerate New CSR.
- To download your CSR, click theDownloadicon next to the key.
- Follow your browser's instructions to save and open the file.
ADDITIONAL INFORMATION
Only one CSR is permitted for each unique Samsung partner ID. If you modify your Samsung partner ID, you must generate a new CSR. - Complete the enrollment process by submitting your CSR to Samsung.
Creating a Project
You use Android Studio to create a new Android Studio project, which is required to
integrate the Samsung SDK.
- Download Android Studio from the following website: https://developer.android.com/studio/index.html.
- Open Android Studio and clickStart a new Android Studio project.
- In the New Project settings menu, enter the name of your application and the company domain.
- To change the package name, clickEdit. By default, Android Studio sets the last element of the project's package name to the name of your application.
- ClickNext.
- In the Target Android Devices settings menu, choose the required API levels.
- ClickNext.
- Choose the required activity and clickFinish.
Integrating the Samsung Pay SDK
- Add thesamsungpay.jarandsdk-v1.0.0.jarfiles to thelibsfolder of your Android project.
- Chooseand enter the dependencies shown below.
ADDITIONAL INFORMATION
dependencies { compile files('libs/samsungpay.jar') compile files(libs/sdk-v1.0.0.jar') } - Import the package.
ADDITIONAL INFORMATION
import com.samsung.android.sdk.samsungpay;
Using the API Key
The API key is used to verify that your app (in debug mode or release mode) can use
the Samsung Pay SDK APIs with the Samsung Pay application. To get the API key, you must
create a
debug-api-key
file and include it in the manifest
file.- To use the API key, include it in themanifestfile with a custom tag. This enables the merchant app androidmanifestfile to provide theDebugMode,spay_debug_api_keyvalues as metadata.
Example: Debug Mode
<meta-data android:name="debug_mode" android:value="Y" /> <meta-data android:name="spay_debug_api_key" android:value="asdfggkndkeie17283094858" />
Example: Release Mode
<meta-data android:name="debug_mode" android:value="N" />
Verify That Your Application is Eligible for Samsung
Pay
You must initialize the
SSamsungPay
class to verify that your application is
eligible for Samsung Pay and to display the Samsung Pay button to the customer (refer to
branding guidelines).The
SSamsungPay
class provides the following API methods:- initialize()—initializes the Samsung Pay SDK and verifies eligibility for Samsung Pay, including the device, software, and business area.Request theinitialize()API method of theSSamsungPayclass before using the Samsung Pay SDK.
- getVersionCode()—retrieves the version number of the Samsung Pay SDK as an integer.
- getVersionName()—retrieves the version name of the Samsung Pay SDK as a string.
After the
initialize()
API method request is successful, display the
Samsung Pay button to the customer.If the
initialize()
API method request fails, the method displays one of
the following errors:- SsdkUnsupportedException—the device is not a Samsung device or does not support the Samsung Pay package.
- NullPointerException—the context passed is null.
Example: Samsung Pay Class
SSamsungPay spay = new SSamsungPay(); try { spay.initialize(mContext); } catch (SsdkUnsupportedException e1) { e1.printStackTrace(); pay_button.setVisibility(View.INVISIBLE); }
Initiating a Payment
You are required to use a specific transaction request structure and required fields to initiate a payment.
Required Fields for Initiating a Payment
The following fields are required for initiating a payment; include these fields in the
PaymentInfo
class:If the required fields are not included, you receive a
NullPointerException
error.- Merchant Name
- The merchant name as it appears on the payment sheet of Samsung Pay and customer’s bank statement.
- Amount
- Payment Protocol
- 3-D Secure.
- Permitted Card Brands
- Specify the card brands that are supported such as American Express, JCB, Mastercard, or Visa.
- Merchant ID
- Order Number
- Shipping Address
- This field is required ifSEND_SHIPPING or NEED_BILLING_AND_SEND_SHIPPINGis set forAddressVisibilityOption.
- Address Visibility Option
- Card Holder Name
- Recurring Option
Example: Transaction Request Structure
private PaymentInfo makeTransactionDetails() { // Supported card brands ArrayList<CardInfo.Brand> brandList = new ArrayList<CardInfo.Brand>(); if (visaBrand.isChecked()) brandList.add(CardInfo.Brand.VISA); if (mcBrand.isChecked()) brandList.add(CardInfo.Brand.Mastercard); if (amexBrand.isChecked()) brandList.add(CardInfo.Brand.AMERICANEXPRESS); // Basic payment information PaymentInfo paymentReq = new PaymentInfo.Builder() .setMerchantId(“merchantID”) .setMerchantName("Test").setAmount(getAmount()) .setShippingAddress(getShippingAddressInfo()) .setOrderNumber(orderNoView.getText().toString()) .setPaymentProtocol(PaymentProtocol.PROTOCOL_3DS) .setAddressInPaymentSheet(AddressInPaymentSheet.DO_NOT_SHOW) .setAllowedCardBrands(brandList) .setRecurringEnabled(isRecurring) .setCardHolderNameEnabled(isCardHolderNameRequired) .build(); return paymentReq; } // Add shipping address details private Address getShippingAddressInfo() { Address address = new Address.Builder() .setAddressee(name.getText().toString()) .setAddressLine1(addLine1.getText().toString()) .setAddressLine2(addline2.getText().toString()) .setCity(city.getText().toString()) .setState(state.getText().toString()) .setCountryCode(country.getSelectedItem().toString()) .setPostalCode(zip.getText().toString()).build(); return address; } // Add amount details private Amount getAmount() { Amount amount = new Amount.Builder() .setCurrencyCode(currencyType.getSelectedItem().toString()) .setItemTotalPrice(productPrice.getText().toString()) .setShippingPrice(shippingPrice.getText().toString()) .setTax(taxPrice.getText().toString()) .setTotalPrice(totalAmount.getText().toString()).build(); return amount; }
Requesting a Payment
- Use thestartSamsungPay()API method in thePaymentManagerclass. ThePaymentManagerclass includes the following API methods:
ADDITIONAL INFORMATION
- startSamsungPay()—requests to initiate payment with Samsung Pay.
- updateAmount()—updates the transaction amount if shipping address or card information is updated by Samsung Pay.
- updateAmountFailed()—returns an error code when the new amount cannot be updated because of a wrong address.
- Request thestartSamsungPay()API method and include the following data:
ADDITIONAL INFORMATION
- PaymentInfo—contains payment information.
- PID—the product ID created in the Samsung Pay Partner Portal.
- StatusListener—the result of the payment request is delivered toStatusListener. This listener should be registered before you call thestartSamsungPay()API method.
When you request thestartSamsungPay()API method, the Samsung Pay online payment sheet is displayed on your application. The customer selects a registered card for payment and can also update the billing and shipping address.The payment reply is delivered as one of the following events toStatusListener:- onSuccess()—this event is requested when Samsung Pay confirms the payment. It includesencryptedPaymentCredentialin JSON format:
- method:Payment protocol: 3-D Secure.
- merchant_ref:Merchant reference code.
- billing_address.street: Number, street name.
- billing_address.state_province:Two-letter state code.
- billing_address.zip_postal_code:Five-character zip code.
- billing_address.city:City name.
- billing_address.county:Two-letter country code.
- 3ds.type:Sfor Samsung Pay. Encrypted.
- 3ds.version:Current version100. Encrypted.
- 3ds.data:Base64-encoded payment data. Encrypted.
- onFailure()—this event is requested when the transaction fails. It returns an error code and error message.
Example: Request startSamsungPay() API Method
public void onPayButtonClicked(View v) { // Call startSamsungPay() method of PaymentManager class. // To create a transaction request for makeTransactionDetails() in the following code, see Example: Transaction Request Structure. try { mPaymentManager.startSamsungPay(makeTransactionDetails(), "enter product ID", mStatusListener); } catch (NullPointerException e) { e.printStackTrace(); } } private PaymentManager.StatusListener mStatusListener = new PaymentManager.StatusListener() { @Override public void onFailure(int errCode, String msg) { Log.d(TAG, " onFailed ); } @Override public void onSuccess(PaymentInfo arg0, String result) { Log.d(TAG, "onSuccess "); };
Services
The following services are available:
Authorization Service
You can authorize a payment for Samsung Pay using two different types of decryption
methods:
Cybersource
or Merchant. Each decryption method requires a
different set of required API fields. In addition, depending on which card type is used,
different fields are required for requesting the authorization service. Payment Processor | Authorization and Capture Information |
---|
Authorizing a Payment with JCB Using Cybersource Decryption
Method
Cybersource
Decryption
MethodThis section provides the following information:
Required Fields for Authorizing a Payment Using JCB and the Cybersource
Decryption Method
Cybersource
Decryption MethodThe following fields are required when submitting an authorization request using the
Cybersource
decryption method:- encryptedPayment_data-set this field to the Base64-encoded value obtained from thepaymentDataproperty of thePKPaymentTokenobject.
- encryptedPayment_descriptor-set this field toRklEPUNPTU1PTi5TQU1TVU5HLklOQVBQLlBBWU1FTlQ=.
- paymentSolution-set this field to008.
Related Information
Authorizing a Payment
- Request the service. Set theccAuthService_runfield totrue, and send the request to one of these endpoints:
- Include the required fields in the request.
- Include optional fields in the request as needed.
- Check the response message to make sure that the request was successful. A value ofACCEPTfor thedecisionfield indicates success. For information about reason codes, see Reason Codes for the Simple Order API.
Example: Cybersource Decryption with JCB
Using the Simple Order API
Cybersource
Decryption with JCB
Using the Simple Order APIAuthorization Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.121"> <merchantID>demomerchant</merchantID> <merchantReferenceCode>demorefnum</merchantReferenceCode> <billTo> <firstName>Jane</firstName> <lastName>Smith</lastName> <street1>123 Main Street</street1> <city>Small Town</city> <state>CA</state> <postalCode>98765</postalCode> <country>US</country> <email>jsmith@example.com</email> </billTo> <purchaseTotals> <currency>USD</currency> <grandTotalAmount>5.00</grandTotalAmount> </purchaseTotals> <encryptedPayment> <descriptor>RklEPUNPTU1PTi5TQU1TVU5HLklOQVBQLlBBWU1FTlQ=</descriptor> <data>ABCDEFabcdefABCDEFabcdef0987654321234567</data> <encoding>Base64</encoding> </encryptedPayment> <card> <cardType>007</cardType> </card> <ccAuthService run="true"/> <paymentSolution>008</paymentSolution> </requestMessage>
Authorization Response
<c:replyMessage> <c:merchantReferenceCode>demorefnum</c:merchantReferenceCode> <c:requestID>4465840340765000001541</c:requestID> <c:decision>ACCEPT</c:decision> <c:reasonCode>100</c:reasonCode> <c:token> <c:expirationMonth>07</c:expirationMonth> <c:expirationYear>2025</c:expirationYear> <c:prefix>239845</c:prefix> <c:suffix>2947</c:suffix> </c:token> <c:purchaseTotals> <c:currency>USD</c:currency> </c:purchaseTotals> <c:ccAuthReply> <c:reasonCode>100</c:reasonCode> <c:amount>5.00</c:amount> <c:authorizationCode>888888</c:authorizationCode> <c:avsCode>X</c:avsCode> <c:avsCodeRaw>I1</c:avsCodeRaw> <c:processorResponse>100</c:processorResponse> <c:reconciliationID>11267051CGJSMQDC</c:reconciliationID> </c:ccAuthReply> </c:replyMessage>
Authorizing a Payment with Mastercard Using Cybersource Decryption
Method
Cybersource
Decryption
MethodThis section provides the following information:
Required Fields for Authorizing a Payment Using Mastercard and the Cybersource Decryption Method
Cybersource
Decryption MethodThe following fields are required when submitting an authorization request using the
Cybersource
decryption method:- ccAuthService_commerceIndicator-set this field tospa.
- encryptedPayment_data
- Set the field to the value that was returned from Samsung Pay in the3ds.datablock as follows:
- Retrieve the payment data from Samsung Pay in JSON Web Encryption (JWE) format.
- Encode it in Base64.
- Add the value to theencryptedPayment_datafield.
- encryptedPayment_descriptor-set this field toRklEPUNPTU1PTi5TQU1TVU5HLklOQVBQLlBBWU1FTlQ=.
- paymentNetworkToken_transactionType-set this field to1.
- paymentSolution-set this field to008.
Related Information
Example: Cybersource Decryption with
Mastercard Using the Simple Order API
Cybersource
Decryption with
Mastercard Using the Simple Order APIAuthorization Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.121"> <merchantID>demomerchant</merchantID> <merchantReferenceCode>demorefnum</merchantReferenceCode> <billTo> <firstName>James</firstName> <lastName>Smith</lastName> <street1>1295 Charleston Road</street1> <city>Test City</city> <state>CA</state> <postalCode>99999</postalCode> <country>US</country> <email>demo@example.com</email> </billTo> <purchaseTotals> <currency>USD</currency> <grandTotalAmount>5.00</grandTotalAmount> </purchaseTotals> <ccAuthService run="true"> <commerceIndicator>spa</commerceIndicator> </ccAuthService> <encryptedPayment> <data>ABCDEFabcdefABCDEFabcdef0987654321234567</data> <descriptor>RklEPUNPTU1PTi5TQU1TVU5HLklOQVBQLlBBWU1FTlQ=</descriptor> </encryptedPayment> <paymentSolution>008</paymentSolution> <paymentNetworkToken> <transactionType>1</transactionType> </paymentNetworkToken> </requestMessage>
Authorization Response
<c:replyMessage> <c:merchantReferenceCode>demorefnum</c:merchantReferenceCode> <c:requestID>4465840340765000001541</c:requestID> <c:decision>ACCEPT</c:decision> <c:reasonCode>100</c:reasonCode> <c:purchaseTotals> <c:currency>USD</c:currency> </c:purchaseTotals> <c:ccAuthReply> <c:reasonCode>100</c:reasonCode> <c:amount>5.00</c:amount> <c:authorizationCode>888888</c:authorizationCode> <c:avsCode>X</c:avsCode> <c:avsCodeRaw>I1</c:avsCodeRaw> <c:authorizedDateTime>2015-11-03T20:53:54Z</c:authorizedDateTime> <c:processorResponse>100</c:processorResponse> <c:reconciliationID>11267051CGJSMQDC</c:reconciliationID> </c:ccAuthReply> <c:token> <c:prefix>128945</c:prefix> <c:suffix>2398</c:suffix> <c:expirationMonth>08</c:expirationMonth> <c:expirationYear>2021</c:expirationYear> </c:token> </c:replyMessage>
Authorizing a Payment with Visa Using Cybersource Decryption
Method
Cybersource
Decryption
MethodThis section provides the following information:
Required Fields for Authorizing a Payment Using Visa and the Cybersource Decryption Method
Cybersource
Decryption MethodThe following fields are required when submitting an authorization request using the
Cybersource
decryption method:- ccAuthService_commerceIndicator-set this field tointernet.
- encryptedPayment_data
- Set the field to the value that was returned from Samsung Pay in the3ds.datablock as follows:
- Retrieve the payment data from Samsung Pay in JSON Web Encryption (JWE) format.
- Encode it in Base64.
- Add the value to theencryptedPayment_datafield.
- encryptedPayment_descriptor-set this field toRklEPUNPTU1PTi5TQU1TVU5HLklOQVBQLlBBWU1FTlQ=.
- paymentNetworkToken_transactionType-set this field to1.
- paymentSolution-set this field to008.
Related Information
Example: Cybersource Decryption with
Visa Using the Simple Order API
Cybersource
Decryption with
Visa Using the Simple Order APIAuthorization Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.121"> <merchantID>demomerchant</merchantID> <merchantReferenceCode>demorefnum</merchantReferenceCode> <billTo> <firstName>James</firstName> <lastName>Smith</lastName> <street1>1295 Charleston Road</street1> <city>Test City</city> <state>CA</state> <postalCode>99999</postalCode> <country>US</country> <email>demo@example.com</email> </billTo> <purchaseTotals> <currency>USD</currency> <grandTotalAmount>5.00</grandTotalAmount> </purchaseTotals> <ccAuthService run="true"> <commerceIndicator>internet</commerceIndicator> </ccAuthService> <encryptedPayment> <data>ABCDEFabcdefABCDEFabcdef0987654321234567</data> <descriptor>RklEPUNPTU1PTi5TQU1TVU5HLklOQVBQLlBBWU1FTlQ=</descriptor> </encryptedPayment> <paymentSolution>008</paymentSolution> <paymentNetworkToken> <transactionType>1</transactionType> </paymentNetworkToken> </requestMessage>
Authorization Response
<c:replyMessage> <c:merchantReferenceCode>demorefnum</c:merchantReferenceCode> <c:requestID>4465840340765000001541</c:requestID> <c:decision>ACCEPT</c:decision> <c:reasonCode>100</c:reasonCode> <c:purchaseTotals> <c:currency>USD</c:currency> </c:purchaseTotals> <c:ccAuthReply> <c:reasonCode>100</c:reasonCode> <c:amount>5.00</c:amount> <c:authorizationCode>888888</c:authorizationCode> <c:avsCode>X</c:avsCode> <c:avsCodeRaw>I1</c:avsCodeRaw> <c:authorizedDateTime>2015-11-03T20:53:54Z</c:authorizedDateTime> <c:processorResponse>100</c:processorResponse> <c:reconciliationID>11267051CGJSMQDC</c:reconciliationID> </c:ccAuthReply> <c:token> <c:prefix>294672</c:prefix> <c:suffix>4397</c:suffix> <c:expirationMonth>08</c:expirationMonth> <c:expirationYear>2021</c:expirationYear> </c:token> </c:replyMessage>
Authorizing a Payment with JCB Using Merchant Decryption Method
This section provides the following information:
Required Fields for Authorizing a Payment Using JCB and the Merchant Decryption
Method
The following fields are required when submitting an authorization request using the
Merchant decryption method:
- ccAuthService_cavv-set this field to the 3-D Secure cryptogram of the payment network token.
- card_accountNumber-set this field to the payment network token value.
- card_expirationMonth-set this field to the payment network token expiration month value.
- card_expirationYear-set this field to the payment network token expiration year value.
- ccAuthService_eciRaw-set this field to the ECI value contained in the Samsung Pay reply message.
- ccAuthService_networkTokenCryptogram-set this field to the network token cryptogram.
- paymentNetworkToken_transactionType-set this field to1.
- paymentSolution-set this field to008.
Related Information
Example: Merchant Decryption with JCB Using the Simple
Order API
Authorization Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.121"> <merchantID>demomerchant</merchantID> <merchantReferenceCode>demorefnum</merchantReferenceCode> <billTo> <firstName>Jane</firstName> <lastName>Smith</lastName> <street1>123 Main Street</street1> <city>Small Town</city> <state>CA</state> <postalCode>98765</postalCode> <country>US</country> <email>jsmith@example.com</email> </billTo> <purchaseTotals> <currency>USD</currency> <grandTotalAmount>5.00</grandTotalAmount> </purchaseTotals> <card> <accountNumber>xxxx11111111xxxx</accountNumber> <expirationMonth>12</expirationMonth> <expirationYear>2020</expirationYear> <cvNumber>123</cvNumber> <cardType>007</cardType> </card> <ccAuthService run="true"> <cavv>ABCDEFabcdefABCDEFabcdef0987654321234567</cavv> <eciRaw>5</eciRaw> </ccAuthService> <paymentNetworkToken> <transactionType>1</transactionType> </paymentNetworkToken> <paymentSolution>008</paymentSolution> </requestMessage>
Authorization Response
<c:replyMessage> <c:merchantReferenceCode>demorefnum</c:merchantReferenceCode> <c:requestID>4465840340765000001541</c:requestID> <c:decision>ACCEPT</c:decision> <c:reasonCode>100</c:reasonCode> <c:purchaseTotals> <c:currency>USD</c:currency> </c:purchaseTotals> <c:ccAuthReply> <c:reasonCode>100</c:reasonCode> <c:amount>5.00</c:amount> <c:authorizationCode>888888</c:authorizationCode> <c:avsCode>X</c:avsCode> <c:avsCodeRaw>I1</c:avsCodeRaw> <c:authorizedDateTime>2015-11-03T20:53:54Z</c:authorizedDateTime> <c:processorResponse>100</c:processorResponse> <c:reconciliationID>11267051CGJSMQDC</c:reconciliationID> </c:ccAuthReply> </c:replyMessage>
NVP Request
merchantID=demomerchant merchantReferenceCode=demorefnum billTo_firstName=Jane billTo_lastName=Smith billTo_street1=123 Main Street billTo_city=Small Town billTo_state=CA billTo_postalCode=98765 billTo_country=US billTo_email=jsmith@example.com purchaseTotals_currency=USD purchastTotals_grandTotalAmount=5.00 card_accountNumber=xxxx00202036xxxx card_expirationYear=2020 card_cvnNumber=123 cardType=007 ccAuthService_cavv=ABCDEFabcdefABCDEFabcdef0987654321234567 ccAuthService_eciRaw=5 paymentNetworkToken_transactionType=1 paymentSolution=008
NVP Response
merchantReferenceCode=demorefnum requestID=4465840340765000001541 decision=accept reasonCode=100 requestToken=Ahj/7wSR5C/4Icd2fdAKakGLadfg5535r/ghx3Z90AoBj3u purchaseTotals_currency=USD ccAuthReply_reasonCode=100 ccAuthReply_amount=5.00 ccAuthReply_authorizationCode=888888 ccAuthReply_avsCode=X ccAuthReply_avsCodeRaw=I1 ccAuthReply_authorizedDateTime=2015-11-03T20:53:54Z ccAuthReply_processorResponse=100 ccAuthReply_reconciliationID=11267051CGJSMQDC
Authorizing a Payment with Mastercard Using Merchant Decryption Method
This section provides the following information:
Required Fields for Authorizing a Payment Using Mastercard and the Merchant Decryption
Method
The following fields are required when submitting an authorization request using the
Merchant decryption method:
- card_accountNumber-set this field to the payment network token value.
- card_expirationMonth-set this field to the payment network token expiration month value.
- card_expirationYear-set this field to the payment network token expiration year value.
- ccAuthService_commerceIndicator- set this field tospa.
- ccAuthService_networkTokenCryptogram-set this field to the network token cryptogram.
- paymentNetworkToken_transactionType-set this field to1.
- paymentSolution-set this field to008.
- ucaf_authenticationData–set this field to the 3-D Secure cryptogram of the payment network token.
- ucaf_collectionIndicator-set this field to2.
Related Information
Example: Merchant Decryption with Mastercard Using the
Simple Order API
Authorization Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.121"> <merchantID>demomerchant</merchantID> <merchantReferenceCode>demorefnum</merchantReferenceCode> <billTo> <firstName>James</firstName> <lastName>Smith</lastName> <street1>1295 Charleston Road</street1> <city>Test City</city> <state>CA</state> <postalCode>99999</postalCode> <country>US</country> <email>demo@example.com</email> </billTo> <purchaseTotals> <currency>USD</currency> <grandTotalAmount>5.00</grandTotalAmount> </purchaseTotals> <card> <accountNumber>xxxx55555555xxxx</accountNumber> <expirationMonth>12</expirationMonth> <expirationYear>2020</expirationYear> </card> <ucaf> <authenticationData>ABCDEFabcdefABCDscdef0987654321234567</authenticationData> <collectionIndicator>2</collectionIndicator> </ucaf> <ccAuthService run="true"> <commerceIndicator>spa</commerceIndicator> </ccAuthService> <paymentNetworkToken> <transactionType>1</transactionType> </paymentNetworkToken> <paymentSolution>008</paymentSolution> </requestMessage>
Authorization Response
<c:replyMessage> <c:merchantReferenceCode>demorefnum</c:merchantReferenceCode> <c:requestID>4465840340765000001541</c:requestID> <c:decision>ACCEPT</c:decision> <c:reasonCode>100</c:reasonCode> <c:purchaseTotals> <c:currency>USD</c:currency> </c:purchaseTotals> <c:ccAuthReply> <c:reasonCode>100</c:reasonCode> <c:amount>5.00</c:amount> <c:authorizationCode>888888</c:authorizationCode> <c:avsCode>X</c:avsCode> <c:avsCodeRaw>I1</c:avsCodeRaw> <c:authorizedDateTime>2015-11-03T20:53:54Z</c:authorizedDateTime> <c:processorResponse>100</c:processorResponse> <c:reconciliationID>11267051CGJSMQDC</c:reconciliationID> </c:ccAuthReply> </c:replyMessage>
Authorizing a Payment with Visa Using Merchant Decryption Method
This section provides the following information:
Required Fields for Authorizing a Payment Using Visa and the Merchant Decryption
Method
The following fields are required when submitting an authorization request using the
Merchant decryption method:
- ccAuthService_cavv-set this field to the 3-D Secure cryptogram of the payment network token.
- card_accountNumber-set this field to the payment network token value.
- card_expirationMonth-set this field to the payment network token expiration month value.
- card_expirationYear-set this field to the payment network token expiration year value.
- ccAuthService_eciRaw-for JCB transactions, set this field to the ECI value contained in the Samsung Pay reply message.
- ccAuthService_commerceIndicator-set this field tointernet.
- ccAuthService_networkTokenCryptogram-set this field to the network token cryptogram.
- paymentNetworkToken_transactionType-set this field to1.
- paymentSolution-set this field to008.
Related Information
Example: Merchant Decryption with Visa Using the Simple
Order API
Authorization Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.121"> <merchantID>demomerchant</merchantID> <merchantReferenceCode>demorefnum</merchantReferenceCode> <billTo> <firstName>James</firstName> <lastName>Smith</lastName> <street1>1295 Charleston Road</street1> <city>Test City</city> <state>CA</state> <postalCode>99999</postalCode> <country>US</country> <email>demo@example.com</email> </billTo> <purchaseTotals> <currency>USD</currency> <grandTotalAmount>5.00</grandTotalAmount> </purchaseTotals> <card> <accountNumber>xxxx10000000xxxx</accountNumber> <expirationMonth>12</expirationMonth> <expirationYear>2020</expirationYear> </card> <ccAuthService run="true"> <cavv>ABCDEFabcdefABCDEFabcdef0987654321234567</cavv> <commerceIndicator>internet</commerceIndicator> </ccAuthService> <paymentNetworkToken> <transactionType>1</transactionType> </paymentNetworkToken> <paymentSolution>008</paymentSolution> </requestMessage>
Authorization Response
<c:replyMessage> <c:merchantReferenceCode>demorefnum</c:merchantReferenceCode> <c:requestID>4465840340765000001541</c:requestID> <c:decision>ACCEPT</c:decision> <c:reasonCode>100</c:reasonCode> <c:purchaseTotals> <c:currency>USD</c:currency> </c:purchaseTotals> <c:ccAuthReply> <c:reasonCode>100</c:reasonCode> <c:amount>5.00</c:amount> <c:authorizationCode>888888</c:authorizationCode> <c:avsCode>X</c:avsCode> <c:avsCodeRaw>I1</c:avsCodeRaw> <c:authorizedDateTime>2015-11-03T20:53:54Z</c:authorizedDateTime> <c:processorResponse>100</c:processorResponse> <c:reconciliationID>11267051CGJSMQDC</c:reconciliationID> </c:ccAuthReply> </c:replyMessage>
Authorization Reversal Service
The authorization reversal service is a follow-on service that uses the request ID
returned from the previous authorization. An authorization reversal releases the hold
that the authorization placed on the customer’s credit card funds. Use this service to
reverse an unnecessary or undesired authorization.
Payment Processor | Authorization Reversal Information |
---|---|
FDC Compass | Card types supported for full authorization reversals: Visa, Mastercard,
American Express, Discover, Diners Club, and JCB. A full authorization reversal
must occur within three days of the authorization. |
Required Fields for Reversing an Authorization
The following fields are required when creating an authorization reversal request:
- ccAuthReversalService_authRequestID
- Set to the request ID that was included in the authorization reply message.
- ccAuthReversalService_run
- Set totrue.
- merchantID
- merchantReferenceCode
- paymentSolution
- Set to008.
- purchaseTotals_currency
- purchaseTotals_grandTotalAmount
- EitherpurchaseTotals_grandTotalAmountoritem_#_unitPricemust be included in the request.
Related Information
Reversing an Authorization
- Request the service. Set theccAuthReversalService_runfield totrue, and send the request to one of these endpoints:
- https://ics2ws.ic3.com/commerce/1.x/transactionProcessor
- https://ics2wsa.ic3.com/commerce/1.x/transactionProcessor
- Check the response message to make sure that the request was successful. A value ofACCEPTfor thedecisionfield indicates success. For information about reason codes, see Reason Codes for the Simple Order API.
XML Example: Basic Credit Card Authorization Reversal
Using the Simple Order API
Authorization Reversal Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.121"> <merchantID>retail_910</merchantID> <merchantReferenceCode>MS299131501003</merchantReferenceCode> <purchaseTotals> <currency>USD</currency> <grandTotalAmount>99.49</grandTotalAmount> </purchaseTotals> <ccAuthReversalService run="true"> <authRequestID>6152173358406291304007</authRequestID> </ccAuthReversalService> <paymentSolution>008</paymentSolution> </requestMessage>
Authorization Reversal Response
<c:replyMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.121"> <c:merchantReferenceCode>MS299131501003</c:merchantReferenceCode> <c:requestID>1019827520348290570293</c:requestID> <c:purchaseTotals> <c:currency>USD</c:currency> </c:purchaseTotals> <c:ccAuthReversalReply> <c:amount>99.49</c:amount> <c:authorizationCode>1</c:authorizationCode> </c:ccAuthReversalReply> </c:replyMessage>
Capture Service
The capture service is a follow-on service that uses the request ID returned from the
previous authorization. The request ID links the capture to the authorization. This
service transfers funds from the customer’s account to your bank and usually takes two
to four days to complete.
Payment Processor | Authorization and Capture Information |
---|
Required Fields for Capturing a Payment
The following fields are required when creating a capture request:
- ccCaptureService_authRequestID
- Set to the request ID that was included in the authorization reply message. Optional whenccAuthServiceandccCaptureServiceare in the same request.
- ccCaptureService_run
- Set totrue.
- merchantID
- merchantReferenceCode
- paymentSolution
- Set to008.
- purchaseTotals_currency
- purchaseTotals_grandTotalAmount
- EitherpurchaseTotals_grandTotalAmountoritem_#_unitPricemust be included in the request.
Related Information
Capturing a Payment
- Request the service. Set theics_applicationsfield toics_bill, and send the request to one of these endpoints:
- https://ics2ws.ic3.com/commerce/1.x/transactionProcessor
- https://ics2wsa.ic3.com/commerce/1.x/transactionProcessor
- Check the response message to make sure that the request was successful. A value ofACCEPTfor thedecisionfield indicates success. For information about reason codes, see Reason Codes for the Simple Order API.
XML Example: Basic Credit Card Capture Using the Simple
Order API
Capture Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.37"> <merchantID>Napa Valley Vacations</merchantID> <merchantReferenceCode>482046C3A7E94F5BD1FE3C66C</merchantReferenceCode> <item id="0"> <unitPrice>49.95</unitPrice> <quantity>1</quantity> </item> <purchaseTotals> <currency>USD</currency> </purchaseTotals> <ccCaptureService run="true"> <authRequestID>0305782650000167905080</authRequestID> </ccCaptureService> <paymentSolution>008</paymentSolution> </requestMessage>
Capture Response
<c:replyMessage xmlns:c="urn:schemas-cybersource-com:transaction-data-1.37"> <c:merchantReferenceCode>482046C3A7E94F5BD1FE3C66C</c:merchantReferenceCode> <c:requestID>1019827520348290570293</c:requestID> <c:decision>ACCEPT</c:decision> <c:reasonCode>100</c:reasonCode> <c:purchaseTotals> <c:currency>USD</c:currency> </c:purchaseTotals> <c:ccCaptureReply> <c:reasonCode>100</c:reasonCode> <c:amount>49.95</c:amount> <c:reconciliationID>1094820975023470</c:reconciliationID> </c:ccCaptureReply> </c:replyMessage>
Sale Service
A sale is a bundled authorization and capture. Request the authorization and capture
services at the same time.
Cybersource
processes the capture immediately. Required Fields for Performing a Sale
The following fields are required when submitting a sale request:
- ccCaptureService_run
- Set this field totrue.
- Fields required for requesting the authorization service
- Use the same values that are set for requesting the Authorization Service.
Related Information
Authorizing and Capturing a Payment
You can authorize and capture a payment at the same time, which is known as
performing a sale.
- Request the service. Set theics_applicationsfield toics_auth,ics_bill, and send the request to one of these internet endpoints:
- https://ics2ws.ic3.com/commerce/1.x/transactionProcessor
- https://ics2wsa.ic3.com/commerce/1.x/transactionProcessor
- Check the response message to make sure that the request was successful. A value ofACCEPTfor thedecisionfield indicates success. For information about reason codes, see Reason Codes for the Simple Order API.
XML Example: Basic Credit Card Sale Using the Simple
Order API
Authorization and Capture (Sale) Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.121"> <merchantID>demomerchant</merchantID> <merchantReferenceCode>demorefnum</merchantReferenceCode> <billTo> <firstName>James</firstName> <lastName>Smith</lastName> <street1>1295 Charleston Road</street1> <city>Test City</city> <state>CA</state> <postalCode>99999</postalCode> <country>US</country> <email>demo@example.com</email> </billTo> <purchaseTotals> <currency>USD</currency> <grandTotalAmount>5.00</grandTotalAmount> </purchaseTotals> <ccCaptureService run="true"> <commerceIndicator>aesk</commerceIndicator> </ccCaptureService> <encryptedPayment> <data>ABCDEFabcdefABCDEFabcdef0987654321234567</data> <descriptor>RklEPUNPTU1PTi5TQU1TVU5HLklOQVBQLlBBWU1FTlQ=</descriptor> </encryptedPayment> <paymentSolution>008</paymentSolution> <paymentNetworkToken> <transactionType>1</transactionType> </paymentNetworkToken> </requestMessage>
Authorization and Capture (Sale) Response
<c:replyMessage> <c:merchantReferenceCode>demorefnum</c:merchantReferenceCode> <c:requestID>4465840340765000001541</c:requestID> <c:decision>ACCEPT</c:decision> <c:reasonCode>100</c:reasonCode> <c:purchaseTotals> <c:currency>USD</c:currency> </c:purchaseTotals> <c:ccAuthReply> <c:reasonCode>100</c:reasonCode> <c:amount>5.00</c:amount> <c:authorizationCode>888888</c:authorizationCode> <c:avsCode>V</c:avsCode> <c:avsCodeRaw>I1</c:avsCodeRaw> <c:authorizedDateTime>2015-11-03T20:53:54Z</c:authorizedDateTime> <c:processorResponse>100</c:processorResponse> <c:reconciliationID>11267051CGJSMQDC</c:reconciliationID> </c:ccAuthReply> <c:ccCaptureReply> <c:reconciliationID>02850840187309570</c:reconciliationID> <c:amount>100.00</c:amount> </c:ccCaptureReply> <c:token> <c:prefix>593056</c:prefix> <c:suffix>0842</c:suffix> <c:expirationMonth>08</c:expirationMonth> <c:expirationYear>2021</c:expirationYear> </c:token> </c:replyMessage>
Authorizing a Payment with American Express Using Cybersource Decryption Method
Cybersource
Decryption MethodExample:
Cybersource Decryption with American Express Using the Simple Order
API
Cybersource
Decryption with American Express Using the Simple Order
APIAuthorization Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.121"> <merchantID>demomerchant</merchantID> <merchantReferenceCode>demorefnum</merchantReferenceCode> <billTo> <firstName>James</firstName> <lastName>Smith</lastName> <street1>1295 Charleston Road</street1> <city>Test City</city> <state>CA</state> <postalCode>99999</postalCode> <country>US</country> <email>demo@example.com</email> </billTo> <purchaseTotals> <currency>USD</currency> <grandTotalAmount>5.00</grandTotalAmount> </purchaseTotals> <ccAuthService run="true"> <commerceIndicator>aesk</commerceIndicator> </ccAuthService> <encryptedPayment> <data>ABCDEFabcdefABCDEFabcdef0987654321234567</data> <descriptor>RklEPUNPTU1PTi5TQU1TVU5HLklOQVBQLlBBWU1FTlQ=</descriptor> </encryptedPayment> <paymentSolution>008</paymentSolution> <paymentNetworkToken> <transactionType>1</transactionType> </paymentNetworkToken> </requestMessage>
Authorization Response
<c:replyMessage> <c:merchantReferenceCode>demorefnum</c:merchantReferenceCode> <c:requestID>4465840340765000001541</c:requestID> <c:decision>ACCEPT</c:decision> <c:reasonCode>100</c:reasonCode> <c:purchaseTotals> <c:currency>USD</c:currency> </c:purchaseTotals> <c:ccAuthReply> <c:reasonCode>100</c:reasonCode> <c:amount>5.00</c:amount> <c:authorizationCode>888888</c:authorizationCode> <c:avsCode>V</c:avsCode> <c:avsCodeRaw>I1</c:avsCodeRaw> <c:authorizedDateTime>2015-11-03T20:53:54Z</c:authorizedDateTime> <c:processorResponse>100</c:processorResponse> <c:reconciliationID>11267051CGJSMQDC</c:reconciliationID> </c:ccAuthReply> <c:token> <c:prefix>593056</c:prefix> <c:suffix>0842</c:suffix> <c:expirationMonth>08</c:expirationMonth> <c:expirationYear>2021</c:expirationYear> </c:token> </c:replyMessage>
Required Fields for Authorizing a Payment Using American Express and the Merchant
Decryption Method
The following fields are required when submitting an authorization request using the
Merchant decryption method:
- ccAuthService_cavv-set this field to the 3-D Secure cryptogram of the payment network token.Include the whole 20-byte cryptogram in the cavv field. For a 40-byte cryptogram, split the cryptogram into two 20-byte binary values (block A and block B). Set the cavv field to the block A value and set the xid field to the block B value.
- card_accountNumber-set this field to the payment network token value.
- card_expirationMonth-set this field to the payment network token expiration month value.
- card_expirationYear-set this field to the payment network token expiration year value.
- ccAuthService_commerceIndicator-set this field toaesk.
- ccAuthService_networkTokenCryptogram-set this field to the network token cryptogram.
- paymentNetworkToken_transactionType-set this field to1.
- paymentSolution-set this field to008.
Related Information
Authorizing a Payment with American Express Using Merchant Decryption Method
Required Fields for Authorizing a Payment Using American Express and the Cybersource Decryption Method
Cybersource
Decryption MethodThe following fields are required when submitting an authorization request using the
Cybersource
decryption method:- ccAuthService_commerceIndicator-set this field toaesk.
- encryptedPayment_data
- Set the field to the value that was returned from Samsung Pay in the3ds.datablock as follows:
- Retrieve the payment data from Samsung Pay in JSON Web Encryption (JWE) format.
- Encode it in Base64.
- Add the value to theencryptedPayment_datafield.
- encryptedPayment_descriptor-set this field toRklEPUNPTU1PTi5TQU1TVU5HLklOQVBQLlBBWU1FTlQ=.
- paymentNetworkToken_transactionType-set this field to1.
- paymentSolution-set this field to008.
Related Information
Example: Merchant Decryption with American Express Using
the Simple Order API
Authorization Request
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.121"> <merchantID>demomerchant</merchantID> <merchantReferenceCode>demorefnum</merchantReferenceCode> <billTo> <firstName>James</firstName> <lastName>Smith</lastName> <street1>1295 Charleston Road</street1> <city>Test City</city> <state>CA</state> <postalCode>99999</postalCode> <country>US</country> <email>demo@example.com</email> </billTo> <purchaseTotals> <currency>USD</currency> <grandTotalAmount>5.00</grandTotalAmount> </purchaseTotals> <card> <accountNumber>xxxx8224631xxxx</accountNumber> <expirationMonth>12</expirationMonth> <expirationYear>2020</expirationYear> </card> <ccAuthService run="true"> <cavv>ABCDEFabcdefABCDEFabcdef0987654321234567</cavv> <commerceIndicator>aesk</commerceIndicator> <xid>1234567890987654321ABCDEFabcdefABCDEF123</xid> </ccAuthService> <paymentNetworkToken> <transactionType>1</transactionType> </paymentNetworkToken> <paymentSolution>008</paymentSolution> </requestMessage>
Authorization Response
<c:replyMessage> <c:merchantReferenceCode>demorefnum</c:merchantReferenceCode> <c:requestID>4465840340765000001541</c:requestID> <c:decision>ACCEPT</c:decision> <c:reasonCode>100</c:reasonCode> <c:purchaseTotals> <c:currency>USD</c:currency> </c:purchaseTotals> <c:ccAuthReply> <c:reasonCode>100</c:reasonCode> <c:amount>5.00</c:amount> <c:authorizationCode>888888</c:authorizationCode> <c:avsCode>V</c:avsCode> <c:avsCodeRaw>I1</c:avsCodeRaw> <c:authorizedDateTime>2015-11-03T20:53:54Z</c:authorizedDateTime> <c:processorResponse>100</c:processorResponse> <c:reconciliationID>11267051CGJSMQDC</c:reconciliationID> </c:ccAuthReply> </c:replyMessage>