khsing / laravel-restapi
Quick but dirty setup a RESTful API project with Laravel, be evil! ;-)
Installs: 315
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 1
Forks: 1
Open Issues: 0
pkg:composer/khsing/laravel-restapi
Requires
- hashids/hashids: ^2.0
- laravel/framework: 5.4.* || 5.5.*
- laravel/passport: ^3.0
Requires (Dev)
- mockery/mockery: ~0.9
- phpunit/phpunit: ~5.0
README
Intro
This package make OAuth2.0 client credentials able to assign User.
Feature
- client ID support Hashids to encrypt real ID.
Installation
- Require this package
composer require khsing/laravel-restapi
- modify config/app.php, add itproviderswith following lines
Khsing\Restapi\OAuth2ServiceProvider::class, Khsing\Restapi\RestapiServiceProvider::class,
- 
execute php artisan migrate
- 
execute php artisan vendor:publish
- 
Need follow laravel/passport setup 
Since Laravel 5.5 LTS, passport would specific route register, can custom in app/Providers/AuthServiceProvider.php
Passport::routes(function ($router) { $router->forAccessTokens(); $router->forTransientTokens(); });
Configuare
Support following configure options.
- enable_hashids, boolean, true/false
- hashids_salt, salt of hashids, NEED REPLACE WITH YOURS.
- hashids_length, length of hashids
- hashids_alphabet, alphabet of hashids
Usage
- create a client app id and secret.
php artisan passport:client
fill user id, client name and get client secret.
- Modify routes/api.php
Route::get('/user', function (Request $request) { return $request->user(); })->middleware('auth:api');
Now, access /api/user will get user's infomation.
btw. Postman is great tools. And the most great part is it's free.
Intergrate with Dingo/api
- install dingo/api, composer require dingo/api:2.0.0-alpha1
- add dingo to providers,Dingo\Api\Provider\LaravelServiceProvider::class,
- php artisan vendor:publish
- modify app/Http/Kernel.phpwith following lines
protected $middlewareGroups = [ ... 'api:auth' => [ 'auth:api', 'api.auth', ], ]
- modify config/api.phpauth part
'auth' => [ 'restapi' => \Khsing\Restapi\DingoAuthServiceProvider::class, ]
- example of dingo/api, in routes/api.phpsame function
$api = app('Dingo\Api\Routing\Router'); $api->version('v1', ['middleware' => 'api:auth'], function ($api) { $api->get('user', function (Request $request) { return $request->user(); }); });
License
This library following MIT License, please keep License file.
Contact
Guixing:
- Twitter: https://twitter.com/khsing
- Email: khsing.cn__AT__.gmail.com