Download the PHP package phpcfdi/finkok without Composer

On this page you can find all versions of the php package phpcfdi/finkok. 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 finkok

phpcfdi/finkok

Source Code Latest Version Software License Build Status Scrutinizer Coverage Status Total Downloads

Librería para conectar con la API de servicios de FINKOK (México)

:us: The documentation of this project is in spanish as this is the natural language for intented audience.

Acerca de phpcfdi/finkok

Esta librería es un esfuerzo de la comunidad de https://www.phpcfdi.com/ para tener un cliente que explote las funcionalidades ofrecidas por el integrador https://www.finkok.com/.

No está relacionado con Finkok y Finkok es una marca registrada de FINKOK, SAPI DE CV.

Instalación

Usa composer

Ejemplo básico de uso

Y también hay otros ejemplos explicados:

Y todos los test de integración, donde se prueba la comunicación y respuestas contra la plataforma de pruebas.

Se recomienda utilizar la clase PhpCfdi\Finkok\QuickFinkok para un uso rápido de los comandos de finkok, sin embargo, se pueden utilizar un modo totalmente explícito y granular por comando, servicio y resultado.

Métodos implementados

La librería utiliza un modelo basado en comando, servicio y resultado. El comando es la definición de la acción que queremos realizar, contiene todos los parámetros necesarios. El servicio es el encargado de usar ese comando como entrada, ejecutarlo en Finkok (vía SOAP) y construir un resultado a partir de la respuesta. El resultado son los datos que representa la respuesta.

No hemos implementado intencionalmente los comandos que requieren transmitir la llave privada de un CSD (Certificado de Sello Digital) o de la eFirma/FIEL (Firma electrónica). No creemos que vayamos a implementarlos porque a) No es necesario y b) Es inseguro.

Servicios de estampado

Finkok tiene dos métodos de firmado: stamp y quickstamp.

El servicio stamped para revisar si previamente se generó un cfdi:

El servicio stampQueryPending por si estás usando pending buffer (que te recomiendo no hacerlo):

Servicios de cancelación

Solo se pueden cancelar cfdi con esta librería usando cancelSignature porque es el único donde no tienes que transmitir información confidencial.

Puedes consultar el estado de un CFDI usando getSatStatus (antes o después de cancelarlo)

Y obtener el último acuse de recibo del SAT a una solicitud de cancelación con getCancelReceipt. Aunque recuerda que tener un acuse no significa que se haya cancelado, el acuse lo único que contiene es la respuesta de cancelación presentada al SAT.

Gracias a getPendingToCancel se puede obtener el listado de CFDI pendientes por cancelar por parte de un receptor.

Se pueden obtener los UUID relacionados hijos (que el UUID consultado relaciona) y padres (que relacionan al UUID consultado) usando getRelatedSignature. Tal como el método cancelSignature este método requiere de un mensaje firmado.

A su vez, se puede aceptar o rechazar una solicitud de cancelación usando acceptRejectSignature. Este método puede trabajar con varios UUID, pero Finkok recomienda que solo se realice uno a la vez. Tal como el método cancelSignature este método requiere de un mensaje firmado.

Utilerías y manejo de clientes

Obtener la hora de Finkok (por si estás teniendo problemas de CFDI fuera de tiempo):

Obtener un CFDI firmado con Finkok en los últimos 3 meses:

Obtener reportes de consumo de crédito y manejo de clientes:

Manifiestos y contrato

Para obtener los contratos y enviar las firmas están getContracts y signContracts respectivamente.

Retenciones

Los CFDI de Retenciones e información de pagos (RET) siguen un estándar más parecido a CFDI 3.2. Su cancelación es inmediata (al contrario de la solicitud de cancelación actual).

Para descargar una retención debe usar el servicio Utilerias, método get_xml que está implementado previamente. Igualmente, se ha creado el método QuickFinkok::retentionDownload($uuid, $rfc) para simplificar su implementación.

