acidjazz / metapi
Laravel API helpers
Installs: 138 904
Dependents: 0
Suggesters: 0
Security: 0
Stars: 28
Watchers: 3
Forks: 5
Open Issues: 1
Requires
- php: ^8.1
- ext-json: *
- illuminate/support: 9.*|10.*|11.*
- jasongrimes/paginator: ^1.0
Requires (Dev)
- mockery/mockery: ^1.4.4
- orchestra/testbench: ^7.0|^8.0
- phpunit/phpunit: ^9.5|^10.4
- dev-master
- v2.3.0
- v2.2.1
- v2.2.0
- v2.1.8
- v2.1.7
- v2.1.4
- v2.1.3
- v2.1.2
- v2.1.1
- v2.1.0
- v2.0.1
- v2.0.0
- v1.4.8
- v1.4.7
- v1.4.6
- v1.4.5
- v1.4.4
- v1.4.3
- v1.4.2
- v1.4.1
- v1.4.0
- v1.3.4
- v1.3.3
- v1.3.2
- v1.3.1
- v1.3.0
- v1.2.0
- v1.1.9
- v1.1.8
- 1.1.7
- v1.1.6
- v1.1.5
- v1.1.4
- v1.1.3
- v1.1.2
- v1.1.1
- v1.1.0
- v1.0.9
- v1.0.8
- v1.0.7
- v1.0.6
- v1.0.5
- v1.0.4
- v1.0.3
- v1.0.2
- v1.0.1
This package is auto-updated.
Last update: 2024-10-25 06:56:19 UTC
README
Own your endpoint
metapi's main purpose is to help make sure your endpoint responses are consistent. By using the built in helper functions like ->option()...->verify
, ->render()
, ->success()
and ->error()
they will all share the same consistent standardized output reflecting the options available, parameters provided, and results.
Dracula dark theme with laravel-debugbar
Features
- Endpoint benchmarking
- Laravel Validation wrapper that reflects requirements
- Support for JSON and JSONP
- Interactive tree browsing with search thanks to jsoneditor
- Dracula Dark theme support to pair with laravel-debugbar
Installation
Install metapi with composer:
composer require acidjazz/metapi
Add the trait
(
app/Http/Controllers/Controller.php
is recommended)
<?php use acidjazz\metapi\MetApi; class Controller { use Metapi;
Examples
<?php namespace App\Http\Controllers; use acidjazz\metapi\MetApi; class OrgController extends Controller { use MetApi; /** * Display a listing of the resource. * * @return \Illuminate\Http\Response */ public function index(Request $request) { $this ->option('approved', 'nullable|boolean'); ->option('type', 'nullable|in:this,that'); ->verify(); ... $this->render($results);
GET /endpoint?approved=1
{ "benchmark": 0.011060953140258789, "query": { "defaults": [], "options": { "approved": "nullable|boolean", "type": "nullable|in:this,that" }, "params": { "approved": "1" }, "combined": { "approved": "1" } }, "data": [ {
GET /endpoint?callback=bob
bob({ "benchmark": 0.011017084121704102, "query": { "defaults": [], "options": { "approved": "nullable|boolean", "type": "nullable|in:this,that" }, "params": [], "combined": [] }, "data": [ {
Add custom attributes to validation.
public function send(Request $request) { $this->option('contact.email', 'required|email', [], 'Email Address') ->option('contact.name', 'required|string', [], 'Firstname') ->option('contact.surname', 'required|string', [], 'Lastname') ->verify(); ... $this->render($results); }
POST /send
{ "status": "error", "errors": [ { "status": 400, "message": "contact.email", "detail": "Email Address is a required field." }, { "status": 400, "message": "contact.name", "detail": "Firstname is a required field." }, { "status": 400, "message": "contact.surname", "detail": "Lastname is a required field." } ] }