vxml-cfdi
v2.0.0
Published
Modulo para generar, firmar, sellar, timbrar y cancelar comprobantes fiscales digitales en Mexico (CFDI 4.0)
Downloads
71
Maintainers
Readme
vxml-cfdi
Librería para firmar, sellar y timbrar CFDI v4.0
- vxml-cfdi
- Librería para firmar, sellar y timbrar CFDI v4.0
- Funciones Referenciadas para Timbrado
- CFDI40.Básicas
- CFDI40.Conceptos
- CFDI.Conceptos.ComplementoConcepto.iedu10
- CFDI.Conceptos.ComplementoConcepto.ventavehiculos11
- CFDI.Complemento.CartaPorte31
- CFDI.Complemento.Nomina12
- CFDI.Complemento.cce20
- CFDI.Complemento.pagos20
- CFDI.Complemento.ImpuestosLocales10
- CFDI.Complemento.Donatarias11
- CFDI.Complemento.INE11
- CFDI.Complemento.Divisas10
- CFDI.Complemento.Aerolineas10
- CFDI.Complemento.NotariosPublicos10
- CFDI.Complemento.VehiculoRenovacionSustitucionVehiculo10
- CFDI.Complemento.LeyendasFiscales10
- CFDI.Complemento.VehiculoUsado10
- CFDI.Complemento.ServicioParcial10
- CFDI.Complemento.SPEI10
- CFDI.Complemento.EstadoCuentaCombustible12
- CFDI.Complemento.ConsumoDeCombustibles11
- CFDI.Complemento.PagoEnEspecie10
- CFDI.Complemento.PFIntegranteCoordinado10
- CFDI.Complemento.TuristaPasajeroExtranjero10
- CFDI.Complemento.ValesDeDespensa10
- CFDI.Complemento.Detallista10
- CFDI.Especiales
- Ejemplos
- Funciones Referenciadas para Timbrado
Introducción
Librería para la generación y cancelación de CFDI 4.0, incluidos todos los complementos vigentes. Incluye el proceso de firmado, Sellado y tambien el Timbrado por medio del servicio de VXML, de acuerdo a la especificación del SAT.
Características
- Generación de CFDI 4.0
- Generación de todos los complementos vigentes:
- [Complementos y Complementos Concepto]
- Cancelación de CFDI 4.0
- Generación de representacion impresa simple (PDF)
- Generación de Codigo de Barras Bidimensional en formatos: png, jpg y bmp
- Sellado local (tu llave privada y clave son usadas localmente)
- Soporta la solicitud de Cancelación de CFDI con el formato vigente a 2022 (tu llave privada y clave son usadas localmente)
Instalación
NPM:
$ npm install --save vxml-cfdi
Requisitos
- Contar con un CSD vigente (Certificado de Sello Digital).
- Contar con los archivos .cer, .key
- Contar con la clave del archivo .key
- En caso de desear timbrar con credenciales diferentes al demo; haber contratado un plan de timbres con VXML
NOTA: Los archivos .cer/.key de la FIEL no funcionan para el proceso de timbrado, deberan usarse los del CSD
Información DEMO
Estas credenciales pueden usarse sin necesidad de ningun tipo de registro
- usuario: demo_nodejs
- rfcemisor: EKU9003173C9
- Certificado Emisor: CSD_EKU9003173C9.cer (archivo ubicado dentro de la carpeta "test" del paquete)
- Llave Privada Emisor: CSD_EKU9003173C9.key (archivo ubicado dentro de la carpeta "test" del paquete)
- Clave Llave Privada: 12345678a
Contacto
- Correo electronico: [email protected]
Métodos
cancelaCFDI2022
Procesa la solicitud de cancelación y devuelve el Acuse de solicitud/estatus Cancelación en caso de ser exitoso.
Esta funcion implementa los nuevos requisitos de cancelacion aplicables a partir de 2022.
Parametros Nombre | Tipo | Requerido | Ejemplo ------------------- | ------------------- | -------- | -------- usuario | Cadena | Sí | demo_nodejs rfcemisor | Cadena | Sí | EKU9003173C9 uuid | Cadena | Sí | FFFFFFFF-FFFF-FFFF-FFFF-FFFFFFFFFFFF motivo | Cadena | Sí | 02 foliosust | Cadena | Sí | Texto en blanco si no se usa certificado | Cadena | Sí | ./MisCertificados/EKU9003173C9.cer o Base64 (MIIF+TCCA+GgAwIBAgI...) llaveprivada | Cadena | Sí | ./MisCertificados/EKU9003173C9.key o Base64 (MIIFDjBABgkqhkiG9w0...) clave | Cadena | Sí | 12345678a outbasepath | Cadena | No | ../../salida/ outprefix | Cadena | No | prefijo outsuffix | Cadena | No | sufijo
Retorno Regresa una promesa. Una solicitud exitosa resolvera la promesa (resolve/then) y la respuesta contendra un exitcode = 201 o exitcode = 202, un uuid y un acuse. Cualquier otro valor sera un error en el proceso y debera referirse al mensaje message = ... normalmente en el rechazo (reject/catch) de la promesa
Resolve (Then)
{ "exitcode": 201, "message": "201 - Solicitud de cancelación recibida." "uuid": "025357315-4D60-4E56-A056-7AA0B1D8D95F", "acuse": "XML del acuse en base64" }
Resolve (Then)
{ "exitcode": 202, "message": "202 - UUID Previamente cancelado." "uuid": "025357315-4D60-4E56-A056-7AA0B1D8D95F", "acuse": "XML del acuse en base64" }
Reject (Catch)
{ "exitcode": 205, "message": "CA205 - El UUID no existe => Error al cancelar el UUID de la factura" }
addFunctionCall
Agrega al Stack FIFO una llamada referenciada a la funcion funcName con los parámetros especificados.
- Parametros Nombre | Tipo | Requerido | Ejemplo ------------------- | ------------------- | -------- | -------- funcName | Cadena | Sí | VXML_SetEmisorInfo_cfdi40 ...args | Multi parámetros | Sí | 'EKU9003173C9', 'NombreDelEmisorRazónSocial', '601'
NOTA: Dependiendo de la funcion referenciada (funcName), el numero de parámetros varía. Ver las funciones disponibles y numero de argumentos en la sección funciones referenciadas para timbrado
- Retorno La instancia de la clase, para usarse con llamadas secuenciales en 1 sola linea si se desea.
emiteCFDI40
Procesa Stack de funciones e intenta timbrar el documento generado.
Parametros Nombre | Tipo | Requerido | Ejemplo ------------------- | ------------------- | -------- | -------- usuario | Cadena | Sí | demo_nodejs rfcemisor | Cadena | Sí | EKU9003173C9 certificado | Cadena | Sí | ./MisCertificados/EKU9003173C9.cer o Base64 (MIIF+TCCA+GgAwIBAgI...) llaveprivada | Cadena | Sí | ./MisCertificados/EKU9003173C9.key o Base64 (MIIFDjBABgkqhkiG9w0...) clave | Cadena | Sí | 12345678a outbasepath | Cadena | No | ../../salida/ outprefix | Cadena | No | prefijo outsuffix | Cadena | No | sufijo qrpng | Bool | No | true qrbmp | Bool | No | false qrjpg | Bool | No | false pdf | Bool | No | true
Retorno Regresa una promesa. Un timbrado exitoso resolvera la promesa (resolve/then) y la respuesta contendra un exitcode = 0, un uuid y un xmltimbrado. Cualquier otro valor sera un error en el proceso y debera referirse al mensaje message = ... normalmente en el rechazo (reject/catch) de la promesa
Resolve (Then)
{ "exitcode": 0, "message": "" "uuid": "025357315-4D60-4E56-A056-7AA0B1D8D95F", "xmltimbrado": "XML en base64", "cadenasat": "Cadena Original del complemento de certificación digital del SAT", "qrpng": "QR.png en base64", "qrjpg": "QR.jpg en base64", "qrbmp": "QR.bmp en base64", "pdf": "Representacion impresa PDF en base64", }
Reject (Catch)
{ "exitcode": -5, "message": "Algunas funciones no son validas: VXML_NoExiste" }
Métodos Administrativos
Métodos útiles para la gestion y mantenimiento de RFC emisores, usuarios (distribuidores) y la asignación de timbres manual o automática; posibilitando una administracion por medio del este paquete sin necesidad de hacer uso del portal administrativo. Para el uso de todos estos métodos, es requerida una APIKEY
adminEmisorAdd
Alta de un nuevo RFC emisor.
Parametros Nombre | Tipo | Requerido | Ejemplo ------------------- | ------------------- | -------- | -------- apikey | Cadena | Sí | 1pIp-j-ZVVff2H2-Y54yTtYpW-Uhdffw8Pb3pJGRt7o usuario | Cadena | Sí | demo_nodejs rfcemisor | Cadena | Sí | EKU9003173C9 pwdconsulta | Cadena | Sí | SomeSecret. Usar texto en blanco para no establecer el valor razonsocial | Cadena | Sí | Some Company AC. email | Cadena | Sí | [email protected]. Texto en blanco si no se usa contacto | Cadena | Sí | IT guy. Texto en blanco si no se usa asignacion | Int | Sí | 100 suspendido | Bool | Sí | false notificacion | Bool | Sí | true reserved | Cadena | No |
Retorno Regresa una promesa. Una solicitud exitosa resolvera la promesa (resolve/then) y la respuesta contendra un campo exitcode y message. Cualquier valor de exitcode diferente a 0 sera un error en el proceso y debera referirse al mensaje message = ... normalmente en el rechazo (reject/catch) de la promesa
Resolve (Then)
{ "exitcode": 0, "message": "" }
Reject (Catch)
{ "exitcode": -2, "message": "RFC previamente agregado" }
adminEmisorUpd
Actualizacion de la informacion general de un RFC emisor asociado a la cuenta del usuario.
Parametros Nombre | Tipo | Requerido | Ejemplo ------------------- | ------------------- | -------- | -------- apikey | Cadena | Sí | 1pIp-j-ZVVff2H2-Y54yTtYpW-Uhdffw8Pb3pJGRt7o usuario | Cadena | Sí | demo_nodejs rfcemisor | Cadena | Sí | EKU9003173C9 pwdconsulta | Cadena | Sí | SomeSecret. Usar texto en blanco para no establecer o alterar el valor actual razonsocial | Cadena | Sí | Some Company AC. email | Cadena | Sí | [email protected]. Texto en blanco si no se usa contacto | Cadena | Sí | IT guy. Texto en blanco si no se usa suspendido | Bool | Sí | false notificacion | Bool | Sí | true reserved | Cadena | No |
Retorno Regresa una promesa. Una solicitud exitosa resolvera la promesa (resolve/then) y la respuesta contendra un campo exitcode y message. Cualquier valor de exitcode diferente a 0 sera un error en el proceso y debera referirse al mensaje message = ... normalmente en el rechazo (reject/catch) de la promesa
Resolve (Then)
{ "exitcode": 0, "message": "" }
Reject (Catch)
{ "exitcode": -3, "message": "Usuario/APIKEY invalida" }
adminEmisorAsigna
Realiza una asignacion de timbres al RFC emisor.
Parametros Nombre | Tipo | Requerido | Ejemplo ------------------- | ------------------- | -------- | -------- apikey | Cadena | Sí | 1pIp-j-ZVVff2H2-Y54yTtYpW-Uhdffw8Pb3pJGRt7o usuario | Cadena | Sí | demo_nodejs rfcemisor | Cadena | Sí | EKU9003173C9 asignacion | Int | Sí | 100 reserved | Cadena | No |
Retorno Regresa una promesa. Una solicitud exitosa resolvera la promesa (resolve/then) y la respuesta contendra un campo exitcode y message. Cualquier valor de exitcode diferente a 0 sera un error en el proceso y debera referirse al mensaje message = ... normalmente en el rechazo (reject/catch) de la promesa
Resolve (Then)
{ "exitcode": 0, "message": "" }
Reject (Catch)
{ "exitcode": -2, "message": "No se permiten asignaciones en 0 o negativas" }
adminEmisorAutoasignacion
Crea o modifica la regla de autoasignación de timbres al RFC emisor. Cuando el total de timbres disponibles del emisor alcance el valor threshold, se asignaran el numero de timbres asignacion siempre que la regla se encuentre activa y el número de timbres totales asignados historicamente al emisor no supere el valor limite.
Parametros Nombre | Tipo | Requerido | Ejemplo ------------------- | ------------------- | -------- | -------- apikey | Cadena | Sí | 1pIp-j-ZVVff2H2-Y54yTtYpW-Uhdffw8Pb3pJGRt7o usuario | Cadena | Sí | demo_nodejs rfcemisor | Cadena | Sí | EKU9003173C9 asignacion | Int | Sí | 100 threshold | Int | Sí | 20 limit | Int | Sí | 5000 active | Bool | Sí | false reserved | Cadena | No |
Retorno Regresa una promesa. Una solicitud exitosa resolvera la promesa (resolve/then) y la respuesta contendra un campo exitcode y message. Cualquier valor de exitcode diferente a 0 sera un error en el proceso y debera referirse al mensaje message = ... normalmente en el rechazo (reject/catch) de la promesa
Resolve (Then)
{ "exitcode": 0, "message": "" }
Reject (Catch)
{ "exitcode": -2, "message": "Los timbres para asignar no debe ser mayor al total de tus timbres disponibles" }
adminUsuarioAdd
Alta de un usuario-hijo (distribuidor) relacionado al usuario actual. Este usuario podrá gestionar sus propios emisores y timbres de forma independiente pero podra recibir asignacion de timbres directamente del usuario padre.
Parametros Nombre | Tipo | Requerido | Ejemplo ------------------- | ------------------- | -------- | -------- apikey | Cadena | Sí | 1pIp-j-ZVVff2H2-Y54yTtYpW-Uhdffw8Pb3pJGRt7o usuario | Cadena | Sí | demo_nodejs distribuidor | Cadena | Sí | childUserName pwd | Cadena | Sí | SomeSecret. Usar texto en blanco para no establecer el valor razonsocial | Cadena | Sí | Some Company AC. email | Cadena | Sí | [email protected]. Texto en blanco si no se usa contacto | Cadena | Sí | IT guy. Texto en blanco si no se usa asignacion | Int | Sí | 100 reserved | Cadena | No |
Retorno Regresa una promesa. Una solicitud exitosa resolvera la promesa (resolve/then) y la respuesta contendra un campo exitcode y message. Cualquier valor de exitcode diferente a 0 sera un error en el proceso y debera referirse al mensaje message = ... normalmente en el rechazo (reject/catch) de la promesa
Resolve (Then)
{ "exitcode": 0, "message": "" }
Reject (Catch)
{ "exitcode": -2, "message": "Ya existe un usuario con este nombre" }
adminUsuarioUpd
Actualizacion de la informacion general de un usuario-hijo (distribuidor) RFC emisor asociado a la cuenta del usuario actual.
Parametros Nombre | Tipo | Requerido | Ejemplo ------------------- | ------------------- | -------- | -------- apikey | Cadena | Sí | 1pIp-j-ZVVff2H2-Y54yTtYpW-Uhdffw8Pb3pJGRt7o usuario | Cadena | Sí | demo_nodejs distribuidor | Cadena | Sí | childUserName pwd | Cadena | Sí | SomeSecret. Usar texto en blanco para no establecer o alterar el valor actual razonsocial | Cadena | Sí | Some Company AC. email | Cadena | Sí | [email protected]. Texto en blanco si no se usa contacto | Cadena | Sí | IT guy. Texto en blanco si no se usa reserved | Cadena | No |
Retorno Regresa una promesa. Una solicitud exitosa resolvera la promesa (resolve/then) y la respuesta contendra un campo exitcode y message. Cualquier valor de exitcode diferente a 0 sera un error en el proceso y debera referirse al mensaje message = ... normalmente en el rechazo (reject/catch) de la promesa
Resolve (Then)
{ "exitcode": 0, "message": "" }
Reject (Catch)
{ "exitcode": -2, "message": "Nombre de usuario en blanco" }
adminUsuarioAsigna
Realiza una asignacion de timbres al usuario-hijo (distribuidor) tomando los timbres disponibles del usuario actual.
Parametros Nombre | Tipo | Requerido | Ejemplo ------------------- | ------------------- | -------- | -------- apikey | Cadena | Sí | 1pIp-j-ZVVff2H2-Y54yTtYpW-Uhdffw8Pb3pJGRt7o usuario | Cadena | Sí | demo_nodejs distribuidor | Cadena | Sí | childUserName asignacion | Int | Sí | 100 reserved | Cadena | No |
Retorno Regresa una promesa. Una solicitud exitosa resolvera la promesa (resolve/then) y la respuesta contendra un campo exitcode y message. Cualquier valor de exitcode diferente a 0 sera un error en el proceso y debera referirse al mensaje message = ... normalmente en el rechazo (reject/catch) de la promesa
Resolve (Then)
{ "exitcode": 0, "message": "" }
Reject (Catch)
{ "exitcode": -2, "message": "Nombre de usuario en blanco" }
Proceso de Timbrado
El siguiente diagrama muestra el proceso de timbrado completo:
Funciones Referenciadas para Timbrado
Estas funciones son añadidas a una pila FIFO (FirstIn-FirstOut) para ser enviadas y ejecutadas remotamente. Constan de un nombre funcName y de 1 o mas parámetros. Las funciones se agregan a la pila mediante el metodo addFunctionCall una vez que la clase VXML ha sido instanciada. El siguiente ejemplo ilustra el modo de uso:
Los parámetros de funcName deberan ser de tipo cadena independientemente del tipo de dato que representen, y deberan tener el formato que corresponda de acuerdo a los lineamientos del SAT.
Los parámetros de funcName deberan ser una cadena vacia si no contiene informacion, y debera respetarse la posicion de los mismos.
const VXML = require('vxml-cfdi');
const vxml = new VXML(); // Nueva Instancia
vxml.addFunctionCall( 'VXML_SetComprobanteInfo_cfdi40', // **funcName**
'NOM', // param01 = Serie
'1', // param02 = Folio
'2018-01-30T05:24:30', // param03 = Fecha
'01', // param04 = FormaPago
'CondiciónDePago', // param05 = CondicionesDePago
'5000.00', // param06 = SubTotal
'', // param07 = Descuento
'MXN', // param08 = Moneda
'', // param09 = TipoCambio
'5000.00', // param10 = Total
'I', // param11 = TipoDeComprobante
'PUE', // param12 = MetodoPago
'68025', // param13 = LugarExpedicion
'', // param14 = Confirmacion
'01'); // param15 = Exportacion
Se pueden agregar tantas llamadas como se necesiten para el correcto llenado del CFDI, teniendo en cuenta que algunos elementos que pueden aparecer varias veces (ej. cfdi.Conceptos), a su vez podran contener un detalle y las funciones del detalle afectaran al ultimo elemento padre al que pertenece. Por ejemplo:
const VXML = require('vxml-cfdi');
const vxml = new VXML(); // Nueva Instancia
vxml.addFunctionCall('VXML_SetComprobanteInfo_cfdi40', 'A', '1', FechaCFDI, '99', 'Contado Comercial', '1000.00', '50.00', 'MXN', '', '1102.00', 'I', 'PPD', '53050', '', '01');
vxml.addFunctionCall('VXML_SetReceptorInfo_cfdi40', 'MAG041126GT8', 'NombreDelReceptorRazónSocial', '', '', 'G01', '53050', '601');
vxml.addFunctionCall('VXML_AddConcepto_cfdi40', '84111506', 'SEFXXX', '1', 'H87', 'Unidad', 'Paquete X - ObjetoImp1', '500.00', '500.00', '', '02');
vmlx.addFunctionCall('VXML_AddConceptoCuentaPredial_cfdi40','5678901');
vxml.addFunctionCall('VXML_AddConcepto_cfdi40', '84111506', 'SEFXXX', '2', 'H87', 'Unidad', 'Paquete X - ObjetoImp2', '250.00', '500.00', '50.00', '02');
vxml.addFunctionCall('VXML_AddConcepto_cfdi40', '84111506', 'SEFXXX', '2', 'H87', 'Unidad', 'Paquete X - ObjetoImp3', '250.00', '500.00', '50.00', '02');
vxml.addFunctionCall('VXML_AddConceptoTraslado_cfdi40', '450.00', '002', 'Tasa', '0.160000', '72.00');
// Para funciones que afectan informacion unica, NO importa el momento en que se llamen
vxml.addFunctionCall('VXML_SetEmisorInfo_cfdi40', 'EKU9003173C9', 'NombreDelEmisorRazónSocial', '601','');
// Esta funcion afectara al ultimo CONCEPTO agregado
vmlx.addFunctionCall('VXML_AddConceptoRetencion_cfdi40','3000.00','003','Tasa','0.300000','900.00');
El resultado seria un CFDI con la siguiente estructura:
CFDI
|--Emisor
|--Receptor
|--Conceptos
|--Concepto01
|--CuentaPredial
|--Concepto02
|--Concepto03
|--Impuestos
|--Traslado
|--Retencion
CFDI40.Básicas
VXML_SetComprobanteInfo_cfdi40
- [01] Serie
- [02] Folio
- [03] Fecha
- [04] FormaPago
- [05] CondicionesDePago
- [06] SubTotal
- [07] Descuento
- [08] Moneda
- [09] TipoCambio
- [10] Total
- [11] TipoDeComprobante
- [12] MetodoPago
- [13] LugarExpedicion
- [14] Confirmacion
- [15] Exportacion
VXML_SetInformacionGlobal_cfdi40
- [01] Periodicidad
- [02] Meses
- [03] Año
VXML_AddCfdiRelacionados_cfdi40
- [01] TipoRelacion
- [02] UUID1
- [03] UUID2
- [04] UUID3
- [05] UUID4
- [06] UUID5
- [07] UUID6
- [08] UUID7
- [09] UUID8
- [10] UUID9
- [11] UUID10
VXML_AddCfdiRelacionado_cfdi40 (Usar antes AddCfdiRelacionados_cfdi40)
- [01] UUID
VXML_SetEmisorInfo_cfdi40
- [01] Rfc
- [02] Nombre
- [03] RegimenFiscal
- [04] FacAtrAdquirente
VXML_SetReceptorInfo_cfdi40
- [01] Rfc
- [02] Nombre
- [03] ResidenciaFiscal
- [04] NumRegIdTrib
- [05] UsoCFDI
- [06] DomicilioFiscalReceptor
- [07] RegimenFiscalReceptor
VXML_SetImpuestosInfo_cfdi40
- [01] TotalImpuestosTrasladados
- [02] TotalImpuestosRetenidos
VXML_AddTraslado_cfdi40 (Usar antes SetImpuestosInfo_cfdi40)
- [01] Impuesto
- [02] TipoFactor
- [03] TasaOCuota
- [04] Importe
- [05] Base
VXML_AddRetencion_cfdi40 (Usar antes SetImpuestosInfo_cfdi40)
- [01] Impuesto
- [02] Importe
VXML_SetAddenda
- [01] FragmentoXML (Debe ser válido e incluir los namespaces que no sean parte de un CFDI)
VXML_SetAddendaText
- [01] TextoAddenda
CFDI40.Conceptos
VXML_AddConcepto_cfdi40
- [01] ClaveProdServ
- [02] NoIdentificacion
- [03] Cantidad
- [04] ClaveUnidad
- [05] Unidad
- [06] Descripcion
- [07] ValorUnitario
- [08] Importe
- [09] Descuento
- [10] ObjetoImp
VXML_AddConceptoTraslado_cfdi40 (Usar antes AddConcepto_cfdi40)
- [01] Base
- [02] Impuesto
- [03] TipoFactor
- [04] TasaOCuota
- [05] Importe
VXML_AddConceptoRetencion_cfdi40 (Usar antes AddConcepto_cfdi40)
- [01] Base
- [02] Impuesto
- [03] TipoFactor
- [04] TasaOCuota
- [05] Importe
VXML_AddConceptoInformacionAduanera_cfdi40 (Usar antes AddConcepto_cfdi40)
- [01] NumeroPedimento
VXML_AddConceptoCuentaPredial_cfdi40 (Usar antes AddConcepto_cfdi40)
- [01] Numero
VXML_AddConceptoParte_cfdi40 (Usar antes AddConcepto_cfdi40)
- [01] ClaveProdServ
- [02] NoIdentificacion
- [03] Cantidad
- [04] Unidad
- [05] Descripcion
- [06] ValorUnitario
- [07] Importe
- [08] NumeroPedimento1
- [09] NumeroPedimento2
- [10] NumeroPedimento3
- [11] NumeroPedimento4
- [12] NumeroPedimento5
VXML_SetConceptoACuentaTerceros_cfdi40 (Usar antes AddConcepto_cfdi40)
- [01] RfcACuentaTerceros
- [02] NombreACuentaTerceros
- [03] RegimenFiscalACuentaTerceros
- [04] DomicilioFiscalACuentaTerceros
CFDI.Conceptos.ComplementoConcepto.iedu10
- VXML_AddConceptoComplementoIedu10 (Usar antes AddConcepto)
- [01] nombreAlumno
- [02] CURP
- [03] nivelEducativo
- [04] autRVOE
- [05] rfcPago
CFDI.Conceptos.ComplementoConcepto.ventavehiculos11
- VXML_AddConceptoComplementoVentaVehiculos11_cfdi40 (Usar antes AddConcepto)
- [01] ClaveVehicular
- [02] Niv
- [03] numero
- [04] fecha
- [05] aduana);
CFDI.Complemento.CartaPorte31
La respuesta de este complemento incluye la URL usada para el QR especifico CCP30, y de solicitarse las imagenes de QR, tambien el QRCCP30
VXML_SetCartaPorte31
- [01] IdCCP
- [02] TranspInternac
- [03] EntradaSalidaMerc
- [04] PaisOrigenDestino
- [05] ViaEntradaSalida
- [06] TotalDistRec
- [07] RegistroISTMO
- [08] UbicacionPoloOrigen
- [09] UbicacionPoloDestino
VXML_CartaPorte31AddRegimenAduanero (Usar antes SetCartaPorte31)
- [01] RegimenAduanero01
- [02] RegimenAduanero02
- [03] RegimenAduanero03
- [04] RegimenAduanero04
- [05] RegimenAduanero05
- [06] RegimenAduanero06
- [07] RegimenAduanero07
- [08] RegimenAduanero08
- [09] RegimenAduanero09
- [10] RegimenAduanero10
VXML_CartaPorte31AddUbicacion (Usar antes SetCartaPorte31)
- [01] TipoUbicacion
- [02] IDUbicacion
- [03] RFCRemitenteDestinatario
- [04] NombreRemitenteDestinatario
- [05] NumRegIdTrib
- [06] ResidenciaFiscal
- [07] NumEstacion
- [08] NombreEstacion
- [09] NavegacionTrafico
- [10] FechaHoraSalidaLlegada
- [11] TipoEstacion
- [12] DistanciaRecorrida
- [13] Calle
- [14] NumeroExterior
- [15] NumeroInterior
- [16] Colonia
- [17] Localidad
- [18] Referencia
- [19] Municipio
- [20] Estado
- [21] Pais
- [22] CodigoPostal
VXML_CartaPorte31SetMercancias
- [01] PesoBrutoTotal
- [02] UnidadPeso
- [03] PesoNetoTotal
- [04] NumTotalMercancias
- [05] CargoPorTasacion
- [06] LogisticaInversaRecoleccionDevolucion
VXML_CartaPorte31AddMercancia (Usar antes CartaPorte31SetMercancias)
- [01] BienesTransp
- [02] ClaveSTCC
- [03] Descripcion
- [04] Cantidad
- [05] ClaveUnidad
- [06] Unidad
- [07] Dimensiones
- [08] MaterialPeligroso
- [09] CveMaterialPeligroso
- [10] Embalaje
- [11] DescripEmbalaje
- [12] SectorCOFEPRIS
- [13] NombreIngredienteActivo
- [14] NomQuimico
- [15] DenominacionGenericaProd
- [16] DenominacionDistintivaProd
- [17] Fabricante
- [18] FechaCaducidad
- [19] LoteMedicamento
- [20] FormaFarmaceutica
- [21] CondicionesEspTransp
- [22] RegistroSanitarioFolioAutorizacion
- [23] PermisoImportacion
- [24] FolioImpoVUCEM
- [25] NumCAS
- [26] RazonSocialEmpImp
- [27] NumRegSanPlagCOFEPRIS
- [28] DatosFabricante
- [29] DatosFormulador
- [30] DatosMaquilador
- [31] UsoAutorizado
- [32] PesoEnKg
- [33] ValorMercancia
- [34] Moneda
- [35] FraccionArancelaria
- [36] UUIDComercioExt
- [37] TipoMateria
- [38] DescripcionMateria
VXML_CartaPorte31SetDetalleMercancia (Usar antes CartaPorte31AddMercancia)
- [01] UnidadPesoMerc
- [02] PesoBruto
- [03] PesoNeto
- [04] PesoTara
- [05] NumPiezas
VXML_CartaPorte31AddMercanciaDocumentacionAduanera (Usar antes CartaPorte31AddMercancia)
- [01] TipoDocumento
- [02] NumPedimento
- [03] IdentDocAduanero
- [04] RFCImpo
VXML_CartaPorte31AddMercanciaGuiasIdentificacion (Usar antes CartaPorte31AddMercancia)
- [01] NumeroGuiaIdentificacion
- [02] DescripGuiaIdentificacion
- [03] PesoGuiaIdentificacion
VXML_CartaPorte31AddMercanciaCantidadTransporta (Usar antes CartaPorte31AddMercancia)
- [01] Cantidad
- [02] IDOrigen
- [03] IDDestino
- [04] CvesTransporte
VXML_CartaPorte31SetMercanciasAutotransporte (Usar antes CartaPorte31AddMercancia)
- [01] PermSCT
- [02] NumPermisoSCT
- [03] ConfigVehicular
- [04] PesoBrutoVehicular
- [05] PlacaVM
- [06] AnioModeloVM
- [07] AseguraRespCivil
- [08] PolizaRespCivil
- [09] AseguraMedAmbiente
- [10] PolizaMedAmbiente
- [11] AseguraCarga
- [12] PolizaCarga
- [13] PrimaSeguro
- [14] SubTipoRem1
- [15] Placa1
- [16] SubTipoRem2
- [17] Placa2
VXML_CartaPorte31SetMercanciasTransporteMaritimo (Usar antes CartaPorte31AddMercancia)
- [01] PermSCT
- [02] NumPermisoSCT
- [03] NombreAseg
- [04] NumPolizaSeguro
- [05] TipoEmbarcacion
- [06] Matricula
- [07] NumeroOMI
- [08] AnioEmbarcacion
- [09] NombreEmbarc
- [10] NacionalidadEmbarc
- [11] UnidadesDeArqBruto
- [12] TipoCarga
- [13] Eslora
- [14] Manga
- [15] Calado
- [16] Puntal
- [17] LineaNaviera
- [18] NombreAgenteNaviero
- [19] NumAutorizacionNaviero
- [20] NumViaje
- [21] NumConocEmbarc
- [22] PermisoTempNavegacion
VXML_CartaPorte31AddMercanciasTransporteMaritimoContenedor (Usar antes CartaPorte31SetMercanciasTransporteMaritimo)
- [01] TipoContenedor
- [02] MatriculaContenedor
- [03] NumPrecinto
- [04] IdCCPRelacionado
- [05] PlacaVMCCP
- [06] FechaCertificacionCCP
- [07] SubTipoRemCCP1
- [08] PlacaCCP1
- [09] SubTipoRemCCP2
- [10] PlacaCCP2
VXML_CartaPorte31SetMercanciasTransporteAereo (Usar antes CartaPorte31AddMercancia)
- [01] PermSCT
- [02] NumPermisoSCT
- [03] MatriculaAeronave
- [04] NombreAseg
- [05] NumPolizaSeguro
- [06] NumeroGuia
- [07] LugarContrato
- [08] CodigoTransportista
- [09] RFCEmbarcador
- [10] NumRegIdTribEmbarc
- [11] ResidenciaFiscalEmbarc
- [12] NombreEmbarcador
VXML_CartaPorte31SetMercanciasTransporteFerroviario (Usar antes CartaPorte31AddMercancia)
- [01] TipoDeServicio
- [02] TipoDeTrafico
- [03] NombreAseg
- [04] NumPolizaSeguro
- [05] TipoDerechoDePaso
- [06] KilometrajePagado
- [07] TipoCarro
- [08] MatriculaCarro
- [09] GuiaCarro
- [10] ToneladasNetasCarro
- [11] TipoContenedor
- [12] PesoContenedorVacio
- [13] PesoNetoMercancia
VXML_CartaPorte31AddMercanciasTransporteFerroviarioDerechosDePaso (Usar antes CartaPorte31SetMercanciasTransporteFerroviario)
- [01] TipoDerechoDePaso
- [02] KilometrajePagado
VXML_CartaPorte31AddMercanciasTransporteFerroviarioCarro (Usar antes CartaPorte31SetMercanciasTransporteFerroviario)
- [01] TipoCarro
- [02] MatriculaCarro
- [03] GuiaCarro
- [04] ToneladasNetasCarro
- [05] TipoContenedor
- [06] PesoContenedorVacio
- [07] PesoNetoMercancia
VXML_CartaPorte31AddMercanciasTransporteFerroviarioCarroContenedor (Usar antes CartaPorte31SetMercanciasTransporteFerroviario)
- [01] TipoContenedor
- [02] PesoContenedorVacio
- [03] PesoNetoMercancia
VXML_CartaPorte31AddFiguraTransporteTiposFigura
- [01] TipoFigura
- [02] RFCFigura
- [03] NumLicencia
- [04] NombreFigura
- [05] NumRegIdTribFigura
- [06] ResidenciaFiscalFigura
- [07] ParteTransporte
- [08] Calle
- [09] NumeroExterior
- [10] NumeroInterior
- [11] Colonia
- [12] Localidad
- [13] Referencia
- [14] Municipio
- [15] Estado
- [16] Pais
- [17] CodigoPostal
VXML_CartaPorte31AddFiguraTransporteTiposFiguraPartesTransporte (Usar antes CartaPorte31AddFiguraTransporteTiposFigura)
- [01] ParteTransporte
CFDI.Complemento.Nomina12
VXML_SetNomina12
- [01] TipoNomina
- [02] FechaPago
- [03] FechaInicialPago
- [04] FechaFinalPago
- [05] NumDiasPagados
- [06] TotalPercepciones
- [07] TotalDeducciones
- [08] TotalOtrosPagos
VXML_Nomina12SetEmisor (Usar antes SetNomina12)
- [01] Curp
- [02] RegistroPatronal
- [03] RfcPatronOrigen
- [04] OrigenRecurso
- [05] MontoRecursoPropio
VXML_Nomina12SetReceptor (Usar antes SetNomina12)
- [01] Curp
- [02] NumSeguridadSocial
- [03] FechaInicioRelLaboral
- [04] Antigüedad
- [05] TipoContrato
- [06] Sindicalizado
- [07] TipoJornada
- [08] TipoRegimen
- [09] NumEmpleado
- [10] Departamento
- [11] Puesto
- [12] RiesgoPuesto
- [13] PeriodicidadPago
- [14] Banco
- [15] CuentaBancaria
- [16] SalarioBaseCotApor
- [17] SalarioDiarioIntegrado
- [18] ClaveEntFed
VXML_Nomina12AddSubContratacion (Usar antes Nomina12SetReceptor)
- [01] RfcLabora
- [02] PorcentajeTiempo
VXML_Nomina12SetPercepciones (Usar antes SetNomina12)
- [01] TotalSueldos
- [02] TotalSeparacionIndemnizacion
- [03] TotalJubilacionPensionRetiro
- [04] TotalGravado
- [05] TotalExento
VXML_Nomina12AddPercepcion (Usar antes Nomina12SetPercepciones)
- [01] TipoPercepcion
- [02] Clave
- [03] Concepto
- [04] ImporteGravado
- [05] ImporteExento
- [06] Dias
- [07] TipoHoras
- [08] HorasExtra
- [09] ImportePagado
- [10] ValorMercado
- [11] PrecioAlOtorgarse
VXML_Nomina12SetJubilacionPensionRetiro (Usar antes Nomina12SetPercepciones)
- [01] TotalUnaExhibicion
- [02] TotalParcialidad
- [03] MontoDiario
- [04] IngresoAcumulable
- [05] IngresoNoAcumulable
VXML_Nomina12SetSeparacionIndemnizacion (Usar antes Nomina12SetPercepciones)
- [01] TotalPagado
- [02] NumAñosServicio
- [03] UltimoSueldoMensOrd
- [04] IngresoAcumulable
- [05] IngresoNoAcumulable
VXML_Nomina12SetDeducciones (Usar antes SetNomina12)
- [01] TotalOtrasDeducciones
- [02] TotalImpuestosRetenidos
VXML_Nomina12AddDeduccion (Usar antes Nomina12SetDeducciones)
- [01] TipoDeduccion
- [02] Clave
- [03] Concepto
- [04] Importe
VXML_Nomina12AddOtroPago (Usar antes SetNomina12)
- [01] TipoOtroPago
- [02] Clave
- [03] Concepto
- [04] Importe
- [05] SaldoAFavor
- [06] Año
- [07] RemanenteSalFav
- [08] SubsidioCausado
VXML_Nomina12AddIncapacidad (Usar antes SetNomina12)
- [01] DiasIncapacidad
- [02] TipoIncapacidad
- [03] ImporteMonetario
CFDI.Complemento.cce20
VXML_SetComercioExterior20
- [01] MotivoTraslado
- [02] ClaveDePedimento
- [03] CertificadoOrigen
- [04] NumCertificadoOrigen
- [05] NumeroExportadorConfiable
- [06] Incoterm
- [07] Observaciones
- [08] TipoCambioUSD
- [09] TotalUSD
VXML_CCE20SetEmisor (Usar antes SetComercioExterior20)
- [01] Curp
- [02] Calle
- [03] NumeroExterior
- [04] NumeroInterior
- [05] Colonia
- [06] Localidad
- [07] Referencia
- [08] Municipio
- [09] Estado
- [10] Pais
- [11] CodigoPostal
VXML_CCE20SetReceptor (Usar antes SetComercioExterior20)
- [01] NumRegIdTrib
- [02] Calle
- [03] NumeroExterior
- [04] NumeroInterior
- [05] Colonia
- [06] Localidad
- [07] Referencia
- [08] Municipio
- [09] Estado
- [10] Pais
- [11] CodigoPostal
VXML_CCE20AddDestinatario (Usar antes SetComercioExterior20)
- [01] NumRegIdTrib
- [02] Nombre
- [03] Calle
- [04] NumeroExterior
- [05] NumeroInterior
- [06] Colonia
- [07] Localidad
- [08] Referencia
- [09] Municipio
- [10] Estado
- [11] Pais
- [12] CodigoPostal
VXML_CCE20AddDestinatarioDomicilio (Usar antes CCE20AddDestinatario)
- [01] Calle
- [02] NumeroExterior
- [03] NumeroInterior
- [04] Colonia
- [05] Localidad
- [06] Referencia
- [07] Municipio
- [08] Estado
- [09] Pais
- [10] CodigoPostal
VXML_CCE20AddPropietario (Usar antes SetComercioExterior20)
- [01] NumRegIdTrib
- [02] ResidenciaFiscal
VXML_CCE20AddMercancia (Usar antes SetComercioExterior20)
- [01] NoIdentificacion
- [02] FraccionArancelaria
- [03] CantidadAduana
- [04] UnidadAduana
- [05] ValorUnitarioAduana
- [06] ValorDolares
- [07] Marca
- [08] Modelo
- [09] SubModelo
- [10] NumeroSerie
VXML_CCE20AddMercanciaDescripcionesEspecificas (Usar antes CCE20AddMercancia)
- [01] Marca
- [02] Modelo
- [03] SubModelo
- [04] NumeroSerie
CFDI.Complemento.pagos20
VXML_SetPagos20
- [01] TotalRetencionesIVA
- [02] TotalRetencionesISR
- [03] TotalRetencionesIEPS
- [04] TotalTrasladosBaseIVA16
- [05] TotalTrasladosImpuestoIVA16
- [06] TotalTrasladosBaseIVA8
- [07] TotalTrasladosImpuestoIVA8
- [08] TotalTrasladosBaseIVA0
- [09] TotalTrasladosImpuestoIVA0
- [10] TotalTrasladosBaseIVAExento
- [11] MontoTotalPagos
VXML_Pagos20AddPago (Usar antes SetPagos20)
- [01] FechaPago
- [02] FormaDePagoP
- [03] MonedaP
- [04] TipoCambioP
- [05] Monto
- [06] NumOperacion
- [07] RfcEmisorCtaOrd
- [08] NomBancoOrdExt
- [09] CtaOrdenante
- [10] RfcEmisorCtaBen
- [11] CtaBeneficiario
- [12] TipoCadPago
- [13] CertPago
- [14] CadPago
- [15] SelloPago
VXML_Pagos20AddPagoDoctoRelacionado (Usar antes Pagos20AddPago)
- [01] IdDocumento
- [02] Serie
- [03] Folio
- [04] MonedaDR
- [05] EquivalenciaDR
- [06] NumParcialidad
- [07] ImpSaldoAnt
- [08] ImpPagado
- [09] ImpSaldoInsoluto
- [10] ObjetoImpDR
VXML_Pagos20AddPagoDoctoRelacionadoRetencionDR (Usar antes Pagos20AddPagoDoctoRelacionado)
- [01] BaseDR
- [02] ImpuestoDR
- [03] TipoFactorDR
- [04] TasaOCuotaDR
- [05] ImporteDR
VXML_Pagos20AddPagoDoctoRelacionadoTrasladoDR (Usar antes Pagos20AddPagoDoctoRelacionado)
- [01] BaseDR
- [02] ImpuestoDR
- [03] TipoFactorDR
- [04] TasaOCuotaDR
- [05] ImporteDR
VXML_Pagos20AddPagoImpuestosPRetencionP (Usar antes Pagos20AddPago)
- [01] ImpuestoP
- [02] ImporteP
VXML_Pagos20AddPagoImpuestosPTrasladoP (Usar antes Pagos20AddPago)
- [01] BaseP
- [02] ImpuestoP
- [03] TipoFactorP
- [04] TasaOCuotaP
- [05] ImporteP
CFDI.Complemento.ImpuestosLocales10
VXML_SetImpuestosLocales10
- [01] TotaldeTraslados
- [02] TotaldeRetenciones
VXML_ImpLocal10AddRetencionesLocales (Usar antes SetImpuestosLocales10)
- [01] ImpLocRetenido
- [02] TasadeRetencion
- [03] Importe
VXML_ImpLocal10AddTrasladosLocales (Usar antes SetImpuestosLocales10)
- [01] ImpLocTrasladado
- [02] TasadeTraslado
- [03] Importe
CFDI.Complemento.Donatarias11
- VXML_SetDonatarias11
- [01] noAutorizacion
- [02] fechaAutorizacion
- [03] leyenda
CFDI.Complemento.INE11
VXML_SetINE11
- [01] TipoProceso
- [02] TipoComite
- [03] IdContabilidad
- [04] ClaveEntidad
- [05] Ambito
- [06] EntidadContabilidadIdContabilidad
VXML_INE11AddEntidad (Usar antes SetINE11)
- [01] ClaveEntidad
- [02] Ambito
- [03] IdContabilidad
VXML_INE11AddEntidadContabilidad (Usar antes INE11AddEntidad)
- [01] IdContabilidad
CFDI.Complemento.Divisas10
- VXML_SetDivisas10
- [01] tipoOperacion
CFDI.Complemento.Aerolineas10
VXML_SetAerolineas10
- [01] TUA
- [02] TotalCargos
- [03] CodigoCargo
- [04] Importe
VXML_Aerolineas10AddCargo (Usar antes SetAerolineas10)
- [01] CodigoCargo
- [02] Importe
CFDI.Complemento.NotariosPublicos10
VXML_SetNotariosPublicos10
- [01] TipoInmueble
- [02] Calle
- [03] NoExterior
- [04] NoInterior
- [05] Colonia
- [06] Localidad
- [07] Referencia
- [08] Municipio
- [09] Estado
- [10] Pais
- [11] CodigoPostal
- [12] NumInstrumentoNotarial
- [13] FechaInstNotarial
- [14] MontoOperacion
- [15] Subtotal
- [16] IVA
- [17] CURP
- [18] NumNotaria
- [19] EntidadFederativa
- [20] Adscripcion
- [21] CoproSocConyugalEEnajenante
- [22] CoproSocConyugalEAdquiriente
VXML_NotariosPublicos10AddDescInmueble (Usar antes SetNotariosPublicos10)
- [01] TipoInmueble
- [02] Calle
- [03] NoExterior
- [04] NoInterior
- [05] Colonia
- [06] Localidad
- [07] Referencia
- [08] Municipio
- [09] Estado
- [10] Pais
- [11] CodigoPostal
VXML_NotariosPublicos10AddDatosUnEnajenante (Usar antes SetNotariosPublicos10)
- [01] Nombre
- [02] ApellidoPaterno
- [03] ApellidoMaterno
- [04] RFC
- [05] CURP
VXML_NotariosPublicos10AddDatosEnajenanteCopSC (Usar antes SetNotariosPublicos10)
- [01] Nombre
- [02] ApellidoPaterno
- [03] ApellidoMaterno
- [04] RFC
- [05] CURP
- [06] Porcentaje
VXML_NotariosPublicos10AddDatosUnAdquiriente (Usar antes SetNotariosPublicos10)
- [01] Nombre
- [02] ApellidoPaterno
- [03] ApellidoMaterno
- [04] RFC
- [05] CURP
VXML_NotariosPublicos10AddDatosAdquirienteCopSC (Usar antes SetNotariosPublicos10)
- [01] Nombre
- [02] ApellidoPaterno
- [03] ApellidoMaterno
- [04] RFC
- [05] CURP
- [06] Porcentaje
CFDI.Complemento.VehiculoRenovacionSustitucionVehiculo10
VXML_SetRenovSustitVehiculos10
- [01] TipoDeDecreto
VXML_RenovSustitVehiculos10AddRenovVehicular (Usar antes SetRenovSustitVehiculos10)
- [01] VehEnaj
- [02] UsadoPrecioVehUsado
- [03] UsadoTipoVeh
- [04] UsadoMarca
- [05] UsadoTipooClase
- [06] UsadoAño
- [07] UsadoModelo
- [08] UsadoNIV
- [09] UsadoNumSerie
- [10] UsadoNumPlacas
- [11] UsadoNumMotor
- [12] UsadoNumFolTarjCir
- [13] UsadoNumPedIm
- [14] UsadoAduana
- [15] UsadoFechaRegulVeh
- [16] UsadoFoliofiscal
- [17] NuevoAño
- [18] NuevoModelo
- [19] NuevoNumPlacas
- [20] NuevoRFC
VXML_RenovSustitVehiculos10AddRenovVehicularVehiculoUsado (Usar antes RenovSustitVehiculos10AddRenovVehicular)
- [01] UsadoPrecioVehUsado
- [02] UsadoTipoVeh
- [03] UsadoMarca
- [04] UsadoTipooClase
- [05] UsadoAño
- [06] UsadoModelo
- [07] UsadoNIV
- [08] UsadoNumSerie
- [09] UsadoNumPlacas
- [10] UsadoNumMotor
- [11] UsadoNumFolTarjCir
- [12] UsadoNumPedIm
- [13] UsadoAduana
- [14] UsadoFechaRegulVeh
- [15] UsadoFoliofiscal
VXML_RenovSustitVehiculos10AddSustitVehicular (Usar antes SetRenovSustitVehiculos10)
- [01] VehEnaj
- [02] UsadoPrecioVehUsado
- [03] UsadoTipoVeh
- [04] UsadoMarca
- [05] UsadoTipooClase
- [06] UsadoAño
- [07] UsadoModelo
- [08] UsadoNIV
- [09] UsadoNumSerie
- [10] UsadoNumPlacas
- [11] UsadoNumMotor
- [12] UsadoNumFolTarjCir
- [13] UsadoNumFolAvisoint
- [14] UsadoNumPedIm
- [15] UsadoAduana
- [16] UsadoFechaRegulVeh
- [17] UsadoFoliofiscal
- [18] NuevoAño
- [19] NuevoModelo
- [20] NuevoNumPlacas
- [21] NuevoRFC
CFDI.Complemento.LeyendasFiscales10
- VXML_SetLeyendasFiscales10Full
- [01] A_disposicionFiscal01
- [02] A_norma01
- [03] A_textoLeyenda01
- [04] A_disposicionFiscal02
- [05] A_norma02
- [06] A_textoLeyenda02
- [07] A_disposicionFiscal03
- [08] A_norma03
- [09] A_textoLeyenda03
- [10] A_disposicionFiscal04
- [11] A_norma04
- [12] A_textoLeyenda04
- [13] A_disposicionFiscal05
- [14] A_norma05
- [15] A_textoLeyenda05
- [16] A_disposicionFiscal06
- [17] A_norma06
- [18] A_textoLeyenda06
- [19] A_disposicionFiscal07
- [20] A_norma07
- [21] A_textoLeyenda07
- [22] A_disposicionFiscal08
- [23] A_norma08
- [24] A_textoLeyenda08
- [25] A_disposicionFiscal09
- [26] A_norma09
- [27] A_textoLeyenda09
- [28] A_disposicionFiscal10
- [29] A_norma10
- [30] A_textoLeyenda10
CFDI.Complemento.VehiculoUsado10
VXML_SetVehiculoUsado10
- [01] montoAdquisicion
- [02] montoEnajenacion
- [03] claveVehicular
- [04] marca
- [05] tipo
- [06] modelo
- [07] numeroMotor
- [08] numeroSerie
- [09] NIV
- [10] valor
- [11] numero
- [12] fecha
- [13] aduana
VXML_VehiculoUsado10AddInformacionAduanera (Usar antes SetVehiculoUsado10)
- [01] numero
- [02] fecha
- [03] aduana
CFDI.Complemento.ServicioParcial10
- VXML_SetServicioParcial10
- [01] NumPerLicoAut
- [02] Calle
- [03] NoExterior
- [04] NoInterior
- [05] Colonia
- [06] Localidad
- [07] Referencia
- [08] Municipio
- [09] Estado
- [10] CodigoPostal
CFDI.Complemento.SPEI10
- VXML_Spei10AddSpeiTercero
- [01] FechaOperacion
- [02] Hora
- [03] ClaveSPEI
- [04] sello
- [05] numeroCertificado
- [06] cadenaCDA
- [07] Concepto
- [08] IVA
- [09] MontoPago
- [10] BancoReceptor
- [11] NombreReceptor
- [12] TipoCuentaReceptor
- [13] CuentaReceptor
- [14] RFCReceptor
- [15] BancoEmisor
- [16] NombreEmisor
- [17] TipoCuentaEmisor
- [18] CuentaEmisor
- [19] RFCEmisor
CFDI.Complemento.EstadoCuentaCombustible12
VXML_SetEstadoDeCuentaCombustible12
- [01] (NumeroDeCuenta
- [02] SubTotal
- [03] Total
VXML_EstadoDeCuentaCombustible12AddConcepto (Usar antes SetEstadoDeCuentaCombustible12)
- [01] Identificador
- [02] Fecha
- [03] Rfc
- [04] ClaveEstacion
- [05] Cantidad
- [06] TipoCombustible
- [07] Unidad
- [08] NombreCombustible
- [09] FolioOperacion
- [10] ValorUnitario
- [11] Importe
VXML_EstadoDeCuentaCombustible12AddConceptoTraslado (Usar antes EstadoDeCuentaCombustible12AddConcepto)
- [01] Impuesto
- [02] TasaOCuota
- [03] Importe
CFDI.Complemento.ConsumoDeCombustibles11
VXML_SetConsumoDeCombustibles11
- [01] numeroDeCuenta
- [02] subTotal
- [03] total
VXML_ConsumoDeCombustibles11AddConcepto (Usar antes SetConsumoDeCombustibles11)
- [01] identificador
- [02] fecha
- [03] rfc
- [04] claveEstacion
- [05] tipoCombustible
- [06] cantidad
- [07] nombreCombustible
- [08] folioOperacion
- [09] valorUnitario
- [10] importe
VXML_ConsumoDeCombustibles11AddConceptoDeterminado (Usar antes ConsumoDeCombustibles11AddConcepto)
- [01] impuesto
- [02] tasaOCuota
- [03] importe
CFDI.Complemento.PagoEnEspecie10
- VXML_SetPagoEnEspecie10
- [01] CvePIC
- [02] FolioSolDon
- [03] PzaArtNombre
- [04] PzaArtTecn
- [05] PzaArtAProd
- [06] PzaArtDim
CFDI.Complemento.PFIntegranteCoordinado10
- VXML_SetPFintegranteCoordinado10
- [01] ClaveVehicular
- [02] Placa
- [03] RFCPF
CFDI.Complemento.TuristaPasajeroExtranjero10
- VXML_SetTuristaPasajeroExtranjero10
- [01] fechadeTransito
- [02] tipoTransito
- [03] Via
- [04] TipoId
- [05] NumeroId
- [06] Nacionalidad
- [07] EmpresaTransporte
- [08] IdTransporte
CFDI.Complemento.ValesDeDespensa10
VXML_SetValesDeDespensa10
- [01] registroPatronal
- [02] numeroDeCuenta
- [03] total
- [04] identificador
- [05] fecha
- [06] rfc
- [07] curp
- [08] nombre
- [09] numSeguridadSocial
- [10] importe
VXML_ValesDeDespensa10AddConcepto (Usar antes SetValesDeDespensa10)
- [01] identificador
- [02] fecha
- [03] rfc
- [04] curp
- [05] nombre
- [06] numSeguridadSocial
- [07] importe
CFDI.Complemento.Detallista10
VXML_SetDetallista10
- [01] A_documentStatus
- [02] E_requestForPaymentIdentification_entityType
- [03] E_orderIdentification_referenceIdentification
- [04] E_orderIdentification_ReferenceDate
- [05] A_AdditionalInformationReferenceIdentification_type
- [06] E_AdditionalInformationReferenceIdentification_referenceIdentification
- [07] E_buyer_gln
- [08] E_buyerContactInformationPersonOrDepartmentName_text
- [09] E_seller_gln
- [10] A_seller_alternatePartyIdentificationType
- [11] E_seller_alternatePartyIdentification
- [12] E_shipTo_gln
- [13] E_shipTo_nameAndAddressName
- [14] E_shipTo_nameAndAddressStreetAddressOne
- [15] E_shipTo_nameAndAddressCity
- [16] E_shipTo_nameAndAddressPostalCode
- [17] E_InvoiceCreator_gln
- [18] A_InvoiceCreator_alternatePartyIdentificationType
- [19] E_InvoiceCreator_alternatePartyIdentification
- [20] E_InvoiceCreator_nameAndAddressName
- [21] E_InvoiceCreator_nameAndAddressStreetAddressOne
- [22] E_InvoiceCreator_nameAndAddressCity
- [23] E_InvoiceCreator_nameAndAddressPostalCode
- [24] A_paymentTerms_paymentTermsEvent
- [25] A_paymentTerms_PaymentTermsRelationTime
- [26] A_paymentTerms_netPaymentNetPaymentTermsType
- [27] A_paymentTerms_netPaymentTimePeriod
- [28] E_paymentTerms_netPaymentValue
- [29] A_paymentTerms_discountPaymentDiscountType
- [30] E_paymentTerms_discountPaymentPercentage
- [31] E_totalAmount_Amount
VXML_Detallista10AddOrderIdentificationReferenceIdentification (Usar antes SetDetallista10)
- [01] E_orderIdentification_referenceIdentification
VXML_Detallista10AddAdditionalInformationReferenceIdentification (Usar antes SetDetallista10)
- [01] A_AdditionalInformationReferenceIdentification_type
- [02] E_AdditionalInformationReferenceIdentification_referenceIdentification
VXML_Detallista10AddSpecialInstruction (Usar antes SetDetallista10)
- [01] A_code
- [02] E_text01
- [03] E_text02
- [04] E_text03
- [05] E_text04
- [06] E_text05
- [07] E_text06
- [08] E_text07
- [09] E_text08
- [10] E_text09
- [11] E_text10
- [12] E_text11
- [13] E_text12
- [14] E_text13
- [15] E_text14
- [16] E_text15
VXML_Detallista10AddDeliveryNote (Usar antes SetDetallista10)
- [01] E_ReferenceDate
- [02] E_referenceIdentification01
- [03] E_referenceIdentification02
- [04] E_referenceIdentification03
- [05] E_referenceIdentification04
- [06] E_referenceIdentification05
- [07] E_referenceIdentification06
- [08] E_referenceIdentification07
- [09] E_referenceIdentification08
- [10] E_referenceIdentification09
- [11] E_referenceIdentification10
- [12] E_referenceIdentification11
- [13] E_referenceIdentification12
- [14] E_referenceIdentification13
- [15] E_referenceIdentification14
- [16] E_referenceIdentification15
- [17] E_referenceIdentification16
- [18] E_referenceIdentification17
- [19] E_referenceIdentification18
- [20] E_referenceIdentification19
- [21] E_referenceIdentification20
VXML_Detallista10AddCustoms (Usar antes SetDetallista10)
- [01] E_gln
VXML_Detallista10AddCurrency (Usar antes SetDetallista10)
- [01] A_currencyISOCode
- [02] E_currencyFunction01
- [03] E_currencyFunction02
- [04] E_currencyFunction03
- [05] E_rateOfChange
VXML_Detallista10AddShipmentDetail (Usar antes SetDetallista10)
- [01] E_shipmentDetail
VXML_Detallista10AddAllowanceCharge (Usar antes SetDetallista10)
- [01] A_allowanceChargeType
- [02] A_settlementType
- [03] A_sequenceNumber
- [04] E_specialServicesType
- [05] A_monetaryAmountOrPercentage_base
- [06] E_monetaryAmountOrPercentage_percentage
VXML_Detallista10AddTotalAllowanceCharge (Usar antes SetDetallista10)
- [01] A_allowanceOrChargeType
- [02] E_specialServicesType
- [03] E_Amount
VXML_Detallista10AddLineItem (Usar antes SetDetallista10)
- [01] A_type
- [02] A_number
- [03] E_tradeItemIdentification_gtin
- [04] A_tradeItemDescriptionInformation_language
- [05] E_tradeItemDescriptionInformation_longText
- [06] A_invoicedQuantity_unitOfMeasure
- [07] E_invoicedQuantity_invoicedQuantity
- [08] E_grossPrice_Amount
- [09] E_netPrice_Amount
- [10] A_AdditionalInformation_type
- [11] E_AdditionalInformation_referenceIdentification
- [12] A_LogisticUnits_type
- [13] E_LogisticUnits_serialShippingContainerCode
- [14] E_palletInformation_palletQuantity
- [15] A_palletInformation_type
- [16] E_palletInformation_description
- [17] E_palletInformation_methodOfPayment
- [18] E_totalLineAmount_grossAmount
- [19] E_totalLineAmount_netAmount
VXML_Detallista10AddLineItemAlternateTradeItemIdentification (Usar antes Detallista10AddLineItem)
- [01] A_type
- [02] E_alternateTradeItemIdentification
VXML_Detallista10AddLineItemAditionalQuantity (Usar antes Detallista10AddLineItem)
- [01] A_QuantityType
- [02] E_aditionalQuantity
VXML_Detallista10AddLineItemCustoms (Usar antes Detallista10AddLineItem)
- [01] E_gln
- [02] A_alternatePartyIdentification_type
- [03] E_alternatePartyIdentification
- [04] E_ReferenceDate
- [05] E_nameAndAddress_name
VXML_Detallista10AddLineItemExtendedAttributes (Usar antes Detallista10AddLineItem)
- [01] A_productionDate
- [02] E_lotNumber
VXML_Detallista10AddLineItemAllowanceCharge (Usar antes Detallista10AddLineItem)
- [01] A_allowanceChargeType
- [02] A_settlementType
- [03] A_sequenceNumber
- [04] E_specialServicesType
- [05] E_percentagePerUnit
- [06] E_amountPerUnit
VXML_Detallista10AddLineItemTradeItemTaxInformation (Usar antes Detallista10AddLineItem)
- [01] E_taxTypeDescription
- [02] E_referenceNumber
- [03] E_taxPercentage
- [04] E_taxAmount
- [05] E_taxCategory
CFDI.Especiales
VXML_AddComplemento
- [01] fragmentoXML (Debe ser válido e incluir los namespaces que pudiera utilizar)
VXML_AddComplementoConcepto
- [01] fragmentoXML (Debe ser válido e incluir los namespaces que pudiera utilizar)
VXML_AddNameSpace Agrega un namespace al nodo principal XML del CFDI.
- [01] Namespace
- [02] url
- [03] schemalocation
Ejemplos
Solicitud de Cancelación
const VXML = require('vxml-cfdi');
let vxml = new VXML();
let ts = Date.now() - (new Date().getTimezoneOffset()) * 60000; // GMT-6
vxml.cancelaCFDI2022("demo_nodejs", // usuario VXML
"EKU9003173C9", // rfcemisor
"163feb31-9c01-40f0-b85b-ebe1c771da1f", // UUID
"02", // Motivo
"", // folioSustitucion
"./test/CSD_EKU9003173C9.cer", // CER
"./test/CSD_EKU9003173C9.key", // KEY
"12345678a", // usuario PWD
"./test/out/", // ruta para guardar acuse generado
"prefijo", // prefijo de archivo para acuse generado
"cancelacion") // sufijo de archivo para acuse generado
.then((response) => {
// Handle Response
}).catch((err) => {
// Handle Error
});
CFDI40 Sin Complemento
const VXML = require('vxml-cfdi');
let vxml = new VXML();
let ts = Date.now() - (new Date().getTimezoneOffset()) * 60000; // GMT-6
let FechaCFDI = (new Date(ts)).toISOString().substring(0, 19); // Fecha formato 2018-03-29T14:22:10
vxml.addFunctionCall('VXML_SetComprobanteInfo_cfdi40', 'A', '1', FechaCFDI, '99', 'Contado Comercial', '1000.00', '50.00', 'MXN', '', '1102.00', 'I', 'PPD', '53050', '', '01');
vxml.addFunctionCall('VXML_AddCfdiRelacionados_cfdi40', '04', 'FF93C8BE-AF7B-4FC5-8854-6DAE18CFB5B4', 'D8E18C2F-2859-4927-A0F0-EA3E93642DDC', '', '', '', '', '', '', '', '');
vxml.addFunctionCall('VXML_AddCfdiRelacionado_cfdi40', 'BE1D4B47-E167-47A3-8049-70D4D43BCBE8');
vxml.addFunctionCall('VXML_AddCfdiRelacionados_cfdi40', '01', 'FDBA380A-9732-4FB5-A6CB-5FB4BD831697', '', '', '', '', '', '', '', '', '');
vxml.addFunctionCall('VXML_SetEmisorInfo_cfdi40', 'EKU9003173C9', 'ESCUELA KEMPER URGATE SA DE CV', '601', '');
vxml.addFunctionCall('VXML_SetReceptorInfo_cfdi40', 'ESD140725UP8', '"E-SI SOLUCIONES DIGITALES"', '', '', 'G01', '53050', '601');
vxml.addFunctionCall('VXML_AddConcepto_cfdi40', '84111506', 'SEFXXX', '1', 'H87', 'Unidad', 'Paquete X - ObjetoImp2', '500.00', '500.00', '', '02');
vxml.addFunctionCall('VXML_AddConceptoTraslado_cfdi40', '500.00', '002', 'Tasa', '0.160000', '80.00');
vxml.addFunctionCall('VXML_AddConcepto_cfdi40', '84111506', 'SEFXXX', '2', 'H87', 'Unidad', 'Paquete X - ObjetoImp2', '250.00', '500.00', '50.00', '02');
vxml.addFunctionCall('VXML_AddConceptoTraslado_cfdi40', '450.00', '002', 'Tasa', '0.160000', '72.00');
vxml.addFunctionCall('VXML_SetImpuestosInfo_cfdi40', '152.00', '');
vxml.addFunctionCall('VXML_AddTraslado_cfdi40', '002', 'Tasa', '0.160000', '152.00', '950.00');
vxml.addFunctionCall('VXML_SetAddenda', '<MyOwnNode name="CFDI40"><AnyChildNode data="BASICO" /></MyOwnNode>');
vxml.emiteCFDI40("demo_nodejs",
"EKU9003173C9",
"./test/CSD_EKU9003173C9.cer",
"./test/CSD_EKU9003173C9.key",
"12345678a",
"./test/out/",
"CFDI40_Basico_" + (new Date(ts)).toISOString().substring(0, 10),
"nodejs", true, true, true, true)
.then((response) => {
// Handle Response