Ayuda para firmado XML para SAT y Finkok

Esta librería implementa el firmado CSD de los mensajes con el SAT para Cancelar, Obtener UUID relacionados y Aceptación o rechazo de solicitud de cancelación. Toda la lógica involucrada en la creación de los XML firmados se encuentra en la librería phpcfdi/xml-cancelacion.

También implementa el firmado con FIEL de manifiestos con Finkok.

Para estas tareas se han creado los siguientes objetos que permiten realizar el firmado de la información:

A su vez, estos métodos utilizan la librería phpcfdi/credentials para poder crear las firmas y la información requerida por el SAT o Finkok.

La clase QuickFinkok ahorra el proceso de firmar peticiones y lo hace de forma automática, sin embargo, se muestra el siguiente ejemplo de cancelación firmada de 1 UUID con certificado y llave privada en archivos.

Notas de implementación

Durante el proceso de implementación he creado diversas notas y documentos:

Capturar conversación HTTP

Algunas veces, al reportar a Finkok un problema, nos solicitan la conversación HTTP (Request y Response) para poder revisar el problema sobre la información enviada.

Esta librería genera mensajes utilizando PSR-3: Logger Interface, y se utiliza dentro del objeto SoapFactory para crear un SoapCaller. Este objeto envía dos tipos de mensajes: LogLevel::ERROR cuando ocurre un error al momento de establecer comunicación con los servicios, y LogLevel::DEBUG cuando se ejecutó una llamada SOAP. Ambos mensajes están representados como una cadena en formato JSON, por lo que, para leerla fácilmente es importante decodificarla.

El formato JSON es mejor dado que permite analizar el texto y encontrar caracteres especiales, mientras que, al convertirlo a un texto más entendible para el humano, estos caracteres especiales se pueden esconder o interpretar de forma errónea.

Se ofrece la clase PhpCfdi\Finkok\Helpers\FileLogger como una utilería de LoggerInterface que manda los mensajes recibidos a la salida estándar o a un archivo.

También se ofrece la clase PhpCfdi\Finkok\Helpers\JsonDecoderLogger como una utilería de LoggerInterface que decodifica el mensaje JSON y luego lo convierte a cadena de caracteres usando la función print_r(), para después mandarlo a otro objeto LoggerInterface.

En el siguiente ejemplo se muestra la forma recomendada para establecer el objeto Logger, también se muestra el uso de JsonDecoderLogger para realizar la conversión de JSON a texto plano y FileLogger para enviar el mensaje a un archivo específico.

La clase JsonDecoderLogger puede generar pérdida de información, pero los mensajes son más entendibles, si deseas también incluir el mensaje JSON puedes usar JsonDecoderLogger::setAlsoLogJsonMessage(true).

Si estás usando Laravel, ya cuentas con una implementación de LoggerInterface, por lo que te recomiendo usar:

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.

Versión de la librería Versión de PHP Fecha de lanzamiento
0.1.0 7.2, 7.3 y 7.4 2019-03-29
0.3.0 7.3, 7.4, 8.0, 8.1, 8.2 y 8.3 2021-03-18

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/finkok library is copyright © PhpCfdi and licensed for use under the MIT License (MIT). Please see LICENSE for more information.


All versions of finkok with dependencies

PHP Build Version
Package Version
Requires php Version >=7.3
ext-dom Version *
ext-json Version *
ext-openssl Version *
ext-soap Version *
eclipxe/enum Version ^0.2.0
eclipxe/micro-catalog Version ^0.1.0
phpcfdi/cfdi-expresiones Version ^3.2
phpcfdi/credentials Version ^1.0.1
phpcfdi/xml-cancelacion Version ^2.0.2
psr/log Version ^1.1 || ^2.0 || ^3.0
robrichards/xmlseclibs Version ^3.0.4
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/finkok contains the following files

Loading the files please wait ....