wdmg / yii2-api
API control module
Installs: 519
Dependents: 1
Suggesters: 0
Security: 0
Stars: 2
Watchers: 4
Forks: 2
Open Issues: 0
Type:yii2-extension
Requires
- bower-asset/clipboard: ^2.0.6
- wdmg/yii2-base: ^1.2.4
- wdmg/yii2-datepicker: ^1.1.0
- wdmg/yii2-options: ^1.5.7
- wdmg/yii2-selectinput: ^1.0.9
- wdmg/yii2-users: ^1.1.8
- yiisoft/yii2: ^2.0.40
This package is auto-updated.
Last update: 2024-10-25 13:20:26 UTC
README
Yii2 API
API control module for Yii2. This module is an integral part of the Butterfly.СMS content management system, but can also be used as an standalone extension. Copyrights (c) 2019-2023 W.D.M.Group, Ukraine
Requirements
- PHP 5.6 or higher
- Yii2 v.2.0.40 and newest
- Yii2 Base module (required)
- Yii2 Users module (required)
- Yii2 Options module (support)
- Yii2 SelectInput widget
- ClipboardJS asset library (required)
Installation
To install the module, run the following command in the console:
$ composer require "wdmg/yii2-api"
After configure db connection, run the following command in the console:
$ php yii api/init
And select the operation you want to perform:
- Apply all module migrations
- Revert all module migrations
Migrations
In any case, you can execute the migration and create the initial data, run the following command in the console:
$ php yii migrate --migrationPath=@vendor/wdmg/yii2-api/migrations
Configure
To add a module to the project, add the following data in your configuration file:
'modules' => [
...
'api' => [
'class' => 'wdmg\api\Module',
'routePrefix' => 'admin', // routing prefix for dashboard
'accessTokenExpire', => 3600 // lifetime of `access_token`, `0` - unlimited
'blockedIp' => [], // array, blocked access from IP`s
'rateLimit' => 30, // request`s to API per minute
'rateLimitHeaders' => false, // send HTTP-headers of rate limit
'sendAccessToken' => true, // send access token with HTTP-headers
'authMethods' => [ // auth methods to allow
'basicAuth' => true,
'bearerAuth' => true,
'paramAuth' => true
],
'authMethods' => [ // allowed API modes
'public' => true,
'private' => true
],
'allowedApiModels' => [ // allowed API models
'public' => [
"wdmg\api\models\api\NewsAPI" => true,
"wdmg\api\models\api\OptionsAPI" => false,
"wdmg\api\models\api\PagesAPI" => false,
"wdmg\api\models\api\UsersAPI" => false,
...
],
'private' => [
"wdmg\api\models\api\NewsAPI" => true,
"wdmg\api\models\api\OptionsAPI" => true,
"wdmg\api\models\api\PagesAPI" => true,
"wdmg\api\models\api\UsersAPI" => true,
...
],
]
],
...
],
Usecase
Request to API with base auth by username and password (option authMethods['basicAuth']
must be set to true
):
$ curl 'http://example.com/api/users' \
-XGET \
-H 'Accept: application/json, text/javascript, */*; q=0.01' \
-H 'Authorization: Basic YOUR_USERNAME_AND_PASSWORD'
Attention! YOUR_USERNAME_AND_PASSWORD in format username:password
and has been encoded, like base64_encode('username:password')
After successful authorization, the server will return X-Access-Token
for use in other requests (option sendAccessToken
must be set to true
).
Request to API with query param access_token
(option authMethods['paramAuth']
must be set to true
):
$ curl 'http://example.com/api/users?access-token=YOUR_API_ACCESS_TOKEN' \
-XGET \
-H 'Accept: application/json, text/javascript, */*; q=0.01'
Request to API with bearer access_token
(option authMethods['bearerAuth']
must be set to true
):
$ curl 'http://example.com/api/users' \
-XGET \
-H 'Accept: application/json, text/javascript, */*; q=0.01' \
-H 'Authorization: Bearer YOUR_API_ACCESS_TOKEN'
If the access token has expired, the server will return new X-Access-Token
for use in other requests (option sendAccessToken
must be set to true
).
Routing
Admin dashboard path by default: http://example.com/admin/api/
Path for access to API endpoint: http://example.com/api/model/module/action
Also see official guideline: https://github.com/yiisoft/yii2/blob/master/docs/guide/rest-quick-start.md
Use the Module::dashboardNavItems()
method of the module to generate a navigation items list for NavBar, like this:
<?php
echo Nav::widget([
'options' => ['class' => 'navbar-nav navbar-right'],
'label' => 'Modules',
'items' => [
Yii::$app->getModule('api')->dashboardNavItems(),
...
]
]);
?>
Status and version [ready to use]
- v.2.0.1 - Add log activity, fix users API save/update
- v.2.0.0 - Basic Auth fixed
- v.1.4.0 - Update dependencies, copyrights
- v.1.3.12 - Added base API for Menu module, request helper
- v.1.3.11 - Update README.md and dependencies
- v.1.3.10 - Added base API for Comments module