The Eloquent Filter Resolver is a package that allows you to resolve a filter string into an Eloquent query in Laravel. It provides a convenient way to filter Eloquent models based on various conditions and operators.
You can install the Eloquent Filter Resolver package via Composer. Run the following command:
composer require ahmadhsalim/eloquent-filter-resolver
To use the Eloquent Filter Resolver, follow the example below:
use App\Http\Controllers\Controller;
use App\Models\User;
use Salim\FilterResolver\EloquentFilterResolver;
class UserController extends Controller
{
public function index()
{
$query = User::query();
$filter = 'contains(name, "john") and eq(status, active)';
EloquentFilterResolver::resolve($query, $filter);
return $query->paginate();
}
}
In the above example, we create an Eloquent query for the User
model and apply a filter using the Eloquent Filter Resolver. The filter string contains(name, "john") and eq(status, active)
filters the users whose names contain "john" and have an active status.
The Eloquent Filter Resolver supports the following operators:
contains
: Performs a case-insensitive search using theLIKE
operator. UsesILIKE
forpgsql
driver. Usage:contains(field, value)
.eq
: Performs an equality comparison using the=
operator. Usage:eq(field, value)
.ne
: Performs a not-equal comparison using the!=
operator. Usage:ne(field, value)
.gt
: Performs a greater-than comparison using the>
operator. Usage:gt(field, value)
.gte
: Performs a greater-than-or-equal comparison using the>=
operator. Usage:gte(field, value)
.lt
: Performs a less-than comparison using the<
operator. Usage:lt(field, value)
.lte
: Performs a less-than-or-equal comparison using the<=
operator. Usage:lte(field, value)
.in
: Performs anIN
comparison for multiple values. Values can be separated by|
. Usage:in(field, "value1|value2|value3")
.notIn
: Performs aNOT IN
comparison for multiple values. Values can be separated by|
. Usage:notIn(field, "value1|value2|value3")
.
- Values can be enclosed in double quotes for strings. Example:
eq(name, "John Doe")
. - Values can have double quotes within the string by escaping them with a backslash (
\
). Example:eq(name, "John \"The Man\" Doe")
. - If a value contains commas, brackets, or spaces, it must be enclosed in double quotes. Example:
eq(name, "John Doe, Jr.")
.
- When the value is
"true"
or"false"
, it will be parsed as a boolean value. - When the value is
"null"
, it will be parsed asnull
.
The Eloquent Filter Resolver supports nested brackets to create complex filter expressions. For example:
$filter = 'eq(name, "John") and (eq(status, "active") or eq(status, "inactive"))';
In the above example, the filter condition checks if the name is "John" and the status is either "active" or "inactive".
The Eloquent Filter Resolver also supports filtering on related models using dot notation. For example:
$filter = 'eq(user.role.name, "admin")';
In the above example, the filter condition checks if the related role
of the user
has a name equal to "admin".
Boolean and null values can be used in filter conditions as follows:
$filter = 'eq(is_active, true) and eq(deleted_at, null)';
In the above example, the filter condition checks if the is_active
field is true and the deleted_at
field is null.
Contributions to the Eloquent Filter Resolver package are welcome. If you find any issues or want to suggest improvements, please create a GitHub issue
The Eloquent Filter Resolver package is open-source software licensed under the MIT license.