Package Data | |
---|---|
Maintainer Username: | FelipeDouradinho |
Maintainer Contact: | feliped1987@gmail.com (Felipe Douradinho) |
Package Create Date: | 2015-09-11 |
Package Last Update: | 2015-09-14 |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2024-11-19 03:06:28 |
Package Statistics | |
---|---|
Total Downloads: | 7 |
Monthly Downloads: | 0 |
Daily Downloads: | 0 |
Total Stars: | 3 |
Total Watchers: | 1 |
Total Forks: | 0 |
Total Open Issues: | 0 |
Make it a breeze to create a jsonapi.org RC3 compliant API with Laravel 5.
Code forked from echo-it/laravel-jsonapi project by Ronni Egeriis Persson.
Add felipe-douradinho/laravel-jsonapi
to your composer.json dependency list
Run composer update
.
This library is made with the concept of exposing models in mind, as found in the RESTful API approach.
In few steps you can expose your models:
Create a route to direct the requests
In this example, we use a route for any OPTION requests, a generic route for interacting with resources, and another route for interacting with resource relationships:
Route::options('api/{model}/{id?}', 'ApiController@handleRequest');
Route::any('api/{model}/{id?}', 'ApiController@handleRequest');
Route::any('api/{model}/{id}/links/{relation}', 'ApiController@handleRequest');
Create your controller to handle the request
Your controller is responsible to handling input, instantiating a handler class and returning the response.
<?php namespace App\Http\Controllers;
use FelipeDouradinho\JsonApi\Request as ApiRequest;
use FelipeDouradinho\JsonApi\ErrorResponse as ApiErrorResponse;
use FelipeDouradinho\JsonApi\Exception as ApiException;
use Request;
class ApiController extends Controller
{
public function handleRequest($modelName, $id = null, $relation = null)
{
/**
* Create handler name from model name
* @var string
*/
$handlerClass = 'App\\Handlers\\' . ucfirst($modelName) . 'Handler';
if (class_exists($handlerClass)) {
$url = Request::url();
$method = Request::method();
$include = ($i = Request::input('include')) ? explode(',', $i) : [];
$sort = ($i = Request::input('sort')) ? explode(',', $i) : [];
$filter = ($i = Request::except('sort', 'include', 'page')) ? $i : [];
$content = Request::getContent();
$page = ($i = Request::input('page')) ? $i : [];
if (!empty($page) && (!is_array($page) || empty($page['size']) || empty($page['number']))) {
return new ApiErrorResponse(400, 400, 'Expected page[size] and page[number]');
}
$request = new ApiRequest(Request::url(), $method, $id, $content, $include, $sort, $filter, $page, $relation);
$handler = new $handlerClass($request);
// A handler can throw EchoIt\JsonApi\Exception which must be gracefully handled to give proper response
try {
$res = $handler->fulfillRequest();
} catch (ApiException $e) {
return $e->response();
}
return $res->toJsonResponse();
}
// If a handler class does not exist for requested model, it is not considered to be exposed in the API
return new ApiErrorResponse(404, 404, 'Entity not found');
}
}
Create a handler for your model
A handler is responsible for exposing a single model.
In this example we have create a handler which supports the following requests:
Requests are automatically routed to appropriate handle functions.
<?php namespace App\Handlers;
use Symfony\Component\HttpFoundation\Response;
use App\Models\User;
use FelipeDouradinho\JsonApi\Exception as ApiException;
use FelipeDouradinho\JsonApi\Request as ApiRequest;
use FelipeDouradinho\JsonApi\Handler as ApiHandler;
use Request;
/**
* Handles API requests for Users.
*/
class UsersHandler extends ApiHandler
{
const ERROR_SCOPE = 1024;
/**
* Handles GET requests.
* @param FelipeDouradinho\JsonApi\Request $request
* @return FelipeDouradinho\JsonApi\Model|Illuminate\Support\Collection|FelipeDouradinho\JsonApi\Response|Illuminate\Pagination\LengthAwarePaginator
*/
public function handleGet(ApiRequest $request)
{
//you can use the default GET functionality, or override with your own
return $this->handleGetDefault($request, new User);
}
/**
* Handles PATCH requests.
* @param FelipeDouradinho\JsonApi\Request $request
* @return FelipeDouradinho\JsonApi\Model|Illuminate\Support\Collection|FelipeDouradinho\JsonApi\Response
*/
public function handlePatch(ApiRequest $request)
{
//you can use the default PATCH functionality, or override with your own
return $this->handlePatchDefault($request, new User);
}
}
Note: Extend your models from FelipeDouradinho\JsonApi\Model
rather than Eloquent
to get the proper response for linked resources. In your model, you can define which relationships should be exposed:
<?php namespace App\Models;
use FelipeDouradinho\JsonApi\Model as ApiModel;
class User extends ApiModel {
public $exposedRelations = ['friends'];
public function friends()
{
return $this->hasMany('App\Models\Friend');
}
}
According to jsonapi.org:
The features in the Handler class are each in their own function (eg. handlePaginationRequest, handleSortRequest, etc.), so you can easily override them with your own behaviour if desired.