Merchant Account API Documentation – Cybersource (Barclays PLC)

This API allows merchants to process transactions using Cybersource via Barclays PLC.

Base URL:
🔗 Test Environment: https://ebctest.cybersource.com/

📌 Authentication:

  • API authentication is handled via HTTP Signature or JWT (JSON Web Token).
  • You must obtain an API Key & Shared Secret from Cybersource.
  • Send credentials in the request header.

1. Authentication

1.1 HTTP Signature Authentication

To authenticate API requests, include the following headers:

Headers:

http
Content-Type: application/json
v-c-merchant-id: {YOUR_MERCHANT_ID}
Date: {CURRENT_DATE}
Host: ebctest.cybersource.com
Digest: SHA-256={GENERATED_DIGEST}
Signature: keyid="{YOUR_KEY_ID}", algorithm="rsa-sha256", headers="host date digest", signature="{GENERATED_SIGNATURE}"

2. API Endpoints

2.1 Create Payment Request

🔹 Endpoint:

http
POST /pts/v2/payments

🔹 Request Example:

json
{
"clientReferenceInformation": {
"code": "ORDER12345"
},
"processingInformation": {
"capture": true
},
"paymentInformation": {
"card": {
"number": "4111111111111111",
"expirationMonth": "12",
"expirationYear": "2026",
"securityCode": "123"
}
},
"orderInformation": {
"amountDetails": {
"totalAmount": "100.00",
"currency": "GBP"
},
"billTo": {
"firstName": "John",
"lastName": "Doe",
"address1": "123 Street",
"locality": "London",
"administrativeArea": "ENG",
"postalCode": "WC1X 9AA",
"country": "GB",
"email": "[email protected]",
"phoneNumber": "447911123456"
}
}
}

🔹 Response Example:

json
{
"id": "6165986539356812304004",
"status": "AUTHORIZED",
"clientReferenceInformation": {
"code": "ORDER12345"
},
"orderInformation": {
"amountDetails": {
"totalAmount": "100.00",
"currency": "GBP"
}
},
"paymentInformation": {
"card": {
"last4": "1111",
"expirationMonth": "12",
"expirationYear": "2026"
}
}
}

2.2 Capture Payment

🔹 Endpoint:

http
POST /pts/v2/payments/{payment_id}/captures

🔹 Request Example:

json
{
"clientReferenceInformation": {
"code": "CAPTURE_12345"
},
"orderInformation": {
"amountDetails": {
"totalAmount": "100.00",
"currency": "GBP"
}
}
}

🔹 Response Example:

json
{
"id": "6165986539356812304005",
"status": "PENDING_SETTLEMENT"
}

2.3 Refund Payment

🔹 Endpoint:

http
POST /pts/v2/payments/{payment_id}/refunds

🔹 Request Example:

json
{
"clientReferenceInformation": {
"code": "REFUND_12345"
},
"orderInformation": {
"amountDetails": {
"totalAmount": "100.00",
"currency": "GBP"
}
}
}

🔹 Response Example:

json
{
"id": "6165986539356812304006",
"status": "PENDING_CREDIT"
}

3. Error Handling

Cybersource returns standard HTTP status codes along with an error response in JSON format.

HTTP StatusMeaningDescription
200SuccessRequest processed successfully
201CreatedResource successfully created
400Bad RequestInvalid input parameters
401UnauthorizedInvalid authentication credentials
403ForbiddenMerchant account not allowed to perform this operation
404Not FoundResource does not exist
500Internal Server ErrorCybersource system error

🔹 Error Response Example:

json
{
"responseStatus": {
"status": "DECLINED",
"reasonCode": "203",
"message": "General decline by issuer"
}
}

4. Testing & Sandbox Environment

Use the following test card numbers to simulate transactions:

Card TypeNumberExpiry DateCVV
Visa411111111111111112/26123
MasterCard555555555555444412/26123
Amex37144963539843112/261234

Test Environment Base URL: https://ebctest.cybersource.com/


5. Webhooks

Merchants can receive real-time notifications on payment events. Configure webhook URLs in your Cybersource merchant dashboard.

🔹 Webhook Event Types:

  • payment.authorized – Payment successfully authorized
  • payment.refunded – Refund processed
  • payment.failed – Payment failed

🔹 Webhook Payload Example:

json
{
"eventType": "payment.authorized",
"paymentId": "6165986539356812304004",
"orderReference": "ORDER12345",
"status": "AUTHORIZED"
}

6. Support & Contact

For technical support, contact:
📧 Email: [email protected]


📌 Notes:

  • This API is designed for Barclays merchants using Cybersource.
  • Ensure API keys are securely stored and rotated periodically.
  • Use the test environment before deploying to production.
24hr Merchant Support

RCPSecure Global LLC and RCPSecurePay are registered ISO/MSP/3rd Party Service Providers, located in the Republic of Mauritius and the United States respectively. All product names, trademarks, and registered trademarks are the property of their respective owners. All pictures, web elements, texts, and animations are copyrighted materials of the owner. External client logos and partner logos are subject to approval before publication.

PCI Compliancy merchant account

© RCPSecurePay 2025 . All Rights Reserved.

  • SOLUTIONS
Merchant Account
Privacy Overview

This website uses cookies so that we can provide you with the best user experience possible. Cookie information is stored in your browser and performs functions such as recognising you when you return to our website and helping our team to understand which sections of the website you find most interesting and useful.