Compare commits
6 Commits
Author | SHA1 | Date | |
---|---|---|---|
5f0679221e | |||
e3719fb7b9 | |||
1f8d4f0bce | |||
025697d37c | |||
375b922537 | |||
de81f16557 |
@ -5,7 +5,7 @@ UI_PATH=./ui
|
|||||||
COMPOSE_PROJECT_NAME=emails
|
COMPOSE_PROJECT_NAME=emails
|
||||||
COMPOSE_PATH_SEPARATOR=:
|
COMPOSE_PATH_SEPARATOR=:
|
||||||
COMPOSE_FILE=./docker-compose.yml:${CLI_PATH}/docker-compose.yml:${API_PATH}/docker-compose.yml:${UI_PATH}/docker-compose.yml
|
COMPOSE_FILE=./docker-compose.yml:${CLI_PATH}/docker-compose.yml:${API_PATH}/docker-compose.yml:${UI_PATH}/docker-compose.yml
|
||||||
COMPOSE_PROFILES=api,ui
|
COMPOSE_PROFILES=api,ui,cli
|
||||||
|
|
||||||
ATT_PATH=./attachments
|
ATT_PATH=./attachments
|
||||||
LOGS_PATH=./logs
|
LOGS_PATH=./logs
|
||||||
|
@ -2,5 +2,4 @@ EMAIL_HOST=imap.gmail.com
|
|||||||
EMAIL_PORT=993
|
EMAIL_PORT=993
|
||||||
EMAIL_USERNAME=@gmail.com
|
EMAIL_USERNAME=@gmail.com
|
||||||
EMAIL_PASSWORD=
|
EMAIL_PASSWORD=
|
||||||
EMAIL_FOLDER=
|
ATTACHMENTS_FOLDER=/attachments
|
||||||
ATTACHMENTS_FOLDER=/attachments
|
|
||||||
|
2
api/.adminer.env.sample
Normal file
2
api/.adminer.env.sample
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
ADMINER_DESIGN=dracula
|
||||||
|
ADMINER_PLUGINS="tables-filter table-indexes-structure table-structure struct-comments json-column edit-calendar edit-textarea dump-bz2 dump-date dump-json dump-php enum-option"
|
4
api/.db.env.sample
Normal file
4
api/.db.env.sample
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
MYSQL_ROOT_PASSWORD=
|
||||||
|
MYSQL_DATABASE=
|
||||||
|
MYSQL_USER=
|
||||||
|
MYSQL_PASSWORD=
|
2
api/.env.sample
Normal file
2
api/.env.sample
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
PASSWORDS_SEPARATOR=,
|
||||||
|
PASSWORDS=
|
38
api/common/Middleware/Logging.php
Normal file
38
api/common/Middleware/Logging.php
Normal 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;
|
||||||
|
}
|
||||||
|
}
|
@ -8,6 +8,11 @@ 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)->error($e);
|
$logger = $app->getContainer()->get(Psr\Log\LoggerInterface::class);
|
||||||
|
if (isset($_REQUEST)) {
|
||||||
|
$logger->debug(Safe\json_encode(compact('_REQUEST')));
|
||||||
|
}
|
||||||
|
$logger->debug(Safe\json_encode(compact('_SERVER')));
|
||||||
|
$logger->error($e);
|
||||||
throw $e;
|
throw $e;
|
||||||
}
|
}
|
||||||
|
2
api/setup/middleware/98_log.php
Normal file
2
api/setup/middleware/98_log.php
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
<?php
|
||||||
|
$app->add($app->getContainer()->get(ProVM\Common\Middleware\Logging::class));
|
@ -18,4 +18,5 @@ return [
|
|||||||
]);
|
]);
|
||||||
},
|
},
|
||||||
'attachments_folder' => $_ENV['ATTACHMENTS_FOLDER'],
|
'attachments_folder' => $_ENV['ATTACHMENTS_FOLDER'],
|
||||||
];
|
'logs_folder' => '/logs',
|
||||||
|
];
|
||||||
|
@ -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'));
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
@ -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;
|
||||||
},
|
},
|
||||||
|
'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));
|
||||||
return $logger;
|
return $logger;
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
1
cli/.env.sample
Normal file
1
cli/.env.sample
Normal file
@ -0,0 +1 @@
|
|||||||
|
API_URI=http://proxy:8080
|
38
cli/common/Middleware/Logging.php
Normal file
38
cli/common/Middleware/Logging.php
Normal 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;
|
||||||
|
}
|
||||||
|
}
|
@ -4,9 +4,12 @@ $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) {
|
||||||
$app->getContainer()->get(\Psr\Log\LoggerInterface::class)->error($e);
|
$logger = $app->getContainer()->get(Psr\Log\LoggerInterface::class);
|
||||||
|
$logger->debug(Safe\json_encode(compact('_SERVER')));
|
||||||
|
$logger->error($e);
|
||||||
throw $e;
|
throw $e;
|
||||||
}
|
}
|
||||||
|
2
cli/setup/middleware/98_log.php
Normal file
2
cli/setup/middleware/98_log.php
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
<?php
|
||||||
|
$app->add($app->getContainer()->get(ProVM\Common\Middleware\Logging::class));
|
@ -14,5 +14,6 @@ return [
|
|||||||
$container->get('resources_folder'),
|
$container->get('resources_folder'),
|
||||||
'commands'
|
'commands'
|
||||||
]);
|
]);
|
||||||
}
|
},
|
||||||
|
'logs_folder' => '/logs',
|
||||||
];
|
];
|
||||||
|
8
cli/setup/setups/03_middleware.php
Normal file
8
cli/setup/setups/03_middleware.php
Normal 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'));
|
||||||
|
}
|
||||||
|
];
|
@ -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;
|
||||||
|
},
|
||||||
|
];
|
||||||
|
1
ui/.env.sample
Normal file
1
ui/.env.sample
Normal file
@ -0,0 +1 @@
|
|||||||
|
API_URI=http://proxy:8080
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
38
ui/common/Middleware/Logging.php
Normal file
38
ui/common/Middleware/Logging.php
Normal 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;
|
||||||
|
}
|
||||||
|
}
|
@ -8,6 +8,11 @@ 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)->error($e);
|
$logger = $app->getContainer()->get(Psr\Log\LoggerInterface::class);
|
||||||
|
if (isset($_REQUEST)) {
|
||||||
|
$logger->debug(Safe\json_encode(compact('_REQUEST')));
|
||||||
|
}
|
||||||
|
$logger->debug(Safe\json_encode(compact('_SERVER')));
|
||||||
|
$logger->error($e);
|
||||||
throw $e;
|
throw $e;
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
|
@ -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)
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -100,4 +100,4 @@
|
|||||||
message.setup('{{$message_id}}')
|
message.setup('{{$message_id}}')
|
||||||
})
|
})
|
||||||
</script>
|
</script>
|
||||||
@endpush
|
@endpush
|
||||||
|
@ -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>
|
||||||
|
2
ui/setup/middleware/98_log.php
Normal file
2
ui/setup/middleware/98_log.php
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
<?php
|
||||||
|
$app->add($app->getContainer()->get(ProVM\Common\Middleware\Logging::class));
|
@ -20,6 +20,7 @@ return [
|
|||||||
$arr['base'],
|
$arr['base'],
|
||||||
'cache'
|
'cache'
|
||||||
]);
|
]);
|
||||||
|
$arr['logs'] = '/logs';
|
||||||
return (object) $arr;
|
return (object) $arr;
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
@ -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')}"
|
||||||
@ -15,4 +15,4 @@ return [
|
|||||||
Psr\Http\Message\RequestFactoryInterface::class => function(ContainerInterface $container) {
|
Psr\Http\Message\RequestFactoryInterface::class => function(ContainerInterface $container) {
|
||||||
return $container->get(Nyholm\Psr7\Factory\Psr17Factory::class);
|
return $container->get(Nyholm\Psr7\Factory\Psr17Factory::class);
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
8
ui/setup/setups/04_middleware.php
Normal file
8
ui/setup/setups/04_middleware.php
Normal 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'));
|
||||||
|
}
|
||||||
|
];
|
@ -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;
|
||||||
|
},
|
||||||
|
];
|
||||||
|
Reference in New Issue
Block a user