LaravelPayU provee una interfaz sencilla para utilizar el sdk de PayU en proyectos que tienen como base el framework Laravel.
Testeado correctamente en la version 6.14 de Laravel.
Este proyecto hace uso del sdk de Payu, pero no es un proyecto oficial de PayU.
Instalar el paquete mediante composer:
composer require toopago/payu
Luego incluir el ServiceProvider en el arreglo de providers en config/app.php
TooPago\Payu\LaravelPayUServiceProvider::class,
Publicar la configuración para incluir la informacion de la cuenta de PayU:
php artisan vendor:publish
Incluir la informacion de la cuenta y ajustes en el archivo .env ó directamente en el archivo de configuración config/payu.php
APP_ENV=local
PAYU_ON_TESTING=true
PAYU_MERCHANT_ID=your-merchant-id
PAYU_API_LOGIN=your-api-login
PAYU_API_KEY=your-api-key
PAYU_ACCOUNT_ID=your-account-id
PAYU_COUNTRY=your-country-ref: AR/BR/CO/CL/MX/PA/PE/US
PSE_REDIRECT_URL=your-pse-redirect-url
PAYU_BUYER_EMAIL="developer@toopago.io"
PAYU_PAYER_NAME="TooPago"
PAYU_PAYER_DNI=xxxxxxxx
Esta versión contiene solo una interfaz para pagos en efectivo , pagos con tarjetas de credito , pagos con tokenización y consultas. Si necesita usar pagos recurrentes o algo mas debe usar el sdk de PayU directamente.
Para consultar la disponibilidad de la plataforma se puede usar el método doPing en el controlador designado:
<?php
namespace App\Http\Controllers;
use TooPago\Payu\LaravelPayU;
class PaymentsController extends Controller
{
LaravelPayU::doPing(function($response) {
$code = $response->code;
// ... revisar el codigo de respuesta
}, function($error) {
// ... Manejo de errores PayUException
});
Permite el pago con VISA||MASTERCARD||AMEX de la siguiente manera:
En este metodo se requiere mandar un array con los datos de la tarjeta , cantidad , pais y moneda
<?php
namespace App;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use TooPago\Payu\Payments;
class MyController extends Controller
{
public function createChargeCard()
{
//PAYER_NAME: APPROVED||PENDING||REJECTED
//PAYMENT_METHOD : VISA||MASTERCARD||AMEX
//CREDIT_CARD_EXPIRATION_DATE : YYYY/MM
//INSTALLMENTS_NUMBER : 1
$sendData = [
'REFERENCE_CODE' => 'referencia_' . uniqid(),
'DESCRIPTION' => 'Deposito de $100',
'VALUE' => 100,
'BUYER_NAME' => 'Juan Lopez',
'PAYER_NAME' => 'PENDING',
'CREDIT_CARD_NUMBER' => '5491234534511478',
'CREDIT_CARD_EXPIRATION_DATE' => '2023/05',
'CREDIT_CARD_SECURITY_CODE' => '897',
'PAYMENT_METHOD' => 'MASTERCARD',
'INSTALLMENTS_NUMBER' => '1',
'CURRENCY' => 'MXN',
'COUNTRY' => 'MX',
];
$Payu = new Payments();
$Payu->CreatePaymentCash($sendData , function($response) {
//**Respuesta Exitosa pero Pendiente**
//$response->state
//$response->orderId
//$response->transactionId
//**Respuesta Exitosa**
//$response->state
//$response->orderId
//$response->transactionId
//$response->trazabilityCode
//$response->authorizationCode
}, function($error) {
//**Respuesta Erronea**
//$error->state
//$error->message
//$error->responseCode //Opcional
//$error->responseMessage //Opcional
});
}
}
Nota: Todos los campos son obligatorios. El campo PAYER_NAME debe llevar el nombre del pagador en producción , si es pruebas , puede ir cualquier estado de los de arriba
Permite el pago con OXXO||SEVEN_ELEVEN||OTHERS_CASH_MX de la siguiente manera: En este metodo se requiere mandar un array con los datos del comprador , cantidad , pais y moneda
<?php
namespace App;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use TooPago\Payu\Payments;
class MyController extends Controller
{
public function createChargeCash()
{
//PAYMENT_METHOD: OXXO||SEVEN_ELEVEN||OTHERS_CASH_MX
$sendData = [
'REFERENCE_CODE' => 'referencia_' . uniqid(),
'DESCRIPTION' => 'Deposito de $100',
'VALUE' => 100,
'PAYMENT_METHOD' => 'OXXO',
'BUYER_NAME' => 'Mi Nombre',
'PAYER_NAME' => 'Mi Nombre',
'CURRENCY' => 'MXN',
'COUNTRY' => 'MX',
];
$Payu = new Payments();
$Payu->CreatePaymentCard($sendData , function($response) {
//**Respuesta Exitosa pero Pendiente de Pago**
//$response->state
//$response->orderId
//$response->transactionId
//$response->EXPIRATION_DATE
//$response->BAR_CODE
//$response->REFERENCE
//$response->URL_PAYMENT_RECEIPT_PDF
//$response->URL_PAYMENT_RECEIPT_HTML
//$response->PAYMENT_WAY_ID
//$response->BANK_REFERENCED_CODE
}, function($error) {
//**Respuesta Erronea**
//$error->message
});
}
}
Permite tokenisar una tarjeta VISA||MASTERCARD||AMEX de la siguiente manera:
En este metodo se requiere mandar un array con los datos de la tarjeta , cantidad , pais y moneda
<?php
namespace App;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use TooPago\Payu\Payments;
class MyController extends Controller
{
public function tokenizarCard()
{
//PAYER_NAME: APPROVED||PENDING||REJECTED
//PAYMENT_METHOD : VISA||MASTERCARD||AMEX
//CREDIT_CARD_EXPIRATION_DATE : YYYY/MM
$sendData = [
'PAYER_NAME' => 'APPROVED',
'PAYER_ID' => '1518', // id del usuario
'CREDIT_CARD_NUMBER' => '5491234534511478',
'CREDIT_CARD_EXPIRATION_DATE' => '2023/05',
'PAYMENT_METHOD' => 'MASTERCARD',
];
$Payu = new Payments();
$Payu->tokenizarCard($sendData , function($response) {
//**Respuesta Exitosa**
//$response->state
//$response->creditCardTokenId
//$response->paymentMethod
//$response->maskedNumber
}, function($error) {
//**Respuesta Erronea**
//$error->message
});
}
}
Nota: Todos los campos son obligatorios. El campo PAYER_NAME debe llevar el nombre del pagador en producción , si es pruebas , puede ir cualquier estado de los de arriba
Permite tokenisar una tarjeta VISA||MASTERCARD||AMEX de la siguiente manera: En este metodo se requiere mandar un array con los datos del usuario , token , cantidad , pais y moneda
<?php
namespace App;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use TooPago\Payu\Payments;
class MyController extends Controller
{
public function changeWithToken()
{
//PAYER_NAME: APPROVED||PENDING||REJECTED
//PAYMENT_METHOD : VISA||MASTERCARD||AMEX
//CREDIT_CARD_EXPIRATION_DATE : YYYY/MM
//INSTALLMENTS_NUMBER : 1
$sendData = [
'REFERENCE_CODE' => 'referencia_' . uniqid(),
'DESCRIPTION' => 'Deposito de $100',
'VALUE' => 100,
'BUYER_NAME' => 'Juan Lopez',
'PAYER_NAME' => 'APPROVED',
'TOKEN_ID' => '759497b1-ab49-4145-b652-0ad581a9f612', // id token tarjeta
'PAYMENT_METHOD' => 'MASTERCARD',
'INSTALLMENTS_NUMBER' => '1',
'CURRENCY' => 'MXN',
'COUNTRY' => 'MX',
];
$Payu = new Payments();
$Payu->tokenizarCard($sendData , function($response) {
//**Respuesta Exitosa**
//$response->state
//$response->orderId
//$response->transactionId}
//Si el estatus es pendiente
//$response->pendingReason
//Si el estatus es exitoso
//$response->trazabilityCode // opcional
//$response->authorizationCode // opcional
//$response->responseMessage // opcional
//$response->responseCode // opcional
}, function($error) {
//**Respuesta Erronea**
//$error->message
});
}
}
Nota: Todos los campos son obligatorios. El campo PAYER_NAME debe llevar el nombre del pagador en producción , si es pruebas , puede ir cualquier estado de los de arriba
Para las consultas por ORDER_ID es de la siguiente manera:
<?php
namespace App;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use TooPago\Payu\Searchable;
class MyController extends Controller
{
public function search()
{
$sendData = [
'ORDER_ID' => 'xxxxx' //ID de la orden
];
$Payu = new Searchable();
$Payu->searchById($sendData , function($response) {
//**Respuesta Exitosa**
}, function($error) {
//**Respuesta Erronea**
//$error->message
});
}
}
Para las consultas por REFERENCE_CODE es de la siguiente manera:
<?php
namespace App;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use TooPago\Payu\Searchable;
class MyController extends Controller
{
public function search()
{
$sendData = [
'REFERENCE_CODE' => 'xxxxx' //REFERENCE_CODE de la orden
];
$Payu = new Searchable();
$Payu->searchByReference($sendData , function($response) {
//**Respuesta Exitosa**
}, function($error) {
//**Respuesta Erronea**
//$error->message
});
}
}
Para las consultas por TRANSACTION_ID es de la siguiente manera:
<?php
namespace App;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use TooPago\Payu\Searchable;
class MyController extends Controller
{
public function search()
{
$sendData = [
'TRANSACTION_ID' => 'xxxxx' //TRANSACTION_ID de la orden
];
$Payu = new Searchable();
$Payu->searchByTransaction($sendData , function($response) {
//**Respuesta Exitosa**
}, function($error) {
//**Respuesta Erronea**
//$error->message
});
}
}
Instalar las dependencias del paquete.
Configurar el archivo phpunit.xml las variables de .env con la configuracion de pruebas de tu cuenta.
Ver información en sitio de PayU y luego si ejecutar las pruebas:
phpunit
Para un error escribir directamente el problema en github issues o enviarlo al correo miguel@lomeli.io. Si desea contribuir con el proyecto por favor enviar los ajustes siguiendo la guía de contribuciones: