Skip to content

Latest commit

 

History

History
224 lines (175 loc) · 4.99 KB

README.md

File metadata and controls

224 lines (175 loc) · 4.99 KB

swagphp

a lite swagger tool, for parse and generate swagger api docs json,yml

Usage

Use composer

  • global install
composer global require toolkit/swagphp 
swagphp --help
swagphp gen -o swagger.json
  • for current project
composer require toolkit/swagphp --dev

Use phar package

wget https://github.com/php-toolkit/swagphp/releases/download/1.0.1/swagphp.phar
mv swagphp.phar /usr/local/bin/swagphp
swagphp --help

Usage from docker

Generate the swagger documentation to a static json file.

docker run -v "$PWD":/app -it sawgphp/box swagphp --help

Annotations

Simple mode

basic info

/**
 * @Version 1.0.0
 * @Title user service center
 * @Description api for user service center
 * @Host localhost:8080
 * @BasePath /v1
 * @ContactName username
 * @ContactEmail [email protected]
 * @ContactUrl http://github.com/inhere
 * @TermsOfService http://github.com/inhere
 * @License Apache 2.0
 * @LicenseUrl http://www.apache.org/licenses/LICENSE-2.0.html
 */

Security

/**
 * 
 */

api operations

/**
 * some api for user
 * @Tag  users  "some api for user"
 */
class UserController 
{
    /**
     * @Summary  summary message
     * @Description description message
     * @Parameter  FIELD  POSITION  TYPE  REQUIRED  DESCRIPTION  EXTRA...
     * @Parameter  status  query  int  true  "the user id"  enums(1, 2, 3)
     * @Parameter  userId  path  int  false  "the user id" min(1) max(10)
     * @Parameter  name  query  string  false  "the user name" minLength(5) maxLength(10)
     * @Parameter  bodyData  body  UserModel  true  "the submit form data"
     * @Response   200  {array}   []UserModel
     * @Response   200  {object}   UserModel
     * @Response   403   no content
     * @Route /users [get]
     */
    public function getUsers() 
    {}
     
    /**
     * summary message
     * description message
     * @Parameter  FIELD  POSITION  TYPE  REQUIRED  DESCRIPTION  EXTRA...
     * @Parameter  status  query  int  true  "the user id"  
     * @Response   200  {object}   []UserModel
     * @Response   403   no content
     * @Route /users/{id} [get]
     */
    public function get() 
    {}
}

Detailed mode

basic info

/**
 * // https://github.com/OAI/OpenAPI-Specification/blob/master/versions/2.0.md#swaggerObject
 * @Project(
 *     host="api.dev",
 *     basePath="/",
 *     schemes={"http", "https"},
 *     consumes={"application/json"},
 *     produces={"application/json"}
 * )
 * @Info(
 *     version="1.0.0",
 *     title="user service center",
 *     description="## user service center, `env: {dev}`
 * test"
 * )
 */

api operations

/**
 * @ApiTag("users", description="some api for user") // is optional
 */
class UserController 
{
    /**
     * @Summary("Post to URL")
     * @Description("description message")
     * @Route(path="/users", method="GET")
     * @Parameter("username", type="string", description="The username", in="header")
     * @Parameter(name="userId", type="int", description="The user ID", in="path", required=true)
     * @Parameter(name="field1", type="int", description="The field message", in="query")
     * @Response(200, type="object", ref="\App\Models\UserModel")
     * @Response(200, type="array", ref="[]\App\Models\UserModel")
     * @Response(403, description="no content")
     */
    public function getUsers() 
    {}
}

Some helper methods

  • setting some info
$swag->swagger->info->version = '1.2.0';
  • pre-add tags
$swag->addTag('users', 'some operation for user');
$swag->addTags([
  'users' => 'some operation for user', 
  'users.follow' => 'tag description', 
  'common' => 'tag description'
]);

Development

generate phar package:

php -d phar.readonly=0 genphar pack -o swagphp.phar

Reference

open api

swagger

other implement

swagger-explained

doc-block parse

LICENSE

MIT