Filtering the desired model records using query string in Laravel app
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 usewith
for 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.