2017 © Pedro Peláez
 

library cfdi-xml

Librería para generar la estructura XML de los Comprobantes Fiscales (CFDI)

image

kinedu/cfdi-xml

Librería para generar la estructura XML de los Comprobantes Fiscales (CFDI)

  • Friday, April 27, 2018
  • by Kinedu
  • Repository
  • 4 Watchers
  • 12 Stars
  • 57 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 4 Versions
  • 24 % Grown

The README.md

Kinedu

Travis StyleCI Quality Score Total Downloads License, (*1)

Instalación

Instalar el paquete mediante Composer., (*2)

composer require kinedu/cfdi-xml

Uso

Factura

CFDI

use Kinedu\CfdiXML\CFDI;

$key = 'AAA010101AAA.key.pem';
$cer = 'AAA010101AAA.cer.pem';

$cfdi = new CFDI([
    'Serie' => 'A',
    'Folio' => 'A0103',
    'Fecha' => '2018-02-01T10:00:00',
    'FormaPago' => '01',
    'NoCertificado' => '3000100000300023708',
    'SubTotal' => '4741.38',
    'Moneda' => 'MXN',
    'TipoCambio' => '1',
    'Total' => '5500.00',
    'TipoDeComprobante' => 'I',
    'MetodoPago' => 'PUE',
    'LugarExpedicion' => '64000',
], $key, $cer);

Ver Resultado
, (*3)

<cfdi:Comprobante xmlns:cfdi="http://www.sat.gob.mx/cfd/3" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.sat.gob.mx/cfd/3 http://www.sat.gob.mx/sitio_internet/cfd/3/cfdv33.xsd" Version="3.3" Serie="A" Folio="A0103" Fecha="2018-02-01T10:00:00" FormaPago="01" NoCertificado="3000100000300023708" SubTotal="4741.38" Moneda="MXN" TipoCambio="1" Total="5500.00" TipoDeComprobante="I" MetodoPago="PUE" LugarExpedicion="64000"/>

, (*4)

⬆️ Regresar al listado, (*5)

Obtener XML

use Kinedu\CfdiXML\CFDI;

$key = file_get_contents('AAA010101AAA.key.pem');
$cer = file_get_contents('AAA010101AAA.cer.pem');

$cfdi = new CFDI([
    'Serie' => 'A',
    'Folio' => 'A0103',
    'Fecha' => '2018-02-01T10:00:00',
    'FormaPago' => '01',
    'NoCertificado' => '3000100000300023708',
    'SubTotal' => '4741.38',
    'Moneda' => 'MXN',
    'TipoCambio' => '1',
    'Total' => '5500.00',
    'TipoDeComprobante' => 'I',
    'MetodoPago' => 'PUE',
    'LugarExpedicion' => '64000',
], $key, $cer);

$cfdi->getXML();

⬆️ Regresar al listado, (*6)

Guardar CFDI

use Kinedu\CfdiXML\CFDI;

$key = 'AAA010101AAA.key.pem';
$cer = 'AAA010101AAA.cer.pem';

$cfdi = new CFDI([
    'Serie' => 'A',
    'Folio' => 'A0103',
    'Fecha' => '2018-02-01T10:00:00',
    'FormaPago' => '01',
    'NoCertificado' => '3000100000300023708',
    'SubTotal' => '4741.38',
    'Moneda' => 'MXN',
    'TipoCambio' => '1',
    'Total' => '5500.00',
    'TipoDeComprobante' => 'I',
    'MetodoPago' => 'PUE',
    'LugarExpedicion' => '64000',
], $key, $cer);

$cfdi->save('./A0103.xml');

Nodos

Relacionado

En este nodo se debe expresar la información de los comprobantes fiscales relacionados con el que se ésta generando, se deben expresar tantos numeros de nodos de CfdiRelacionado, como comprobantes se requieran relacionar., (*7)

use Kinedu\CfdiXML\CFDI;
use Kinedu\CfdiXML\Node\Relacionado;

$cfdi = new CFDI(...);

