Integrate BLIK using the Orders API
Last updated: Feb 17th, 10:40pm
Render payment buttons and process payments with the Orders API.
Know before you code
- Request approval to enable BLIK by visiting the following sandbox and live links:
- Sandbox: https://www.sandbox.paypal.com/bizsignup/entry?product=blik&capabilities=BLIK&country.x=<merchant's country>
- Live: https://www.paypal.com/bizsignup/add-product?product=blik&capabilities=BLIK&country.x=<merchant's country>
- Partners: Be sure to onboard your merchants upfront, before they accept payments. Onboarding after making payments, specifically Progressive Onboarding, isn't supported for alternative payment methods.
Note: The integration steps for implementing alternative payment methods are similar. If you've integrated another alternative payment method before, you can likely reuse that code with adjustments for this payment method.
- Make sure you're subscribed to the following webhook events:
PAYMENT.CAPTURE.COMPLETED
- Listen for this webhook to get notified about a successful order capture.PAYMENT.CAPTURE.DENIED
- This webhook tells you when an order capture fails.
- Make sure your preference for receiving payments in your PayPal business account or merchant account is set to accept and convert to the currency in your account. In your profile, select Account Settings > Payment preferences > Block payments and click Update to mark this preference.
- When processing BLIK payments, you don't need to capture payment for the order.
Offer BLIK on the checkout page
You'll need to create the user interface to offer BLIK and collect the buyer's information, then you'll use the API calls described in the remainder of this topic to:
- Create the order with the buyer’s
full_name
,country_code
, and BLIK as the payment source. - Redirect the buyer to BLIK
Refer to Payment method icons for icons you can use and download locations.
Create an order
Use the buyer information you captured from your user interface to create an order with BLIK as the payment source.
API endpoint used: Create order
- Sample request
- Sample response
1curl -v -X POST https://api-m.sandbox.paypal.com/v2/checkout/orders \2-H "PayPal-Request-Id: <PayPal-RequestId>" \3-H "Content-Type: application/json" \4-H "Authorization: Bearer <Access-Token>" \5-d '{6 "intent": "CAPTURE",7 "payment_source": {8 "blik": {9 "country_code": "PL",10 "name": "John Doe",11 "email": "buyer@example.com"12 }13 },14 "processing_instruction": "ORDER_COMPLETE_ON_PAYMENT_APPROVAL",15 "purchase_units": [16 {17 "reference_id": "d9f80740-38f0-11e8-b467-0ed5f89f718b",18 "amount": {19 "currency_code": "PLN",20 "value": "1.00"21 }22 }23 ],24 "application_context": {25 "locale": "en-PL",26 "return_url": "https://example.com/returnUrl",27 "cancel_url": "https://example.com/cancelUrl"28 }29}'
Modify the code
After you copy the code in the sample request, modify the following:
PayPal-Request-Id
- Replace the sample ID with a unique ID you generate. This ID helps prevent duplicate authorizations in the event that the API call is disrupted. See also: API idempotencyintent
- To use an alternative payment method, this parameter must be set toCAPTURE
as it is in this sample code.processing_instruction
- Set this value toORDER_COMPLETE_ON_PAYMENT_APPROVAL
as it is in this sample code.purchase_units: amount
- Pass the amount of the order and the currency code.payment_source
- SpecifyBLIK
as the payment method and include the country code and account holder's full name. You can optionally include the buyer's email address.application_context
- Specify the preferred language for returned errors, the URL the buyer is returned to after approving the purchase with their selected payment method, and the URL the buyer is returned to after canceling an approval with their selected payment method. Whilereturn_url
andcancel_url
are optional fields, this integration requires you specify them to handle the handoff from the payment method back to your site. You can use thecancel_url
to redirect buyers when an error occurs while they're on the payment method's site, so make sure your cancel URL works for that situation as well as an actual cancellation by the buyer.
Note: Change or add other parameters in the Create order request body to create an order that reflects the actual order details.
Step result
A successful request results in the following:
- A return status code of HTTP
200 OK
. - A JSON response body that contains the order ID. You'll use the order ID and
payer-action
HATEOAS URL in the next step. See also: HATEOAS links.
Redirect buyer for purchase approval
In your user interface, attach the payer-action
redirect URL returned in the Create Order
response to the BLIK payment button. This sends the buyer to their bank to approve the purchase. Once the buyer approves the purchase, the payment is automatically captured.
In the sample, the redirect URL is: "https://sandbox.paypal.com/payment/blik?token=7S180378AE2002441"
.
Step result
After successfully completing the bank approval:
- The buyer is redirected to the
return_url
mentioned in the Create Order request. - The
PAYMENT.CAPTURE.COMPLETED
webhook event is triggered, which indicates that payment capture was successful.
After unsuccessful bank approval:
- The buyer is redirected to the
cancel_url
mentioned in the Create Order request.
Listen to webhooks for payment status
Listen to the following webhooks to get the result of order capture:
- The
PAYMENT.CAPTURE.COMPLETED
webhook event indicates a successful order capture. - The
PAYMENT.CAPTURE.DENIED
webhook events indicate a failed order capture. - Optional: Use Show order details endpoint to determine the status of an order.
- The
up
HATEOAS link indicates the order associated with this capture.
- The
See Subscribe to checkout webhooks for more information.
Here are some additional resources as you create webhook handler code:
- Webhook Management API - Manage webhooks, list event notifications, and more.
- Webhook events
- Checkout webhook events - Checkout buyer approval-related webhooks.
- Order webhook events - Other order-related webhooks.
- Show order details endpoint - Determine the status of an order.
Sample webhook payloads
- Sample PAYMENT.CAPTURE.COMPLETED webhook
- Sample PAYMENT.CAPTURE.DENIED webhook
- Sample CHECKOUT.ORDER.DECLINED webhook
1{2 "id": "WH-2B342482FC0449155-12X09416XP387753C",3 "event_version": "1.0",4 "zts": 1481046241,5 "create_time": "2022-04-05T10:37:05Z",6 "resource_type": "capture",7 "resource_version": "2.0",8 "event_type": "PAYMENT.CAPTURE.COMPLETED",9 "summary": "Payment completed for PLN 1.00 PLN",10 "resource": {11 "amount": {12 "currency_code": "PLN",13 "value": "1.00"14 },15 "create_time": "2022-04-05T10:37:05Z",16 "update_time": "2022-04-05T10:37:05Z",17 "final_capture": true,18 "seller_receivable_breakdown": {19 "paypal_fee": {20 "value": "0.20",21 "currency_code": "PLN"22 },23 "gross_amount": {24 "value": "1.00",25 "currency_code": "PLN"26 },27 "net_amount": {28 "value": "0.80",29 "currency_code": "PLN"30 }31 },32 "links": [33 {34 "method": "GET",35 "rel": "self",36 "href": "https://api-m.sandbox.paypal.com/v2/payments/captures/8SS60826HT082593F"37 },38 {39 "method": "POST",40 "rel": "refund",41 "href": "https://api-m.sandbox.paypal.com/v2/payments/captures/8SS60826HT082593F/refund"42 },43 {44 "method": "GET",45 "rel": "up",46 "href": "https://api-m.sandbox.paypal.com/v2/checkout/orders/7S180378AE2002441"47 }48 ],49 "id": "8SS60826HT082593F",50 "status": "COMPLETED"51 },52 "links": [53 {54 "href": "https://api-m.sandbox.paypal.com/v1/notifications/webhooks-events/WH-2B342482FC0449155-12X09416XP387753C",55 "rel": "self",56 "method": "GET"57 },58 {59 "href": "https://api-m.sandbox.paypal.com/v1/notifications/webhooks-events/WH-2B342482FC0449155-12X09416XP387753C/resend",60 "rel": "resend",61 "method": "POST"62 }63 ]64}
- order ID from Step 2 should match
resource.supplementary_data.related_ids.order_id
parameter in the webhook payload ofPAYMENT.CAPTURE.COMPLETED
andPAYMENT.CAPTURE.DENIED
. - When an order is declined, the
CHECKOUT.ORDER.DECLINED
webhook passes the error code and message in themost_recent_error
parameter of thepurchase_unit
object.
Alternatively, you can get the order capture result from the Show order details endpoint.
Important: Exercise caution when polling for order capture result using the Show order details endpoint. PayPal enforces rate limits on API requests.
- Sample request
- Sample response
1curl -v -X GET https://api-m.sandbox.paypal.com/v2/checkout/orders/7S180378AE2002441 \2-H "Content-Type: application/json" \3-H "Authorization: Bearer <Access-Token>"
Step result
A successful request returns the HTTP 200 OK
status code with a JSON response body that returns a COMPLETED
status.
A successfully captured order has the following:
- The order status as
COMPLETED
, which means the order was captured successfully. - A capture with
COMPLETED
status is present in the response parameterpurchase_units[0].payments.captures[0]
. - The
up
HATEOAS link indicates the order associated with this capture.
Notify buyer of success
After a successful payment, notify the buyer of a successful transaction. You can do this by sending a confirmation email.