samavidev/model-filtration
最新稳定版本:1.1.0
Composer 安装命令:
composer require samavidev/model-filtration
包简介
Filtering the desired model records using query string
README 文档
README
This package provides an annotation to retrieve records of a specific model filtered using a query string. Here's a quick example:
namespace App\Models; use Illuminate\Foundation\Auth\User as Authenticatable; use SamaviDev\ModelFiltration\Attributes\Filter; #[Filter(['name' => 'username'])] class User extends Authenticatable { ... }
Installation
You can install the package via composer:
composer require samavidev/model-filtration
Usage
- The first argument is valid fields that can be used in the query string. which can be in the form of a string or an array, you can also use an association array to assign a query to a specific model.
- The second argument is the operator that is applied to the table fields (
and,or,like,like:or). You can even usewithfor relationships. The default value isand.
for example:
#[Filter(['name' => 'username', 'email' => 'useremail'], 'or')]
It can also be used multiple times.
namespace App\Models; use Illuminate\Foundation\Auth\User as Authenticatable; use SamaviDev\ModelFiltration\Attributes\Filter; #[Filter('id')] #[Filter(['name' => 'username'])] class User extends Authenticatable { ... }
Filter group definition:
You can also define an Attribute class to use as a group of filters for your models. For this, you must implement the Group interface.
namespace App\Attributes; use Attribute; use SamaviDev\ModelFiltration\Contracts\Group; #[Attribute] class UsersFilter implements Group { public function props(): array { return [ 'or' => ['attribute', ...] 'and' => ['attribute' => 'alias', ...], ... ]; } }
And finally, you can use it in your model like this:
namespace App\Models; use Illuminate\Foundation\Auth\User as Authenticatable; use App\Attributes\UsersFilter; #[UsersFilter] class User extends Authenticatable { ... }
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.
统计信息
- 总下载量: 8
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 2
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2023-01-30