Skip to the content.

<- Regresar a la documentación

6.1. Generar intención de pago (Botón de pago).

Este método permite crear una intención de pago mediante un botón de pago y enviársela a un cliente.

Importante: En el parámetro “paymentintent[intent]” debe enviar el valor “sale”.

URL: api/payment-intent/.json

Método HTTP: POST

Documentación completa de la API: Ir a la documentación

Datos mínimos a enviar:

{
    "paymentintent": {
        "intent": "sale",
        "redirectUrls": {
            "returnUrl": "http://localhost:5000/payments/ExecutePayment.php?success=true&carId=200",
            "cancelUrl": "http://localhost:5000/payments/ExecutePayment.php?success=false&carId=200"
        },
        "transactions": {
            "0": {
                "amount": {
                    "total": "20"
                },
                "description": "Compra por eBay",
                "items": {
                    "0": {
                        "name": "telefono",
                        "price": "7.5"
                    }
                }
            }
        }
    }
}

Ejemplo de petición:

curl -X POST \
  https://test.mpandco.com/api/payment-intent/.json \
  -H 'authorization: Bearer OAUTH-TOKEN' \
 -F 'paymentintent[intent]=sale' \
 -F 'paymentintent[redirectUrls][returnUrl]=http://localhost:5000/payments/ExecutePayment.php?success=true&carId=200' \
 -F 'paymentintent[redirectUrls][cancelUrl]=http://localhost:5000/payments/ExecutePayment.php?success=false&carId=200' \
  -F 'paymentintent[transactions][0][digitalAccountDestination]=demo01' \
  -F 'paymentintent[transactions][0][amount][total]=20' \
  -F 'paymentintent[transactions][0][amount][currency]=VES' \
  -F 'paymentintent[transactions][0][amount][details][shipping]=0' \
  -F 'paymentintent[transactions][0][amount][details][tax]=1.3' \
  -F 'paymentintent[transactions][0][amount][details][subTotal]=17.50' \
  -F 'paymentintent[transactions][0][description]=Compra por eBay' \
  -F 'paymentintent[transactions][0][invoiceNumber]=F00015' \
  -F 'paymentintent[transactions][0][items][0][name]=telefono' \
  -F 'paymentintent[transactions][0][items][0][quantity]=1' \
  -F 'paymentintent[transactions][0][items][0][sku]=P001' \
  -F 'paymentintent[transactions][0][items][0][price]=7.5' \
  -F 'paymentintent[transactions][0][items][0][currency]=VES'

Respuesta:

200 - Correcto. Retorna JSON de tipo ‘PaymentIntent’

Ejemplo de respuesta (200):

{
  "id":"03b9f66c-fefb-11e8-a647-b62cbc289574",
  "intent":"sale",
  "state":"created",
  "redirect_urls":{
  "return_url":"http:\/\/localhost\/payments\/ExecutePayment.php?success=true&carId=200",
  "cancel_url":"http:\/\/localhost\/payments\/ExecutePayment.php?success=false&carId=200",
  "history_responses":[
  ]
},
  "total":{
     "currency":{
        "id":"VES"
      },
      "items":17.5,
      "shipping":0,
      "tax":1.3,
      "amount":18.8
  },
   "transactions":[
      {
         "id":"03bb1538-fefb-11e8-a647-b62cbc289574",
         "amount":{
            "currency":{
               "id":"VES"
            },
            "total":20,
            "details":{
               "shipping":0,
               "tax":1.3,
               "sub_total":17.5
            }
         },
         "items":[
            {
              "name":"telefono",
              "quantity":1,
              "currency":{
                "id":"VES"
               },
               "sku":"P001",
               "price":7.5
            }
         ],
         "description":"Compra por eBay",
         "invoice_number":"F00015"
      }
   ],
   "pay_tokens":[

   ],
   "_links":{
      "self":{
      "href":"http://test.mpandco.com/api/payment-intent/show?id=03b9f66c-fefb-11e8-a647-b62cbc289574",
        "method":"GET"
     },
     "execute":{
      "href":"http://test.mpandco.com/api/payment-intent/execute/sale.json?id=03b9f66c-fefb-11e8-a647-b62cbc289574",
       "method":"POST"
       },
       "approval_url":{
       "href":"http://test.mpandco.com/p/express-checkout/03b9f66c-fefb-11e8-a647-b62cbc289574/1",
      "method":"GET"
      }
   }
}

Al abrir “approval_url” el cliente deberá ingresar con sus credenciales y autorizar el pago:

