This commit is contained in:
2022-12-01 14:15:54 -03:00
parent c0ddd00cc6
commit de81f16557
22 changed files with 211 additions and 35 deletions

View File

@ -0,0 +1,38 @@
<?php
namespace ProVM\Common\Middleware;
use Psr\Http\Message\ResponseInterface;
use Psr\Http\Message\ServerRequestInterface;
use Psr\Http\Server\RequestHandlerInterface;
use Psr\Log\LoggerInterface;
class Logging
{
public function __construct(LoggerInterface $logger) {
$this->setLogger($logger);
}
protected LoggerInterface $logger;
public function getLogger(): LoggerInterface
{
return $this->logger;
}
public function setLogger(LoggerInterface $logger): Logging
{
$this->logger = $logger;
return $this;
}
public function __invoke(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
{
$response = $handler->handle($request);
$output = [
'uri' => var_export($request->getUri(), true),
'body' => $request->getBody()->getContents()
];
$this->getLogger()->info(\Safe\json_encode($output, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE));
return $response;
}
}

View File

@ -0,0 +1,2 @@
<?php
$app->add($app->getContainer()->get(ProVM\Common\Middleware\Logging::class));

View File

@ -18,4 +18,5 @@ return [
]); ]);
}, },
'attachments_folder' => $_ENV['ATTACHMENTS_FOLDER'], 'attachments_folder' => $_ENV['ATTACHMENTS_FOLDER'],
'logs_folder' => '/logs',
]; ];

View File

@ -7,5 +7,8 @@ return [
$container->get(Nyholm\Psr7\Factory\Psr17Factory::class), $container->get(Nyholm\Psr7\Factory\Psr17Factory::class),
$container->get(Psr\Log\LoggerInterface::class) $container->get(Psr\Log\LoggerInterface::class)
); );
},
ProVM\Common\Middleware\Logging::class => function(ContainerInterface $container) {
return new ProVM\Common\Middleware\Logging($container->get('request_logger'));
} }
]; ];

View File

@ -10,10 +10,20 @@ return [
$handler->setFormatter($container->get(Monolog\Formatter\SyslogFormatter::class)); $handler->setFormatter($container->get(Monolog\Formatter\SyslogFormatter::class));
return $handler; return $handler;
}, },
'request_logger' => function(ContainerInterface $container) {
$logger = new Monolog\Logger('request_logger');
$handler = new Monolog\Handler\RotatingFileHandler(implode(DIRECTORY_SEPARATOR, [$container->get('logs_folder'), 'requests.log']));
$handler->setFormatter($container->get(Monolog\Formatter\SyslogFormatter::class));
$dedupHandler = new Monolog\Handler\DeduplicationHandler($handler, null, Monolog\Level::Info);
$logger->pushHandler($dedupHandler);
$logger->pushProcessor($container->get(Monolog\Processor\PsrLogMessageProcessor::class));
$logger->pushProcessor($container->get(Monolog\Processor\IntrospectionProcessor::class));
$logger->pushProcessor($container->get(Monolog\Processor\MemoryUsageProcessor::class));
return $logger;
},
Psr\Log\LoggerInterface::class => function(ContainerInterface $container) { Psr\Log\LoggerInterface::class => function(ContainerInterface $container) {
$logger = new Monolog\Logger('file_logger'); $logger = new Monolog\Logger('file_logger');
$logger->pushHandler($container->get(Monolog\Handler\DeduplicationHandler::class)); $logger->pushHandler($container->get(Monolog\Handler\DeduplicationHandler::class));
//$logger->pushHandler($container->get(Monolog\Handler\RotatingFileHandler::class));
$logger->pushProcessor($container->get(Monolog\Processor\PsrLogMessageProcessor::class)); $logger->pushProcessor($container->get(Monolog\Processor\PsrLogMessageProcessor::class));
$logger->pushProcessor($container->get(Monolog\Processor\IntrospectionProcessor::class)); $logger->pushProcessor($container->get(Monolog\Processor\IntrospectionProcessor::class));
$logger->pushProcessor($container->get(Monolog\Processor\MemoryUsageProcessor::class)); $logger->pushProcessor($container->get(Monolog\Processor\MemoryUsageProcessor::class));

View File

@ -0,0 +1,38 @@
<?php
namespace ProVM\Common\Middleware;
use Psr\Http\Message\ResponseInterface;
use Psr\Http\Message\ServerRequestInterface;
use Psr\Http\Server\RequestHandlerInterface;
use Psr\Log\LoggerInterface;
class Logging
{
public function __construct(LoggerInterface $logger) {
$this->setLogger($logger);
}
protected LoggerInterface $logger;
public function getLogger(): LoggerInterface
{
return $this->logger;
}
public function setLogger(LoggerInterface $logger): Logging
{
$this->logger = $logger;
return $this;
}
public function __invoke(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
{
$response = $handler->handle($request);
$output = [
'uri' => var_export($request->getUri(), true),
'body' => $request->getBody()->getContents()
];
$this->getLogger()->info(\Safe\json_encode($output, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE));
return $response;
}
}

View File

@ -4,6 +4,7 @@ $app = require_once implode(DIRECTORY_SEPARATOR, [
'setup', 'setup',
'app.php' 'app.php'
]); ]);
Monolog\ErrorHandler::register($app->getContainer()->get(Psr\Log\LoggerInterface::class));
try { try {
$app->run(); $app->run();
} catch (Error | Exception $e) { } catch (Error | Exception $e) {

View File

@ -0,0 +1,2 @@
<?php
$app->add($app->getContainer()->get(ProVM\Common\Middleware\Logging::class));

View File

@ -14,5 +14,6 @@ return [
$container->get('resources_folder'), $container->get('resources_folder'),
'commands' 'commands'
]); ]);
} },
'logs_folder' => '/logs',
]; ];

