@ -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,7 @@ | |||||
* text=auto | |||||
/.github export-ignore | |||||
.styleci.yml export-ignore | |||||
.scrutinizer.yml export-ignore | |||||
BACKERS.md export-ignore | |||||
CONTRIBUTING.md export-ignore | |||||
CHANGELOG.md export-ignore |
@ -0,0 +1,5 @@ | |||||
/vendor | |||||
/.idea | |||||
/.vscode | |||||
/.vagrant | |||||
.phpunit.result.cache |
@ -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,44 @@ | |||||
<?php | |||||
namespace App\Commands; | |||||
use Illuminate\Console\Scheduling\Schedule; | |||||
use LaravelZero\Framework\Commands\Command; | |||||
class InspiringCommand extends Command | |||||
{ | |||||
/** | |||||
* The signature of the command. | |||||
* | |||||
* @var string | |||||
*/ | |||||
protected $signature = 'inspiring {name=Artisan}'; | |||||
/** | |||||
* The description of the command. | |||||
* | |||||
* @var string | |||||
*/ | |||||
protected $description = 'Display an inspiring quote'; | |||||
/** | |||||
* Execute the console command. | |||||
* | |||||
* @return mixed | |||||
*/ | |||||
public function handle() | |||||
{ | |||||
$this->info('Simplicity is the ultimate sophistication.'); | |||||
} | |||||
/** | |||||
* Define the command's schedule. | |||||
* | |||||
* @param \Illuminate\Console\Scheduling\Schedule $schedule | |||||
* @return void | |||||
*/ | |||||
public function schedule(Schedule $schedule) | |||||
{ | |||||
// $schedule->command(static::class)->everyMinute(); | |||||
} | |||||
} |
@ -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,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,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,18 @@ | |||||
{ | |||||
"chmod": "0755", | |||||
"directories": [ | |||||
"app", | |||||
"bootstrap", | |||||
"config", | |||||
"vendor" | |||||
], | |||||
"files": [ | |||||
"composer.json" | |||||
], | |||||
"exclude-composer-files": false, | |||||
"compression": "GZ", | |||||
"compactors": [ | |||||
"KevinGH\\Box\\Compactor\\Php", | |||||
"KevinGH\\Box\\Compactor\\Json" | |||||
] | |||||
} |
@ -0,0 +1,49 @@ | |||||
{ | |||||
"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", | |||||
"laravel-zero/framework": "^7.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' => 'Application', | |||||
/* | |||||
|-------------------------------------------------------------------------- | |||||
| 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,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,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); | |||||
} | |||||
} |