| @ -0,0 +1,16 @@ | |||||
| root = true | |||||
| [*] | |||||
| charset = utf-8 | |||||
| end_of_line = lf | |||||
| insert_final_newline = true | |||||
| indent_style = space | |||||
| indent_size = 4 | |||||
| trim_trailing_whitespace = true | |||||
| [*.md] | |||||
| trim_trailing_whitespace = false | |||||
| [*.yml] | |||||
| indent_style = space | |||||
| indent_size = 2 | |||||
| @ -0,0 +1,15 @@ | |||||
| vendor | |||||
| .idea | |||||
| .vscode | |||||
| .vagrant | |||||
| .phpunit.result.cache | |||||
| database/database.sqlite | |||||
| .env | |||||
| storage/logs/* | |||||
| storage/tmp | |||||
| !storage/tmp/.gitkeep | |||||
| resources/templates/nginx | |||||
| !resources/templates/nginx/.gitkeep | |||||
| @ -0,0 +1,37 @@ | |||||
| <p align="center"> | |||||
| <img title="Laravel Zero" height="100" src="https://raw.githubusercontent.com/laravel-zero/docs/master/images/logo/laravel-zero-readme.png" /> | |||||
| </p> | |||||
| <p align="center"> | |||||
| <a href="https://github.com/laravel-zero/framework/actions"><img src="https://img.shields.io/github/workflow/status/laravel-zero/framework/Continuous%20Integration.svg" alt="Build Status"></img></a> | |||||
| <a href="https://scrutinizer-ci.com/g/laravel-zero/framework"><img src="https://img.shields.io/scrutinizer/g/laravel-zero/framework.svg" alt="Quality Score"></img></a> | |||||
| <a href="https://packagist.org/packages/laravel-zero/framework"><img src="https://poser.pugx.org/laravel-zero/framework/d/total.svg" alt="Total Downloads"></a> | |||||
| <a href="https://packagist.org/packages/laravel-zero/framework"><img src="https://poser.pugx.org/laravel-zero/framework/v/stable.svg" alt="Latest Stable Version"></a> | |||||
| <a href="https://packagist.org/packages/laravel-zero/framework"><img src="https://poser.pugx.org/laravel-zero/framework/license.svg" alt="License"></a> | |||||
| </p> | |||||
| <h4> <center>This is a <bold>community project</bold> and not an official Laravel one </center></h4> | |||||
| Laravel Zero was created by, and is maintained by [Nuno Maduro](https://github.com/nunomaduro), and is a micro-framework that provides an elegant starting point for your console application. It is an **unofficial** and customized version of Laravel optimized for building command-line applications. | |||||
| - Built on top of the [Laravel](https://laravel.com) components. | |||||
| - Optional installation of Laravel [Eloquent](https://laravel-zero.com/docs/database/), Laravel [Logging](https://laravel-zero.com/docs/logging/) and many others. | |||||
| - Supports interactive [menus](https://laravel-zero.com/docs/build-interactive-menus/) and [desktop notifications](https://laravel-zero.com/docs/send-desktop-notifications/) on Linux, Windows & MacOS. | |||||
| - Ships with a [Scheduler](https://laravel-zero.com/docs/task-scheduling/) and a [Standalone Compiler](https://laravel-zero.com/docs/build-a-standalone-application/). | |||||
| - Integration with [Collision](https://github.com/nunomaduro/collision) - Beautiful error reporting | |||||
| ------ | |||||
| ## Documentation | |||||
| For full documentation, visit [laravel-zero.com](https://laravel-zero.com/). | |||||
| ## Support the development | |||||
| **Do you like this project? Support it by donating** | |||||
| - PayPal: [Donate](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=66BYDWAT92N6L) | |||||
| - Patreon: [Donate](https://www.patreon.com/nunomaduro) | |||||
| ## License | |||||
| Laravel Zero is an open-source software licensed under the [MIT license](https://github.com/laravel-zero/laravel-zero/blob/stable/LICENSE.md). | |||||
| @ -0,0 +1,59 @@ | |||||
| <?php | |||||
| namespace App\Commands; | |||||
| use Illuminate\Console\Scheduling\Schedule; | |||||
| use LaravelZero\Framework\Commands\Command; | |||||
| use Illuminate\Support\Facades\File; | |||||
| use App\Facades\Install; | |||||
| use Log; | |||||
| class InstallMariadbCommand extends Command | |||||
| { | |||||
| /** | |||||
| * The signature of the command. | |||||
| * | |||||
| * @var string | |||||
| */ | |||||
| protected $signature = 'install:nginx'; | |||||
| /** | |||||
| * The description of the command. | |||||
| * | |||||
| * @var string | |||||
| */ | |||||
| protected $description = 'Install mariadb and set configuration'; | |||||
| /** | |||||
| * Execute the console command. | |||||
| * | |||||
| * @return mixed | |||||
| */ | |||||
| public function handle() | |||||
| { | |||||
| $this->info('Mariadb install...'); | |||||
| exec('apt update 2>&1'); | |||||
| exec('apt install -y mariadb-server mariadb-client 2>&1'); | |||||
| $link = mysqli_connect('127.0.0.1', 'root', $password); | |||||
| //exec('UPDATE mysql.user SET Password=PASSWORD('${install_mysql_password}') WHERE User='root';'); | |||||
| //mysql_query("UPDATE mysql.user SET Password=PASSWORD('$password') WHERE User='root';"); | |||||
| // | |||||
| mysqli_close($link); | |||||
| if (Install::isReady('mariadb-server mariadb-client')) { | |||||
| // get status of nginx | |||||
| exec('nginx -v 2>&1', $output); | |||||
| $status = "$output[0] installed"; | |||||
| $this->info($status); | |||||
| Log::info($status); | |||||
| } | |||||
| } | |||||
| } | |||||
| @ -0,0 +1,60 @@ | |||||
| <?php | |||||
| namespace App\Commands; | |||||
| use Illuminate\Console\Scheduling\Schedule; | |||||
| use LaravelZero\Framework\Commands\Command; | |||||
| use Illuminate\Support\Facades\File; | |||||
| use App\Facades\Install; | |||||
| use Log; | |||||
| class InstallPhpFpmCommand extends Command | |||||
| { | |||||
| /** | |||||
| * The signature of the command. | |||||
| * | |||||
| * @var string | |||||
| */ | |||||
| protected $signature = 'install:php-fpm'; | |||||
| /** | |||||
| * The description of the command. | |||||
| * | |||||
| * @var string | |||||
| */ | |||||
| protected $description = 'Install php-fpm'; | |||||
| /** | |||||
| * Execute the console command. | |||||
| * | |||||
| * @return mixed | |||||
| */ | |||||
| public function handle() | |||||
| { | |||||
| //$option = $this->menu('Install') | |||||
| // ->addOption('nginx', 'Nginx') | |||||
| // ->open(); | |||||
| //File::put('/etc/kkk', '/etc/kkk'); | |||||
| //$workers = exec('echo $(grep ^processor /proc/cpuinfo | wc -l)'); | |||||
| //$ | |||||
| //$ | |||||
| $this->info('Install PHP FPM'); | |||||
| exec('apt update 2>&1'); | |||||
| exec('apt install -y php-fpm php-curl php-mysql php-pear php-mbstring php-dev php-gd 2>&1'); | |||||
| if (Install::isReady('nginx')) { | |||||
| // get status of nginx | |||||
| exec('nginx -v 2>&1', $output); | |||||
| $status = "$output[0] installed"; | |||||
| $this->info($status); | |||||
| Log::info($status); | |||||
| } | |||||
| } | |||||
| } | |||||
| @ -0,0 +1,58 @@ | |||||
| <?php | |||||
| namespace App\Commands; | |||||
| use Illuminate\Console\Scheduling\Schedule; | |||||
| use LaravelZero\Framework\Commands\Command; | |||||
| use Illuminate\Support\Facades\File; | |||||
| use App\Facades\Install; | |||||
| use Log; | |||||
| class InstallUfwCommand extends Command | |||||
| { | |||||
| /** | |||||
| * The signature of the command. | |||||
| * | |||||
| * @var string | |||||
| */ | |||||
| protected $signature = 'install:nginx'; | |||||
| /** | |||||
| * The description of the command. | |||||
| * | |||||
| * @var string | |||||
| */ | |||||
| protected $description = 'Install mariadb and set configuration'; | |||||
| /** | |||||
| * Execute the console command. | |||||
| * | |||||
| * @return mixed | |||||
| */ | |||||
| public function handle() | |||||
| { | |||||
| $this->line('Install ufw...'); | |||||
| exec('apt update 2>&1'); | |||||
| exec('apt install -y ufw 2>&1'); | |||||
| exec('ufw allow ssh'); | |||||
| exec('ufw allow "Nginx Full"'); | |||||
| exec('ufw allow "OpenSSH"'); | |||||
| // starting | |||||
| exec('service ufw start'); | |||||
| exec('echo "y" | ufw enable'); | |||||
| if (Install::isReady('ufw')) { | |||||
| $status = "Install ufw...success"; | |||||
| $this->info($status); | |||||
| Log::info($status); | |||||
| } else { | |||||
| $this->error('Install ufw...failed'); | |||||
| } | |||||
| } | |||||
| } | |||||
| @ -0,0 +1,62 @@ | |||||
| <?php | |||||
| namespace App\Commands; | |||||
| use Illuminate\Console\Scheduling\Schedule; | |||||
| use LaravelZero\Framework\Commands\Command; | |||||
| use Log; | |||||
| class MonitoringStateCommand extends Command | |||||
| { | |||||
| /** | |||||
| * The signature of the command. | |||||
| * | |||||
| * @var string | |||||
| */ | |||||
| protected $signature = 'monitoring:state'; | |||||
| /** | |||||
| * The description of the command. | |||||
| * | |||||
| * @var string | |||||
| */ | |||||
| protected $description = 'I'; | |||||
| /** | |||||
| * Execute the console command. | |||||
| * | |||||
| * @return mixed | |||||
| */ | |||||
| public function handle() | |||||
| { | |||||
| // getting harddisks | |||||
| exec('df -H | grep \'^/dev\'', $harddisks); | |||||
| // | |||||
| exec('$(apt list --upgradable 2>/dev/null | grep "\-security" | wc -l)', $securityUpgrades); | |||||
| if (isset($securityUpgrades[0]) && intval($securityUpgrades[0]) > 0) { | |||||
| exec('apt list --upgradable 2>/dev/null | grep "\-security"', $securityUpgrades); | |||||
| // remove listening | |||||
| if (isset($securityUpgrades[1])) { | |||||
| unset($securityUpgrades[1]); | |||||
| } | |||||
| } | |||||
| // getting info of files | |||||
| exec('echo $(apt list --upgradable 2>/dev/null | grep -v "\-security" | wc -l)', $upgrades); | |||||
| if (isset($upgrades[0]) && intval($upgrades[0]) > 0) { | |||||
| exec('apt list --upgradable 2>/dev/null | grep -v "\-security"', $upgrades); | |||||
| // remove listening | |||||
| if (isset($upgrades[1])) { | |||||
| unset($upgrades[1]); | |||||
| } | |||||
| } | |||||
| echo (implode("\n", $upgrades)); | |||||
| } | |||||
| } | |||||
| @ -0,0 +1,126 @@ | |||||
| <?php | |||||
| namespace App\Commands; | |||||
| use Illuminate\Console\Scheduling\Schedule; | |||||
| use LaravelZero\Framework\Commands\Command; | |||||
| use Illuminate\Support\Facades\File; | |||||
| use App\Facades\Install; | |||||
| use PhpSchool\CliMenu\Builder\CliMenuBuilder; | |||||
| use PhpSchool\CliMenu\CliMenu; | |||||
| use PhpSchool\CliMenu\MenuItem\CheckboxItem; | |||||
| use PhpSchool\CliMenu\Style\SelectableStyle; | |||||
| use Log; | |||||
| use App\Facades\Nginx; | |||||
| class NginxCertsCommand extends Command | |||||
| { | |||||
| /** | |||||
| * The signature of the command. | |||||
| * | |||||
| * @var string | |||||
| */ | |||||
| protected $signature = 'nginx:certs'; | |||||
| /** | |||||
| * The description of the command. | |||||
| * | |||||
| * @var string | |||||
| */ | |||||
| protected $description = 'Create and Manage Nginx Vhosts'; | |||||
| /** | |||||
| * | |||||
| * | |||||
| */ | |||||
| /** | |||||
| * Execute the console command. | |||||
| * | |||||
| * @return mixed | |||||
| */ | |||||
| public function handle() | |||||
| { | |||||
| var_dump(Nginx::getVhosts()); | |||||
| // create menu | |||||
| //$main = $this->menu('Nginx Let\'s Encrypt'); | |||||
| //$main | |||||
| // ->addLineBreak('-') | |||||
| // ->open(); | |||||
| /*** | |||||
| $itemCallable = function(CliMenu $menu) { | |||||
| // getting sites-available | |||||
| $sitesAvailable = scandir('/etc/nginx/sites-available'); | |||||
| // getting sites-endabled | |||||
| $sitesEnabled = scandir('/etc/nginx/sites-enabled'); | |||||
| foreach($sitesAvailable as $site) { | |||||
| if ($site !== '.' && $site !== '..') { | |||||
| // getting title | |||||
| $title = str_replace('.conf', '', $site); | |||||
| $checkbox = new CheckboxItem('enabled', function(CliMenu $menu) use ($site, $title) { | |||||
| // check status | |||||
| if ($menu->getSelectedItem()->getChecked()) { | |||||
| symlink('/etc/nginx/sites-available/'.$site, '/etc/nginx/sites-enabled/'.$site); | |||||
| $status = 'enabled'; | |||||
| } else { | |||||
| unlink('/etc/nginx/sites-enabled/'.$site); | |||||
| $status = 'disabled'; | |||||
| } | |||||
| // starting | |||||
| exec('service nginx restart'); | |||||
| exec('service nginx status', $output); | |||||
| if (strpos(implode(' ', $output), 'active') !== false) { | |||||
| $menu->confirm($title.' is '.$status.'!')->display('OK!'); | |||||
| } else { | |||||
| $menu->confirm('Error! Something not working!')->display('OK!'); | |||||
| } | |||||
| }); | |||||
| // adding checkbox | |||||
| if (in_array($site, $sitesEnabled)) { | |||||
| $checkbox->setChecked(true); | |||||
| } | |||||
| $menuMain | |||||
| ->addSubmenu($title, function(CliMenuBuilder $builder) use ($site, $title, $checkbox) { | |||||
| $builder->setTitle("Nginx > $title") | |||||
| ->addItem('edit', function(CliMenu $menu) use ($site, $title) { | |||||
| system('nano /etc/nginx/sites-available/'.$site.' > `tty`'); | |||||
| }) | |||||
| ->addItem('delete', function(CliMenu $menu) use ($site) { | |||||
| if (file_exists('/etc/nginx/sites-enabled/'.$site)) { | |||||
| $menu->confirm('Error! Please disable '.$title.' first!')->display('OK!'); | |||||
| } else { | |||||
| unlink('/etc/nginx/sites-available/'.$site); | |||||
| $menu->confirm("$site is deleted!")->display('OK!'); | |||||
| } | |||||
| }) | |||||
| ->addLineBreak('-') | |||||
| ->addMenuItem($checkbox) | |||||
| ->addLineBreak('-'); | |||||
| }); | |||||
| } | |||||
| } | |||||
| };*/ | |||||
| } | |||||
| } | |||||
| @ -0,0 +1,60 @@ | |||||
| <?php | |||||
| namespace App\Commands; | |||||
| use Illuminate\Console\Scheduling\Schedule; | |||||
| use LaravelZero\Framework\Commands\Command; | |||||
| use Illuminate\Support\Facades\File; | |||||
| use App\Facades\Install; | |||||
| use Log; | |||||
| class NginxInstallCommand extends Command | |||||
| { | |||||
| /** | |||||
| * The signature of the command. | |||||
| * | |||||
| * @var string | |||||
| */ | |||||
| protected $signature = 'nginx:install'; | |||||
| /** | |||||
| * The description of the command. | |||||
| * | |||||
| * @var string | |||||
| */ | |||||
| protected $description = 'Install Nginx'; | |||||
| /** | |||||
| * Execute the console command. | |||||
| * | |||||
| * @return mixed | |||||
| */ | |||||
| public function handle() | |||||
| { | |||||
| //$option = $this->menu('Install') | |||||
| // ->addOption('nginx', 'Nginx') | |||||
| // ->open(); | |||||
| //File::put('/etc/kkk', '/etc/kkk'); | |||||
| //$workers = exec('echo $(grep ^processor /proc/cpuinfo | wc -l)'); | |||||
| //$ | |||||
| //$ | |||||
| $this->info('Nginx install...'); | |||||
| exec('apt update 2>&1'); | |||||
| exec('apt install -y nginx 2>&1'); | |||||
| if (Install::isReady('nginx')) { | |||||
| // get status of nginx | |||||
| exec('nginx -v 2>&1', $output); | |||||
| $status = "$output[0] installed"; | |||||
| $this->info($status); | |||||
| Log::info($status); | |||||
| } | |||||
| } | |||||
| } | |||||
| @ -0,0 +1,176 @@ | |||||
| <?php | |||||
| namespace App\Commands; | |||||
| use Illuminate\Console\Scheduling\Schedule; | |||||
| use LaravelZero\Framework\Commands\Command; | |||||
| use Illuminate\Support\Facades\File; | |||||
| use App\Facades\Install; | |||||
| use PhpSchool\CliMenu\Builder\CliMenuBuilder; | |||||
| use PhpSchool\CliMenu\CliMenu; | |||||
| use PhpSchool\CliMenu\MenuItem\CheckboxItem; | |||||
| use PhpSchool\CliMenu\Style\SelectableStyle; | |||||
| use Log; | |||||
| class NginxVhostsCommand extends Command | |||||
| { | |||||
| // path templates | |||||
| const TEMPLATES_DIR = '/resources/templates/nginx'; | |||||
| /** | |||||
| * The signature of the command. | |||||
| * | |||||
| * @var string | |||||
| */ | |||||
| protected $signature = 'nginx:vhosts'; | |||||
| /** | |||||
| * The description of the command. | |||||
| * | |||||
| * @var string | |||||
| */ | |||||
| protected $description = 'Create and Manage Nginx Vhosts'; | |||||
| /** | |||||
| * | |||||
| * | |||||
| * | |||||
| */ | |||||
| private function add(CliMenuBuilder $builder) | |||||
| { | |||||
| } | |||||
| /** | |||||
| * Execute the console command. | |||||
| * | |||||
| * @return mixed | |||||
| */ | |||||
| public function handle() | |||||
| { | |||||
| // create menu | |||||
| $main = $this->menu(self::MENU_TITLE) | |||||
| ->addSubMenu('add', function(CliMenuBuilder $builder) { | |||||
| // getting templates | |||||
| $templates = scandir(base_path().self::TEMPLATES_DIR); | |||||
| foreach($templates as $template) { | |||||
| $builder | |||||
| ->addSubMenu($template, function(CliMenuBuilder $builder) use ($template) { | |||||
| $configuration = [ | |||||
| 'domain' => '', | |||||
| 'ssl' => true, | |||||
| 'redirect_www' => true | |||||
| ]; | |||||
| $checkboxSSL = new CheckboxItem('ssl', function(CliMenu $menu) use (&$configuration) { | |||||
| $configuration['ssl'] = $menu->getSelectedItem()->getChecked(); | |||||
| }); | |||||
| $checkboxSSL->setChecked($configuration['ssl']); | |||||
| $checkboxRedirect = new CheckboxItem('redirect www', function(CliMenu $menu) use (&$configuration) { | |||||
| $configuration['redirect www'] = $menu->getSelectedItem()->getChecked(); | |||||
| }); | |||||
| $checkboxRedirect->setChecked($configuration['redirect_www']); | |||||
| $builder | |||||
| ->setTitle('Nginx Vhosts > add > '.$template) | |||||
| ->addItem('domain', function(CliMenu $menu) use (&$configuration) { | |||||
| $result = $menu->askText()->ask(); | |||||
| $configuration['domain'] = $result->fetch(); | |||||
| $menu->getSelectedItem()->setText('domain -> '.$result->fetch()); | |||||
| $menu->redraw(); | |||||
| }) | |||||
| ->addLineBreak('-') | |||||
| ->addMenuItem($checkboxSSL) | |||||
| ->addMenuItem($checkboxRedirect) | |||||
| ->addLineBreak('-') | |||||
| ->addItem('save', function() use (&$configuration) { | |||||
| var_dump($configuration); | |||||
| }) | |||||
| ->addLineBreak('-'); | |||||
| }); | |||||
| } | |||||
| //exec('touch /etc/nginx/sites-available/'); | |||||
| }) | |||||
| ->addLineBreak('-'); | |||||
| /*** | |||||
| $itemCallable = function(CliMenu $menu) { | |||||
| // getting sites-available | |||||
| $sitesAvailable = scandir('/etc/nginx/sites-available'); | |||||
| // getting sites-endabled | |||||
| $sitesEnabled = scandir('/etc/nginx/sites-enabled'); | |||||
| foreach($sitesAvailable as $site) { | |||||
| if ($site !== '.' && $site !== '..') { | |||||
| // getting title | |||||
| $title = str_replace('.conf', '', $site); | |||||
| $checkbox = new CheckboxItem('enabled', function(CliMenu $menu) use ($site, $title) { | |||||
| // check status | |||||
| if ($menu->getSelectedItem()->getChecked()) { | |||||
| symlink('/etc/nginx/sites-available/'.$site, '/etc/nginx/sites-enabled/'.$site); | |||||
| $status = 'enabled'; | |||||
| } else { | |||||
| unlink('/etc/nginx/sites-enabled/'.$site); | |||||
| $status = 'disabled'; | |||||
| } | |||||
| // starting | |||||
| exec('service nginx restart'); | |||||
| exec('service nginx status', $output); | |||||
| if (strpos(implode(' ', $output), 'active') !== false) { | |||||
| $menu->confirm($title.' is '.$status.'!')->display('OK!'); | |||||
| } else { | |||||
| $menu->confirm('Error! Something not working!')->display('OK!'); | |||||
| } | |||||
| }); | |||||
| // adding checkbox | |||||
| if (in_array($site, $sitesEnabled)) { | |||||
| $checkbox->setChecked(true); | |||||
| } | |||||
| $menuMain | |||||
| ->addSubmenu($title, function(CliMenuBuilder $builder) use ($site, $title, $checkbox) { | |||||
| $builder->setTitle("Nginx > $title") | |||||
| ->addItem('edit', function(CliMenu $menu) use ($site, $title) { | |||||
| system('nano /etc/nginx/sites-available/'.$site.' > `tty`'); | |||||
| }) | |||||
| ->addItem('delete', function(CliMenu $menu) use ($site) { | |||||
| if (file_exists('/etc/nginx/sites-enabled/'.$site)) { | |||||
| $menu->confirm('Error! Please disable '.$title.' first!')->display('OK!'); | |||||
| } else { | |||||
| unlink('/etc/nginx/sites-available/'.$site); | |||||
| $menu->confirm("$site is deleted!")->display('OK!'); | |||||
| } | |||||
| }) | |||||
| ->addLineBreak('-') | |||||
| ->addMenuItem($checkbox) | |||||
| ->addLineBreak('-'); | |||||
| }); | |||||
| } | |||||
| } | |||||
| };*/ | |||||
| $main->addLineBreak('-')->open(); | |||||
| } | |||||
| } | |||||
| @ -0,0 +1,20 @@ | |||||
| <?php | |||||
| namespace App\Facades; | |||||
| use Illuminate\Support\Facades\Facade; | |||||
| /** | |||||
| * Install | |||||
| * | |||||
| * @author Björn Hase | |||||
| * @license http://opensource.org/licenses/MIT The MIT License | |||||
| * @link https://github.com/nirgendswo/fuzzy-cms GitHub Repository | |||||
| */ | |||||
| class Install extends Facade | |||||
| { | |||||
| protected static function getFacadeAccessor() | |||||
| { | |||||
| return 'App\Helpers\InstallHelper'; | |||||
| } | |||||
| } | |||||
| @ -0,0 +1,20 @@ | |||||
| <?php | |||||
| namespace App\Facades; | |||||
| use Illuminate\Support\Facades\Facade; | |||||
| /** | |||||
| * Nginx | |||||
| * | |||||
| * @author Björn Hase | |||||
| * @license http://opensource.org/licenses/MIT The MIT License | |||||
| * @link https://github.com/nirgendswo/fuzzy-cms GitHub Repository | |||||
| */ | |||||
| class Nginx extends Facade | |||||
| { | |||||
| protected static function getFacadeAccessor() | |||||
| { | |||||
| return 'App\Helpers\NginxHelper'; | |||||
| } | |||||
| } | |||||
| @ -0,0 +1,28 @@ | |||||
| <?php | |||||
| namespace App\Helpers; | |||||
| class InstallHelper | |||||
| { | |||||
| // | |||||
| const PACKAGE_STATUS = 'Status: install ok installed'; | |||||
| /** | |||||
| * check if a packege is installed | |||||
| * | |||||
| * @param string $name | |||||
| * @return boolean | |||||
| */ | |||||
| public function isReady($name) | |||||
| { | |||||
| $result = false; | |||||
| exec('echo $(dpkg -s nginx 2>&1 | grep "'.self::PACKAGE_STATUS.'")', $output); | |||||
| if (isset($output[0]) && $output[0] === self::PACKAGE_STATUS) { | |||||
| $result = true; | |||||
| } | |||||
| return $result; | |||||
| } | |||||
| } | |||||
| @ -0,0 +1,131 @@ | |||||
| <?php | |||||
| namespace App\Helpers; | |||||
| /** | |||||
| * | |||||
| * | |||||
| * | |||||
| * | |||||
| */ | |||||
| class NginxHelper | |||||
| { | |||||
| // path for available files | |||||
| const SITES_AVAILABLE = '/etc/nginx/sites-available'; | |||||
| // path for enabled files | |||||
| const SITES_ENABLED = '/etc/nginx/sites-enabled'; | |||||
| // regex to get files for | |||||
| const REGEX_SSL_CERTIFICATE = '/\bssl_certificate\s+\K\S+/'; | |||||
| const REGEX_SSL_CERTIFICATE_KEY = '/\bssl_certificate_key\s+\K\S+/'; | |||||
| // ignore files | |||||
| const IGNORE_FILES = [ | |||||
| '.', '..' | |||||
| ]; | |||||
| /** | |||||
| * | |||||
| * | |||||
| * | |||||
| * @return array | |||||
| * | |||||
| */ | |||||
| private function getSitesAvailable() | |||||
| { | |||||
| return scandir(self::SITES_AVAILABLE); | |||||
| } | |||||
| /** | |||||
| * | |||||
| * | |||||
| * | |||||
| * @return array | |||||
| * | |||||
| */ | |||||
| private function getSitesEnabled() | |||||
| { | |||||
| return scandir(self::SITES_ENABLED); | |||||
| } | |||||
| /** | |||||
| * find path for certificates in .conf-files | |||||
| * | |||||
| * | |||||
| * ssl_certificate /etc/letsencrypt/live/<domain>/fullchain.pem; | |||||
| * ssl_certificate_key /etc/letsencrypt/live/<domain>/privkey.pem; | |||||
| * | |||||
| */ | |||||
| private function getCertificate($path) | |||||
| { | |||||
| $result = [ | |||||
| 'ssl' => false, | |||||
| 'ssl_certificate_exists' => false, | |||||
| 'ssl_certificate_expired_at' => false | |||||
| ]; | |||||
| // getting .conf-file | |||||
| $content = file_get_contents($path); | |||||
| // check for path of sites | |||||
| preg_match(self::REGEX_SSL_CERTIFICATE, $content, $matches); | |||||
| preg_match(self::REGEX_SSL_CERTIFICATE_KEY, $content, $matches); | |||||
| // check for ssl certificates | |||||
| if (count($matches) >= 2) { | |||||
| $result['ssl'] = true; | |||||
| if (file_exists($matches[0]) && file_exists($matches[1])) { | |||||
| $result['ssl_certificate_exists'] = true; | |||||
| } | |||||
| exec('openssl x509 -noout -dates -in '.$path, $openssl); | |||||
| if (isset($openssl[1])) { | |||||
| $openssl = str_replace('notAfter=', '', $openssl[1]); | |||||
| } | |||||
| } | |||||
| return $result; | |||||
| } | |||||
| /** | |||||
| * getting vhosts | |||||
| * | |||||
| */ | |||||
| public function find() | |||||
| { | |||||
| $results = []; | |||||
| // getting available | |||||
| $available = $this->getSitesAvailable(); | |||||
| // getting enabled | |||||
| $enabled = $this->getSitesEnabled(); | |||||
| foreach($available as $filename) | |||||
| { | |||||
| if (!in_array($filename, self::IGNORE_FILES)) { | |||||
| // getting full path | |||||
| $path = self::SITES_AVAILABLE.'/'.$filename; | |||||
| // getting certificates from a configuration | |||||
| $certificate = $this->getCertificate($path); | |||||
| $result = array_merge([ | |||||
| 'domain' => str_replace('.conf', '', $filename), | |||||
| 'path' => $path, | |||||
| 'file' => $filename, | |||||
| 'enabled' => in_array($filename, $enabled), | |||||
| ], $certificate); | |||||
| $results[] = $result; | |||||
| } | |||||
| } | |||||
| return $results; | |||||
| } | |||||
| } | |||||
| @ -0,0 +1,73 @@ | |||||
| <?php | |||||
| namespace App\Helpers; | |||||
| /** | |||||
| * | |||||
| * | |||||
| * | |||||
| * | |||||
| */ | |||||
| class NginxTemplateHelper | |||||
| { | |||||
| // path for templates files | |||||
| const TEMPLATES_PATH = '/ressources/templates'; | |||||
| // path for custom template files | |||||
| const CUSTOM_TEMPLATES_PATH = '/ressources/templates/custom'; | |||||
| /** | |||||
| * | |||||
| * | |||||
| * | |||||
| * @return array | |||||
| * | |||||
| */ | |||||
| private function getTemplates() | |||||
| { | |||||
| $results = []; | |||||
| array_merge( | |||||
| scandir(self::TEMPLATES_PATH), | |||||
| scandir(self::CUSTOM_TEMPLATES_PATH) | |||||
| ); | |||||
| return $templates; | |||||
| } | |||||
| /** | |||||
| * | |||||
| * @param [type] $files [description] | |||||
| * @param [type] $templatePath [description] | |||||
| * @return [type] [description] | |||||
| */ | |||||
| private function getTemplates($templatePath) | |||||
| { | |||||
| $results = []; | |||||
| foreach(scandir(base_dir().$templatePath) as $file) { | |||||
| if (!in_array($file, self::IGNORE_FILES)) { | |||||
| $results[] = [ | |||||
| 'filename' => $file, | |||||
| 'path' => $templatePath | |||||
| ]; | |||||
| } | |||||
| } | |||||
| return $results; | |||||
| } | |||||
| /** | |||||
| * getting templates | |||||
| * | |||||
| */ | |||||
| public function find() | |||||
| { | |||||
| $results = array_merge( | |||||
| $this->getTemplates(self::TEMPLATES_DIR), | |||||
| $this->getTemplates(self::TEMPLATES_CUSTOM_DIR) | |||||
| ); | |||||
| return $results; | |||||
| } | |||||
| } | |||||
| @ -0,0 +1,28 @@ | |||||
| <?php | |||||
| namespace App\Providers; | |||||
| use Illuminate\Support\ServiceProvider; | |||||
| class AppServiceProvider extends ServiceProvider | |||||
| { | |||||
| /** | |||||
| * Bootstrap any application services. | |||||
| * | |||||
| * @return void | |||||
| */ | |||||
| public function boot() | |||||
| { | |||||
| } | |||||
| /** | |||||
| * Register any application services. | |||||
| * | |||||
| * @return void | |||||
| */ | |||||
| public function register() | |||||
| { | |||||
| } | |||||
| } | |||||
| @ -0,0 +1,50 @@ | |||||
| <?php | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Create The Application | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | The first thing we will do is create a new Laravel application instance | |||||
| | which serves as the "glue" for all the components of Laravel, and is | |||||
| | the IoC container for the system binding all of the various parts. | |||||
| | | |||||
| */ | |||||
| $app = new LaravelZero\Framework\Application( | |||||
| dirname(__DIR__) | |||||
| ); | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Bind Important Interfaces | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | Next, we need to bind some important interfaces into the container so | |||||
| | we will be able to resolve them when needed. The kernels serve the | |||||
| | incoming requests to this application from both the web and CLI. | |||||
| | | |||||
| */ | |||||
| $app->singleton( | |||||
| Illuminate\Contracts\Console\Kernel::class, | |||||
| LaravelZero\Framework\Kernel::class | |||||
| ); | |||||
| $app->singleton( | |||||
| Illuminate\Contracts\Debug\ExceptionHandler::class, | |||||
| Illuminate\Foundation\Exceptions\Handler::class | |||||
| ); | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Return The Application | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | This script returns the application instance. The instance is given to | |||||
| | the calling script so we can separate the building of the instances | |||||
| | from the actual running of the application and sending responses. | |||||
| | | |||||
| */ | |||||
| return $app; | |||||
| @ -0,0 +1,53 @@ | |||||
| { | |||||
| "name": "laravel-zero/laravel-zero", | |||||
| "description": "The Laravel Zero Framework.", | |||||
| "keywords": ["framework", "laravel", "laravel zero", "console", "cli"], | |||||
| "homepage": "https://laravel-zero.com", | |||||
| "type": "project", | |||||
| "license": "MIT", | |||||
| "support": { | |||||
| "issues": "https://github.com/laravel-zero/laravel-zero/issues", | |||||
| "source": "https://github.com/laravel-zero/laravel-zero" | |||||
| }, | |||||
| "authors": [ | |||||
| { | |||||
| "name": "Nuno Maduro", | |||||
| "email": "enunomaduro@gmail.com" | |||||
| } | |||||
| ], | |||||
| "require": { | |||||
| "php": "^7.2.5", | |||||
| "illuminate/log": "^7.0", | |||||
| "jenssegers/blade": "^1.3", | |||||
| "laminas/laminas-text": "^2.7", | |||||
| "laravel-zero/framework": "^7.0", | |||||
| "nunomaduro/laravel-console-menu": "^3.0" | |||||
| }, | |||||
| "require-dev": { | |||||
| "mockery/mockery": "^1.3.1", | |||||
| "phpunit/phpunit": "^8.5" | |||||
| }, | |||||
| "autoload": { | |||||
| "psr-4": { | |||||
| "App\\": "app/" | |||||
| } | |||||
| }, | |||||
| "autoload-dev": { | |||||
| "psr-4": { | |||||
| "Tests\\": "tests/" | |||||
| } | |||||
| }, | |||||
| "config": { | |||||
| "preferred-install": "dist", | |||||
| "sort-packages": true, | |||||
| "optimize-autoloader": true | |||||
| }, | |||||
| "scripts": { | |||||
| "post-create-project-cmd": [ | |||||
| "@php application app:rename" | |||||
| ] | |||||
| }, | |||||
| "minimum-stability": "dev", | |||||
| "prefer-stable": true, | |||||
| "bin": ["application"] | |||||
| } | |||||
| @ -0,0 +1,60 @@ | |||||
| <?php | |||||
| return [ | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Application Name | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | This value is the name of your application. This value is used when the | |||||
| | framework needs to place the application's name in a notification or | |||||
| | any other location as required by the application or its packages. | |||||
| | | |||||
| */ | |||||
| 'name' => 'MCP', | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Application Version | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | This value determines the "version" your application is currently running | |||||
| | in. You may want to follow the "Semantic Versioning" - Given a version | |||||
| | number MAJOR.MINOR.PATCH when an update happens: https://semver.org. | |||||
| | | |||||
| */ | |||||
| 'version' => app('git.version'), | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Application Environment | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | This value determines the "environment" your application is currently | |||||
| | running in. This may determine how you prefer to configure various | |||||
| | services the application utilizes. This can be overridden using | |||||
| | the global command line "--env" option when calling commands. | |||||
| | | |||||
| */ | |||||
| 'env' => 'development', | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Autoloaded Service Providers | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | The service providers listed here will be automatically loaded on the | |||||
| | request to your application. Feel free to add your own services to | |||||
| | this array to grant expanded functionality to your applications. | |||||
| | | |||||
| */ | |||||
| 'providers' => [ | |||||
| App\Providers\AppServiceProvider::class, | |||||
| ], | |||||
| ]; | |||||
| @ -0,0 +1,80 @@ | |||||
| <?php | |||||
| return [ | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Default Command | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | Laravel Zero will always run the command specified below when no command name is | |||||
| | provided. Consider update the default command for single command applications. | |||||
| | You cannot pass arguments to the default command because they are ignored. | |||||
| | | |||||
| */ | |||||
| 'default' => NunoMaduro\LaravelConsoleSummary\SummaryCommand::class, | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Commands Paths | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | This value determines the "paths" that should be loaded by the console's | |||||
| | kernel. Foreach "path" present on the array provided below the kernel | |||||
| | will extract all "Illuminate\Console\Command" based class commands. | |||||
| | | |||||
| */ | |||||
| 'paths' => [app_path('Commands')], | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Added Commands | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | You may want to include a single command class without having to load an | |||||
| | entire folder. Here you can specify which commands should be added to | |||||
| | your list of commands. The console's kernel will try to load them. | |||||
| | | |||||
| */ | |||||
| 'add' => [ | |||||
| // .. | |||||
| ], | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Hidden Commands | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | Your application commands will always be visible on the application list | |||||
| | of commands. But you can still make them "hidden" specifying an array | |||||
| | of commands below. All "hidden" commands can still be run/executed. | |||||
| | | |||||
| */ | |||||
| 'hidden' => [ | |||||
| NunoMaduro\LaravelConsoleSummary\SummaryCommand::class, | |||||
| Symfony\Component\Console\Command\HelpCommand::class, | |||||
| Illuminate\Console\Scheduling\ScheduleRunCommand::class, | |||||
| Illuminate\Console\Scheduling\ScheduleFinishCommand::class, | |||||
| Illuminate\Foundation\Console\VendorPublishCommand::class, | |||||
| ], | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Removed Commands | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | Do you have a service provider that loads a list of commands that | |||||
| | you don't need? No problem. Laravel Zero allows you to specify | |||||
| | below a list of commands that you don't to see in your app. | |||||
| | | |||||
| */ | |||||
| 'remove' => [ | |||||
| // .. | |||||
| ], | |||||
| ]; | |||||
| @ -0,0 +1,100 @@ | |||||
| <?php | |||||
| use Monolog\Handler\NullHandler; | |||||
| use Monolog\Handler\StreamHandler; | |||||
| use Monolog\Handler\SyslogUdpHandler; | |||||
| return [ | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Default Log Channel | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | This option defines the default log channel that gets used when writing | |||||
| | messages to the logs. The name specified in this option should match | |||||
| | one of the channels defined in the "channels" configuration array. | |||||
| | | |||||
| */ | |||||
| 'default' => env('LOG_CHANNEL', 'stack'), | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Log Channels | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | Here you may configure the log channels for your application. Out of | |||||
| | the box, Laravel uses the Monolog PHP logging library. This gives | |||||
| | you a variety of powerful log handlers / formatters to utilize. | |||||
| | | |||||
| | Available Drivers: "single", "daily", "slack", "syslog", | |||||
| | "errorlog", "monolog", | |||||
| | "custom", "stack" | |||||
| | | |||||
| */ | |||||
| 'channels' => [ | |||||
| 'stack' => [ | |||||
| 'driver' => 'stack', | |||||
| 'channels' => ['stderr'], | |||||
| 'ignore_exceptions' => false, | |||||
| ], | |||||
| 'single' => [ | |||||
| 'driver' => 'single', | |||||
| 'path' => storage_path('logs/laravel.log'), | |||||
| 'level' => 'debug', | |||||
| ], | |||||
| 'daily' => [ | |||||
| 'driver' => 'daily', | |||||
| 'path' => storage_path('logs/laravel.log'), | |||||
| 'level' => 'debug', | |||||
| 'days' => 14, | |||||
| ], | |||||
| 'slack' => [ | |||||
| 'driver' => 'slack', | |||||
| 'url' => env('LOG_SLACK_WEBHOOK_URL'), | |||||
| 'username' => 'Laravel Log', | |||||
| 'emoji' => ':boom:', | |||||
| 'level' => 'critical', | |||||
| ], | |||||
| 'papertrail' => [ | |||||
| 'driver' => 'monolog', | |||||
| 'level' => 'debug', | |||||
| 'handler' => SyslogUdpHandler::class, | |||||
| 'handler_with' => [ | |||||
| 'host' => env('PAPERTRAIL_URL'), | |||||
| 'port' => env('PAPERTRAIL_PORT'), | |||||
| ], | |||||
| ], | |||||
| 'stderr' => [ | |||||
| 'driver' => 'monolog', | |||||
| 'handler' => StreamHandler::class, | |||||
| 'formatter' => env('LOG_STDERR_FORMATTER'), | |||||
| 'with' => [ | |||||
| 'stream' => 'php://stderr', | |||||
| ], | |||||
| ], | |||||
| 'syslog' => [ | |||||
| 'driver' => 'syslog', | |||||
| 'level' => 'debug', | |||||
| ], | |||||
| 'errorlog' => [ | |||||
| 'driver' => 'errorlog', | |||||
| 'level' => 'debug', | |||||
| ], | |||||
| 'null' => [ | |||||
| 'driver' => 'monolog', | |||||
| 'handler' => NullHandler::class, | |||||
| ], | |||||
| ], | |||||
| ]; | |||||
| @ -0,0 +1,72 @@ | |||||
| <?php | |||||
| return [ | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Enabled | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | This value determines if the app name should be represented as an | |||||
| | ASCII logo. This file provides a sane default location for all | |||||
| | information concerning the logo and is display customization. | |||||
| | | |||||
| */ | |||||
| 'enabled' => true, | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Default Font | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | This option defines the font which should be used for rendering. | |||||
| | By default, one default font is shipped. However, you are free | |||||
| | to download and use additional fonts: http://www.figlet.org. | |||||
| | | |||||
| */ | |||||
| 'font' => \LaravelZero\Framework\Components\Logo\FigletString::DEFAULT_FONT, | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Output Width | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | This option defines the maximum width of the output string. This is | |||||
| | used for word-wrap as well as justification. Be careful when using | |||||
| | small values, because they may result in an undefined behavior. | |||||
| | | |||||
| */ | |||||
| 'outputWidth' => 80, | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Justification | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | This option defines the justification of the logo text. By default, | |||||
| | justification is provided, which will work well on most of your | |||||
| | console apps. Of course, you are free to change this value. | |||||
| | | |||||
| */ | |||||
| 'justification' => null, | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Right To Left | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | This option defines the option in which the text is written. By, default | |||||
| | the setting of the font-file is used. When justification is not defined, | |||||
| | a text written from right-to-left is automatically right-aligned. | |||||
| | | |||||
| | Possible values: "right-to-left", "left-to-right", null | |||||
| | | |||||
| */ | |||||
| 'rightToLeft' => null, | |||||
| ]; | |||||
| @ -0,0 +1,28 @@ | |||||
| #!/usr/bin/env bash | |||||
| # | |||||
| # | |||||
| # | |||||
| set -o errexit | |||||
| set -o pipefail | |||||
| set -o nounset | |||||
| _hash=${1:-} | |||||
| if [ -z "${_hash}" ]; then | |||||
| echo -e "\$1 is required, please check on https://composer.github.io/pubkeys.html" | |||||
| exit 0 | |||||
| fi | |||||
| # installing dependencies | |||||
| apt install -y curl php-cli php-mbstring php-dom git unzip | |||||
| # download installer | |||||
| curl -sS https://getcomposer.org/installer -o composer-setup.php | |||||
| # check hash | |||||
| php -r "if (hash_file('SHA384', 'composer-setup.php') === '$_hash') { echo 'Installer verified'; } else { echo 'Installer corrupt'; unlink('composer-setup.php'); } echo PHP_EOL;" | |||||
| php composer-setup.php --install-dir=/usr/local/bin --filename=composer | |||||
| # remove installer | |||||
| rm composer-setup.php | |||||
| @ -0,0 +1,53 @@ | |||||
| #!/usr/bin/env php | |||||
| <?php | |||||
| define('LARAVEL_START', microtime(true)); | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Register The Auto Loader | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | Composer provides a convenient, automatically generated class loader | |||||
| | for our application. We just need to utilize it! We'll require it | |||||
| | into the script here so that we do not have to worry about the | |||||
| | loading of any our classes "manually". Feels great to relax. | |||||
| | | |||||
| */ | |||||
| $autoloader = require file_exists(__DIR__.'/vendor/autoload.php') ? __DIR__.'/vendor/autoload.php' : __DIR__.'/../../autoload.php'; | |||||
| $app = require_once __DIR__.'/bootstrap/app.php'; | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Run The Artisan Application | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | When we run the console application, the current CLI command will be | |||||
| | executed in this console and the response sent back to a terminal | |||||
| | or another output device for the developers. Here goes nothing! | |||||
| | | |||||
| */ | |||||
| $kernel = $app->make(Illuminate\Contracts\Console\Kernel::class); | |||||
| $status = $kernel->handle( | |||||
| $input = new Symfony\Component\Console\Input\ArgvInput, | |||||
| new Symfony\Component\Console\Output\ConsoleOutput | |||||
| ); | |||||
| /* | |||||
| |-------------------------------------------------------------------------- | |||||
| | Shutdown The Application | |||||
| |-------------------------------------------------------------------------- | |||||
| | | |||||
| | Once Artisan has finished running, we will fire off the shutdown events | |||||
| | so that any final work may be done by the application before we shut | |||||
| | down the process. This is the last thing to happen to the request. | |||||
| | | |||||
| */ | |||||
| $kernel->terminate($input, $status); | |||||
| exit($status); | |||||
| @ -0,0 +1,24 @@ | |||||
| <?xml version="1.0" encoding="UTF-8"?> | |||||
| <phpunit backupGlobals="false" | |||||
| backupStaticAttributes="false" | |||||
| bootstrap="vendor/autoload.php" | |||||
| colors="true" | |||||
| convertErrorsToExceptions="true" | |||||
| convertNoticesToExceptions="true" | |||||
| convertWarningsToExceptions="true" | |||||
| processIsolation="false" | |||||
| stopOnFailure="false"> | |||||
| <testsuites> | |||||
| <testsuite name="Feature"> | |||||
| <directory suffix="Test.php">./tests/Feature</directory> | |||||
| </testsuite> | |||||
| <testsuite name="Unit"> | |||||
| <directory suffix="Test.php">./tests/Unit</directory> | |||||
| </testsuite> | |||||
| </testsuites> | |||||
| <filter> | |||||
| <whitelist processUncoveredFilesFromWhitelist="true"> | |||||
| <directory suffix=".php">./app</directory> | |||||
| </whitelist> | |||||
| </filter> | |||||
| </phpunit> | |||||
| @ -0,0 +1 @@ | |||||
| /etc/kkk | |||||
| @ -0,0 +1,22 @@ | |||||
| <?php | |||||
| namespace Tests; | |||||
| use Illuminate\Contracts\Console\Kernel; | |||||
| trait CreatesApplication | |||||
| { | |||||
| /** | |||||
| * Creates the application. | |||||
| * | |||||
| * @return \Illuminate\Foundation\Application | |||||
| */ | |||||
| public function createApplication() | |||||
| { | |||||
| $app = require __DIR__.'/../bootstrap/app.php'; | |||||
| $app->make(Kernel::class)->bootstrap(); | |||||
| return $app; | |||||
| } | |||||
| } | |||||
| @ -0,0 +1,20 @@ | |||||
| <?php | |||||
| namespace Tests\Feature; | |||||
| use Tests\TestCase; | |||||
| class InspiringCommandTest extends TestCase | |||||
| { | |||||
| /** | |||||
| * A basic test example. | |||||
| * | |||||
| * @return void | |||||
| */ | |||||
| public function testInspiringCommand() | |||||
| { | |||||
| $this->artisan('inspiring') | |||||
| ->expectsOutput('Simplicity is the ultimate sophistication.') | |||||
| ->assertExitCode(0); | |||||
| } | |||||
| } | |||||
| @ -0,0 +1,10 @@ | |||||
| <?php | |||||
| namespace Tests; | |||||
| use LaravelZero\Framework\Testing\TestCase as BaseTestCase; | |||||
| abstract class TestCase extends BaseTestCase | |||||
| { | |||||
| use CreatesApplication; | |||||
| } | |||||
| @ -0,0 +1,18 @@ | |||||
| <?php | |||||
| namespace Tests\Unit; | |||||
| use Tests\TestCase; | |||||
| class ExampleTest extends TestCase | |||||
| { | |||||
| /** | |||||
| * A basic test example. | |||||
| * | |||||
| * @return void | |||||
| */ | |||||
| public function testBasicTest() | |||||
| { | |||||
| $this->assertTrue(true); | |||||
| } | |||||
| } | |||||