base on A Laravel Development Package for Creating Enums, Traits, Services Classes and more . # Laravel Maker: A Laravel Development Package for Creating Classes , Enums, Traits, Services Classes and more . [![Latest Version on Packagist](https://img.shields.io/packagist/v/ammaraldwayma/laravel-maker.svg?style=flat-square)](https://packagist.org/packages/ammaraldwayma/laravel-maker) [![Total Downloads](https://img.shields.io/packagist/dt/ammaraldwayma/laravel-maker.svg?style=flat-square)](https://packagist.org/packages/ammaraldwayma/laravel-maker) **Laravel Maker** is a powerful Laravel development package designed to help you to enhance your development process by creating Classes , Enums, Traits, Interfaces, Services and more with a single command. With Laravel Maker you can create the following classes: - [Classes](#creating-a-new-class) - [Enums](#creating-a-new-enum) - [Traits](#creating-a-new-trait) - [Interfaces](#creating-a-new-interface) - [Services](#creating-a-new-service--third-party-service) - [Repositories](#creating-a-new-repository) ## Installation You can install the package via composer: ```bash composer require ammaraldwayma/laravel-maker --dev ``` ## Usage ### Creating a new Class ```bash php artisan make:class Actions/StoreUserAction ``` This command will create a new class in the `app/Actions` directory. The class will be named `StoreUserAction` and will contain the following code: ```php <?php namespace App\Actions; class StoreUserAction { } ``` ### Creating a new Enum ```bash php artisan make:enum Statuses ``` This command will create a new enum class in the `app/Enums` directory. The class will be named `Statuses` and will contain the following constants: ```php <?php namespace App\Enums; enum Statuses: string { // } ``` [//]: # (You can also specify the values of the constants by passing them as arguments to the command:) [//]: # () [//]: # (```bash) [//]: # (php artisan make:enum Statuses PENDING APPROVED REJECTED) [//]: # (```) [//]: # () [//]: # (This will create the following enum class:) [//]: # () [//]: # (```php) [//]: # (<?php) [//]: # () [//]: # (enum Statuses: string) [//]: # ({) [//]: # ( case PENDING = 'PENDING';) [//]: # ( case APPROVED = 'APPROVED';) [//]: # ( case REJECTED = 'REJECTED';) [//]: # (}) [//]: # (```) ### Creating a new Trait ```bash php artisan make:trait HasStatus ``` This command will create a new trait class in the `app/Traits` directory. The class will be named `HasStatus` and will contain the following code: ```php <?php namespace App\Traits; trait HasStatus { // } ``` ### Creating a new Interface ```bash php artisan make:interface UserRepositoryInterface ``` This command will create a new interface class in the `app/Interfaces` directory. The class will be named `UserRepository` and will contain the following code: ```php <?php namespace App\Interfaces; interface UserRepositoryInterface { // } ``` ### Creating a new Service / Third-party Service ```bash php artisan make:service GoogleTranslationService ``` This command will create a new service class in the `app/Services` directory. The class will be named `GoogleTranslationService` and will contain the following code: ```php <?php namespace App\Services; class GoogleTranslationService { /** * @param PendingRequest $httpClient * @param array $serviceKeys */ public function __construct( protected PendingRequest $httpClient, protected array $serviceKeys = [], ) { $this->serviceKeys = config('services.google_translation'); $this->httpClient = Http::asJson() ->acceptJson() ->withoutVerifying() ->baseUrl($this->serviceKeys['base_url']) ->timeout($this->serviceKeys['timeout']); } /** * Get {{ name }} data . * * @param array $data * @return array */ public function get(array $data = []): array { $response = $this->httpClient->get('/'); if ($response->failed()) { return [ 'status' => false, 'data' => [], ]; } return [ 'status' => true, 'data' => $response->json(), ]; } } ``` ### Creating a new Repository ```bash php artisan make:repo UserRepository ``` This command will create a new repository class in the `app/Repositories` directory with a interface class in the `app/Repositories/Interfaces` directory. The class will be named `UserRepository` and will contain the following code: ```php <?php namespace App\Repositories; use App\Repositories\Interfaces\UserRepositoryInterface; use App\Models\User; class UserRepository implements UserRepositoryInterface { /** * @param User $user */ public function __construct( protected User $user, ) { // } } ``` ## Customizing the default namespaces You can customize the default namespaces for the different types of classes that you can generate it by the package by - Publishing the config file: ```bash php artisan vendor:publish --tag="maker-config" ``` - Changing the values of the `default_namespaces` array in the published config file: ```php return [ /* |-------------------------------------------------------------------------- | Default Namespaces |-------------------------------------------------------------------------- | Here you can specify the default namespaces for the different types of | classes that you can generate it by the package. | */ 'default_namespaces' => [ 'enum' => 'App\Enums', 'trait' => 'App\Traits', 'interface' => 'App\Interfaces', 'service' => 'App\Services', 'repository' => 'App\Repositories', ], ]; ``` ## Testing ```bash composer test ``` ## Changelog Please see [CHANGELOG](CHANGELOG.md) for more information on what has changed recently. ## License The MIT License (MIT). Please see [License File](LICENSE.md) for more information. ", Assign "at most 3 tags" to the expected json: {"id":"6744","tags":[]} "only from the tags list I provide: [{"id":77,"name":"3d"},{"id":89,"name":"agent"},{"id":17,"name":"ai"},{"id":54,"name":"algorithm"},{"id":24,"name":"api"},{"id":44,"name":"authentication"},{"id":3,"name":"aws"},{"id":27,"name":"backend"},{"id":60,"name":"benchmark"},{"id":72,"name":"best-practices"},{"id":39,"name":"bitcoin"},{"id":37,"name":"blockchain"},{"id":1,"name":"blog"},{"id":45,"name":"bundler"},{"id":58,"name":"cache"},{"id":21,"name":"chat"},{"id":49,"name":"cicd"},{"id":4,"name":"cli"},{"id":64,"name":"cloud-native"},{"id":48,"name":"cms"},{"id":61,"name":"compiler"},{"id":68,"name":"containerization"},{"id":92,"name":"crm"},{"id":34,"name":"data"},{"id":47,"name":"database"},{"id":8,"name":"declarative-gui "},{"id":9,"name":"deploy-tool"},{"id":53,"name":"desktop-app"},{"id":6,"name":"dev-exp-lib"},{"id":59,"name":"dev-tool"},{"id":13,"name":"ecommerce"},{"id":26,"name":"editor"},{"id":66,"name":"emulator"},{"id":62,"name":"filesystem"},{"id":80,"name":"finance"},{"id":15,"name":"firmware"},{"id":73,"name":"for-fun"},{"id":2,"name":"framework"},{"id":11,"name":"frontend"},{"id":22,"name":"game"},{"id":81,"name":"game-engine "},{"id":23,"name":"graphql"},{"id":84,"name":"gui"},{"id":91,"name":"http"},{"id":5,"name":"http-client"},{"id":51,"name":"iac"},{"id":30,"name":"ide"},{"id":78,"name":"iot"},{"id":40,"name":"json"},{"id":83,"name":"julian"},{"id":38,"name":"k8s"},{"id":31,"name":"language"},{"id":10,"name":"learning-resource"},{"id":33,"name":"lib"},{"id":41,"name":"linter"},{"id":28,"name":"lms"},{"id":16,"name":"logging"},{"id":76,"name":"low-code"},{"id":90,"name":"message-queue"},{"id":42,"name":"mobile-app"},{"id":18,"name":"monitoring"},{"id":36,"name":"networking"},{"id":7,"name":"node-version"},{"id":55,"name":"nosql"},{"id":57,"name":"observability"},{"id":46,"name":"orm"},{"id":52,"name":"os"},{"id":14,"name":"parser"},{"id":74,"name":"react"},{"id":82,"name":"real-time"},{"id":56,"name":"robot"},{"id":65,"name":"runtime"},{"id":32,"name":"sdk"},{"id":71,"name":"search"},{"id":63,"name":"secrets"},{"id":25,"name":"security"},{"id":85,"name":"server"},{"id":86,"name":"serverless"},{"id":70,"name":"storage"},{"id":75,"name":"system-design"},{"id":79,"name":"terminal"},{"id":29,"name":"testing"},{"id":12,"name":"ui"},{"id":50,"name":"ux"},{"id":88,"name":"video"},{"id":20,"name":"web-app"},{"id":35,"name":"web-server"},{"id":43,"name":"webassembly"},{"id":69,"name":"workflow"},{"id":87,"name":"yaml"}]" returns me the "expected json"