2017 © Pedro Peláez
 

library api-sugar

A library that makes creating apis easier

image

calebdre/api-sugar

A library that makes creating apis easier

  • Tuesday, January 5, 2016
  • by calebdre
  • Repository
  • 1 Watchers
  • 3 Stars
  • 20 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 1 Forks
  • 0 Open issues
  • 1 Versions
  • 0 % Grown

The README.md

Api Sugar

A library that allows for quick and easy API creation, (*1)

This library uses Flight and Eloquent for routing and database interactions.
You shouldn't need to look at Flight's api except for setup, but the Eloquent documentation is important to look at if you aren't aleady familiar. Find it here, (*2)

Usage:

Set up server routing

First you'll need to make sure that all urls reroute to your index.php file., (*3)

For Apache, edit your .htaccess file with the following:, (*4)

RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ index.php [QSA,L]

For Nginx, add the following to your server declaration:, (*5)

server {
    location / {
        try_files $uri $uri/ /index.php;
    }
}

Include the project via composer

run composer require calebdre/api-sugar, (*6)

Create your endpoint class

Create a class that contains the endpoints and methods for the api:, (*7)

class UserController extends ApiController{

    public $mappings = [
        'crud' => ['model' => 'Namespace\To\Model', 'resource_name' => 'users'],
    'fetchComment' => ['method' => 'get', 'route' => '/users/comment/@id'
    ];

    public function fetchComment($id){
    // do fetch comment stuff 
    }
}

Lets break class down:
class UserController extends ApiController
All endpoint classes need to extend the ApiController class., (*8)

$mappings
This is the array that you can add to to create api endpoints. The structure is:
'methodName' => ['method' => 'get/post/put/delete', 'route' => '/end/point/path']
The method name is the name of the method in the class that should be called when the route is hit., (*9)

You can also pass in crud to the array to scaffold CRUD route for an Eloquent model. the syntax for that is:
'crud' => ['model' => 'namespace/to/model/class', 'resource_name' => 'nameOfRoutePrefix'], (*10)

Instatiate the API object and configure the database

    $api = new Api();
    $api->configureDB([
        'driver'    => 'driver',
        'host'      => 'host',
        'database'  => 'database',
        'username'  => 'username',
        'password'  => 'pass',
        'charset'   => 'utf8',
        'collation' => 'utf8_unicode_ci',
        'prefix'    => '',
    ]);

    $api->addClass(new UserController());
    $api->execute();

You can add the class that you just created with the addClass method. To activate the api, use the execute method at the end.
You can also use the addEndPoint($methodType, $routeName, Callable $callable) function to add routes manually., (*11)

After that you should have everything good to go!, (*12)

Note on returning json

In order to return json in your methods, make sure to use Flight::json($array) to create a json response. DO NOT USE RETURN., (*13)

Please feel free to contribute to this project!, (*14)

The Versions

05/01 2016

dev-master

9999999-dev https://github.com/calebdre/api-sugar

A library that makes creating apis easier

  Sources   Download

MIT

The Requires

 

by Caleb Lewis

api