image018.png

image020.png

6.1.1 Generar intención de pago y distribuir fondos (Botón de pago).

Puede generar una intención de pago y especificar cuentas donde desee distribuir el monto recibido, para esto debe especificarlas en el campo “distributions” (ver el ejemplo), una vez ejecute la intención de pago, automaticamente se distribuye el monto.

Importante Las cuentas electrónicas para la distribución deben ser autorizadas previamente en su aplicación.

Ejemplo de data con distribución:

{
    "paymentintent": {
        "intent": "sale",
        "redirectUrls": {
            "returnUrl": "http://localhost:5000/payments/ExecutePayment.php?success=true&carId=200",
            "cancelUrl": "http://localhost:5000/payments/ExecutePayment.php?success=false&carId=200"
        },
        "transactions": {
            "0": {
                "digitalAccountDestination": "demo05",
                "amount": {
                    "total": "100"
                },
                "description": "Compra por Amazon",
                "invoiceNumber": "F00015",
                "items": {
                    "0": {
                        "name": "telefono",
                        "price": "7.5"
                    }
                },
                "distributions": [
                    {
                        "digitalAccountDestination": "pizzaexpress",
                        "amount": "30",
                        "description": "Comision del TV"
                    }
                ]
            }
        }
    }
}

6.2. Ejecutar intención de pago (Botón de pago).

Ejecuta una intención de pago de tipo “sale” autorizada por un cliente y abona el dinero al comercio.

URL: api/payment-intent/execute/sale.json

Método HTTP: POST

Documentación completa de la API: Ir a la documentación

Ejemplo de petición:

curl -X POST \
  'https://test.mpandco.com/api/payment-intent/execute/sale.json?id=03b9f66c-fefb-11e8-a647-b62cbc289574' \
  -H 'authorization: Bearer OAUTH-TOKEN' \
  -F 'payment_execution[paymentIntent]=03b9f66c-fefb-11e8-a647-b62cbc289574' \
  -F 'payment_execution[payer]=70be5130-fef7-11e8-a647-b62cbc289574'

Respuesta:

200 - Correcto. Retorna JSON de tipo ‘PaymentIntent’

Ejemplo de respuesta (200):

{
   "id":"177e0446-feff-11e8-a647-b62cbc289574",
   "payer":{
      "payer_info":{
         "id":"104dfa28-feff-11e8-a647-b62cbc289574",
         "_data":{
            "fullname":"584125550001"
         }
      }
   },
   "intent":"sale",
   "state":"executed",
   "redirect_urls":{
"return_url":"http://test.mpandco.com/bc38875a09308af/callback-API?success=true&car=231",
"cancel_url":"http://test.mpandco.com/bc38875a09308af/callback-API?success=false&car=231",
       "history_responses":[

     ]
   },
   "total":{
      "currency":{
         "id":"VES"
      },
      "items":17.5,
      "shipping":1.2,
      "tax":1.3,
      "amount":20
   },
   "transactions":[
      {
         "id":"177f2286-feff-11e8-a647-b62cbc289574",
         "amount":{  
            "currency":{
                 "id":"VES"
            },
            "total":2000,
            "details":{
               "shipping":1.2,
               "tax":1.3,
               "sub_total":17.5
            }
         },
         "items":[
             {
               "name":"televiso 65'",
               "quantity":1,
               "currency":{
                 "id":"VES"
               },
               "sku":"P002",
               "price":2
            }
         ],
         "description":"Compra por eBay",
         "invoice_number":"F00015",
         "related_resources": {
                “sale”: {
                       “id”: “0368dbf8-2405-11e9-865d-5254008a2539”,
                       “ref”: “P1901293671246”
                 }
          }
     }
   ],
   "pay_tokens":[

   ],
   "_links":{
     "self":{
        "href":"http://test.mpandco.com/api/payment-intent/show?id=177e0446-feff-11e8-a647-b62cbc289574",
        "method":"GET"
      },
      "execute":{
          "href":"http://test.mpandco.com/api/payment-intent/execute/sale?id=177e0446-feff-11e8-a647-b62cbc289574",
          "method":"POST"
      },
      "approval_url":{
          "href":"http://test.mpandco.com/p/express-checkout/177e0446-feff-11e8-a647-b62cbc289574/1",
          "method":"GET"
     }
   }
}

Importante: Debe verificar que el estatus de la intención de pago en la respuesta es “executed”, el campo “related_resources.sale” tiene el pago generado por la transacción.