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
{
...
}
You can install the package via composer:
composer require samavidev/model-filtration
- 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
{
...
}
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
{
...
}
Please see CHANGELOG for more information on what has changed recently.
Please see CONTRIBUTING for details.
Please review our security policy on how to report security vulnerabilities.
The MIT License (MIT). Please see License File for more information.