Skip to content

Commit

Permalink
feat(admin): add download logs action
Browse files Browse the repository at this point in the history
  • Loading branch information
EdieLemoine committed Oct 2, 2024
1 parent 5a8a208 commit 72c152f
Show file tree
Hide file tree
Showing 4 changed files with 50 additions and 36 deletions.
23 changes: 0 additions & 23 deletions src/Hooks/Concern/UsesPdkRequestConverter.php
Original file line number Diff line number Diff line change
Expand Up @@ -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
{
Expand Down Expand Up @@ -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;
}
}

43 changes: 41 additions & 2 deletions src/Logger/WcLogger.php
Original file line number Diff line number Diff line change
Expand Up @@ -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

Check warning on line 17 in src/Logger/WcLogger.php

View check run for this annotation

Codecov / codecov/patch

src/Logger/WcLogger.php#L17

Added line #L17 was not covered by tests
{
$logger = $this->getWcLogger();

Check warning on line 19 in src/Logger/WcLogger.php

View check run for this annotation

Codecov / codecov/patch

src/Logger/WcLogger.php#L19

Added line #L19 was not covered by tests

if (! $logger) {
return parent::getLogFiles();

Check warning on line 22 in src/Logger/WcLogger.php

View check run for this annotation

Codecov / codecov/patch

src/Logger/WcLogger.php#L21-L22

Added lines #L21 - L22 were not covered by tests
}

$logDirectory = trailingslashit(LoggingUtil::get_log_directory());
$foundFiles = glob(sprintf('%s%s-*.log', $logDirectory, $this->getLogPrefix()));

Check warning on line 26 in src/Logger/WcLogger.php

View check run for this annotation

Codecov / codecov/patch

src/Logger/WcLogger.php#L25-L26

Added lines #L25 - L26 were not covered by tests

if (! $foundFiles) {
return parent::getLogFiles();

Check warning on line 29 in src/Logger/WcLogger.php

View check run for this annotation

Codecov / codecov/patch

src/Logger/WcLogger.php#L28-L29

Added lines #L28 - L29 were not covered by tests
}

return $foundFiles;

Check warning on line 32 in src/Logger/WcLogger.php

View check run for this annotation

Codecov / codecov/patch

src/Logger/WcLogger.php#L32

Added line #L32 was not covered by tests
}

/**
* @param $level
* @param $message
Expand All @@ -18,14 +41,30 @@ 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;
}

$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()]);

Check warning on line 52 in src/Logger/WcLogger.php

View check run for this annotation

Codecov / codecov/patch

src/Logger/WcLogger.php#L52

Added line #L52 was not covered by tests
}

/**
* @return string
*/
private function getLogPrefix(): string

Check warning on line 58 in src/Logger/WcLogger.php

View check run for this annotation

Codecov / codecov/patch

src/Logger/WcLogger.php#L58

Added line #L58 was not covered by tests
{
return Pdk::getAppInfo()->name;

Check warning on line 60 in src/Logger/WcLogger.php

View check run for this annotation

Codecov / codecov/patch

src/Logger/WcLogger.php#L60

Added line #L60 was not covered by tests
}

/**
* @return null|\WC_Logger_Interface
*/
private function getWcLogger(): ?WC_Logger_Interface
{
return function_exists('wc_get_logger') ? wc_get_logger() : null;
}
}
13 changes: 6 additions & 7 deletions src/Pdk/Hooks/AbstractPdkEndpointHooks.php
Original file line number Diff line number Diff line change
Expand Up @@ -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
{
Expand All @@ -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

Check warning on line 38 in src/Pdk/Hooks/AbstractPdkEndpointHooks.php

View check run for this annotation

Codecov / codecov/patch

src/Pdk/Hooks/AbstractPdkEndpointHooks.php#L38

Added line #L38 was not covered by tests
{
error_reporting(error_reporting() & ~E_NOTICE);

$convertedRequest = $this->convertRequest($request);
$response = $this->endpoint->call($convertedRequest, $context);

Check warning on line 43 in src/Pdk/Hooks/AbstractPdkEndpointHooks.php

View check run for this annotation

Codecov / codecov/patch

src/Pdk/Hooks/AbstractPdkEndpointHooks.php#L43

Added line #L43 was not covered by tests

$response = $this->endpoint->call($convertedRequest, $context);
$response->send();

Check warning on line 45 in src/Pdk/Hooks/AbstractPdkEndpointHooks.php

View check run for this annotation

Codecov / codecov/patch

src/Pdk/Hooks/AbstractPdkEndpointHooks.php#L45

Added line #L45 was not covered by tests

return $this->convertResponse($response);
exit;

Check warning on line 47 in src/Pdk/Hooks/AbstractPdkEndpointHooks.php

View check run for this annotation

Codacy Production / Codacy Static Code Analysis

src/Pdk/Hooks/AbstractPdkEndpointHooks.php#L47

The method processRequest() contains an exit expression.

Check warning on line 47 in src/Pdk/Hooks/AbstractPdkEndpointHooks.php

View check run for this annotation

Codecov / codecov/patch

src/Pdk/Hooks/AbstractPdkEndpointHooks.php#L47

Added line #L47 was not covered by tests
}
}
7 changes: 3 additions & 4 deletions src/Pdk/Hooks/PdkAdminEndpointHooks.php
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand All @@ -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

Check warning on line 24 in src/Pdk/Hooks/PdkAdminEndpointHooks.php

View check run for this annotation

Codecov / codecov/patch

src/Pdk/Hooks/PdkAdminEndpointHooks.php#L24

Added line #L24 was not covered by tests
{
return $this->processRequest(PdkEndpoint::CONTEXT_BACKEND, $request);
$this->processRequest(PdkEndpoint::CONTEXT_BACKEND, $request);

Check warning on line 26 in src/Pdk/Hooks/PdkAdminEndpointHooks.php

View check run for this annotation

Codecov / codecov/patch

src/Pdk/Hooks/PdkAdminEndpointHooks.php#L26

Added line #L26 was not covered by tests
}

/**
Expand Down

0 comments on commit 72c152f

Please sign in to comment.