yjballestero / yii2-oas3
Yii2 Open Api Swagger 3 integration
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 11
pkg:composer/yjballestero/yii2-oas3
Requires
- php: >=8.0
- ext-json: *
- bower-asset/swagger-ui: ^4.17
- yiisoft/yii2: ~2.0.45
- zircote/swagger-php: ^5.5
Requires (Dev)
- phpunit/phpunit: ^10.5
- roave/security-advisories: dev-latest
This package is auto-updated.
Last update: 2025-10-30 04:32:25 UTC
README
Requirements
- PHP 8.0
- Yii2 Framework
Installation
The preferred way to install this wrapper is through composer.
php composer.phar require yjballestero/yii2-oas3 "*"
or
composer require yjballestero/yii2-oas3 "*"
or add to the "require" section of composer.json
"yjballestero/yii2-oas3" : "*"
Integration
Add action to web controller (for example SiteController.php):
public function actions() { return [ 'api-docs' => [ 'class' => 'yjballestero\swagger\ViewAction', 'apiJsonUrl' => \yii\helpers\Url::to(['/site/api-json'], true), ], 'api-json' => [ 'class' => 'yjballestero\swagger\JsonAction', 'dirs' => [ Yii::getAlias('@api/modules/api/controllers'), Yii::getAlias('@api/modules/api/models'), Yii::getAlias('@api/models'), ], ], ]; }
Open Api Swagger 3 example annotation
Api server description
/** * @OA\Info( * version="1.0", * title="Application API", * description="Server - Mobile app API", * @OA\Contact( * name="John Smith", * email="john@example.com", * ), * ), * @OA\Server( * url="https://example.com/api", * description="main server", * ) * @OA\Server( * url="https://dev.example.com/api", * description="dev server", * ) */ class DefaultController extends Controller { ...
Controller annotation
/** * @OA\Get(path="/", * summary="Handshake", * tags={"handshake"}, * @OA\Parameter( * name="access-token", * in="header", * required=false, * @OA\Schema( * type="string" * ) * ), * @OA\Response( * response=200, * description="Returns Hello object", * @OA\MediaType( * mediaType="application/json", * @OA\Schema(ref="#/components/schemas/Hello"), * ), * ), * ) */ public function actionIndex() { ...
Model annotation
/** *@OA\Schema( * schema="Hello", * @OA\Property( * property="message", * type="string", * description="Text message" * ), * @OA\Property( * property="time", * type="integer", * description="Server current Unix time" * ), * @OA\Property( * property="date", * type="string", * format="date-time", * description="Server current date time" * ) *) */ class Hello extends Model { ...
LICENSE
This curl wrapper is released under the MIT license.