Descripción: Se ha realizado una refactorización mayor del sistema de notificaciones y generación de comprobantes para eliminar dependencias legacy (Imagick/FTP) y modernizar la arquitectura. 🚀 Nuevas Características (Features) Microservicio PDF (pdf-cropper): Nuevo servicio en Python (FastAPI + Poppler) desplegado en Docker (Puerto 8050) para la conversión de PDF a Imagen. Reemplaza la librería Imagick de PHP, aislando el procesamiento pesado fuera del plugin. Modo Full: Garantiza la conversión del PDF completo respetando su relación de aspecto original (sin recortes ni "square crop"). Overlay de Texto: Capacidad nativa en el backend para sobreescribir texto dinámicamente (ej. cambiar "Tarjeta de crédito Stripe" por "OXXO Pay") basado en parámetros. Integración S3 / MinIO: Implementación de MinioStorageService . Los comprobantes (JPG) y Vouchers OXXO se suben automáticamente a MinIO en lugar de usar FTP. Generación de URLs públicas seguras. 🧹 Mantenimiento y Limpieza (Chores/Refactor) Limpieza Automática (Cleanup): Se implementó lógica para eliminar archivos temporales locales (PDFs descargados, JPGs generados) inmediatamente después de una subida exitosa a MinIO. Aplica tanto para comprobantes de pago como para Vouchers OXXO. Refactor ClientCallBellAPI : Eliminación de código muerto relacionado con FTP de WordPress. Implementación de cliente HTTP Guzzle para comunicación con pdf-cropper. Cache Busting: Se añade Timestamp al nombre de archivo (_time()) para evitar caché agresivo en WhatsApp/Navegadores. Detección de Método: Lógica preliminar para detectar "OXXO" o "Transferencia" en notas de pago y aplicar Overlay. Docker Infraestructura: Actualización de docker-compose.yml para incluir pdf-cropper. Instalación de fuentes (fonts-dejavu-core) para renderizado correcto de texto. 🐛 Correcciones (Bug Fixes) Fix Recorte de Imagen: Se eliminó la restricción de relación de aspecto 1:1 (cuadrado) que cortaba headers y footers en documentos rectangulares. Standardización de Notas: Actualización de AbstractStripeOperationsFacade para incluir explícitamente "OXXO" o "Transferencia" en las notas de pago de UCRM (preparación para lógica de plantillas).
95 lines
3.0 KiB
PHP
95 lines
3.0 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace GuzzleHttp\Psr7;
|
|
|
|
use Psr\Http\Message\RequestFactoryInterface;
|
|
use Psr\Http\Message\RequestInterface;
|
|
use Psr\Http\Message\ResponseFactoryInterface;
|
|
use Psr\Http\Message\ResponseInterface;
|
|
use Psr\Http\Message\ServerRequestFactoryInterface;
|
|
use Psr\Http\Message\ServerRequestInterface;
|
|
use Psr\Http\Message\StreamFactoryInterface;
|
|
use Psr\Http\Message\StreamInterface;
|
|
use Psr\Http\Message\UploadedFileFactoryInterface;
|
|
use Psr\Http\Message\UploadedFileInterface;
|
|
use Psr\Http\Message\UriFactoryInterface;
|
|
use Psr\Http\Message\UriInterface;
|
|
|
|
/**
|
|
* Implements all of the PSR-17 interfaces.
|
|
*
|
|
* Note: in consuming code it is recommended to require the implemented interfaces
|
|
* and inject the instance of this class multiple times.
|
|
*/
|
|
final class HttpFactory implements RequestFactoryInterface, ResponseFactoryInterface, ServerRequestFactoryInterface, StreamFactoryInterface, UploadedFileFactoryInterface, UriFactoryInterface
|
|
{
|
|
public function createUploadedFile(
|
|
StreamInterface $stream,
|
|
?int $size = null,
|
|
int $error = \UPLOAD_ERR_OK,
|
|
?string $clientFilename = null,
|
|
?string $clientMediaType = null
|
|
): UploadedFileInterface {
|
|
if ($size === null) {
|
|
$size = $stream->getSize();
|
|
}
|
|
|
|
return new UploadedFile($stream, $size, $error, $clientFilename, $clientMediaType);
|
|
}
|
|
|
|
public function createStream(string $content = ''): StreamInterface
|
|
{
|
|
return Utils::streamFor($content);
|
|
}
|
|
|
|
public function createStreamFromFile(string $file, string $mode = 'r'): StreamInterface
|
|
{
|
|
try {
|
|
$resource = Utils::tryFopen($file, $mode);
|
|
} catch (\RuntimeException $e) {
|
|
if ('' === $mode || false === \in_array($mode[0], ['r', 'w', 'a', 'x', 'c'], true)) {
|
|
throw new \InvalidArgumentException(sprintf('Invalid file opening mode "%s"', $mode), 0, $e);
|
|
}
|
|
|
|
throw $e;
|
|
}
|
|
|
|
return Utils::streamFor($resource);
|
|
}
|
|
|
|
public function createStreamFromResource($resource): StreamInterface
|
|
{
|
|
return Utils::streamFor($resource);
|
|
}
|
|
|
|
public function createServerRequest(string $method, $uri, array $serverParams = []): ServerRequestInterface
|
|
{
|
|
if (empty($method)) {
|
|
if (!empty($serverParams['REQUEST_METHOD'])) {
|
|
$method = $serverParams['REQUEST_METHOD'];
|
|
} else {
|
|
throw new \InvalidArgumentException('Cannot determine HTTP method');
|
|
}
|
|
}
|
|
|
|
return new ServerRequest($method, $uri, [], null, '1.1', $serverParams);
|
|
}
|
|
|
|
public function createResponse(int $code = 200, string $reasonPhrase = ''): ResponseInterface
|
|
{
|
|
return new Response($code, [], null, '1.1', $reasonPhrase);
|
|
}
|
|
|
|
public function createRequest(string $method, $uri): RequestInterface
|
|
{
|
|
return new Request($method, $uri);
|
|
}
|
|
|
|
public function createUri(string $uri = ''): UriInterface
|
|
{
|
|
return new Uri($uri);
|
|
}
|
|
}
|