hamzaouaghad / multilayering
A tiny laravel package to speed up the workflow with the multilayering convetion
Requires
- php: >=5.3.0
- illuminate/support: ~5.1
Requires (Dev)
- phpunit/phpunit: 4.*
- scrutinizer/ocular: ~1.1
This package is not auto-updated.
Last update: 2024-11-23 18:49:42 UTC
README
This package is a tiny laravel package that generates artisan commands to generate the multilayer conventions faster, and speed up the workflow.
If you don't know what multilayer is , feel free to have quick read at coderwall
Install
Via Composer
$ composer require hamzaouaghad/multilayering
Usage
Make sure you add this line in your Config\app.php
'providers' => [ Hamzaouaghad\Multilayering\MultilayerGeneratorServiceProvider::class, Hamzaouaghad\Multilayering\RegisterCommandsServiceProvider::class, ],
save and run
$ composer dumpautoload -o $ php artisan vendor:publish
Now to go your 'app/providers/', you will find a new providers added :
MultilayerGeneratorServiceProvider
If it's your first time, and you still need to generate the new folder structure, please run:
php artisan make:multilayer
And afterwards, again, add this to your providers:
App\Providers\MultilayerGeneratorServiceProvider`.
Again,
$ composer dumpautoload -o $ php artisan vendor:publish
I could easily automate the process of adding all of these service providers and calling them for you, however, this is never the best approach, if not a bad practice, as adding them manually -unlinke automatic registering- actually keeps track of all of the service providers you are using, in your providers array.
So bare the pain of keeping your work organized, it's worth it.
If you wish to quicken the paste, and bake all, you may use the following command :
php artisan bake:all ClassName
This command will generate an eloquent class, an interface for it, and a repository that uses this interface. Also, at the http layer, it generates a motor for it that injects that repository.
If you may to bake all with specifics, you may use the following options:
--interface : The name of the interface to be created for our calss --motor : the name of the motor to be created for our class --trait : the name of the trait that your motor maye use --repository : the name of the repository that this class would be covered under.
After each file generation, you'll have to run
$ php artisan vendor:publish
As it will mention to you everytime, so I think you won't forget.
##Examples
php artisan bake:all User --repository=Accounts --interface=Security --motor=STAFF --trait=Authentication
This will create :
class User extends Eloquent
and
interface SecurityInterface
and
class AccountsRepository implements SecurityInterface
and
class STAFFmotor extends Motor { public function __construct(AccountsRepository $repo) { $this->repository = $repo; } use /Authentication; }
After all of this, the Providers\MultilayerGeneratorServiceProvider
will be updated as follows :
class MultilayerGeneratorServiceProvider extends ServiceProvider { /** * Bootstrap the application services. * * @return void */ public function boot() { // } /** * Register the application services. * * @return void */ public function register() { $this->app->booting(function(){ $loader = \Illuminate\Foundation\AliasLoader::getInstance(); /* | | Repositories Classes | */ $loader->alias('AccountsRepository', 'App\DataLayer\Repositories\AccountsRepository'); $loader->alias('AccountsRepoInterface', 'AccountsRepository'); /* | | Object Classes | */ $loader->alias('User', 'App\DataLayer\Objects\User'); /* | | Traits | */ $loader->alias('CRUDtrait', 'App\Http\Traits\CRUDtrait');//don't modify this. $loader->alias('AuthenticationTrait', 'App\Http\Traits\AuthenticationTrait'); /* | | Motors | */ $loader->alias('Motor', 'App\Http\Motors\Motor'); $loader->alias('STAFFmotor', 'App\Http\Controllers\Motors\STAFFmotor'); }); } }
Available commands
bake bake:all Creates an eloquent class, an interface and a repository for it, also a motor, and a trait if specified. bake:datalayer Bake the data layer for the given class make make:controller Create a new resource controller class make:datalayer Creates the datalayer directory structure make:datalayer:class Creates an eloquent class, its interface and its repository. make:datalayer:interface Creates an interface. make:datalayer:repository Creates a repository make:httplayer Creates the httplayer directory structure make:httplayer:basemotor Creates an abstract motor class for inheritence. make:httplayer:motor Creates a motor, with the injected specified repository, and the trait to be used. make:httplayer:trait make:multilayer This command generates the directory structure for the multilayering conventions.
If you wish to go your own way, without mass baking, you can use the following
php artisan make:datalayer:class <name> php artisan make:datalayer:interface <name> php artisan make:datalayer:repository <name> (with options: --interface= the one you wish your repo to implement, --class=The class whose repo is this php artisan make:httplayer:motor <name> --trait= : The trait that is desired to be used --repository= : A specific repository to be implemented php artisan make:httplayer:trait <name>
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email ouaghad.hamza@gmail.com instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.