123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- package docgen
- import (
- "bytes"
- "fmt"
- "html/template"
- "strconv"
- "strings"
- "github.com/tal-tech/go-zero/core/stringx"
- "github.com/tal-tech/go-zero/tools/goctl/api/gogen"
- "github.com/tal-tech/go-zero/tools/goctl/api/spec"
- "github.com/tal-tech/go-zero/tools/goctl/api/util"
- )
- const (
- markdownTemplate = `
- ### {{.index}}. {{.routeComment}}
- 1. 路由定义
- - Url: {{.uri}}
- - Method: {{.method}}
- - Request: {{.requestType}}
- - Response: {{.responseType}}
- 2. 类型定义
- {{.responseContent}}
- `
- )
- func genDoc(api *spec.ApiSpec, dir string, filename string) error {
- fp, _, err := util.MaybeCreateFile(dir, "", filename)
- if err != nil {
- return err
- }
- defer fp.Close()
- var builder strings.Builder
- for index, route := range api.Service.Routes() {
- routeComment := route.JoinedDoc()
- if len(routeComment) == 0 {
- routeComment = "N/A"
- }
- responseContent, err := responseBody(api, route)
- if err != nil {
- return err
- }
- t := template.Must(template.New("markdownTemplate").Parse(markdownTemplate))
- var tmplBytes bytes.Buffer
- err = t.Execute(&tmplBytes, map[string]string{
- "index": strconv.Itoa(index + 1),
- "routeComment": routeComment,
- "method": strings.ToUpper(route.Method),
- "uri": route.Path,
- "requestType": "`" + stringx.TakeOne(route.RequestTypeName(), "-") + "`",
- "responseType": "`" + stringx.TakeOne(route.ResponseTypeName(), "-") + "`",
- "responseContent": responseContent,
- })
- if err != nil {
- return err
- }
- builder.Write(tmplBytes.Bytes())
- }
- _, err = fp.WriteString(strings.Replace(builder.String(), """, `"`, -1))
- return err
- }
- func responseBody(api *spec.ApiSpec, route spec.Route) (string, error) {
- if len(route.ResponseTypeName()) == 0 {
- return "", nil
- }
- var tps = make([]spec.Type, 0)
- tps = append(tps, route.ResponseType)
- if definedType, ok := route.ResponseType.(spec.DefineStruct); ok {
- associatedTypes(definedType, &tps)
- }
- value, err := gogen.BuildTypes(tps)
- if err != nil {
- return "", err
- }
- return fmt.Sprintf("\n\n```golang\n%s\n```\n", value), nil
- }
- func associatedTypes(tp spec.DefineStruct, tps *[]spec.Type) {
- *tps = append(*tps, tp)
- for _, item := range tp.Members {
- if definedType, ok := item.Type.(spec.DefineStruct); ok {
- associatedTypes(definedType, tps)
- }
- }
- }
|