$cfdi->add(new Relacionado([
    'UUID' => '5FB2822E-396D-4725-8521-CDC4BDD20CCF',
], [
    'TipoRelacion' => '01',
]));

Ver Resultado
, (*8)

<cfdi:CfdiRelacionados TipoRelacion="01">
    <cfdi:CfdiRelacionado UUID="5FB2822E-396D-4725-8521-CDC4BDD20CCF"/>
</cfdi:CfdiRelacionados>

, (*9)

⬆️ Regresar al listado, (*10)

Emisor

En este nodo se debe expresar la información del contribuyente que emite el comprobante fiscal., (*11)

use Kinedu\CfdiXML\CFDI;
use Kinedu\CfdiXML\Node\Emisor;

$cfdi = new CFDI(...);

$cfdi->add(new Emisor([
    'Rfc' => 'XAXX010101000',
    'Nombre' => 'John Doe',
    'RegimenFiscal' => '601',
]));

Ver Resultado
, (*12)

<cfdi:Emisor Rfc="XAXX010101000" Nombre="John Doe" RegimenFiscal="601"/>

, (*13)

⬆️ Regresar al listado, (*14)

Receptor

En este nodo se debe expresar la información del contribuyente receptor del comprobante., (*15)

use Kinedu\CfdiXML\CFDI;
use Kinedu\CfdiXML\Node\Receptor;

$cfdi = new CFDI(...);

$cfdi->add(new Receptor([
    'Rfc' => 'XEXX010101000',
    'Nombre' => 'John Doe',
    'ResidenciaFiscal' => 'USA',
    'NumRegIdTrib' => '121585958',
    'UsoCFDI' => 'G03',
]));

Ver Resultado
, (*16)

<cfdi:Receptor Rfc="XEXX010101000" Nombre="John Doe" ResidenciaFiscal="USA" NumRegIdTrib="121585958" UsoCFDI="G03"/>

, (*17)

⬆️ Regresar al listado, (*18)

Impuestos

Traslado
Traslado en comprobante
use Kinedu\CfdiXML\CFDI;
use Kinedu\CFDI\Node\Impuesto\Traslado;

$cfdi = new CFDI([...]);

$cfdi->add(new Traslado([
    'Impuesto' => '002',
    'TipoFactor' => 'Tasa',
    'TasaOCuota' => '0.160000',
    'Importe' => '4500',
], [], [
    'TotalImpuestosTrasladados' => '4500',
]));

Ver Resultado
, (*19)

<cfdi:Impuestos TotalImpuestosTrasladados="4500">
    <cfdi:Traslados>
        <cfdi:Traslado Impuesto="002" TipoFactor="Tasa" TasaOCuota="0.160000" Importe="4500"/>
    </cfdi:Traslados>
</cfdi:Impuestos>

, (*20)

Traslado en concepto
use Kinedu\CfdiXML\CFDI;
use Kinedu\CfdiXML\Node\Concepto;
use Kinedu\CFDI\Node\Impuesto\Traslado;

$cfdi = new CFDI([...]);

$concepto = new Concepto([...]);

$concepto->add(new Traslado([
    'Base' => '4500',
    'Impuesto' => '002',
    'TipoFactor' => 'Tasa',
    'TasaOCuota' => '0.160000',
    'Importe' => '720',
]));

Ver Resultado
, (*21)

<cfdi:Conceptos>
    <cfdi:Concepto>
        <cfdi:Impuestos>
            <cfdi:Traslados>
                <cfdi:Traslado Base="4500" Impuesto="002" TipoFactor="Tasa" TasaOCuota="0.160000" Importe="720"/>
            </cfdi:Traslados>
        </cfdi:Impuestos>
    </cfdi:Concepto>
</cfdi:Conceptos>

, (*22)

Retención
Retención en comprobante
use Kinedu\CfdiXML\CFDI;
use Kinedu\CFDI\Node\Impuesto\Retencion;

$cfdi = new CFDI([...]);

$cfdi->add(new Retencion([
    'Impuesto' => '002',
    'Importe' => '4500',
], [], [
    'TotalImpuestosRetenidos' => '4500',
]));

Ver Resultado
, (*23)

<cfdi:Impuestos TotalImpuestosRetenidos="4500">
    <cfdi:Retenciones>
        <cfdi:Retencion Impuesto="002" Importe="4500"/>
    </cfdi:Retenciones>
</cfdi:Impuestos>

, (*24)

Retención en concepto
use Kinedu\CfdiXML\CFDI;
use Kinedu\CfdiXML\Node\Concepto;
use Kinedu\CFDI\Node\Impuesto\Retencion;

$cfdi = new CFDI([...]);

$concepto = new Concepto([...]);

$concepto->add(new Retencion([
    'Base' => '4500',
    'Impuesto' => '003',
    'TipoFactor' => 'Tasa',
    'TasaOCuota' => '0.530000',
    'Importe' => '2385',
]));

Ver Resultado
, (*25)

<cfdi:Conceptos>
    <cfdi:Concepto>
        <cfdi:Impuestos>
            <cfdi:Retenciones>
                <cfdi:Retencion Base="4500" Impuesto="003" TipoFactor="Tasa" TasaOCuota="0.530000" Importe="2385"/>
            </cfdi:Retenciones>
        </cfdi:Impuestos>
    </cfdi:Concepto>
</cfdi:Conceptos>

, (*26)

Concepto

En este nodo se debe expresar la información detallada de un bien o servicio descrito en el comprobante., (*27)

use Kinedu\CfdiXML\CFDI;
use Kinedu\CfdiXML\Node\Concepto;

$cfdi = new CFDI(...);

$cfdi->add(new Concepto([
    'ClaveProdServ' => '10317331',
    'NoIdentificacion' => 'UT421511',
    'Cantidad' => '24',
    'ClaveUnidad' => 'H87',
    'Unidad' => 'Pieza',
    'Descripcion' => 'Arreglo de 24 tulipanes rosadas recién cortados',
    'ValorUnitario' => '56.00',
    'Importe' => '1344.00',
    'Descuento' => '10.00',
]));

Ver Resultado
, (*28)

<cfdi:Conceptos>
    <cfdi:Concepto ClaveProdServ="60121001" NoIdentificacion="UT421510" Cantidad="5.555555" ClaveUnidad="KGM" Unidad="Kilo" ValorUnitario="I"/>
</cfdi:Conceptos>

, (*29)

⬆️ Regresar al listado, (*30)

Parte

En este nodo se pueden expresar las partes o componentes que integran la totalidad del concepto expresado en el comprobante fiscal digital por Internet., (*31)

use Kinedu\CfdiXML\CFDI;
use Kinedu\CfdiXML\Node\Parte;
use Kinedu\CfdiXML\Node\Concepto;

$cfdi = new CFDI(...);

$concepto = new Concepto([
    'ClaveProdServ' => '27113201',
    'NoIdentificacion' => 'UT421456',
    'Cantidad' => '1',
    'ClaveUnidad' => 'KT',
    'Unidad' => 'Kit',
    'Descripcion' => 'Kit de destornillador',
    'ValorUnitario' => '217.30',
    'Importe' => '217.30',
    'Descuento' => '0.00',
]);

$tornillo = new Parte([
    'ClaveProdServ' => '31161500',
    'NoIdentificacion' => 'UT367898',
    'Cantidad' => '34',
    'ClaveUnidad' => 'H87',
    'Unidad' => 'Pieza',
    'Descripcion' => 'Tornillo',
    'ValorUnitario' => '00.20',
    'Importe' => '6.80',
]);

$tornilloPerno = new Parte([
    'ClaveProdServ' => '31161501',
    'NoIdentificacion' => 'UT367899',
    'Cantidad' => '14',
    'ClaveUnidad' => 'H87',
    'Unidad' => 'Pieza',
    'Descripcion' => 'Tornillo de Perno',
    'ValorUnitario' => '00.75',
    'Importe' => '10.50',
]);

