swag

package
v0.12.4 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 6, 2021 License: MIT Imports: 8 Imported by: 0

README

Swag 注册文档

将接口文档注册到swagger

安装

go get github.com/hanguangbaihuo/sparrow_cloud_go/swag

使用前必知

1. go语言中swag文档书写方法 https://github.com/swaggo/swag#general-api-info
2. api注释说明 https://github.com/swaggo/swag#general-api-info
3. 直接拷贝命令代码至根目录下,运行即可。注意修改配置为你的服务名称

文档书写示例1

// @Summary 接口用途,列表页接口后展示该字段
// @Description ### 接口格式请求格式说明<br> 
// @Description     参数:<br> 
// @Description         {<br> 
// @Description             "name": "hpa_name", //hpa的名字<br> 
// @Description             "min": 1,<br> 
// @Description             "max": 3<br> 
// @Description         }<br> 
// @Description     返回:200<br>
// @Description         {<br> 
// @Description             "message":"ok"<br> 
// @Description         }<br>
// @Router /api/sparrow_test/justtest/create [post]
func processReuqest (iris.Context) {
    //do something
}

文档书写示例2

// @Summary 接口用途,列表页接口后展示该字段
// @Description.markdown processReuqest.md
// @Router /api/sparrow_test/justtest/create [post]
func processReuqest (iris.Context) {
    //do something
}
使用该种方式需要配置接口文档路径:cfg.MarkdownFilesDir,其中processReuqest.md文件必须放在该目录下

文档书写示例3

// @Summary 接口用途,列表页接口后展示该字段
// @Description.markdown ./app/processReuqest.md@create api
// @Router /api/sparrow_test/justtest/create [post]
func processReuqest (iris.Context) {
    //do something
}

该方式可以指定目录,目录是针对cmd.go文件的相对路径。不指定目录则使用配置的公共路径cfg.MarkdownFilesDir;
同时也可以指定文件中的路由数据,即@create api,如果不指定则为整个文件数据。markdown文件书写方式如下,一个markdown文件可以写多个路由的描述
使用该种方式需要替换官方源码,在go.mod最后添加 replace github.com/swaggo/swag => github.com/hanguangbaihuo/swag v1.7.1

示例3的markdown文件书写示例

@create api
# 这个某个接口的post描述
    参数:
        {
            "id":1,
            "name":"test"
        }
    返回:
        {
            "message":"ok"
            "code":0
        }
@delete some router
# 只要按照markdown格式写就可以
## 参数
    {
        "payload":"sssss",
        "method":"delete"
    }
## 返回
    {
        "code":-1,
        "message":"error"
    }

命令文件

// cmd.go
package main

import (
    "fmt"
    "github.com/hanguangbaihuo/sparrow_cloud_go/swag"
)

func main() {
    cfg := swag.DefaultConfig()
    // cfg.OutputFlag = true //如果设置为true,则会在文件根目录下生成./docs/swagger.json文档
    cfg.MarkdownFilesDir = "./dir/" //该配置是当使用Description.markdown注释时,寻找md文件的公共路径,接口文档需要放在该目录下,是相对于命令文件所在位置的相对路径
    swagcfg := swag.ServiceConfig{
        "sparrow-schema-svc.frontend:8001", //此处是swagger服务的名称
        "/api/schema_i/register/", //此处为swagger服务的api接口
        "YourServiceName", //该名称需要设置为你的服务的名称
        []string{"waro163","倩倩"}, //项目的贡献者,便于前端查看接口文档联系项目维护人
    }
    err := swag.Build(cfg, swagcfg)
    if err != nil {
        fmt.Println(err)
    }
}

运行示例

//修改服务的代理
http_proxy=http://12.34.56.78:8888 go run -mod=vendor cmd.go

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func Build

func Build(config Config, svcConfig ServiceConfig) error

Types

type Config

type Config struct {
	// SearchDir the swag would be parse
	SearchDir string

	// excludes dirs and files in SearchDir,comma separated
	Excludes string

	//OutputFlag represents whether output swagger.json file to local directory
	OutputFlag bool

	// OutputDir represents the output directory for all the generated files
	OutputDir string

	// MainAPIFile the Go file path in which 'swagger general API Info' is written
	MainAPIFile string

	// PropNamingStrategy represents property naming strategy like snakecase,camelcase,pascalcase
	PropNamingStrategy string

	// ParseVendor whether swag should be parse vendor folder
	ParseVendor bool

	// ParseDependencies whether swag should be parse outside dependency folder
	ParseDependency bool

	// ParseInternal whether swag should parse internal packages
	ParseInternal bool

	// MarkdownFilesDir used to find markdownfiles, which can be used for tag descriptions
	MarkdownFilesDir string

	// GeneratedTime whether swag should generate the timestamp at the top of docs.go
	GeneratedTime bool

	// CodeExampleFilesDir used to find code example files, which can be used for x-codeSamples
	CodeExampleFilesDir string

	// ParseDepth dependency parse depth
	ParseDepth int
}

func DefaultConfig

func DefaultConfig() Config

type ServiceConfig

type ServiceConfig struct {
	// SwaggerService represents remote swagger service
	SwaggerService string
	// APIPath
	APIPath string
	// ServiceName is the service name, used for app_name
	ServiceName string
	// Contributors is Contributors of the service
	Contributors []string
}

type SwaggerData

type SwaggerData struct {
	Swagger      string      `json:"swagger,omitempty"`
	Info         *spec.Info  `json:"info,omitempty"`
	Paths        *spec.Paths `json:"paths"`
	Contributors []string    `json:"contributors"`
	ServiceName  string      `json:"service_name"`
}

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL