ichavezrg / heybanco-client
Cliente PHP para la API de HeyBanco
v0.0.2
2025-09-10 22:15 UTC
Requires
- php: >=8.1
- ext-curl: *
- ext-json: *
- guzzlehttp/guzzle: ^7.0
- web-token/jwt-framework: ^3.2
Requires (Dev)
- phpstan/phpstan: ^1.0
- phpunit/phpunit: ^10.0 || ^11.0
- squizlabs/php_codesniffer: ^3.0
This package is auto-updated.
Last update: 2025-09-10 22:17:12 UTC
README
Cliente PHP para la API de HeyBanco que proporciona una interfaz simple y elegante para interactuar con los servicios CAAS (Customer as a Service) de HeyBanco.
Características
- ✅ Autenticación mTLS: Soporte completo para autenticación mutua TLS
- ✅ Firma digital: Implementación de firmas JWE/JWS para seguridad
- ✅ CAAS Services: Soporte para Agreement, Collection y User services
- ✅ PSR-4: Autoloading compatible con PSR-4
- ✅ PHP 8.1+: Aprovecha las características modernas de PHP
- ✅ Guzzle HTTP: Cliente HTTP robusto y confiable
Instalación
Puedes instalar el paquete vía Composer:
composer require ichavez/heybanco-client
Requisitos
- PHP 8.1 o superior
- Extensión cURL
- Extensión JSON
- Certificados mTLS válidos de HeyBanco
Uso Básico
Configuración Inicial
<?php require_once 'vendor/autoload.php'; use Ichavez\HeyBancoClient\Client; use Ichavez\HeyBancoClient\Auth; use Ichavez\HeyBancoClient\Signature; use Ichavez\HeyBancoClient\Caas; use Ichavez\HeyBancoClient\HeyBancoClient; // Configuración de conexión $bApplication = "tu-b-application-id"; $mtlsKeystorePath = 'path/to/your/keystore.p12'; $mtlsKeystorePassword = 'tu-keystore-password'; // Crear cliente base $client = new Client( host: 'https://sbox-api-tech.hey.inc', bApplication: $bApplication, mtlsKeystorePath: $mtlsKeystorePath, mtlsKeystorePassword: $mtlsKeystorePassword ); // Configurar autenticación $auth = new Auth($client); // Configurar firma digital $signature = new Signature( bApplication: $bApplication, mtlsCertificatePath: $mtlsKeystorePath, mtlsCertificatePassword: $mtlsKeystorePassword, privateKeyPath: 'path/to/private_key.pem', privateKeyPhrase: '', publicServerKeyPath: 'path/to/server_public_key.pem' ); // Inicializar servicios CAAS $caas = new Caas( new Caas\Agreement($client, $auth, $signature), new Caas\Collection($client, $auth), new Caas\User($client, $auth) ); // Crear cliente principal $heybanco = new HeyBancoClient($caas);
Trabajar con Agreements
// Obtener agreements $agreements = $heybanco->caas->agreement->find( accountNumber: '220914510015', bTransaction: 'unique-transaction-id', clientId: 'your-client-id', clientSecret: 'your-client-secret' );
Trabajar con Collections
// Operaciones con collections $collections = $heybanco->caas->collection->find($agreementId);
Trabajar con Users
// Operaciones con usuarios $users = $heybanco->caas->user->find($agreementId);
Configuración de Entorno
Variables de Entorno
Se recomienda usar variables de entorno para datos sensibles:
# .env
HEYBANCO_B_APPLICATION=tu-b-application-id
HEYBANCO_HOST=https://sbox-api-tech.hey.inc
HEYBANCO_MTLS_KEYSTORE_PATH=/path/to/keystore.p12
HEYBANCO_MTLS_KEYSTORE_PASSWORD=tu-password
HEYBANCO_PRIVATE_KEY_PATH=/path/to/private_key.pem
HEYBANCO_PUBLIC_SERVER_KEY_PATH=/path/to/server_public_key.pem
HEYBANCO_CLIENT_ID=tu-client-id
HEYBANCO_CLIENT_SECRET=tu-client-secret
Ejemplo con Variables de Entorno
$client = new Client( host: $_ENV['HEYBANCO_HOST'], bApplication: $_ENV['HEYBANCO_B_APPLICATION'], mtlsKeystorePath: $_ENV['HEYBANCO_MTLS_KEYSTORE_PATH'], mtlsKeystorePassword: $_ENV['HEYBANCO_MTLS_KEYSTORE_PASSWORD'] );
Manejo de Errores
try { $agreements = $heybanco->caas->agreement->getAgreements( accountNumber: '220914510015', bTransaction: 'unique-transaction-id', clientId: 'your-client-id', clientSecret: 'your-client-secret' ); } catch (\Exception $e) { echo "Error: " . $e->getMessage(); }
Testing
Ejecutar las pruebas:
# Ejecutar todas las pruebas composer test # Ejecutar pruebas con coverage composer test-coverage # Análisis estático con PHPStan composer phpstan # Verificar estilo de código composer cs-check # Corregir estilo de código automáticamente composer cs-fix
Desarrollo
Estructura del Proyecto
src/
├── Auth.php # Manejo de autenticación
├── Client.php # Cliente HTTP base
├── HeyBancoClient.php # Cliente principal
├── Signature.php # Manejo de firmas digitales
├── Caas.php # Contenedor de servicios CAAS
└── Caas/
├── Agreement.php # Servicio de agreements
├── Collection.php # Servicio de collections
└── User.php # Servicio de usuarios
Contribuir
- Fork el proyecto
- Crea una rama para tu feature (
git checkout -b feature/nueva-funcionalidad
) - Commit tus cambios (
git commit -am 'Agrega nueva funcionalidad'
) - Push a la rama (
git push origin feature/nueva-funcionalidad
) - Crea un Pull Request
Seguridad
Si descubres alguna vulnerabilidad de seguridad, por favor envía un email a ichavez@redgirasol.com en lugar de usar el issue tracker.
Licencia
Este paquete es software de código abierto licenciado bajo la Licencia MIT.
Changelog
Por favor consulta CHANGELOG para más información sobre los cambios recientes.