mirror of
https://github.com/beego/bee.git
synced 2025-01-10 22:07:13 +00:00
feat: modify swagger index.html file to support mutil-namespace.
This commit is contained in:
parent
59d489f1f7
commit
cf58ccf783
@ -15,6 +15,7 @@
|
|||||||
package swaggergen
|
package swaggergen
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bufio"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
@ -22,6 +23,7 @@ import (
|
|||||||
"go/build"
|
"go/build"
|
||||||
"go/parser"
|
"go/parser"
|
||||||
"go/token"
|
"go/token"
|
||||||
|
"io"
|
||||||
"os"
|
"os"
|
||||||
"path"
|
"path"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
@ -198,7 +200,7 @@ func GenerateDocs(curpath string) {
|
|||||||
if f.Comments != nil {
|
if f.Comments != nil {
|
||||||
for _, c := range f.Comments {
|
for _, c := range f.Comments {
|
||||||
var namespacePrefix string
|
var namespacePrefix string
|
||||||
rootapi := &swagger.Swagger{
|
rootapi := swagger.Swagger{
|
||||||
Infos: swagger.Information{},
|
Infos: swagger.Information{},
|
||||||
SwaggerVersion: "2.0",
|
SwaggerVersion: "2.0",
|
||||||
}
|
}
|
||||||
@ -206,7 +208,7 @@ func GenerateDocs(curpath string) {
|
|||||||
if strings.HasPrefix(s, "@NamespacePrefix") {
|
if strings.HasPrefix(s, "@NamespacePrefix") {
|
||||||
namespacePrefix = strings.TrimSpace(s[len("@NamespacePrefix"):])
|
namespacePrefix = strings.TrimSpace(s[len("@NamespacePrefix"):])
|
||||||
if _, exist := rootapiMap[namespacePrefix]; !exist {
|
if _, exist := rootapiMap[namespacePrefix]; !exist {
|
||||||
rootapiMap[namespacePrefix] = rootapi
|
rootapiMap[namespacePrefix] = &rootapi
|
||||||
}
|
}
|
||||||
} else if strings.HasPrefix(s, "@APIVersion") {
|
} else if strings.HasPrefix(s, "@APIVersion") {
|
||||||
rootapi.Infos.Version = strings.TrimSpace(s[len("@APIVersion"):])
|
rootapi.Infos.Version = strings.TrimSpace(s[len("@APIVersion"):])
|
||||||
@ -293,10 +295,10 @@ func GenerateDocs(curpath string) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// when namespacePrefix not defined, then add default namespacePrefix
|
_, namespacePrefixExist := rootapiMap[namespacePrefix]
|
||||||
if _, exist := rootapiMap[namespacePrefix]; !exist {
|
if !namespacePrefixExist && !rootapiSingle {
|
||||||
rootapiSingle = true
|
rootapiSingle = true
|
||||||
rootapiDefault = *rootapi
|
rootapiDefault = rootapi
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -340,7 +342,7 @@ func GenerateDocs(curpath string) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if !rootapiSingle && rootapi.BasePath == "" {
|
if rootapi.BasePath == "" {
|
||||||
rootapi.BasePath = version
|
rootapi.BasePath = version
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -350,7 +352,7 @@ func GenerateDocs(curpath string) {
|
|||||||
var controllerName string
|
var controllerName string
|
||||||
if selname := pp.Fun.(*ast.SelectorExpr).Sel.String(); selname == "NSNamespace" {
|
if selname := pp.Fun.(*ast.SelectorExpr).Sel.String(); selname == "NSNamespace" {
|
||||||
s, params := analyseNewNamespace(pp)
|
s, params := analyseNewNamespace(pp)
|
||||||
if rootapiSingle {
|
if rootapi.BasePath == "" {
|
||||||
s = path.Join(version, s)
|
s = path.Join(version, s)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -420,6 +422,8 @@ func GenerateDocs(curpath string) {
|
|||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
modifySwaggerIndexFile(curpath, rootapiSingle, rootapiMap)
|
||||||
}
|
}
|
||||||
|
|
||||||
// analyseNewNamespace returns version and the others params
|
// analyseNewNamespace returns version and the others params
|
||||||
@ -1508,3 +1512,56 @@ func checkAndLoadPackage(imports []*ast.ImportSpec, realType, curPkgName string)
|
|||||||
|
|
||||||
pkgLoadedCache[pkgPath] = struct{}{}
|
pkgLoadedCache[pkgPath] = struct{}{}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func modifySwaggerIndexFile(curpath string, rootapiSingle bool, rootapiMap map[string]*swagger.Swagger) {
|
||||||
|
swaggerIndexFilename := "index.html"
|
||||||
|
swaggerIndexFullname := path.Join(curpath, "swagger", swaggerIndexFilename)
|
||||||
|
|
||||||
|
swaggerJsonFilename := "swagger.json"
|
||||||
|
swaggerUIBundleSign := `SwaggerUIBundle(`
|
||||||
|
var swaggerUIBundleSignPass bool
|
||||||
|
|
||||||
|
if _, err := os.Stat(swaggerIndexFullname); !os.IsNotExist(err) {
|
||||||
|
var swaggerJsonUrl string
|
||||||
|
if rootapiSingle {
|
||||||
|
swaggerJsonUrl = fmt.Sprintf(` url: "%s",`, swaggerJsonFilename)
|
||||||
|
} else {
|
||||||
|
urls := make([]string, 0)
|
||||||
|
for namespace, _ := range rootapiMap {
|
||||||
|
namespace = strings.TrimLeft(namespace, "/")
|
||||||
|
urls = append(urls, fmt.Sprintf(`{url: "%s", name: "%s"}`, path.Join(namespace, swaggerJsonFilename), namespace))
|
||||||
|
}
|
||||||
|
swaggerJsonUrl = fmt.Sprintf(` urls: [%s],`, strings.Join(urls, ", "))
|
||||||
|
}
|
||||||
|
|
||||||
|
var indexFileContent string
|
||||||
|
if f, err := os.Open(swaggerIndexFullname); err == nil {
|
||||||
|
defer f.Close()
|
||||||
|
|
||||||
|
buf := bufio.NewReader(f)
|
||||||
|
for {
|
||||||
|
line, _, c := buf.ReadLine()
|
||||||
|
if c == io.EOF {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
if strings.Contains(string(line), swaggerUIBundleSign) {
|
||||||
|
swaggerUIBundleSignPass = true
|
||||||
|
}
|
||||||
|
if swaggerUIBundleSignPass && (strings.Contains(string(line), "url:") || strings.Contains(string(line), "urls:")) {
|
||||||
|
indexFileContent += swaggerJsonUrl + "\n"
|
||||||
|
} else {
|
||||||
|
indexFileContent += string(line) + "\n"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if fw, err := os.OpenFile(swaggerIndexFullname, os.O_WRONLY|os.O_CREATE|os.O_TRUNC, 0666); err == nil {
|
||||||
|
defer fw.Close()
|
||||||
|
|
||||||
|
w := bufio.NewWriter(fw)
|
||||||
|
w.WriteString(indexFileContent)
|
||||||
|
w.Flush()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user