Delay disbursement

DocsCurrent

Last updated: Oct 30th, 1:39pm

Use this integration to hold funds from a buyer before disbursing it to your seller. Holding funds gives you time to conduct additional vetting. If you want to capture funds immediately, use Immediate capture.

Delayed disbursement supports:

  • Authorization: Set intent to authorize in the create order call to authorize a payment and place funds on hold after the customer makes a payment.
  • Capture: Set intent to capture create order call to capture payment immediately after the customer makes a payment.

Know before you code

To use this integration you must:

  • Contact us to be an approved partner.
  • Onboard merchants with the DELAY_FUNDS_DISBURSEMENT feature in the developer dashboard before you use this integration.
  • Inform your merchants of PayPal's Seller Protection policy, so they are aware of use cases that invalidate that protection, such as shipping to an address other than the one in the transaction confirmation.
1

Generate PayPal-Auth-Assertion header

You’ll need to Pass the PayPal-Auth-Assertion header with the standard Content-Type, Authorization, and PayPal-Request-ID headers. In client-side JavaScript, the value of the PayPal-Auth-Assertion header can be generated as follows:

    1// client-side JavaScript
    2
    3
    4function encodeObjectToBase64(object) {
    5 const objectString = JSON.stringify(object);
    6 return window.btoa(objectString);
    7}
    8
    9
    10const clientId = "CLIENT-ID";
    11const sellerPayerId = "SELLER-PAYER-ID"; // preferred
    12// const sellerEmail = "SELLER-ACCOUNT-EMAIL"; // use instead of payer-id if required
    13
    14
    15const header = {
    16 alg: "none"
    17};
    18const encodedHeader = encodeObjectToBase64(header);
    19
    20
    21const payload = {
    22 iss: clientId,
    23 payer_id: sellerPayerId
    24 // email: sellerEmail
    25};
    26const encodedPayload = encodeObjectToBase64(payload);
    27
    28
    29const jwt = `${encodedHeader}.${encodedPayload}.`; // json web token
    30console.log(`Paypal-Auth-Assertion=${jwt}`);

    Modify the code

    • Use the client ID of the platform or marketplace from the PayPal Developer dashboard for clientId.
    • In the given example, the sellerPayerId is the payer ID of the receiving seller's PayPal account. You can also use email instead of payer_id and supply the email address of the seller's PayPal account.

    Example functions to generate the PayPal-Auth-Assertion header in other programming environments:

    Node.js

      1// Node.js
      2
      3
      4function encodeObjectToBase64(object) {
      5 const objectString = JSON.stringify(object);
      6 return Buffer
      7 .from(objectString)
      8 .toString("base64");
      9}
      10
      11
      12const clientId = "CLIENT-ID";
      13const sellerPayerId = "SELLER-PAYER-ID"; // preferred
      14// const sellerEmail = "SELLER-ACCOUNT-EMAIL"; // use instead if payer-id unknown
      15
      16
      17const header = {
      18 alg: "none"
      19};
      20const encodedHeader = encodeObjectToBase64(header);
      21
      22
      23const payload = {
      24 iss: clientId,
      25 payer_id: sellerPayerId
      26 // email: sellerEmail
      27};
      28const encodedPayload = encodeObjectToBase64(payload);
      29
      30
      31const jwt = `${encodedHeader}.${encodedPayload}.`; // json web token
      32console.log(`Paypal-Auth-Assertion=${jwt}`);

      Java

        1// Java
        2
        3
        4import org.apache.commons.codec.binary.Base64;
        5
        6
        7public class Base64Encode {
        8
        9
        10 public static void main(String[] args) {
        11 String clientId = "CLIENT-ID";
        12 String sellerPayerId = "SELLER-PAYER-ID"; // preferred
        13 // String sellerEmail = "SELLER-ACCOUNT-EMAIL"; // use instead if payer-id unknown
        14
        15
        16 String header = "{\"alg\":\"none\"}";
        17 String payload =
        18 "{\"iss\":\"" + clientId + "\",\"payer_id\":\"" + sellerPayerId + "\"}";
        19 // "{"iss":"" + clientId + "","email":"" + sellerEmail + ""}";
        20
        21
        22 byte[] encodedHeader = Base64.encodeBase64(header.getBytes());
        23 byte[] encodedPayload = Base64.encodeBase64(payload.getBytes());
        24
        25
        26 String jwt = new String(encodedHeader) +
        27 "." +
        28 new String(encodedPayload) +
        29 "."; // json web token
        30 System.out.println("Paypal-Auth-Assertion=" + jwt);
        31 }
        32}
        2

        Create Order

        You must first create an order and capture funds. To create an order, copy the following code and modify as follows:

        • Replace BN-CODE with your PayPal attribution ID.
        • Replace PAYPAL-AUTH-ASSERTION with your PayPal auth assertion generated from Step 1.
        • Use the purchase_units/payee object to specify the end receiver of the funds.
        • Use the purchase_units/payment_instruction/disbursement_mode field to specify when funds should be disbursed to the payee upon calling capture order. In this integration, set this field to DELAYED.
        • Use the purchase_units/payment_instruction/platform_fees array to specify fees for the order. To use this array, ensure that the merchants are onboarded with the Platform Fee feature enabled for your app. On the app settings page of your app, you can configure specific features. To configure your app to include PARTNER_FEE, from the developer dashboard, navigate to your app settings page and toggle Platform Fee to select the feature.

        Sample request - cURL

          1curl -v -XPOSThttps://api-m.sandbox.paypal.com/v2/checkout/orders
          2-H'Content-Type: application/json'
          3-H'Authorization: Bearer ACCESS-TOKEN'
          4-H'PayPal-Partner-Attribution-Id: BN-CODE'
          5-H'PayPal-Auth-Assertion: PAYPAL-AUTH-ASSERTION'
          6-d '{
          7"intent":"CAPTURE",
          8"purchase_units":[{
          9"amount":{
          10"currency_code":"USD",
          11"value":"100.00"
          12},
          13"payee":{
          14"email_address":"seller@example.com"
          15},
          16"payment_instruction":{
          17"disbursement_mode":"DELAYED",
          18"platform_fees":[{
          19"amount":{
          20"currency_code":"USD",
          21"value":"25.00"
          22}
          23}]
          24}
          25}]
          26}'

          Sample request - Node

            1var express =require('express');
            2var request =require('request');
            3express().post('/my-server/create-order',function(req, res){
            4 request.post('https://api-m.sandbox.paypal.com/v2/checkout/orders',{
            5headers:{
            6"Content-Type":"application/json",
            7"Authorization":"Bearer ACCESS-TOKEN",
            8"PayPal-Partner-Attribution-Id":"BN-CODE",
            9"PayPal-Auth-Assertion":"PAYPAL-AUTH-ASSERTION"
            10},
            11body:{
            12"intent":"CAPTURE",
            13"purchase_units":[{
            14"amount":{
            15"currency_code":"USD",
            16"value":"100.00"
            17},
            18"payee":{
            19"email_address":"seller@example.com"
            20},
            21"payment_instruction":{
            22"disbursement_mode":"DELAYED",
            23"platform_fees":[{
            24"amount":{
            25"currency_code":"USD",
            26"value":"25.00"
            27}
            28}]
            29}
            30}],
            31},
            32json:true
            33},function(err, response, body){
            34if(err){
            35console.error(err);
            36return res.sendStatus(500);
            37}
            38 res.json({
            39id: body.id
            40});
            41});
            42});
            3

            Capture Order

            After your buyer approves the order, call capture order to capture the buyer’s funds.

            Copy the following code and modify as follows:

            • Replace ACCESS-TOKEN with your access token.
            • Replace BN-CODE with your PayPal partner attribution ID.
            • Replace PAYPAL-AUTH-ASSERTION with your PayPal auth assertion generated from Step 1.

            Sample request - cURL

              1curl -v -k -X POST https://api-m.paypal.com/v2/checkout/orders/5O190127TN364715T/capture
              2-H 'Content-Type: application/json'
              3-H 'Authorization: Bearer ACCESS-TOKEN'
              4-H 'PayPal-Partner-Attribution-Id: BN-CODE'
              5-H 'PayPal-Auth-Assertion: PAYPAL-AUTH-ASSERTION'
              6-d '{}'

              Sample request - Node

                1var express = require('express');
                2var request = require('request');
                3express().post('/my-server/handle-approve/:id', function(req, res) {
                4 var OrderID = req.params.id;
                5 request.post('https://api-m.sandbox.paypal.com/v2/checkout/orders/' + OrderID + '/capture', {
                6 headers: {
                7 "Content-Type": "application/json",
                8 "Authorization": "Bearer ACCESS-TOKEN",
                9 "PayPal-Partner-Attribution-Id": "BN-CODE",
                10 "PayPal-Auth-Assertion": "PAYPAL-AUTH-ASSERTION"
                11 }
                12 }, function(err, response, body) {
                13 if (err) {
                14 console.error(err);
                15 return res.sendStatus(500);
                16 }
                17 res.json({
                18 status: 'success'
                19 });
                20 });
                21});
                4

                Show order details

                To see your order details, pass the order ID as a path parameter in a show order details call.

                Copy the following code and modify as follows:

                • Replace ACCESS-TOKEN with your access token.
                • Replace BN-CODE with your PayPal partner attribution ID.
                • Replace PAYPAL-AUTH-ASSERTION with your PayPal auth assertion generated from Step 1.

                Sample request - cURL

                  1curl -v -X GET https://api-m.sandbox.paypal.com/v2/checkout/orders/5O190127TN364715T
                  2-H "Content-Type: application/json"
                  3-H 'Authorization: Bearer ACCESS-TOKEN'
                  4-H 'PayPal-Partner-Attribution-Id: BN-CODE'
                  5-H 'PayPal-Auth-Assertion: PAYPAL-AUTH-ASSERTION'

                  Sample request - Node

                    1var http = require("https");
                    2var options = {
                    3 "method": "GET",
                    4 "hostname": "api-m.sandbox.paypal.com",
                    5 "port": null,
                    6 "path": "/v2/checkout/orders/5O190127TN364715T",
                    7 "headers": {
                    8 "Content-Type": "application/json",
                    9 "Authorization": "Bearer ACCESS-TOKEN",
                    10 "PayPal-Partner-Attribution-Id": "BN-CODE",
                    11 "PayPal-Auth-Assertion": "PAYPAL-AUTH-ASSERTION"
                    12 }
                    13};
                    14var req = http.request(options, function(res) {
                    15 var chunks = [];
                    16 res.on("data", function(chunk) {
                    17 chunks.push(chunk);
                    18 });
                    19 res.on("end", function() {
                    20 var body = Buffer.concat(chunks);
                    21 console.log(body.toString());
                    22 });
                    23});
                    24req.end();

                    A successful request returns the HTTP 200 OK status code and a JSON response body that shows order details.

                      1{
                      2 "id": "5O190127TN364715T",
                      3 "status": "CREATED",
                      4 "intent": "CAPTURE",
                      5 "purchase_units": [
                      6 {
                      7 "reference_id": "d9f80740-38f0-11e8-b467-0ed5f89f718b",
                      8 "amount": {
                      9 "currency_code": "USD",
                      10 "value": "100.00"
                      11 }
                      12 }
                      13 ],
                      14 "create_time": "2018-04-01T21:18:49Z",
                      15 "links": [
                      16 {
                      17 "href": "https://api-m.paypal.com/v2/checkout/orders/5O190127TN364715T",
                      18 "rel": "self",
                      19 "method": "GET"
                      20 },
                      21 {
                      22 "href": "https://www.paypal.com/checkoutnow?token=5O190127TN364715T",
                      23 "rel": "approve",
                      24 "method": "GET"
                      25 },
                      26 {
                      27 "href": "https://api-m.paypal.com/v2/checkout/orders/5O190127TN364715T/capture",
                      28 "rel": "capture",
                      29 "method": "POST"
                      30 }
                      31 ]
                      32}
                      5

                      Disburse funds

                      Once funds are captured, call /v1/payments/referenced-payouts-items to disburse funds to your seller. To make this call you must pass a reference_id. Retrieve the reference_id by making a show order details call and note down the urchase_units/payments/captures/id field.

                      Copy the following code and modify as follows:

                      Sample request - cURL

                        1curl -v https://api-m.sandbox.paypal.com/v1/payments/referenced-payouts-items
                        2-XPOST
                        3-H"Content-Type: application/json"
                        4-H"Authorization: Bearer ACCESS-TOKEN"
                        5-H"PayPal-Partner-Attribution-Id: BN-CODE"
                        6-d '{
                        7"reference_id":"29N36144XH0198422",
                        8"reference_type":"TRANSACTION_ID"
                        9}'

                        Sample request - Node

                          1var http =require("https");
                          2var options ={
                          3"method":"GET",
                          4"hostname":"api-m.sandbox.paypal.com",
                          5"port":null,
                          6"path":"/v2/checkout/orders/5O190127TN364715T",
                          7"headers":{
                          8"content-type":"application/json",
                          9"Authorization":"Bearer ACCESS-TOKEN",
                          10}
                          11};
                          12var req = http.request(options,
                          13function(res){
                          14var chunks =[];
                          15 res.on("data ",function(chunk){
                          16 chunks.push(chunk);
                          17});
                          18 res.on("end ",function(){
                          19var body =Buffer.concat(chunks);
                          20console.log(body.toString());
                          21})
                          22;});
                          23req.end();

                          A successful request returns the HTTP 200 OK status code and a JSON response body that shows order details.

                          Next steps

                          Integration Checklist

                          Go through the integration checklist before you go live.

                          We use cookies to improve your experience on our site. May we use marketing cookies to show you personalized ads? Manage all cookies