codelko / ciberfactura
Libreria para la Emisión de Facturas Electrónicas
Requires
- genkgo/xsl: ^0.6.11
- dev-master
- 0.4.0
- 0.1.85
- 0.1.84
- 0.1.83
- 0.1.82
- 0.1.81
- 0.1.80
- 0.1.79
- 0.1.78
- 0.1.77
- 0.1.76
- 0.1.75
- 0.1.74
- 0.1.73
- 0.1.72
- 0.1.71
- 0.1.70
- 0.1.69
- 0.1.68
- 0.1.67
- 0.1.66
- 0.1.64
- 0.1.63
- 0.1.62
- 0.1.61
- 0.1.60
- 0.1.59
- 0.1.58
- 0.1.57
- 0.1.56
- 0.1.55
- 0.1.54
- 0.1.53
- 0.1.52
- 0.1.51
- 0.1.50
- 0.1.49
- 0.1.48
- 0.1.47
- 0.1.46
- 0.1.45
- 0.1.44
- 0.1.43
- 0.1.42
- 0.1.41
- 0.1.40
- 0.1.39
- 0.1.38
- 0.1.37
- 0.1.36
- 0.1.35
- 0.1.34
- 0.1.33
- 0.1.32
- 0.1.31
- 0.1.30
- 0.1.29
- 0.1.28
- 0.1.27
- 0.1.26
- 0.1.25
- 0.1.24
- 0.1.23
- 0.1.22
- 0.1.21
- 0.1.20
- 0.1.19
- 0.1.18
- 0.1.17
- 0.1.16
- 0.1.15
- 0.1.14
- 0.1.13
- 0.1.12
- 0.1.11
- 0.1.10
- 0.1.9
- 0.1.8
- 0.1.7
- 0.1.6
- 0.1.5
- 0.1.4
- 0.1.3
- 0.1.2
- 0.1.1
- 0.1.0
- dev-cfdi40
- dev-pagos20
- dev-ORS-923
This package is auto-updated.
Last update: 2024-12-13 17:32:27 UTC
README
Libreria que simplifica el proceso de creación y timbrado de CFDIs v3.3
Instalación
Para iniciar la instalación de la libreria es necesario agregar la dependencia en nuestro composer.json en la raíz de Laravel.
{
"require": {
"codelko/ciberfactura": "0.1.*"
}
}
Laravel 5.4
Registrar el siguiente Service Provider. y Alias
// config/app.php
'providers' => [
Codelko\Ciberfactura\CiberfacturaServiceProvider::class,
];
'aliases' => [
'Cfdi' => Codelko\Ciberfactura\Facades\Cfdi::class,
];
Enseguida, publicar la configuración por defecto.
php artisan vendor:publish --provider="Codelko\Ciberfactura\CiberfacturaServiceProvider"
Este comando además de crear el archivo de configuración config/packages/codelko/ciberfactura/config.php
, creará un grupo de archivos con las migrations para crear las tablas necesarias para la creación de cfdis.
Para que la configuración funcione de manera adecuada debemos definir las variables de ambiente en nuestro archivo .env con sus apropiados valores.
Esta libreria servira para emitir facturas con Smarter Web, el cual es un proveedor autorizado de certificación del SAT.
Migrations
Antes de probar el funcionamiento de la libreria, es necesario ejecutar los migrations que crearán las tablas donde se almacenan los CFDIs.
php artisan migrate
Despues de ejecutar este comando se habrán creado las tablas necesarias para la integración la librería, así como los catálogos proporcionados por el SAT y son necesarios para la emisión de facturas con la versión 3.3
- Tipos de Comprobante
- Regimenes Fiscales
- Formas de Pago
- Métodos de Pago
- Impuestos
- Monedas
- Estados
- Paises
- Tipos de Factor
- Tipos de Relación
- Usos de Cfdi
- Unidades
- Productos y/o Servicios
- Tipos
- Segmentos
- Familias
- Clases
Código de Ejemplo
DB::beginTransaction();
$cfdi_factura = CfdiFactura::create([
'version' => 3.3,
'serie' => 'AS',
'folio' => '3972',
'fecha' => str_replace(" ", "T", date("Y-m-d H:i:s")),
'forma_pago' => "03",
'sub_total' => 1000,
'descuento' => 0,
'moneda' => 'MXN',
'total' => 1000,
'tipo_de_comprobante' => 'I',
'metodo_pago' => 'PUE',
'lugar_expedicion' => '46600',
'condiciones_de_pago' => 'Condiciones No Definidas'
]);
$cfdi_factura->addEmisor([
'rfc' => 'AAA010101AAA',
'nombre' => 'ACCEM SERVICIOS EMPRESARIALES SC',
'regimen_fiscal' => '601'
]);
$cfdi_factura->addReceptor([
'rfc' => 'VECR8307073J1',
'nombre' => 'Ramiro Alonso Vera Contreras',
'residencia_fiscal' => 'MEX',
'num_reg_id_trib' => '',
'uso_cfdi' => 'G03'
]);
$cfdi_concepto = $cfdi_factura->addConcepto([
'cfdi_id' => $cfdi_factura->id,
'clave_prod_serv' => '10151810',
'no_identificacion' => '',
'cantidad' => 5,
'clave_unidad' => 'E49',
'unidad' => 'Litro',
'descripcion' => 'Concepto de Prueba 1',
'valor_unitario' => 100.00,
'importe' => 500.00,
'descuento' => 0.00
]);
$cfdi_concepto->addImpuesto([
'cfdi_id' => $cfdi_factura->id,
'type' => 'retencion',
'base' => 500.00,
'impuesto' => '001',
'tipo_factor' => 'Tasa',
'tasa_o_cuota' => 0.1600,
'importe' => 80.00
]);
$cfdi_concepto = $cfdi_factura->addConcepto([
'cfdi_id' => $cfdi_factura->id,
'clave_prod_serv' => '10151810',
'no_identificacion' => '',
'cantidad' => 5,
'clave_unidad' => 'E49',
'unidad' => 'Litro',
'descripcion' => 'Concepto de Prueba 2',
'valor_unitario' => 100.00,
'importe' => 500.00,
'descuento' => 0.00
]);
$cfdi_concepto->addImpuesto([
'type' => 'traslado',
'base' => 500.00,
'impuesto' => '002',
'tipo_factor' => 'Tasa',
'tasa_o_cuota' => 0.1600,
'importe' => 80.00
]);
$cfdi = new Cfdi();
$cfdi->setTimbrador(new CfdiTimbrador($cfdi->rfc, $cfdi->certificate, $cfdi->production));
$cfdi->load($cfdi_factura);
$sello = $cfdi->sellar();
$uuid = $cfdi->timbrar();
$xml = $cfdi->xml();
DB::commit();