From 72c152f2be4c74be67d20d342440ba5939921c72 Mon Sep 17 00:00:00 2001 From: Edie Lemoine Date: Wed, 2 Oct 2024 17:02:36 +0200 Subject: [PATCH] feat(admin): add download logs action Needs myparcelnl/pdk#288 Needs myparcelnl/js-pdk#221 --- src/Hooks/Concern/UsesPdkRequestConverter.php | 23 ---------- src/Logger/WcLogger.php | 43 ++++++++++++++++++- src/Pdk/Hooks/AbstractPdkEndpointHooks.php | 13 +++--- src/Pdk/Hooks/PdkAdminEndpointHooks.php | 7 ++- 4 files changed, 50 insertions(+), 36 deletions(-) diff --git a/src/Hooks/Concern/UsesPdkRequestConverter.php b/src/Hooks/Concern/UsesPdkRequestConverter.php index d17286d4d..3d41c5d8b 100644 --- a/src/Hooks/Concern/UsesPdkRequestConverter.php +++ b/src/Hooks/Concern/UsesPdkRequestConverter.php @@ -5,9 +5,7 @@ namespace MyParcelNL\WooCommerce\Hooks\Concern; use Symfony\Component\HttpFoundation\Request; -use Symfony\Component\HttpFoundation\Response; use WP_REST_Request; -use WP_REST_Response; trait UsesPdkRequestConverter { @@ -35,26 +33,5 @@ protected function convertRequest(WP_REST_Request $wpRestRequest): Request return $request; } - - /** - * Convert a WP_REST_Response to a Symfony Response. - * - * @param \Symfony\Component\HttpFoundation\Response $response - * - * @return \WP_REST_Response - */ - protected function convertResponse(Response $response): WP_REST_Response - { - if ($response->headers->has('Content-Type') && $response->headers->get('Content-Type') === 'application/json') { - $content = json_decode($response->getContent(), true); - } else { - $content = $response->getContent(); - } - - $wpResponse = new WP_REST_Response($content, $response->getStatusCode()); - $wpResponse->header('Content-Type', $response->headers->get('Content-Type')); - - return $wpResponse; - } } diff --git a/src/Logger/WcLogger.php b/src/Logger/WcLogger.php index 3c375a5b5..cf13ee85c 100644 --- a/src/Logger/WcLogger.php +++ b/src/Logger/WcLogger.php @@ -4,11 +4,34 @@ namespace MyParcelNL\WooCommerce\Logger; +use Automattic\WooCommerce\Utilities\LoggingUtil; use MyParcelNL\Pdk\Facade\Pdk; use MyParcelNL\Pdk\Logger\AbstractLogger; +use WC_Logger_Interface; class WcLogger extends AbstractLogger { + /** + * @return array + */ + public function getLogFiles(): array + { + $logger = $this->getWcLogger(); + + if (! $logger) { + return parent::getLogFiles(); + } + + $logDirectory = trailingslashit(LoggingUtil::get_log_directory()); + $foundFiles = glob(sprintf('%s%s-*.log', $logDirectory, $this->getLogPrefix())); + + if (! $foundFiles) { + return parent::getLogFiles(); + } + + return $foundFiles; + } + /** * @param $level * @param $message @@ -18,7 +41,7 @@ class WcLogger extends AbstractLogger */ public function log($level, $message, array $context = []): void { - $logger = function_exists('wc_get_logger') ? wc_get_logger() : null; + $logger = $this->getWcLogger(); if (! $logger) { return; @@ -26,6 +49,22 @@ public function log($level, $message, array $context = []): void $json = count($context) ? PHP_EOL . json_encode($context, JSON_PRETTY_PRINT) : ''; - $logger->log($level, $message . $json, ['source' => Pdk::getAppInfo()->name]); + $logger->log($level, $message . $json, ['source' => $this->getLogPrefix()]); + } + + /** + * @return string + */ + private function getLogPrefix(): string + { + return Pdk::getAppInfo()->name; + } + + /** + * @return null|\WC_Logger_Interface + */ + private function getWcLogger(): ?WC_Logger_Interface + { + return function_exists('wc_get_logger') ? wc_get_logger() : null; } } diff --git a/src/Pdk/Hooks/AbstractPdkEndpointHooks.php b/src/Pdk/Hooks/AbstractPdkEndpointHooks.php index 4902a9585..87d52635f 100644 --- a/src/Pdk/Hooks/AbstractPdkEndpointHooks.php +++ b/src/Pdk/Hooks/AbstractPdkEndpointHooks.php @@ -8,7 +8,6 @@ use MyParcelNL\WooCommerce\Hooks\Concern\UsesPdkRequestConverter; use MyParcelNL\WooCommerce\Hooks\Contract\WordPressHooksInterface; use WP_REST_Request; -use WP_REST_Response; abstract class AbstractPdkEndpointHooks implements WordPressHooksInterface { @@ -28,23 +27,23 @@ public function __construct(PdkEndpoint $endpoint) } /** - * Convert the request to a format that the PDK understands, calls the endpoint and converts the response back to - * a format that WordPress understands. + * Convert the request to a format that the PDK understands, calls the endpoint and sends the response. * Disables notices to prevent random plugin notices from breaking the response. * * @param string $context * @param \WP_REST_Request $request * - * @return \WP_REST_Response + * @return void */ - protected function processRequest(string $context, WP_REST_Request $request): WP_REST_Response + protected function processRequest(string $context, WP_REST_Request $request): void { error_reporting(error_reporting() & ~E_NOTICE); $convertedRequest = $this->convertRequest($request); + $response = $this->endpoint->call($convertedRequest, $context); - $response = $this->endpoint->call($convertedRequest, $context); + $response->send(); - return $this->convertResponse($response); + exit; } } diff --git a/src/Pdk/Hooks/PdkAdminEndpointHooks.php b/src/Pdk/Hooks/PdkAdminEndpointHooks.php index a73b22384..9160c81d3 100644 --- a/src/Pdk/Hooks/PdkAdminEndpointHooks.php +++ b/src/Pdk/Hooks/PdkAdminEndpointHooks.php @@ -7,7 +7,6 @@ use MyParcelNL\Pdk\App\Api\PdkEndpoint; use MyParcelNL\Pdk\Facade\Pdk; use WP_REST_Request; -use WP_REST_Response; use WP_REST_Server; final class PdkAdminEndpointHooks extends AbstractPdkEndpointHooks @@ -20,11 +19,11 @@ public function apply(): void /** * @param \WP_REST_Request $request * - * @return \WP_REST_Response + * @return void */ - public function processBackendRequest(WP_REST_Request $request): WP_REST_Response + public function processBackendRequest(WP_REST_Request $request): void { - return $this->processRequest(PdkEndpoint::CONTEXT_BACKEND, $request); + $this->processRequest(PdkEndpoint::CONTEXT_BACKEND, $request); } /**