$destornillador = new Parte([
    'ClaveProdServ' => '27111701',
    'NoIdentificacion' => 'UT367900',
    'Cantidad' => '2',
    'ClaveUnidad' => 'H87',
    'Unidad' => 'Pieza',
    'Descripcion' => 'Destornillador',
    'ValorUnitario' => '100.00',
    'Importe' => '200.00',
]);

$concepto->add($tornillo);
$concepto->add($tornilloPerno);
$concepto->add($destornillador);

$cfdi->add($concepto);

Ver Resultado
, (*32)

<cfdi:Conceptos>
    <cfdi:Concepto ClaveProdServ="27113201" NoIdentificacion="UT421456" Cantidad="1" ClaveUnidad="KT" Unidad="Kit" Descripcion="Kit de destornillador" ValorUnitario="217.30" Importe="217.30" Descuento="0.00">
        <cfdi:Parte ClaveProdServ="31161500" NoIdentificacion="UT367898" Cantidad="34" ClaveUnidad="H87" Unidad="Pieza" Descripcion="Tornillo" ValorUnitario="00.20" Importe="6.80"/>
        <cfdi:Parte ClaveProdServ="31161501" NoIdentificacion="UT367899" Cantidad="14" ClaveUnidad="H87" Unidad="Pieza" Descripcion="Tornillo de Perno" ValorUnitario="00.75" Importe="10.50"/>
        <cfdi:Parte ClaveProdServ="27111701" NoIdentificacion="UT367900" Cantidad="2" ClaveUnidad="H87" Unidad="Pieza" Descripcion="Destornillador" ValorUnitario="100.00" Importe="200.00"/>
    </cfdi:Concepto>
</cfdi:Conceptos>

, (*33)

⬆️ Regresar al listado, (*34)

Información Aduanera

En este nodo se debe expresar la información aduanera correspondiente a cada concepto cuando se trate de ventas de primera mano de mercancías importadas., (*35)

use Kinedu\CfdiXML\CFDI;
use Kinedu\CfdiXML\Node\Concepto;
use Kinedu\CfdiXML\Node\InformacionAduanera;

$cfdi = new CFDI(...);

$concepto = new Concepto(...);

$concepto->add(new InformacionAduanera([
    'NumeroPedimento' => '00 00 0000 0000000',
]));

$cfdi->add($concepto);

Ver Resultado
, (*36)

<cfdi:Conceptos>
    <cfdi:Concepto ClaveProdServ="60121001" NoIdentificacion="UT421510" Cantidad="5.555555" ClaveUnidad="KGM" Unidad="Kilo" ValorUnitario="I">
        <cfdi:InformacionAduanera NumeroPedimento="00 00 0000 0000000"/>
    </cfdi:Concepto>
</cfdi:Conceptos>

, (*37)

⬆️ Regresar al listado, (*38)

Licencia

CFDI XML esta bajo la Licencia MIT, si quieres saber más al respecto puedes ver el archivo de Licencia que se encuentra en este mismo repositorio., (*39)

The Versions

27/04 2018

dev-master

9999999-dev https://github.com/Kinedu/cfdi-xml

Librería para generar la estructura XML de los Comprobantes Fiscales (CFDI)

  Sources   Download

MIT

The Requires

 

The Development Requires

sat cfdi kinedu

12/03 2018

v0.1.2

0.1.2.0 https://github.com/Kinedu/cfdi-xml

Librería para generar la estructura XML de los Comprobantes Fiscales (CFDI)

  Sources   Download

MIT

The Requires

 

The Development Requires

sat cfdi kinedu

15/02 2018

v0.1.1

0.1.1.0 https://github.com/Kinedu/cfdi-xml

Librería para generar la estructura XML de los Comprobantes Fiscales (CFDI)

  Sources   Download

MIT

The Requires

 

The Development Requires

sat cfdi kinedu

06/02 2018

v0.1.0

0.1.0.0 https://github.com/Kinedu/cfdi-xml

  Sources   Download

MIT

The Requires

  • php ^7.1

 

The Development Requires

cfdi kinedu