View File

@ -0,0 +1,8 @@
<?php
use Psr\Container\ContainerInterface;
return [
ProVM\Common\Middleware\Logging::class => function(ContainerInterface $container) {
return new ProVM\Common\Middleware\Logging($container->get('request_logger'));
}
];

View File

@ -2,14 +2,28 @@
use Psr\Container\ContainerInterface; use Psr\Container\ContainerInterface;
return [ return [
\Monolog\Handler\RotatingFileHandler::class => function(ContainerInterface $container) { Monolog\Handler\RotatingFileHandler::class => function(ContainerInterface $container) {
$handler = new \Monolog\Handler\RotatingFileHandler($container->get('log_file')); $handler = new Monolog\Handler\RotatingFileHandler($container->get('log_file'));
$handler->setFormatter($container->get(\Monolog\Formatter\LineFormatter::class)); $handler->setFormatter($container->get(Monolog\Formatter\LineFormatter::class));
return $handler; return $handler;
}, },
\Psr\Log\LoggerInterface::class => function(ContainerInterface $container) { 'request_logger' => function(ContainerInterface $container) {
$logger = new \Monolog\Logger('file_logger'); $logger = new Monolog\Logger('request_logger');
$logger->pushHandler($container->get(\Monolog\Handler\RotatingFileHandler::class)); $handler = new Monolog\Handler\RotatingFileHandler(implode(DIRECTORY_SEPARATOR, [$container->get('logs_folder'), 'requests.log']));
$handler->setFormatter($container->get(Monolog\Formatter\SyslogFormatter::class));
$dedupHandler = new Monolog\Handler\DeduplicationHandler($handler, null, Monolog\Level::Info);
$logger->pushHandler($dedupHandler);
$logger->pushProcessor($container->get(Monolog\Processor\PsrLogMessageProcessor::class));
$logger->pushProcessor($container->get(Monolog\Processor\IntrospectionProcessor::class));
$logger->pushProcessor($container->get(Monolog\Processor\MemoryUsageProcessor::class));
return $logger; return $logger;
} },
Psr\Log\LoggerInterface::class => function(ContainerInterface $container) {
$logger = new Monolog\Logger('file_logger');
$logger->pushHandler($container->get(Monolog\Handler\RotatingFileHandler::class));
$logger->pushProcessor($container->get(Monolog\Processor\PsrLogMessageProcessor::class));
$logger->pushProcessor($container->get(Monolog\Processor\IntrospectionProcessor::class));
$logger->pushProcessor($container->get(Monolog\Processor\MemoryUsageProcessor::class));
return $logger;
},
]; ];

