Skip to content

Filtering the desired model records using query string in Laravel app

License

Notifications You must be signed in to change notification settings

samaviam/model-filtration

Repository files navigation

Filtering the desired model records using query string in Laravel app

Latest Version on Packagist GitHub Tests Action Status GitHub Code Style Action Status Total Downloads

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 use with for relationships. The default value is and.

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.

About

Filtering the desired model records using query string in Laravel app

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages