luttamustache/op-laravel-swagger 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

luttamustache/op-laravel-swagger

Composer 安装命令:

composer require --dev luttamustache/op-laravel-swagger

包简介

Fork from ronasit/laravel-swagger for old php versions (<=7.2).

README 文档

README

This plugin is fork made from RonasIT/laravel-swagger to support old versions of PHP (<=7.2).

Instalation

Composer

  1. composer require luttamustache/op-laravel-swagger

Laravel

  1. Add LuttaMustache\Support\AutoDoc\AutoDocServiceProvider::class to providers in config/app.php
  2. Add \RonasIT\Support\DataCollectors\LocalDataCollectorServiceProvider::class to providers in config/app.php
  3. php artisan vendor:publish

Plugin

  1. Add middleware \LuttaMustache\Support\AutoDoc\Http\Middleware\AutoDocMiddleware::class to Http/Kernel.php.
  2. Set \LuttaMustache\Support\AutoDoc\Tests\AutoDocTestCase as parent of your TestCase in tests/TestCase.php
  3. In config/auto-doc.php you can specify enabling of plugin, info of your project, some defaults descriptions and route for rendering of documentation.
  4. In .env file you should add following lines LOCAL_DATA_COLLECTOR_PROD_PATH=/example-folder/documentation.json LOCAL_DATA_COLLECTOR_TEMP_PATH=/tmp/documentation.json

Usages

For correct working of plugin you have to dispose all the validation rules in the rules() method of class YourRequest, which must be connected to the controller via DependencyInjection. In annotation of custom request you can specify summary and description of this request. Plugin will take validation rules from your request and use it as description of input parameter.

The plugin will automatically generate Swagger 2.0 documentation after you run phpunit.

Every phpunit execution rewrites the documentation file fully. That means, if you want to maintain documentation full, you need to run phpunit on every test you have.

Example

<?php

namespace App\Http\Requests;  

use Illuminate\Foundation\Http\FormRequest;

/**
 * @summary Updating of user
 *
 * @description
 *  This request mostly needed to specity flags <strong>free_comparison</strong> and 
 *  <strong>all_cities_available</strong> of user
 *
 * @_204 Successful MF!
 */
class UpdateUserDataRequest extends FormRequest
{
    /**
     * Determine if the user is authorized to make this request.
     *
     * @return bool
     */
    public function authorize()
    {
        return true;
    }  
  
    /**
     * Get the validation rules that apply to the request.
     *
     * @return array
     */
    public function rules()
    {
        return [
            'all_cities_available' => 'boolean',
            'free_comparison' => 'boolean'
        ];
    }
}
  • @summary - short description of request
  • @description - Implementation Notes
  • @_204 - Custom description of code of response. You can specify any code as you want.

If you do not create a class Request, the summary, Implementation Notes and parameters will be empty. Plugin will collect codes and examples of responses only.

If you do not create annotations to request summary will generate automatically from Name of Request. For example request UpdateUserDataRequest will have summary Update user data request.

If you do not create annotations for descriptions of codes it will be generated automatically the following priorities:

  1. Annotations of request
  2. Default description from auto-doc.defaults.code-descriptions.{$code}
  3. Descriptions from Symfony\Component\HttpFoundation\Response::$statusTexts

Note about configs:

  • auto-doc.route - it's a route where will be located generated documentation
  • auto-doc.basePath - it's a route where located root of your api

Also you can specify way to collect documentation by creating your custom data collector class.

统计信息

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

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 49
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2020-03-27