View File

@ -4,14 +4,13 @@ namespace ProVM\Common\Controller;
use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ResponseInterface;
use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Message\ServerRequestInterface;
use ProVM\Common\Service\Api as Service; use ProVM\Common\Service\Api as Service;
use Psr\Log\LoggerInterface;
class Api class Api
{ {
public function __invoke(ServerRequestInterface $request, ResponseInterface $response, Service $service): ResponseInterface public function __invoke(ServerRequestInterface $request, ResponseInterface $response, Service $service, LoggerInterface $logger): ResponseInterface
{ {
$body = $request->getBody(); $json = $request->getParsedBody();
$json = \Safe\json_decode($body->getContents(), JSON_OBJECT_AS_ARRAY);
return $service->sendRequest($json); return $service->sendRequest($json);
} }
} }

View File

@ -0,0 +1,38 @@
<?php
namespace ProVM\Common\Middleware;
use Psr\Http\Message\ResponseInterface;
use Psr\Http\Message\ServerRequestInterface;
use Psr\Http\Server\RequestHandlerInterface;
use Psr\Log\LoggerInterface;
class Logging
{
public function __construct(LoggerInterface $logger) {
$this->setLogger($logger);
}
protected LoggerInterface $logger;
public function getLogger(): LoggerInterface
{
return $this->logger;
}
public function setLogger(LoggerInterface $logger): Logging
{
$this->logger = $logger;
return $this;
}
public function __invoke(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
{
$response = $handler->handle($request);
$output = [
'uri' => var_export($request->getUri(), true),
'body' => $request->getParsedBody()
];
$this->getLogger()->info(\Safe\json_encode($output, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE));
return $response;
}
}

View File

@ -8,6 +8,7 @@ Monolog\ErrorHandler::register($app->getContainer()->get(Psr\Log\LoggerInterface
try { try {
$app->run(); $app->run();
} catch (Error | Exception $e) { } catch (Error | Exception $e) {
$app->getContainer()->get(Psr\Log\LoggerInterface::class)->debug(json_encode(compact('_REQUEST')));
$app->getContainer()->get(Psr\Log\LoggerInterface::class)->error($e); $app->getContainer()->get(Psr\Log\LoggerInterface::class)->error($e);
throw $e; throw $e;
} }

View File

@ -1,4 +1,4 @@
<?php <?php
use ProVM\Common\Controller\Api; use ProVM\Common\Controller\Api;
$app->post('/api', Api::class); $app->post('/api[/]', Api::class);

View File

@ -3,7 +3,7 @@
@section('emails_content') @section('emails_content')
<h3>Message - <span id="subject"></span> - <span id="from"></span></h3> <h3>Message - <span id="subject"></span> - <span id="from"></span></h3>
<h4 id="date_time"></h4> <h4 id="date_time"></h4>
<div class="ui list" id="attachments"></div> <div class="ui bulleted link list" id="attachments"></div>
@endsection @endsection
@push('page_scripts') @push('page_scripts')
@ -82,7 +82,7 @@
attachments: parent => { attachments: parent => {
this.get().attachments().forEach(attachment => { this.get().attachments().forEach(attachment => {
parent.append( parent.append(
$('<a></a>').attr('href', _urls.base + '/attachment/' + attachment.id).attr('download', attachment.fullname).html(attachment.fullname) $('<a></a>').attr('href', '{{$urls->base}}/attachment/' + attachment.id).attr('download', attachment.fullname).html(attachment.fullname)
) )
}) })
} }

View File

@ -3,18 +3,17 @@
base_url: '{{$urls->api}}', base_url: '{{$urls->api}}',
base: function({method, uri, data = null}) { base: function({method, uri, data = null}) {
const request = { const request = {
uri: uri.replace(/^\//g, ''), uri: uri,
method method
} }
const options = { const options = {
url: this.base_url, url: this.base_url,
method: 'post', method: 'post',
contentType: 'application/json'
} }
if (method.toLowerCase() !== 'get' && data !== null) { if (method.toLowerCase() !== 'get' && data !== null) {
request['data'] = data request['data'] = data
} }
options['data'] = JSON.stringify(request) options['data'] = request
return $.ajax(options) return $.ajax(options)
}, },
get: function(uri) { get: function(uri) {
@ -30,5 +29,5 @@
return this.base({method: 'delete', uri, data}) return this.base({method: 'delete', uri, data})
} }
} }
const _urls = JSON.parse('{!! Safe\json_encode($urls) !!}') //const _urls = JSON.parse('{!! Safe\json_encode($urls) !!}')
</script> </script>

View File

@ -0,0 +1,2 @@
<?php
$app->add($app->getContainer()->get(ProVM\Common\Middleware\Logging::class));

View File

@ -20,6 +20,7 @@ return [
$arr['base'], $arr['base'],
'cache' 'cache'
]); ]);
$arr['logs'] = '/logs';
return (object) $arr; return (object) $arr;
} }
]; ];

View File

@ -4,7 +4,7 @@ use Psr\Container\ContainerInterface;
return [ return [
Psr\Http\Client\ClientInterface::class => function(ContainerInterface $container) { Psr\Http\Client\ClientInterface::class => function(ContainerInterface $container) {
return new GuzzleHttp\Client([ return new GuzzleHttp\Client([
'base_uri' => "http://proxy:8080", 'base_uri' => $container->get('urls')->api,
'headers' => [ 'headers' => [
'Authorization' => [ 'Authorization' => [
"Bearer {$container->get('api_key')}" "Bearer {$container->get('api_key')}"

View File

@ -0,0 +1,8 @@
<?php
use Psr\Container\ContainerInterface;
return [
ProVM\Common\Middleware\Logging::class => function(ContainerInterface $container) {
return new ProVM\Common\Middleware\Logging($container->get('request_logger'));
}
];

View File

@ -10,13 +10,23 @@ return [
$handler->setFormatter($container->get(Monolog\Formatter\SyslogFormatter::class)); $handler->setFormatter($container->get(Monolog\Formatter\SyslogFormatter::class));
return $handler; return $handler;
}, },
Psr\Log\LoggerInterface::class => function(ContainerInterface $container) { 'request_logger' => function(ContainerInterface $container) {
$logger = new Monolog\Logger('file_logger'); $logger = new Monolog\Logger('request_logger');
$logger->pushHandler($container->get(Monolog\Handler\DeduplicationHandler::class)); $handler = new Monolog\Handler\RotatingFileHandler(implode(DIRECTORY_SEPARATOR, [$container->get('folders')->logs, 'requests.log']));
//$logger->pushHandler($container->get(Monolog\Handler\RotatingFileHandler::class)); $handler->setFormatter($container->get(Monolog\Formatter\SyslogFormatter::class));
$dedupHandler = new Monolog\Handler\DeduplicationHandler($handler, null, Monolog\Level::Info);
$logger->pushHandler($dedupHandler);
$logger->pushProcessor($container->get(Monolog\Processor\PsrLogMessageProcessor::class)); $logger->pushProcessor($container->get(Monolog\Processor\PsrLogMessageProcessor::class));
$logger->pushProcessor($container->get(Monolog\Processor\IntrospectionProcessor::class)); $logger->pushProcessor($container->get(Monolog\Processor\IntrospectionProcessor::class));
$logger->pushProcessor($container->get(Monolog\Processor\MemoryUsageProcessor::class)); $logger->pushProcessor($container->get(Monolog\Processor\MemoryUsageProcessor::class));
return $logger; return $logger;
} },
Psr\Log\LoggerInterface::class => function(ContainerInterface $container) {
$logger = new Monolog\Logger('file_logger');
$logger->pushHandler($container->get(Monolog\Handler\DeduplicationHandler::class));
$logger->pushProcessor($container->get(Monolog\Processor\PsrLogMessageProcessor::class));
$logger->pushProcessor($container->get(Monolog\Processor\IntrospectionProcessor::class));
$logger->pushProcessor($container->get(Monolog\Processor\MemoryUsageProcessor::class));
return $logger;
},
]; ];