contica / facturador-electronico-cr
Un facturador de código libre para integrar facturación electrónica en Costa Rica a un proyecto PHP
Installs: 18 368
Dependents: 0
Suggesters: 0
Security: 0
Stars: 18
Watchers: 7
Forks: 24
Open Issues: 2
Requires
- php: >=7.4
- defuse/php-encryption: ^2.4
- guzzlehttp/guzzle: ^7.9
- league/flysystem: ^2.5
- league/flysystem-aws-s3-v3: ^2.5
- monolog/monolog: ^2.10
- ramsey/uuid: ^4.2
- sabre/xml: ^4.0
Requires (Dev)
- phpunit/phpunit: ^5.7
- squizlabs/php_codesniffer: ^3.11
- dev-master
- v3.5.3
- v3.5.2
- v3.5.1
- v3.5.0
- v3.4.2
- v3.4.1
- v3.4.0
- v3.3.8
- v3.3.7
- v3.3.6
- v3.3.5
- v3.3.4
- v3.3.3
- v3.3.2
- v3.3.1
- v3.3.0
- v3.2.1
- 3.2.0
- v3.1.1
- v3.1.0
- v3.0.10
- v3.0.9
- v3.0.8
- v3.0.7
- v3.0.6
- v3.0.5
- v3.0.4
- v3.0.3
- v3.0.2
- v3.0.1
- v3.0
- v2.4.2
- v2.4.1
- v2.4.0
- v2.3.3
- v2.3.2
- v2.3.1
- v2.3.0
- v2.2.21
- v2.2.20
- v2.2.19
- v2.2.18
- v2.2.17
- v2.2.16
- v2.2.15
- v2.2.14
- v2.2.13
- 2.2.12
- v2.2.11
- v2.2.10
- v2.2.9
- v2.2.8
- v2.2.7
- v2.2.6
- v2.2.5
- v2.2.4
- v2.2.3
- v2.2.2
- v2.2.1
- v2.2.0
- v2.1.0
- v2.0.2
- v2.0.1
- v2.0
- v1.31
- v1.3.05
- v1.3.1
- v1.3.0
- v1.2.1
- dev-Developer
This package is auto-updated.
Last update: 2024-12-24 03:55:12 UTC
README
Este es un componente PHP que provee toda la funcionalidad para crear, enviar, y almacenar los comprobantes electrónicos requeridos por el Ministerio de Hacienda en Costa Rica.
Instalación
Por medio de Composer
composer require contica/facturador-electronico-cr
Inicializar
/** * Crear la conexión a la base de datos */ $db = new mysqli( 'host', 'usuario', 'contraseña', 'base_de_datos' ); /** * Inicializar la base de datos * Tambien para ejecutar migraciones después de una actualización */ Storage::runMigrations($db);
Inicializar componente
Si quiere encriptar los datos de conexión a Hacienda en la base de datos se puede crear una llave de encriptación usando el siguiente comando:
composer generateKey
o usando el método
FacturadorElectronico::crearLlaveSeguridad();
El valor que genera se debe guardar en un lugar seguro y suministrarlo al
ajuste crypto_key
en la lista de ajustes.
$ajustes = [ 'storage_path' => '', // ruta completa en donde guardar los comprobantes 'crypto_key' => '', // (opcional) Llave para encriptar datos de conexion 'callback_url' => '', // (opcional) URL donde se recibe el callback 'storage_type' => 'local', // 'local' o 's3' para el tipo de almacenaje 's3_client_options' => [ // ajustes opcionales si se usa almacenaje s3 'credentials' => [ 'key' => 'llave', 'secret' => 'secreto' ], 'endpoint' => 'https://us-east-1.linodeobjects.com', // (opcional) 'region' => 'region', // por ej, us-east-1 'version' => 'latest', // version ], 's3_bucket_name' => 'nombre_de_bucket' // (opcional) nombre de balde en s3 ]; /** * Esto crea el objeto que se usa para ejecturar todos los métodos disponibles */ $facturador = new FacturadorElectronico($db, $ajustes);
Registrar empresa emisora en el componente
Para poder procesar los comprobantes de un emisor, primero hay que registrar el emisor. El siguiente método se usa para registrar un emisor nuevo al igual que actualizarlo.
$llave = file_get_contents('llave_criptografica.p12'); $datos_de_empresa = [ 'cedula' => '909990999', 'ambiente' => '1', // 1 prod, 2 stag 'usuario' => 'usuario_mh', 'contra' => 'contraseña_mh', 'pin' => 'pin_llave', 'llave_criptografica' => $llave ]; /** * Registrar empresa nueva * * El valor devuelto se tiene que usar para todas las * operaciones futuras sobre la empresa registrada */ $id_empresa = $facturador->guardarEmpresa($datos_de_empresa); /** * Modificar los datos de la empresa * * En $datos_de_empresa solo es necesario incluir los datos * que se están modificando */ $facturador->guardarEmpresa($datos_de_empresa, $id_empresa);
Crear un comprobante electrónico
/** * Datos de ejemplo para factura electrónica * * La estructura del array debe cumplir con la estructura * establecida para los comprobantes electrónicos */ $comprobante = [ 'Clave' => '{$clave}', // Omitir nodo para que se genere automáticamente 'NumeroConsecutivo' => '00100001010000000001', 'FechaEmision' => date('c'), 'Emisor' => [ 'Nombre' => 'Emisor', 'Identificacion' => [ 'Tipo' => '01', 'Numero' => '909990999' ], 'Ubicacion' => [ 'Provincia' => '6', 'Canton' => '01', 'Distrito' => '01', 'OtrasSenas' => 'direccion' ], 'CorreoElectronico' => 'correo@gmail.com' ], 'Receptor' => [ 'Nombre' => 'Receptor', 'Identificacion' => [ 'Tipo' => '01', 'Numero' => '909990999' ], 'Ubicacion' => [ 'Provincia' => '6', 'Canton' => '01', 'Distrito' => '01', 'OtrasSenas' => 'direccion' ], 'CorreoElectronico' => 'correo@gmail.com' ], 'CondicionVenta' => '01', 'MedioPago' => ['01', '02'], 'DetalleServicio' => [ 'LineaDetalle' => [ [ 'NumeroLinea' => '1', 'Codigo' => 'codigo CABYS', 'CodigoComercial' => [ 'Tipo' => '01', 'Codigo' => '00001' ], 'Cantidad' => '1', 'UnidadMedida' => 'Unid', 'Detalle' => 'Producto sin IVA', 'PrecioUnitario' => '15000.00', 'MontoTotal' => '15000.00', 'Descuento' => [ // Incluir cuando hay descuento 'MontoDescuento' => '1000.00', 'NaturalezaDescuento' => '...' ], 'Subtotal' => '14000.00', 'MontoTotalLinea' => '14000.00' ], [ 'NumeroLinea' => '2', 'Codigo' => 'codigo CABYS', 'Codigo' => [ 'Tipo' => '04', 'Codigo' => '00002' ], 'Cantidad' => '2', 'UnidadMedida' => 'Hr', 'Detalle' => 'Servicio con IVA', 'PrecioUnitario' => '3000.00', 'MontoTotal' => '6000.00', 'Subtotal' => '6000.00', 'Impuesto' => [ 'Codigo' => '01', 'CodigoTarifa' => '08', 'Tarifa' => '13.00', 'Monto' => '780.00' ] 'MontoTotalLinea' => '6780.00' ] ] ], 'ResumenFactura' => [ 'TotalServGravados' => '6000.00', 'TotalMercanciasExentas' => '15000.00', 'TotalGravado' => '6000.00', 'TotalExento' => '15000.00', 'TotalVenta' => '21000.00', 'TotalDescuentos' => '1000.00', 'TotalVentaNeta' => '20000.00', 'TotalImpuesto' => '780.00', 'TotalComprobante' => '20780.00' ] ]; /** * Esta funcion devuelve la clave del comprobante * Necesario para futuras consultas */ $clave = $facturador->enviarComprobante( $comprobante, $id_empresa );
El comprobante generado queda guardado en la cola de envío. Para enviarlo a Hacienda, se ejecuta el siguiente método:
$docs_enviados = $facturador->enviarCola(); /** * Contenido de ejemplo devuelto en $docs_enviados * * [ * [ * 'clave' => 'clave...', * 'tipo' => 'E', // E para emision, R para recepcion * ], * [...] * ] * */
Consultar el estado
$estado = $facturador->consultarEstado( $clave, 'E', // E para emision, R para recepcion $id_empresa ); /** * Contenido de ejemplo devuelto en $estado * * [ * 'clave' => 'clave...', * 'estado' => 1, // 1 pendiente, 2 enviado, 3 aceptado, 4 rechazado * 'mensaje' => 'Mensaje Hacienda', * 'xml' => 'Contenido del xml de respuesta si existe' * ] * */
Coger el xml de un comprobante
Hay que especificar cuál tipo es el que uno quiere.
- 1: XML del comprobante
- 2: XML de respuesta para el tipo 1
- 3: XML del mensaje receptor para un comprobante recibido (recepciones)
- 4: XML de la respuesta para el tipo 3 (recepciones)
$xml = $facturador->cogerXml( $clave, 'E', // E para emision, R para recepcion 1, // El tipo $id_empresa ); /** * Convertir el xml a un array para poder procesar */ $xml_decodificado = Comprobante::analizarXML($xml);
Procesar callback de Hacienda
Código para pasar el contenido del POST que hace Hacienda al facturador. Implementar el callback hace innecesario estar siempre consultando manualmente el estado.
$body = file_get_contents('php://input'); $estado = $facturador->procesarCallbackHacienda($body); /** * El contenido de $estado es idéntico a Consultar Estado más arriba. */
Registro de cambios
Por favor vea el CHANGELOG para más información de lo que ha cambiado recientemente.
Pruebas
composer test
Seguridad
Si descubre problemas relacionados a la seguridad, por favor envíe un correo electrónico a josias@solucionesinduso.com.
Créditos
Licencia
Licencia MIT (MIT). Favor ver LICENCIA para más información.