diff --git a/README.md b/README.md index c316445..46daa0a 100644 --- a/README.md +++ b/README.md @@ -86,10 +86,10 @@ GOPROXY=https://goproxy.cn/,direct go install github.com/zeromicro/goctl-swagger goctl api plugin -plugin goctl-swagger="swagger -filename user.json" -api user.api -dir . ``` -* 指定Host,basePath [api-host-and-base-path](https://swagger.io/docs/specification/2-0/api-host-and-base-path/) +* 指定Host,basePath,schemes [api-host-and-base-path](https://swagger.io/docs/specification/2-0/api-host-and-base-path/) ```shell script - goctl api plugin -plugin goctl-swagger="swagger -filename user.json -host 127.0.0.2 -basepath /api" -api user.api -dir . + goctl api plugin -plugin goctl-swagger="swagger -filename user.json -host 127.0.0.2 -basepath /api -schemes https,wss" -api user.api -dir . ``` * swagger ui 查看生成的文档 diff --git a/action/action.go b/action/action.go index ae6459c..94a4c4c 100644 --- a/action/action.go +++ b/action/action.go @@ -19,5 +19,6 @@ func Generator(ctx *cli.Context) error { } basepath := ctx.String("basepath") host := ctx.String("host") - return generate.Do(fileName, host, basepath, p) + schemes := ctx.String("schemes") + return generate.Do(fileName, host, basepath, schemes, p) } diff --git a/generate/generate.go b/generate/generate.go index fc27163..190ebcb 100644 --- a/generate/generate.go +++ b/generate/generate.go @@ -9,8 +9,8 @@ import ( "github.com/zeromicro/go-zero/tools/goctl/plugin" ) -func Do(filename string, host string, basePath string, in *plugin.Plugin) error { - swagger, err := applyGenerate(in, host, basePath) +func Do(filename string, host string, basePath string, schemes string, in *plugin.Plugin) error { + swagger, err := applyGenerate(in, host, basePath, schemes) if err != nil { fmt.Println(err) } diff --git a/generate/parser.go b/generate/parser.go index b4af259..57d02dd 100644 --- a/generate/parser.go +++ b/generate/parser.go @@ -4,6 +4,7 @@ import ( "bytes" "encoding/json" "fmt" + "log" "net/http" "reflect" "regexp" @@ -53,7 +54,7 @@ func parseRangeOption(option string) (float64, float64, bool) { return min, max, true } -func applyGenerate(p *plugin.Plugin, host string, basePath string) (*swaggerObject, error) { +func applyGenerate(p *plugin.Plugin, host string, basePath string, schemes string) (*swaggerObject, error) { title, _ := strconv.Unquote(p.Api.Info.Properties["title"]) version, _ := strconv.Unquote(p.Api.Info.Properties["version"]) desc, _ := strconv.Unquote(p.Api.Info.Properties["desc"]) @@ -79,6 +80,19 @@ func applyGenerate(p *plugin.Plugin, host string, basePath string) (*swaggerObje s.BasePath = basePath } + if len(schemes) > 0 { + supportedSchemes := []string{"http", "https", "ws", "wss"} + ss := strings.Split(schemes, ",") + for i := range ss { + scheme := ss[i] + scheme = strings.TrimSpace(scheme) + if !contains(supportedSchemes, scheme) { + log.Fatalf("unsupport scheme: [%s], only support [http, https, ws, wss]", scheme) + } + ss[i] = scheme + } + s.Schemes = ss + } s.SecurityDefinitions = swaggerSecurityDefinitionsObject{} newSecDefValue := swaggerSecuritySchemeObject{} newSecDefValue.Name = "Authorization" diff --git a/main.go b/main.go index ef90d22..8f630fc 100644 --- a/main.go +++ b/main.go @@ -29,6 +29,10 @@ var ( Name: "filename", Usage: "swagger save file name", }, + &cli.StringFlag{ + Name: "schemes", + Usage: "swagger support schemes: http, https, ws, wss", + }, }, }, }