ssheduardo/redsys-laravel

Package redsys for laravel

1.4.6 2024-05-02 00:19 UTC

This package is auto-updated.

Last update: 2024-12-02 01:45:26 UTC


README

Latest Version on Packagist Software License Total Downloads

Introducción

Tras finalizar la actualización de la clases Redsys para trabajar con sha256, he aprovechado en crear este package para laravel, de esta forma hacemos más ameno el trabajar con este framework.

Instalación

Via Composer

Laravel 5.1

$ composer require "ssheduardo/redsys-laravel=1.0.*"

Laravel 5.2, 5.3, 5.4

$ composer require "ssheduardo/redsys-laravel=~1.1.0"

Laravel 5.5, 5.6, 5.7, 5.8

$ composer require "ssheduardo/redsys-laravel=~1.3.0"

Laravel 6.0, 7.x, 8.x, 9.x, 10.x

$ composer require "ssheduardo/redsys-laravel=~1.4.0"

O si lo prefieres, puedes agregarlo en la sección require de tu composer.json

Laravel 5.1

  "ssheduardo/redsys-laravel": "1.0.*"

Laravel 5.2, 5.3, 5.4

  "ssheduardo/redsys-laravel": "~1.1.0"

Laravel 5.5, 5.6, 5.7, 5.8

  "ssheduardo/redsys-laravel": "~1.3.0"

Laravel 6.0, 7.x, 8.x, 9.x, 10.x

  "ssheduardo/redsys-laravel": "~1.4.0"

Ahora debemos cargar nuestro Services Provider dentro del array 'providers' (config/app.php)

Si usas Laravel 5.5 o superior, no necesitas cargar el services provider

Ssheduardo\Redsys\RedsysServiceProvider::class

Creamos un alias dentro del array 'aliases' (config/app.php)

Si usas Laravel 5.5 o superior no necesitas crear el alias

'Redsys'    => Ssheduardo\Redsys\Facades\Redsys::class,

Y finalmente publicamos nuestro archivo de configuración

php artisan vendor:publish --tag="redsys-config"

Esto nos creará un archivo llamado redsys.php dentro de config, en este archivo debemos configurar nuestra key, url ok y ko.

Uso

Imaginemos que tenemos esta ruta http://ubublog.com/redsys que enlaza con RedsysController@index

Route::controller(RedsysController::class)->prefix('redsys')
    ->group(function () {
        Route::get('/', 'index');
    });

Y el contenido del controlador RedsysController sería este:

<?php

namespace App\Http\Controllers;

use Exception;
use Illuminate\Http\Request;
use Ssheduardo\Redsys\Facades\Redsys;

class RedsysController extends Controller
{
    public function index()
    {
        try {
            $key = config('redsys.key');
            $code = config('redsys.merchantcode');

            Redsys::setAmount(rand(10, 600));
            Redsys::setOrder(time());
            Redsys::setMerchantcode($code); //Reemplazar por el código que proporciona el banco
            Redsys::setCurrency('978');
            Redsys::setTransactiontype('0');
            Redsys::setTerminal('1');
            Redsys::setMethod('T'); //Solo pago con tarjeta, no mostramos iupay
            Redsys::setNotification(config('redsys.url_notification')); //Url de notificacion
            Redsys::setUrlOk(config('redsys.url_ok')); //Url OK
            Redsys::setUrlKo(config('redsys.url_ko')); //Url KO
            Redsys::setVersion('HMAC_SHA256_V1');
            Redsys::setTradeName('Tienda S.L');
            Redsys::setTitular('Pedro Risco');
            Redsys::setProductDescription('Compras varias');
            Redsys::setEnviroment('test'); //Entorno test

            $signature = Redsys::generateMerchantSignature($key);
            Redsys::setMerchantSignature($signature);

            $form = Redsys::createForm();
        } catch (Exception $e) {
            echo $e->getMessage();
        }
        return view('redsys', compact('form'));
    }
}

Podemos hacer un pequeño diseño usando una plantilla blade quedando algo así

image

Esta clase hereda de mi clase principal https://github.com/ssheduardo/sermepa, aquí encontrarán más ejemplos de los métodos que trae la clase Tvp.php

Notas adicionales

Dentro del archivo /config/redsys.php, se debe configurar el FUC (Merchant Code) y nuestra key. Puntos a tener en cuenta de la configuración si no has trabajado con redsys-laravel anteriormente:

  • Si queremos usar el entorno de producción debemos usar el string 'live' como environment.

  • El FUC en el entorno de pruebas debe ser real, de otro modo se obtendrá el error de importe 0 (https://github.com/ssheduardo/redsys-laravel#20)

  • La url OK ('url_ok') se usa para redireccionar tras un pago correcto (no contiene información del pago), lo mismo ocurre con la url de KO ('url_ko'). La url que tiene información del pago realizado es la URL de notificación ('url_notification') que deberá comprobar la firma de la información del siguiente modo:

  $key = config('redsys.key');
  $parameters = Redsys::getMerchantParameters($request->input('Ds_MerchantParameters'));
  $DsResponse = $parameters["Ds_Response"];
  $DsResponse += 0;

  if (Redsys::check($key, $request->input()) && $DsResponse <= 99) {
      // lo que quieras que haya si es positiva la confirmación de redsys


  } else {
      //lo que quieras que haga si no es positivo

  }

Change log

Please see CHANGELOG for more information what has changed recently.

Security

If you discover any security related issues, please email :author_email instead of using the issue tracker.

Credits

License

The MIT License (MIT). Please see License File for more information.

Donación

¿Te gustaría apoyarme? ¿Aprecias mi trabajo? ¿Lo usas en proyectos comerciales?

¡Siéntete libre de hacer una pequeña donación! 😉

paypal