Download the PHP package phpcfdi/sat-estado-cfdi without Composer

On this page you can find all versions of the php package phpcfdi/sat-estado-cfdi. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package sat-estado-cfdi

phpcfdi/sat-estado-cfdi

Source Code Packagist PHP Version Support Discord Latest Version Software License Build Status Reliability Maintainability Code Coverage Violations Total Downloads

Consulta el estado de un CFDI en el webservice del SAT

:us: This library contains helpers to consume the Servicio de Consulta de CFDI from SAT. The documentation of this project is in spanish as this is the natural language for intended audience.

:mexico: Esta librería se utiliza para consumir el Servicio de Consulta de CFDI del SAT. La documentación del proyecto está en español porque ese es el lenguaje de los usuarios que la utilizarán.

Esta librería solo permite verificar el estado de un CFDI Regular y no de CFDI de Retenciones e información de pagos. Para estos últimos, use la librería phpcfdi/sat-estado-retenciones.

Servicio de Consulta de CFDI del SAT:

Cambios recientes en el servicio:

Instalación

Usa composer

Ejemplo básico de uso

Los pasos básicos son:

Clientes de consumo ConsumerClientInterface

Esta librería incluye dos diferentes clientes de consumo: SoapConsumerClient y HttpConsumerClient.

Además, puedes usar tu propio cliente de consumo implementando la interface ConsumerClientInterface.

Cliente SOAP SoapConsumerClient

El cliente SoapConsumerClient permite hacer el consumo usando la estrategia SOAP.

Requerimientos:

Ejemplo:

Cliente HTTP PSR HttpConsumerClient

El cliente HttpConsumerClient permite hacer el consumo usando la estrategia HTTP con base en los estándares PSR.

Estándares utilizados:

Las librerías de Guzzle guzzlehttp/guzzle, y guzzlehttp/psr7 proveen los estándares necesarios.

O puedes ver en Packagist los que te agraden:

Requerimientos:

Ejemplo:

El siguiente es un ejemplo usando symfony/http-client y nyholm/psr7:

Para Laravel puedes usar algún paquete adicional como wimski/laravel-psr-http, que gracias al uso del propio framework y php-http/discovery, facilita la creación de los objetos, ya sea que los fabrique directamente usando el contenedor, o bien los inyecte como dependencias.

También te recomiendo hacer tu propio Service Provider o configurar el Service Container y solo requerir la clase Consumer como cualquier otra dependencia y permitir que sea inyectada.

Expresiones (input)

El consumidor requiere una expresión para poder consultar. La expresión es el texto que viene en el código QR de la representación impresa de un CFDI.

Las expresiones son diferentes para CFDI 3.2, CFDI 3.3, CFDI 4.0, RET 1.0 y RET 2.0. Tienen reglas específicas de formato y de la información que debe contener.

Si no cuentas con la expresión, te recomiendo usar la librería phpcfdi/cfdi-expresiones que puedes instalar usando composer require phpcfdi/cfdi-expresiones.

Estados (salida)

Después de consumir el servicio, se responderá con un objeto CfdiStatus que agrupa de los cuatro estados.

Los estados son enumeradores, puedes compararlos rápidamente usando métodos de ayuda is*, por ejemplo: $response->document->isCancelled().

Posibles estados:

Estados mutuamente excluyentes

CodigoEstatus Estado EsCancelable EstatusCancelacion Explicación
N - ... * * * El SAT no sabe del CFDI con la expresión dada
S - ... Cancelado * Plazo vencido Cancelado por plazo vencido
S - ... Cancelado * Cancelado con aceptación Cancelado con aceptación del receptor
S - ... Cancelado * Cancelado sin aceptación No fue requerido preguntarle al receptor y se canceló
S - ... Vigente No cancelable * No se puede cancelar
S - ... Vigente Cancelable sin aceptación * Se puede cancelar, pero no se ha realizado la cancelación
S - ... Vigente Cancelable con aceptación (ninguno) Se puede cancelar, pero no se ha realizado la solicitud
S - ... Vigente Cancelable con aceptación En proceso Se hizo la solicitud y está en espera de respuesta
S - ... Vigente Cancelable con aceptación Solicitud rechazada Se hizo la solicitud y fue rechazada

Cuando tienes un CFDI en estado Cancelable con aceptación y mandas a hacer la cancelación entonces su estado de cancelación cambiaría a En proceso.

El receptor puede aceptar la cancelación (Cancelado con aceptación) o rechazarla (Solicitud rechazada).

Si es la primera vez que se hace la solicitud, el receptor tiene 72 horas para aceptarla o rechazarla, si no lo hace entonces automáticamente será cancelada (Plazo vencido).

Podrías volver a enviar la solicitud de cancelación por segunda vez aun cuando la solicitud fue previamente rechazada.

En ese caso, el receptor puede aceptar o rechazar la cancelación, pero ya no aplicará un lapso de 72 horas. Por lo anterior entonces podrías tener el CFDI en estado de cancelación en proceso indefinidamente. Incluso, que la cancelación suceda meses después de lo esperado.

Compatibilidad

Esta librería se mantendrá compatible con al menos la versión con soporte activo de PHP más reciente.

También utilizamos Versionado Semántico 2.0.0 por lo que puedes usar esta librería sin temor a romper tu aplicación.

sat-estado-cfdi Versiones soportadas de PHP
1.0.3 7.3, 7.4, 8.0, 8.1, 8.2, 8.3
2.0.0 8.2, 8.3

Contribuciones

Las contribuciones con bienvenidas. Por favor lee CONTRIBUTING para más detalles y recuerda revisar el archivo de tareas pendientes TODO y el archivo CHANGELOG.

Copyright and License

The phpcfdi/sat-estado-cfdi library is copyright © PhpCfdi and licensed for use under the MIT License (MIT). Please see LICENSE for more information.


All versions of sat-estado-cfdi with dependencies

PHP Build Version
Package Version
Requires php Version >=8.2
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package phpcfdi/sat-estado-cfdi contains the following files

Loading the files please wait ....