Skrill 1-Tap
Skrill offers a single-click payment service that enables customers to automatically debit transactions from your customer’s Skrill account without the customer having to log in to their account and authorizes each time.
After each 1-Tap payment, customers receive an email notification, and they can check the progress of all their 1-Tap payments in the History section of their Skrill Wallet account.
This payment method works on a subscription model, customer subscribes to a merchant with their Skrill wallet or Card and can make transactions until the subscription is canceled
Customers can pay using Skrill 1-Tap with any of the following payment methods linked to their Skrill account:
- Credit/debit card (Visa and MasterCard)
- Skrill account balance
To access this account service, merchants must be onboarded with Skrill's Solution.
The Payments API caters to the following needs for Skrill 1-Tap
- Payment Instrument: Skrill 1-Tap
-
Payment method: Card Transactions or Wallet Balance
- Currencies:
- Available: EUR, USD, GBP, HKD, SGD, JPY, CAD, AUD, CHF, DKK, SEK, NOK, ILS, MYR, NZD, TRY, AED, MAD, QAR, SAR, TWD, THB, CZK, HUF, BGN, PLN, ISK, INR, KRW, ZAR, RON, HRK, JOD, OMR, RSD, TND, BHD, KWD
- Banned: AF, CU, ER, IR, IQ, JP, KG, LY, KP, SD, SS, SY
Setup Requirements
For Paysafe to create a test account in the sandbox and production environment, we need the following details.
- Merchant's Skrill Pay to Email
-
Merchant's Skrill account API/MQI Password
Typical Scenarios
Subscription + First Payments Flow
For a new user to consume this service, the below steps are required:
The user will have to log in to their skrill account in which they will provide consent for Subsequent payments without login and complete the first transaction. The merchant is supposed to provide few important parameters which will be used to identify the user in subsequent calls
- Create a Payment Handle request with the transactionType parameter set to PAYMENT and the paymentType parameter set to SKRILL1TAP.
- In the skrill1tap object of the request packet, the consumerId should be set to the set to a unique ID of the user which will be used in subsequent calls to identify the user, account and subscription, along with it maxAmount is also passed which puts a limit on the amount of the subsequent transactions.
Post: paymenthub/v1/paymenthandles
Parameter | Description |
---|---|
consumerId | Unique ID of the user which is used to identify to account and user in subsequent calls. |
maxAmount | This acts as an upper limit, any subsequent transactions for this subscription cannot be more than the maxAmount set. |
- Since the customer has to complete payment and provide consent for subsequent transactions on the Skrill platform by logging in, Paysafe returns a response with the following:
- The action parameter is set to REDIRECT
- A payment_redirect link points to Skrill Page redirect URL
- The status of the Payment Handle will be in INITIATED stage.
- After the user is redirected to payment_redirect on the Skrill page, the user will have to log in and complete the transaction.
- After the completion of this transaction, the user is redirected to the success or failed page of the merchant, depending upon the status of the transaction.
- The status of the Payment Handle becomes PAYABLE after a Successful transaction and FAILED if the transaction fails. The merchant gets notified of this status change via a webhook that has been configured.
- Use the paymentHandleToken returned in the response to process the Payments API request.
- paymenthub/v1/payments
The user can have multiple subscriptions with the same merchant, each subscription will be identified on the basis of consumerId .
The user can see all active subscriptions in their Skrill account along with the maxAmount set and can cancel it anytime.
Once the subscription is canceled, all saved information apart from transaction history will be cleared and the user will be considered as new even if the same consumerId is used again.
APIs to use
Subsequent Payments Flow
This flow will be active once the user has subscribed to Skrill 1-tap for the merchant and has completed the first Payment.
The consumerId has to be the same as what was used in the Subscription call otherwise, the user will be considered a new user.
- Create a Payment Handle request with the transactionType parameter set to PAYMENT and the paymentType parameter set to SKRILL1TAP.
- In the skrill1tap object of the request packet, the consumerId should be set to the set to the unique ID of the user for this subscription that was used in first transaction.
Post: paymenthub/v1/paymenthandles
- There will be no redirection
- The status of the Payment Handle becomes PAYABLE after a Successful transaction and FAILED if the transaction fails. The merchant gets notified of this status change via a webhook that has been configured.
- Use the paymentHandleToken returned in the response to process the Payments API request.
- paymenthub/v1/payments
APIs to use
Withdrawal/Payout Flow
This flow will be active once the user has subscribed to Skrill 1-tap for the merchant and has completed the first Payment.
The consumerId has to be the same as what was used in the Subscription call otherwise, the user will be considered a new user.
- Create a Payment Handle request with the transactionType parameter set to STANDALONE_CREDIT and the paymentType parameter set to SKRILL1TAP.
- In the skrill1tap object of the request packet, the consumerId should be set to the set to the unique ID of the user for this subscription that was used in the first transaction, some extra parameters are needed as this transaction is for withdrawal.
Parameter | Description |
---|---|
consumerId | Unique ID of the user which is used to identify to account and user in subsequent calls. |
emailSubject | Customizable subject of the email that would be triggered to the user informing them about the details of the transaction. |
emailMessage | Customizable body of the email that would be triggered to the user informing them about the details of the transaction. |
Post: paymenthub/v1/paymenthandles
- There will be no redirection
- The status of the Payment Handle becomes PAYABLE after a Successful transaction and FAILED if the transaction fails. The merchant gets notified of this status change via a webhook that has been configured.
- Use the paymentHandleToken returned in the response to process the Standalone Credits API request.
- paymenthub/v1/standalonecredits
APIs to use
Refunds
Refunds can only be triggered once payment is completed and settled and the transaction ID of the Payment is used.
- Once the Payment is done i.e. the status is COMPLETED in the response of Payments information the refund can be initiated using the payment ID.
- Create a refund request with the Refunds API
Post: /paymenthub/v1/settlements/{paymentId }/refunds
- The request will take an amount, which could be equal to what was in the Payments, or could be a partial refund with an amount lower than what was in the Payments.
- Multiple partial refunds can be initiated till the total sum of the amounts is lesser than the initial payment amount.
- The Response will contain the details of the payment done and a unique identifier that could be used to refer to each individual refund, either partial or full.
- The status of the refund will initially be in the PENDING state and will move to COMPLETED once the refund is processed to the user's Account, at each step a webhook will be triggered to the merchant.
Payments PaymentHandle API Request
{
"merchantRefNum": "e926b809-9517-48bd-8600-dfd2599737cf",
"transactionType": "PAYMENT",
"paymentType": "SKRILL1TAP",
"amount": 100,
"currencyCode": "USD",
"customerIp": "172.0.0.1",
"skrill1tap": {
"consumerId": "1234898",
"maxAmount": 500
},
"billingDetails": {
"nickName": "Home",
"street": "100 Queen",
"street2": "Unit 201",
"city": "Toronto",
"zip": "M5H 2N2",
"country": "CA"
},
"merchantDescriptor": {
"dynamicDescriptor": "OnlineStore",
"phone": "12345678"
},
"profile": {
"firstName": "pawan",
"lastName": "Kalyan",
"email": "test@paysafe.com",
"phone": "1234567890"
},
"returnLinks": [
{
"rel": "default",
"href": "https://usgaminggamblig.com/payment/return/success"
},
{
"rel": "on_failed",
"href": "https://usgaminggamblig.com/payment/return/failed"
},
{
"rel": "on_cancelled",
"href": "https://usgaminggamblig.com/payment/return/cancelled"
}
]
}
Payments PaymentHandle API Response
{
"id": "0bfc4c1f-7b8d-4051-ac29-a4185b268ab9",
"paymentType": "SKRILL1TAP",
"paymentHandleToken": "PHEnrVLdLGqgm8ti",
"merchantRefNum": "cf5d5aca-f303-44c2-be0e-dfeb8cb46128",
"currencyCode": "USD",
"txnTime": "2022-09-21T05:04:49Z",
"billingDetails": {
"street": "100 Queen",
"street2": "Unit 201",
"city": "Toronto",
"zip": "M5H 2N2",
"country": "CA"
},
"customerIp": "172.0.0.1",
"status": "INITIATED",
"links": [
{
"rel": "redirect_payment",
"href": "https://api.dev.paysafe.com/alternatepayments/v1/redirect?accountId=1001570964&paymentHandleId=0bfc4c1f-7b8d
}
],
"liveMode": false,
"simulator": "EXTERNAL",
"usage": "SINGLE_USE",
"action": "REDIRECT",
"executionMode": "SYNCHRONOUS",
"amount": 100,
"merchantDescriptor": {
"dynamicDescriptor": "OnlineStore",
"phone": "12345678"
},
"timeToLiveSeconds": 898,
"gatewayResponse": {
"processor": "SKRILL_QCO",
"sid": "19d40425ccce5e94eeac97111f82fa5a"
},
"returnLinks": [
{
"rel": "on_failed",
"href": "https://usgaminggamblig.com/payment/return/failed"
},
{
"rel": "default",
"href": "https://usgaminggamblig.com/payment/return/success"
},
{
"rel": "on_cancelled",
"href": "https://usgaminggamblig.com/payment/return/cancelled"
}
],
"transactionType": "PAYMENT",
"gatewayReconciliationId": "8aa6cd6f-ee43-4539-b1eb-7de7decb4dc0",
"updatedTime": "2022-09-21T05:04:51Z",
"statusTime": "2022-09-21T05:04:51Z",
"skrill1tap": {
"consumerId": "1234898",
"maxAmount": 500
},
"profile": {
"firstName": "pawan",
"lastName": "Kalyan",
"email": "test@paysafe.com",
"phone": "1234567890"
}
}
Payments API Request
{
"merchantRefNum": "5bb81950-bed0-4e4a-8cce-8af39a6192c7",
"amount": 1000,
"currencyCode": "USD",
"dupCheck": true,
"settleWithAuth": true,
"paymentHandleToken": "PHtxnH0z99GXgc0Z",
"customerIp": "172.0.0.1",
"description": "Test Paysafe"
}
Payments API Response
{
"id": "f7a0ced2-3ac4-4eac-8a24-5c6be97fcae3",
"paymentType": "SKRILL1TAP",
"paymentHandleToken": "PHx3N14y6wOe4cv1",
"merchantRefNum": "bcb58c35-94ba-4a60-a7d5-9d7af44be3e6",
"currencyCode": "USD",
"settleWithAuth": true,
"dupCheck": true,
"txnTime": "2022-09-20T13:25:05Z",
"billingDetails": {
"street1": "100 Queen",
"street2": "Unit 201",
"city": "Toronto",
"zip": "M5H 2N2",
"country": "CA"
},
"status": "COMPLETED",
"gatewayReconciliationId": "9b5328a2-85ad-46a5-8374-96ef241b2ee3",
"amount": 100,
"availableToRefund": 100,
"consumerIp": "172.0.0.1",
"liveMode": false,
"simulator": "EXTERNAL",
"updatedTime": "2022-09-20T13:27:27Z",
"statusTime": "2022-09-20T13:27:27Z",
"gatewayResponse": {
"transaction_id": "9b5328a2-85ad-46a5-8374-96ef241b2ee3",
"amount": "1.00",
"mb_transaction_id": "4423459195",
"pay_from_email": "user.mail@skrill.com",
"pay_to_email": "merchant@skrill.com",
"currency": "USD",
"merchant_id": "48091998",
"id": "4423459195",
"processor": "SKRILL_QCO",
"status": "2",
"sid": "57942312386d83447bccca957788b0a6"
},
"availableToSettle": 0,
"profile": {
"firstName": "John",
"lastName": "Doe",
"email": "user.mail@skrill.com",
"phone": "1234567890"
},
"settlements": {
"amount": 100,
"txnTime": "2022-09-20T13:25:05.000+0000",
"availableToRefund": 100,
"merchantRefNum": "bcb58c35-94ba-4a60-a7d5-9d7af44be3e6",
"id": "f7a0ced2-3ac4-4eac-8a24-5c6be97fcae3",
"status": "COMPLETED"
}
}
To know more about each parameter, you can visit Payments
Standalone Credits PaymentHandle API Request
{
"merchantRefNum": "1aaaee73-d688-47c7-979f-a58265d4b782",
"transactionType": "STANDALONE_CREDIT",
"paymentType": "SKRILL1TAP",
"amount": 500,
"currencyCode": "USD",
"customerIp": "172.0.0.1",
"skrill1tap": {
"consumerId": "1234898",
"language": "EN",
"logoUrl": "http://www.paysafe.com/icon.jpg",
"recipientDescription": "Recipient Description",
"detail1Text": "Detail 1 text",
"detail1Description": "Detail 1 description",
"descriptor": "test descriptor",
"emailSubject":"Email",
"emailMessage":"Email Description"
},
"billingDetails": {
"nickName": "Home",
"street": "100 Queen",
"street2": "Unit 201",
"city": "Toronto",
"zip": "M5H 2N2",
"country": "CA"
},
"profile": {
"firstName": "pawan",
"lastName": "Kalyan",
"email" : "test@paysafe.com",
"phone": "1234567890"
},
"merchantDescriptor": {
"dynamicDescriptor": "OnlineStore",
"phone": "12345678"
},
"returnLinks": [
{
"rel": "default",
"href": "https://usgaminggamblig.com/payment/return/success"
},
{
"rel": "on_failed",
"href": "https://usgaminggamblig.com/payment/return/failed"
},
{
"rel": "on_cancelled",
"href": "https://usgaminggamblig.com/payment/return/cancel"
}
]
}
Standalone Credits PaymentHandle API Response
{
"id": "c90716af-11a9-4ee2-9383-5d9f2997b2e6",
"paymentType": "SKRILL1TAP",
"paymentHandleToken": "PHAYfKXAhADsD6AS",
"merchantRefNum": "782b1a62-f3a1-4a62-9956-29662d58ddbf",
"currencyCode": "USD",
"txnTime": "2022-09-20T12:52:59Z",
"billingDetails": {
"street": "100 Queen",
"street2": "Unit 201",
"city": "Toronto",
"zip": "M5H 2N2",
"country": "CA"
},
"customerIp": "172.0.0.1",
"status": "PAYABLE",
"liveMode": false,
"usage": "SINGLE_USE",
"action": "NONE",
"executionMode": "SYNCHRONOUS",
"amount": 500,
"merchantDescriptor": {
"dynamicDescriptor": "OnlineStore",
"phone": "12345678"
},
"timeToLiveSeconds": 899,
"gatewayResponse": {
"processor": "SKRILL_QCO"
},
"returnLinks": [
{
"rel": "on_cancelled",
"href": "https://usgaminggamblig.com/payment/return/cancel"
},
{
"rel": "default",
"href": "https://usgaminggamblig.com/payment/return/success"
},
{
"rel": "on_failed",
"href": "https://usgaminggamblig.com/payment/return/failed"
}
],
"transactionType": "STANDALONE_CREDIT",
"gatewayReconciliationId": "3dc3693f-c733-4c28-be6c-51b34bdd822e",
"updatedTime": "2022-09-20T12:52:59Z",
"statusTime": "2022-09-20T12:52:59Z",
"skrill1tap": {
"consumerId": "1234898",
"emailSubject": "Email",
"emailMessage": "Email Description"
},
"profile": {
"firstName": "pawan",
"lastName": "Kalyan",
"email": "test@paysafe.com",
"phone": "1234567890"
}
}
Standalone Credits API Request
{
"merchantRefNum": "e10abc4d4be42ba19cf0",
"amount": "3000",
"currencyCode": "USD",
"dupCheck": true,
"settleWithAuth": true,
"paymentHandleToken": "PH9pFHcgzpdqZLQB",
"customerIp": "172.0.0.1",
"description": "Magazine subscription"
}
Standalone Credits API Response
{
"id": "a3e71149-d04d-47ac-adb0-3fcac10615d0",
"paymentType": "SKRILL1TAP",
"paymentHandleToken": "PHAYfKXAhADsD6AS",
"merchantRefNum": "782b1a62-f3a1-4a62-9956-29662d58ddbf",
"currencyCode": "USD",
"dupCheck": true,
"txnTime": "2022-09-20T12:53:09Z",
"billingDetails": {
"street1": "100 Queen",
"street2": "Unit 201",
"city": "Toronto",
"zip": "M5H 2N2",
"country": "CA"
},
"customerIp": "204.91.0.12",
"status": "PENDING",
"gatewayReconciliationId": "AEAAAAE4PM",
"amount": 500,
"returnLinks": [
{
"rel": "on_cancelled",
"href": "https://usgaminggamblig.com/payment/return/cancel"
},
{
"rel": "default",
"href": "https://usgaminggamblig.com/payment/return/success"
},
{
"rel": "on_failed",
"href": "https://usgaminggamblig.com/payment/return/failed"
}
],
"liveMode": false,
"updatedTime": "2022-09-20T12:53:10Z",
"statusTime": "2022-09-20T12:53:10Z",
"gatewayResponse": {
"status_msg": "scheduled",
"id": "-1165087146",
"processor": "SKRILL_QCO",
"sid": "5ffc4a6603354619abfa5e0a8d9b60de",
"status": "1"
},
"profile": {
"firstName": "pawan",
"lastName": "Kalyan",
"email": "test@paysafe.com",
"phone": "1234567890"
}
}
Refunds
Refunds API Request
POST:paymenthub/v1/settlements/{paymentId}/refunds
{
"merchantRefNum": "db1c255c-3081-4e04-8838-fe1ab2545445",
"amount": 2500,
"dupCheck": true
}
Refund API Response
{
"id": "8df5d060-259c-4486-9ae7-4c47771dcbcf",
"paymentType": "SKRILL1TAP",
"merchantRefNum": "032876a3-b389-4225-9271-3301134fc8a71",
"currencyCode": "USD",
"txnTime": "2022-09-20T12:53:59Z",
"status": "COMPLETED",
"gatewayReconciliationId": "4423418578",
"amount": 50,
"updatedTime": "2022-09-20T12:54:00Z",
"statusTime": "2022-09-20T12:54:00Z",
"liveMode": false,
"simulator": "EXTERNAL",
"gatewayResponse": {
"id": "4423418578",
"status": "2",
"merchant_id": "48091998",
"processor": "SKRILL_QCO"
},
"source": "SingleAPI"
}
Appendix
Payment Handle
- PAYMENT_HANDLE_PAYABLE - This webhook signifies that the Payment Handle token created for the required purpose can now be executed and the preliminary requirements are completed, and the next API call with the payment handle can be done.
- PAYMENT_HANDLE_PROCESSING - This webhook is triggered when the user is successfully redirected to the Payment Platform page and operation has started for the payment by the user.
- PAYMENT_HANDLE_COMPLETED - This webhook is triggered when the process of the payment handle token is completed after triggering the next API i.e. Payments or Standalone Credit API.
- PAYMENT_HANDLE_EXPIRED - This webhook is triggered when the next step is not initiated after the payment handle is created within the given time frame, the duration can be seen in the response to/paymenthub/v1/paymenthandles API under the tag timeToLiveSeconds.
- PAYMENT_HANDLE_FAILED
Payments
- PAYMENT_PROCESSING: The payment is in progress. In some cases, there might be delays due to an action pending by the customer or the merchant.
- PAYMENT_COMPLETED/SETTLEMENT_COMPLETED - The payment was completed successfully.
- PAYMENT_FAILED - This webhook is triggered when the Payment fails during the process.
Standalone Credits/Withdrawal
- SA_CREDIT_FAILED - This webhook is triggered in case the transaction was initially completed and later failed due to some settlement error.
- SA_CREDIT_CANCELLED - This webhook is triggered when the transaction was canceled after it was completed
- SA_CREDIT_ERRORED - This webhook is used when there is a technical error during the initiation of a transaction.
- SA_CREDIT_PENDING - This webhook is triggered when the withdrawal has been initiated but due to any delays in the processing, the actual money transfer has not happened immediately.
Refunds
- REFUND_FAILED - This webhook is triggered when the refund is initiated but failed due to a functional error for e.g. Refund amount is more than the Payment amount.
- REFUND_COMPLETED - This webhook is triggered when the refund has been successfully transferred from the merchant account to the user's account
- REFUND_PENDING - This webhook is triggered when the withdrawal has been initiated but due to any delays in the processing, the actual money transfer has not happened immediately.
Error Codes of Skrill 1-Tap
Error | Description |
---|---|
SESSION_EXPIRED | Session has expired. Session IDs are only valid for 15 minutes |
CUSTOMER_IS_LOCKED | The customer's account is locked for outgoing payments |
BALANCE_NOT_ENOUGH | The customer's account balance is insufficient |
RECIPIENT_LIMIT_EXCEEDED | The customer's account limits are not sufficient |
CARD_FAILED | The customer's credit or debit card failed |
REQUEST_FAILED | Generic response for transaction failing for any other reason |
ONDEMAND_CANCELLED | The customer has cancelled this Skrill 1-Tap payment |
ONDEMAND_INVALID | The Skrill 1-Tap payment requested does not exist |
MAX_REQ_REACHED | Too many failed Skrill 1-Tap payment requests to the API. For security reasons, only two failed attempts per user per 24 hours are allowed |
MAX_AMOUNT_REACHED | The payment amount is greater than the maximum amount configured when 1-Tap payments were setup for this user. |
INVALID_OR_MISSING_ACTION | Wrong action or no action is provided |
LOGIN_INVALID | Email address and/or password were not provided |
INVALID_REC_PAYMENT_ID | Invalid recurring payment ID is submitted by the merchant |
MISSING_EMAIL | Provide registered email address of merchant account |
MISSING_PASSWORD | Provide correct API/MQI password |
MISSING_AMOUNT | Provide amount you wish to send |
MISSING_CURRENCY | Provide currency you wish to send |
MISSING_BNF_EMAIL | Provide email address of the beneficiary |
MISSING_SUBJECT | Provide subject of the payment |
MISSING_NOTE | Provide notes for the payment |
Unauthorised/ Cannot log in | Authentication is required and has failed or has not yet been provided. |
Payment Required | Reserved for future use. |
Forbidden | The request was a valid request, but the server is refusing to respond to it. For example, the provided credentials were successfully authenticated but do not grant the client permission to access the resource. |
Not Found | The requested resource could not be found. |
Method not Allowed | A request was made of a resource using a request method not supported. For example, using GET on a method which requires data to be presented via POST. |
The table below contains all possible values of the ‘failed_reason_code’ parameter and their corresponding meanings. Failed reason codes are mappings of the codes Skrill receives from external processors and any failures due to internal procedures.
Error Codes of Skrill 1-Tap
Code | Description |
---|---|
1 | Referred by Card Issuer |
2 | Invalid Merchant |
3 | Pick up Card |
4 | Declined by Card Issuer |
5 | Insufficient funds |
6 | Transaction failed |
7 | Incorrect PIN |
8 | PIN tries exceed - card blocked |
9 | Invalid Transaction |
10 | Transaction frequency limit exceeded |
11 | Invalid Amount/ Amount too high /Limit Exceeded |
12 | Invalid credit card or bank account |
13 | Invalid Card Issuer |
15 | Duplicate transaction |
19 | Retry transaction |
24 | Card expired |
27 | Requested function not available |
28 | Lost/Stolen card |
30 | Format Failure |
32 | Card Security Code (CVV2/CVC2) Check Failed |
34 | Illegal Transaction |
37 | Card restricted by Card Issuer |
38 | Security Violation |
42 | Card blocked by Card Issuer |
44 | Card Issuing Bank or Network is not available |
45 | Processing error - card type is not processed by the authorization centre |
51 | System error |
58 | Transaction not permitted by acquirer |
63 | Transaction not permitted to cardholder |
67 | BitPay session expired |
70 | Customer failed 3DS verification |
80 | Fraud rules declined |
98 | Error in communication with provider |
99 | Other |