定制 calebdre/api-sugar 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

calebdre/api-sugar

Composer 安装命令:

composer require calebdre/api-sugar

包简介

A library that makes creating apis easier

关键字:

README 文档

README

A library that allows for quick and easy API creation

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

Usage:

Set up server routing

First you'll need to make sure that all urls reroute to your index.php file.

For Apache, edit your .htaccess file with the following:

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

For Nginx, add the following to your server declaration:

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

Include the project via composer

run composer require calebdre/api-sugar

Create your endpoint class

Create a class that contains the endpoints and methods for the api:

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.

$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.

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']

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.

After that you should have everything good to go!

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.

Please feel free to contribute to this project!

统计信息

  • 总下载量: 28
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 3
  • 点击次数: 2
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 3
  • Watchers: 0
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-09-10

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固