PHPackages                             apichef/laravel-request-to-eloquent - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Database &amp; ORM](/categories/database)
4. /
5. apichef/laravel-request-to-eloquent

ActiveLibrary[Database &amp; ORM](/categories/database)

apichef/laravel-request-to-eloquent
===================================

Easily translate request query string to Eloquent query.

v1.0.1(5y ago)254MITPHPPHP ~7.4 || ^8.0CI failing

Since Feb 14Pushed 5y ago1 watchersCompare

[ Source](https://github.com/apichef/laravel-request-to-eloquent)[ Packagist](https://packagist.org/packages/apichef/laravel-request-to-eloquent)[ Docs](https://github.com/apichef/laravel-request-to-eloquent)[ RSS](/packages/apichef-laravel-request-to-eloquent/feed)WikiDiscussions master Synced yesterday

READMEChangelogDependencies (5)Versions (12)Used By (0)

laravel-request-to-eloquent
===========================

[](#laravel-request-to-eloquent)

[![Latest Version on Packagist](https://camo.githubusercontent.com/d9ba43943f1d5d22b5c0c70517f26730d5daafac8104d2acf3242cc69d6990bb/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f762f617069636865662f6c61726176656c2d726571756573742d746f2d656c6f7175656e742e7376673f7374796c653d666c61742d737175617265)](https://packagist.org/packages/apichef/laravel-request-to-eloquent)[![Software License](https://camo.githubusercontent.com/55c0218c8f8009f06ad4ddae837ddd05301481fcf0dff8e0ed9dadda8780713e/68747470733a2f2f696d672e736869656c64732e696f2f62616467652f6c6963656e73652d4d49542d627269676874677265656e2e7376673f7374796c653d666c61742d737175617265)](LICENSE.md)[![Build Status](https://github.com/apichef/laravel-request-to-eloquent/workflows/CI/badge.svg)](https://github.com/apichef/laravel-request-to-eloquent/actions)[![Coverage Status](https://camo.githubusercontent.com/3720ce16a7f117d48ae69ee611d0a319d241f607c8775b7c531c485a8e3dd0cb/68747470733a2f2f696d672e736869656c64732e696f2f7363727574696e697a65722f636f7665726167652f672f617069636865662f6c61726176656c2d726571756573742d746f2d656c6f7175656e742e7376673f7374796c653d666c61742d737175617265)](https://scrutinizer-ci.com/g/apichef/laravel-request-to-eloquent/code-structure)[![Quality Score](https://camo.githubusercontent.com/b2ce4399a86913e85cd4eae8920d225e93e223c6174a15a8cc0b6092c6581e96/68747470733a2f2f696d672e736869656c64732e696f2f7363727574696e697a65722f672f617069636865662f6c61726176656c2d726571756573742d746f2d656c6f7175656e742e7376673f7374796c653d666c61742d737175617265)](https://scrutinizer-ci.com/g/apichef/laravel-request-to-eloquent)[![Total Downloads](https://camo.githubusercontent.com/11c8cf25a3a2a202ce0be57bc784d1c2c3de810a5b6a41279f5f7d62c50bc7b8/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f64742f617069636865662f6c61726176656c2d726571756573742d746f2d656c6f7175656e742e7376673f7374796c653d666c61742d737175617265)](https://packagist.org/packages/apichef/laravel-request-to-eloquent)

Easily translate request query string to Eloquent query.
========================================================

[](#easily-translate-request-query-string-to-eloquent-query)

Install
-------

[](#install)

Via Composer

```
$ composer require apichef/laravel-request-to-eloquent
```

We use `apichef/laravel-request-query-helper` package as a dependency. You can publish it's the config file with:

```
$ php artisan vendor:publish --provider="ApiChef\RequestQueryHelper\RequestQueryHelperServiceProvider"
```

Basic usage
-----------

[](#basic-usage)

Model class:

```
namespace App;

use App\Comment;
use App\Tag;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\Model;

class Post extends Model
{
    protected $dates = [
        'published_at',
    ];

    public function comments()
    {
        return $this->hasMany(Comment::class);
    }

    public function tags()
    {
        return $this->belongsToMany(Tag::class);
    }

    public function scopeDraft(Builder $builder)
    {
        return $builder->whereNull('published_at');
    }
}
```

Request query class:

```
namespace App\Queries;

use App\Post;
use ApiChef\RequestToEloquent\QueryBuilderAbstract;
use Illuminate\Http\Request;

class PostListQuery extends QueryBuilderAbstract
{
    protected function init(Request $request)
    {
        return Post::query();
    }

    protected $availableIncludes = [
        'comments',
        'tags',
    ];

    protected $availableFilters = [
        'draft',
    ];

    protected $availableSorts = [
        'published_at',
    ];
}
```

Controller:

```
namespace App\Http\Controllers;

use App\User;
use App\Queries\PostListQuery;

class DashboardController extends Controller
{
    public function index(PostListQuery $postListQuery)
    {
        return $postListQuery
            ->parseAllowedIncludes([
                'comments',
                'tags',
            ])
            ->get()
            ->toArray();
    }
}
```

Http request:

```
GET /posts?include=comments,tags&filter[draft]&sort=-published_at
```

Change log
----------

[](#change-log)

Please see [CHANGELOG](CHANGELOG.md) for more information on what has changed recently.

Testing
-------

[](#testing)

```
$ composer test
```

Contributing
------------

[](#contributing)

Please see [CONTRIBUTING](CONTRIBUTING.md) and [CODE\_OF\_CONDUCT](CODE_OF_CONDUCT.md) for details.

Security
--------

[](#security)

If you discover any security related issues, please email  instead of using the issue tracker.

Credits
-------

[](#credits)

- [Milroy E. Fraser](https://github.com/milroyfraser)
- [All Contributors](../../contributors)

License
-------

[](#license)

The MIT License (MIT). Please see [License File](LICENSE.md) for more information.

###  Health Score

30

—

LowBetter than 64% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity11

Limited adoption so far

Community7

Small or concentrated contributor base

Maturity68

Established project with proven stability

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~58 days

Recently: every ~93 days

Total

8

Last Release

1871d ago

Major Versions

v0.5.0 → v1.0.12021-03-28

PHP version history (3 changes)v0.0.1PHP ~7.2

0.0.5PHP ~7.2 || ^8.0

v1.0.1PHP ~7.4 || ^8.0

### Community

Maintainers

![](https://www.gravatar.com/avatar/6f3ba1935044647e51c405868792beea05a76250a8f7ef408c9b706edf51fcb6?d=identicon)[milroy.me](/maintainers/milroy.me)

---

Top Contributors

[![milroyfraser](https://avatars.githubusercontent.com/u/3282475?v=4)](https://github.com/milroyfraser "milroyfraser (17 commits)")

---

Tags

apicheflaravel-request-to-eloquent

###  Code Quality

TestsPHPUnit

Code StylePHP\_CodeSniffer

### Embed Badge

![Health badge](/badges/apichef-laravel-request-to-eloquent/health.svg)

```
[![Health](https://phpackages.com/badges/apichef-laravel-request-to-eloquent/health.svg)](https://phpackages.com/packages/apichef-laravel-request-to-eloquent)
```

###  Alternatives

[doctrine/orm

Object-Relational-Mapper for PHP

10.2k285.3M6.2k](/packages/doctrine-orm)[jdorn/sql-formatter

a PHP SQL highlighting library

3.9k115.1M102](/packages/jdorn-sql-formatter)[illuminate/database

The Illuminate Database package.

2.8k52.4M9.4k](/packages/illuminate-database)[mongodb/mongodb

MongoDB driver library

1.6k64.0M546](/packages/mongodb-mongodb)[ramsey/uuid-doctrine

Use ramsey/uuid as a Doctrine field type.

90340.3M211](/packages/ramsey-uuid-doctrine)[reliese/laravel

Reliese Components for Laravel Framework code generation.

1.7k3.4M16](/packages/reliese-laravel)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
