CLI Base App
This commit is contained in:
3
cli/bin/emails
Normal file
3
cli/bin/emails
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
php /app/public/index.php "$@"
|
7
cli/public/index.php
Normal file
7
cli/public/index.php
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<?php
|
||||||
|
$app = require_once implode(DIRECTORY_SEPARATOR, [
|
||||||
|
dirname(__FILE__, 2),
|
||||||
|
'setup',
|
||||||
|
'app.php'
|
||||||
|
]);
|
||||||
|
$app->run();
|
43
cli/setup/app.php
Normal file
43
cli/setup/app.php
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
<?php
|
||||||
|
require_once 'composer.php';
|
||||||
|
|
||||||
|
$builder = new \DI\ContainerBuilder();
|
||||||
|
|
||||||
|
$folders = [
|
||||||
|
'settings',
|
||||||
|
'setups'
|
||||||
|
];
|
||||||
|
foreach ($folders as $f) {
|
||||||
|
$folder = implode(DIRECTORY_SEPARATOR, [
|
||||||
|
__DIR__,
|
||||||
|
$f
|
||||||
|
]);
|
||||||
|
if (!file_exists($folder)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$files = new FilesystemIterator($folder);
|
||||||
|
foreach ($files as $file) {
|
||||||
|
if ($file->isDir()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$builder->addDefinitions($file->getRealPath());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$app = new \ProVM\Common\Wrapper\Application($builder->build());
|
||||||
|
|
||||||
|
$folder = implode(DIRECTORY_SEPARATOR, [
|
||||||
|
__DIR__,
|
||||||
|
'middleware'
|
||||||
|
]);
|
||||||
|
if (file_exists($folder)) {
|
||||||
|
$files = new FilesystemIterator($folder);
|
||||||
|
foreach ($files as $file) {
|
||||||
|
if ($file->isDir()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
include_once $file->getRealPath();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $app;
|
6
cli/setup/composer.php
Normal file
6
cli/setup/composer.php
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
<?php
|
||||||
|
require_once implode(DIRECTORY_SEPARATOR, [
|
||||||
|
dirname(__FILE__, 2),
|
||||||
|
'vendor',
|
||||||
|
'autoload.php'
|
||||||
|
]);
|
9
cli/setup/middleware/02_commands.php
Normal file
9
cli/setup/middleware/02_commands.php
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
<?php
|
||||||
|
$folder = $app->getContainer()->get('commands_folder');
|
||||||
|
$files = new FilesystemIterator($folder);
|
||||||
|
foreach ($files as $file) {
|
||||||
|
if ($file->isDir()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
include_once $file->getRealPath();
|
||||||
|
}
|
16
cli/setup/settings/01_env.php
Normal file
16
cli/setup/settings/01_env.php
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
return [
|
||||||
|
'email' => function() {
|
||||||
|
$data = [
|
||||||
|
'host' => $_ENV['EMAIL_HOST'],
|
||||||
|
'username' => $_ENV['EMAIL_USERNAME'],
|
||||||
|
'password' => $_ENV['EMAIL_PASSWORD'],
|
||||||
|
'folder' => $_ENV['EMAIL_FOLDER'],
|
||||||
|
'attachments' => $_ENV['ATTACHMENTS_FOLDER'],
|
||||||
|
];
|
||||||
|
if (isset($_ENV['EMAIL_PORT'])) {
|
||||||
|
$data['port'] = $_ENV['EMAIL_PORT'];
|
||||||
|
}
|
||||||
|
return json_decode(json_encode($data));
|
||||||
|
}
|
||||||
|
];
|
18
cli/setup/settings/02_folders.php
Normal file
18
cli/setup/settings/02_folders.php
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
<?php
|
||||||
|
use Psr\Container\ContainerInterface;
|
||||||
|
|
||||||
|
return [
|
||||||
|
'base_folder' => dirname(__FILE__, 3),
|
||||||
|
'resources_folder' => function(ContainerInterface $container) {
|
||||||
|
return implode(DIRECTORY_SEPARATOR, [
|
||||||
|
$container->get('base_folder'),
|
||||||
|
'resources'
|
||||||
|
]);
|
||||||
|
},
|
||||||
|
'commands_folder' => function(ContainerInterface $container) {
|
||||||
|
return implode(DIRECTORY_SEPARATOR, [
|
||||||
|
$container->get('resources_folder'),
|
||||||
|
'commands'
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
];
|
4
cli/setup/settings/98_log.php
Normal file
4
cli/setup/settings/98_log.php
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
<?php
|
||||||
|
return [
|
||||||
|
'log_file' => '/logs/php.log'
|
||||||
|
];
|
25
cli/setup/setups/03_imap.php
Normal file
25
cli/setup/setups/03_imap.php
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
<?php
|
||||||
|
use Psr\Container\ContainerInterface;
|
||||||
|
|
||||||
|
return [
|
||||||
|
\Ddeboer\Imap\ServerInterface::class => function(ContainerInterface $container) {
|
||||||
|
$emails = $container->get('email');
|
||||||
|
if (isset($emails->port)) {
|
||||||
|
return new \Ddeboer\Imap\Server($emails->host, $emails->port);
|
||||||
|
}
|
||||||
|
return new \Ddeboer\Imap\Server($emails->host);
|
||||||
|
},
|
||||||
|
\Ddeboer\Imap\ConnectionInterface::class => function(ContainerInterface $container) {
|
||||||
|
$emails = $container->get('email');
|
||||||
|
$server = $container->get(\Ddeboer\Imap\ServerInterface::class);
|
||||||
|
return $server->authenticate($emails->username, $emails->password);
|
||||||
|
},
|
||||||
|
\ProVM\Common\Service\Emails::class => function(ContainerInterface $container) {
|
||||||
|
return new \ProVM\Common\Service\Emails(
|
||||||
|
$container->get(\Ddeboer\Imap\ConnectionInterface::class),
|
||||||
|
$container->get(\Psr\Log\LoggerInterface::class),
|
||||||
|
$container->get('email')->folder,
|
||||||
|
$container->get('email')->attachments
|
||||||
|
);
|
||||||
|
}
|
||||||
|
];
|
15
cli/setup/setups/98_log.php
Normal file
15
cli/setup/setups/98_log.php
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
<?php
|
||||||
|
use Psr\Container\ContainerInterface;
|
||||||
|
|
||||||
|
return [
|
||||||
|
\Monolog\Handler\RotatingFileHandler::class => function(ContainerInterface $container) {
|
||||||
|
$handler = new \Monolog\Handler\RotatingFileHandler($container->get('log_file'));
|
||||||
|
$handler->setFormatter($container->get(\Monolog\Formatter\LineFormatter::class));
|
||||||
|
return $handler;
|
||||||
|
},
|
||||||
|
\Psr\Log\LoggerInterface::class => function(ContainerInterface $container) {
|
||||||
|
$logger = new \Monolog\Logger('file_logger');
|
||||||
|
$logger->pushHandler($container->get(\Monolog\Handler\RotatingFileHandler::class));
|
||||||
|
return $logger;
|
||||||
|
}
|
||||||
|
];
|
Reference in New Issue
Block a user