Card Payment Initialization
Learn how to initialize card payments securely via the Juicyway API
Overview
Card payment initialization is the first step in processing a card payment. This endpoint creates a payment session that can be used to securely process credit and debit card transactions.
Endpoint
Request Parameters
Payment amount in minor units (e.g., kobo, cents)
-
Minimum: 10000
-
Examples:
-
10000 (NGN 100.00)
-
150000 (USD 1,500.00)
-
Three-letter currency code
-
Supported values: NGN, USD, CAD
-
Must match the payment method’s supported currencies
Description of the payment transaction
-
Maximum length: 255 characters
-
Will appear on customer’s statement
Payment method details
Customer information object
Payment direction
- Valid values: incoming, outgoing
Unique reference for the payment
-
Must be unique across all transactions
-
Alphanumeric characters only
Additional transaction data
Example Requests
Test Cards
Use these test cards in your sandbox environment to simulate different payment scenarios:
Response Examples
Authentication Flows
Some card payments may require additional authentication steps. The response will indicate the required authentication type:
3D Secure Authentication
If 3DS is required, you’ll receive:
Redirect the customer to complete 3DS verification, then:
-
Listen for webhook notification, or
-
Poll payment status endpoint
OTP Validation
For OTP authentication:
Submit OTP via:
PIN Verification
For PIN authentication:
Submit PIN via:
Security Requirements
Error Handling
Card declined by issuing bank
-
Status code: 402
-
Possible reasons:
-
Insufficient funds
-
Suspicious activity
-
Expired card
-
Invalid card details provided
-
Status code: 400
-
Check:
-
Card number
-
Expiry date
-
CVV
-
Failed authentication (3DS/OTP/PIN)
-
Status code: 401
-
Verify credentials and retry
Common error scenarios to handle:
-
Invalid currency code
-
Amount below minimum
-
Missing customer information
-
Invalid phone/email format
-
Incorrect billing address
-
Network timeouts
Next Steps
After successful initialization:
-
Handle any required authentication
-
Listen for webhook notifications
Need Help?
-
Review Authentication Guide
-
Check Error Handling
-
Contact Support