jayc89 / slim-json-api
Slim extension to implement fast JSON API's
Requires
- php: >=5.3.0
This package is not auto-updated.
Last update: 2024-12-25 07:36:57 UTC
README
This is an extension to the SLIM framework to implement json API's with great ease.
##Installation Using composer you can add use this as your composer.json
{ "require": { "slim/slim": "2.*", "jayc89/slim-json-api": "dev-master" } }
##Usage To include the middleware and view you just have to load them using the default Slim way. Read more about Slim Here (https://github.com/codeguy/Slim#getting-started)
require 'vendor/autoload.php'; $app = new \Slim\Slim(); $app->view(new \JsonApiView()); $app->add(new \JsonApiMiddleware());
###.htaccess sample Here's an .htaccess sample for simple RESTful API's
RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^ index.php [QSA,L]
###example method
all your requests will be returning a JSON output.
the usage will be $app->render( (int)$HTTP_CODE, (array)$DATA);
####example Code
$app->get('/', function() use ($app) { $app->render(200,array( 'msg' => 'welcome to my API!', )); });
####example output
{ "msg":"welcome to my API!", "error":false, "status":200 }
##Errors
To display an error just set the error => true
in your data array.
All requests will have an error
param that defaults to false.
$app->get('/user/:id', function($id) use ($app) { //your code here $app->render(404,array( 'error' => TRUE, 'msg' => 'user not found', )); });
{ "msg":"user not found", "error":true, "status":404 }
You can optionally throw exceptions, the middleware will catch all exceptions and display error mensages.
$app->get('/user/:id', function($id) use ($app) { //your code here if(...){ throw new Exception("Something wrong with your request!"); } });
{ "error": true, "msg": "ERROR: Something wrong with your request!", "status": 500 }
##routing specific requests to the API If your site is using regular HTML responses and you just want to expose an API point on a specific route, you can use Slim router middlewares to define this.
function APIrequest(){ $app = \Slim\Slim::getInstance(); $app->view(new \JsonApiView()); $app->add(new \JsonApiMiddleware()); } $app->get('/home',function() use($app){ //regular html response $app->render("template.tpl"); }); $app->get('/api','APIrequest',function() use($app){ //this request will have full json responses $app->render(200,array( 'msg' => 'welcome to my API!', )); });
##middleware The middleware will set some static routes for default requests. if you dont want to use it, you can copy its content code into your bootstrap file.
IMPORTANT: remember to use $app->config('debug', false);
or errors will still be printed in HTML