shureban/laravel-easy-request
最新稳定版本:1.0.0
Composer 安装命令:
composer require shureban/laravel-easy-request
包简介
Laravel easy way to write methods for requests
README 文档
README
Installation
Require this package with composer using the following command:
composer require shureban/laravel-easy-request
Add the following class to the providers array in config/app.php:
Shureban\LaravelEasyRequest\EasyRequestServiceProvider::class,
You can also publish the config file to change implementations (ie. interface to specific class).
php artisan vendor:publish --provider="Shureban\LaravelEasyRequest\EasyRequestServiceProvider"
How to use
All what you need, that is type PhpDoc for your request class.
For example:
/** * @method string name() * @method boolean isConfirmed() * @method bool isAdult() * @method integer age() * @method int size() * @method float salary() * @method array workingDays() * @method mixed description() * @method additionalInformation() * @method string|null managerName() * @method DateTime birthday() * @method Carbon firstWorkingDay() */ class CustomRequest extends \Illuminate\Foundation\Http\FormRequest { } class RegistrationController extends Controller { public function __invoke(CustomRequest $request): JsonResponse { dd( $request->name(), // return value with string type $request->isConfirmed(), // return value with bool type $request->isAdult(), // return value with bool type $request->age(), // return value with integer type $request->size(), // return value with integer type $request->salary(), // return value with float type $request->workingDays(), // return array value $request->description(), // return original value $request->additionalInformation(), // return original value $request->managerName(), // return string value or NULL $request->birthday(), // return date with type DateTime $request->firstWorkingDay(), // return date as Carbon type ); } }
That is not a problem if you methods written in camelCase format and your request data in snake_case. You may use any of cases to get your value.
For example:
/** * @method int userId() * @method int client_id() */ class CustomRequest extends \Illuminate\Foundation\Http\FormRequest { public function rules(): array { return [ 'user_id' => ['required', 'int'], 'clientId' => ['required', 'int'], ]; } } class RegistrationController extends Controller { public function __invoke(CustomRequest $request): JsonResponse { dd( $request->userId(), // return value for field user_id $request->client_id(), // return value for field clientId ); } }
If you need to work with models, and get model by field_id, that is easy.
For example:
/** * @method User user() */ class CustomRequest extends \Illuminate\Foundation\Http\FormRequest { public function rules(): array { return [ 'user_id' => ['required', 'int'], ]; } } class RegistrationController extends Controller { public function __invoke(CustomRequest $request): JsonResponse { dd( $request->user(), // return instance of models User ); } }
You have to name your property with _id ending or Id(in camel case), and set method type which is extends Model.
统计信息
- 总下载量: 1.97k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 3
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2024-06-08