mesak / laravel-api-response
build a Laravel api response package
v1.3.2
2023-09-15 02:09 UTC
Requires
- php: ^8.0
README
Laravel Api Response
Control the api format with a unified callback method
installation
composer require mesak/laravel-api-response
Or you could directly reference it into your composer.json
file as a dependency
{ "require": { "mesak/laravel-api-response": "^1.0.0" } }
Controller
change your api controller, to extend Mesak\LaravelApiResponse\Http\Controllers\Controller
namespace App\Http\Controllers; use Mesak\LaravelApiResponse\Http\Controllers\ApiController as BaseController; class MainController extends BaseController { }
then you can return your all response
Example
Use Pagination
class MainController extends BaseController { function index(Request $request) { return \App\Models\User::paginate(15); } }
Use Resources
class MainController extends BaseController { function index(Request $request) { $users = \App\Models\User::paginate(15); return \App\Http\Resources\User::collection($users); } }
Use Exception
class MainController extends BaseController { function index(Request $request) { $users = \App\Models\User::paginate(15); if( $users->isEmpty() ) { throw new \Exception('No users found'); } return \App\Http\Resources\User::collection($users); } }
Use Extends Exception
class MainController extends BaseController { function index(Request $request) { $users = \App\Models\User::paginate(15); if( $users->isEmpty() ) { throw new \Mesak\LaravelApiResponse\Exceptions\BaseException('No users found' ); //statusCode 500 } return \App\Http\Resources\User::collection($users); } }
Use Custom Exception
create your custom exception class app/Exceptions/BadRequestException.php
namespace App\Exceptions; class BadRequestException extends \Mesak\LaravelApiResponse\Exceptions\BaseException { protected $errorCode = 400; protected $statusCode = 400; public function __construct($message = 'Bad Request') { parent::__construct($message); } }
then you can use it in your controller
use App\Exceptions\BadRequestException; class MainController extends BaseController { function index(Request $request) { $users = \App\Models\User::paginate(15); if( $users->isEmpty() ) { throw new BadRequestException(); //statusCode 400 } return \App\Http\Resources\User::collection($users); } }
without ApiController
if you don't want to extend Mesak\LaravelApiResponse\Http\Controllers\ApiController
you can use
response()->success($data,$statusCode);
response()->error($data,$statusCode);
class MainController extends \App\Http\Controllers\Controller { function index(Request $request) { $users = \App\Models\User::paginate(15); if( $users->isEmpty() ) { return response()->error('no data',400); } $result = \App\Http\Resources\User::collection($users); return response()->success($result); } }
custom config
You can customise your api schema content with a custom config.php.
php artisan vendor:publish --tag=api-response --force