biliboobrian / lumen-angular-code-generator by biliboobrian

Model, controller, provider and service generator for Lumen 5+ and Angular 6+ from DB schema
453
6
2
Package Data
Maintainer Username: biliboobrian
Maintainer Contact: biliboobrian@yahoo.fr (biliboobrian)
Package Create Date: 2018-07-10
Package Last Update: 2021-08-03
Home Page:
Language: PHP
License: MIT
Last Refreshed: 2025-01-14 15:14:19
Package Statistics
Total Downloads: 453
Monthly Downloads: 12
Daily Downloads: 4
Total Stars: 6
Total Watchers: 2
Total Forks: 3
Total Open Issues: 0

lumen-angular-code-generator

!! WORK IN PROGRESS > ANGULAR GENERATOR !!

Model, controller provider and service generator for lumen 5.6 and angular 6 from DB schema.

Installation

Use composer to install it in your lumen project.

composer require biliboobrian/lumen-angular-code-generator

Modify your bootstrap/app.php providers to add generators to Artisan.

$app->register(biliboobrian\lumenAngularCodeGenerator\Provider\GeneratorServiceProvider::class);

Usage

Scaffolding from DB

You need a database connection setup in your project.

Build CRUD models and controllers with various commands (List of available commands will be updated with development progress):

  bilibo:lumen:ctrl      Generate CRUD controller for a table name.
  bilibo:lumen:ctrls     Generate CRUD controllers for all tables.
  bilibo:lumen:model     Generate Eloquent model according to table passed in argument.
  bilibo:lumen:models    Generate Eloquent models for all tables.

Default configuration is the following ( you can override them with -c option in command line to provide another config.php file):

    'lumen_model_namespace'       	=> 'App\Models',
    'lumen_ctrl_namespace'       	=> 'App\Http\Controllers',
    'base_class_lumen_model_name' 	=> \biliboobrian\lumenAngularCodeGenerator\Model\MicroServiceExtendModel::class,
    'base_class_lumen_ctrl_name' 	=> \biliboobrian\lumenAngularCodeGenerator\Controller\CrudExtendController::class,
    'lumen_model_output_path'     	=> app_path() . '/Models',
    'lumen_ctrl_output_path'      	=> app_path() . '/Http/Controllers',
    'no_timestamps'   				=> null,
    'date_format'     				=> null,
	'connection'      				=> null,
	'add_route'      				=> null,
	'add_cache'      				=> null,

Use command help for more infos

$ php artisan bilibo:lumen:ctrl -h

Generation of controllers and models extend lushdigital/microservice-crud.

Usage of Generated Controllers and models

By default all controllers provide a set of applicable routes what you can add to your routes/web.php:

//for full tables retrieve
$router->get(   '/model',                 'ModelController@index');

//for paginated tables retrieve
$router->get(   '/model',                 'ModelController@get');


$router->get(   '/model/{id}/{relation}', 'ModelController@getRelationList');
$router->get(   '/model/{id}',            'ModelController@show');
$router->post(  '/model',                 'ModelController@store');
$router->put(   '/model/{id}',            'ModelController@update');
$router->delete('/model/{id}',            'ModelController@destroy');

You can add all routes to your web.php using -a option in the bilibo:lumen:ctrls command.

License

MIT