leandroibarra / lumen-request-parser by leandroibarra

A request query parameter parser for REST-APIs based on ngabor84/lumen-api-query-parser and for Laravel's Lumen framework.
8
0
1
Package Data
Maintainer Username: leandroibarra
Maintainer Contact: lea14_9@hotmail.com (Leandro Ibarra)
Package Create Date: 2024-01-08
Package Last Update: 2024-01-09
Language: PHP
License: MIT
Last Refreshed: 2024-12-12 15:00:23
Package Statistics
Total Downloads: 8
Monthly Downloads: 0
Daily Downloads: 0
Total Stars: 0
Total Watchers: 1
Total Forks: 0
Total Open Issues: 0

Lumen request parser

Description

A request query parameter parser for REST-APIs based on ngabor84/lumen-api-query-parser and for Laravel's Lumen framework.

Requirements

  • PHP >=8.1
  • Lumen framework >= 10.0

Installation

  • Add leandroibarra/lumen-request-parser to your composer.json and make composer update, or just execute:
    composer require leandroibarra/lumen-request-parser
    
  • Setup the service provider: in bootstrap/app.php add the following line:
    $app->register(LumenRequestParser\Providers\RequestParserProvider::class);
    

Usage

    // app/Http/Controllers/UserController.php
    namespace App\Http\Controllers;
    
    use App\Models\User;

    use LumenRequestParser\Traits\RequestParserTrait;
    use LumenRequestParser\Traits\RequestBuilderApplierTrait;
    
    class UserController extends Controller
    {
        use RequestParserTrait;
        use RequestBuilderApplierTrait;
                
        public function index(Request $request)
        {
            /**
             * I suggest to make a first level request validation. For example:
             * $this->validate($request, [
             *      'page' => 'nullable|integer|min:1',
             *      'limit' => 'nullable|integer|min:1|max:100',
             *      'filter' => [
             *          'nullable',
             *          'regex:/^([a-zA-Z]+:(ct|nct|sw|ew|eq|ne|gt|ge|lt|le|in|nin)+:[^,]+,)*([a-zA-Z]+:(ct|nct|sw|ew|eq|ne|gt|ge|lt|le|in|nin)+:[^,]+)$/i',
             *      ],
             *      'sort' => [
             *          'nullable',
             *          'regex:/^([-+]?[a-zA-Z]+(,[-+]?[a-zA-Z]+)*)?$/i'
             *      ]
             * ]);
             */

            $params = $this->parseQueryParams($request);
            /**
             * Or even you can set sorting or page size (limit) options. For example:
             * $options = ['sort' => 'email', 'limit' => 50];
             * $params = $this->parseQueryParams($request, $options);
             */

            $query = User::query();
            $userPaginator = $this->applyParams($query, $params);

            return response()->json($userPaginator);
        }
    }

Query syntax

Filtering

Request: /users?filter=first_name:ct:admin Response: Will return the collection of the users whose first names contains the admin string.

Available filter options

| Operator | Description | Example | | ------------- | --------------------- | ------- | | ct | String contains | name:ct:Peter | | nct | String NOT contains | name:nct:Peter | | sw | String starts with | username:sw:admin | | ew | String ends with | email:ew:gmail.com | | eq | Equals | level:eq:3 | | ne | Not equals | level:ne:4 | | gt | Greater than | level:gt:2 | | ge | Greater than or equal | level:ge:3 | | lt | Lesser than | level:lt:4 | | le | Lesser than or equal | level:le:3 | | in | In array | level:in:1|2|3 |

Ordering

Request: /users?sort=name,-email Response: Will return the collection of the users sort by their names ascending and by their email descending.

Pagination

Request: /users?page=3 Response: Will return the third page of the collection of users.

Pagination with page size (limit)

Request: /users?limit=50&page=2 Response: Will return a part of the collection of the users (from the 51st to 100th).