-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmarkdown.go
More file actions
110 lines (96 loc) · 3.55 KB
/
markdown.go
File metadata and controls
110 lines (96 loc) · 3.55 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
package main
import (
"fmt"
"io/ioutil"
"os"
"path"
"strings"
)
func GenerateMarkDownFile(filename string) error {
var b []byte
var err error
if strings.Contains(filename, "http://") {
b, err = ReadFromURL(filename)
} else {
b, err = ReadFromJson(filename)
}
if err != nil {
return err
}
api, err := DecodeJSON(b)
if err != nil {
return err
}
currpath, _ := os.Getwd()
for _, v := range api.Tags {
mdPath := path.Join(currpath, v.Name)
os.MkdirAll(mdPath, 0755)
}
apiservice := NewAPIService(api)
weightMap := make(map[string]int)
for _, serviceInterface := range apiservice.ServiceInterfaces {
serviceInterface.OperationID = strings.Replace(serviceInterface.OperationID, ".", "_", -1)
weightMap[serviceInterface.Tag]++
markdownDoc := ""
hugoHeader := fmt.Sprintf("+++\ntitle=\"%s\"\nurl=\"/%s/%s\"\n[menu.side]\n name=\"%s\"\n parent=\"%s\"\n weight=%d\n+++\n\n",
serviceInterface.Description, serviceInterface.Tag, strings.ToLower(serviceInterface.OperationID), serviceInterface.Description, serviceInterface.Tag, weightMap[serviceInterface.Tag])
markdownDoc += hugoHeader
desc := fmt.Sprintf("## %s\n\n", serviceInterface.Description)
markdownDoc += desc
method := fmt.Sprintf("**请求方式**\n\n`%s`\n\n", serviceInterface.Method)
markdownDoc += method
uri := fmt.Sprintf("**请求路径**\n\n`%s`\n\n", api.BasePath+serviceInterface.URI)
markdownDoc += uri
if len(serviceInterface.Params) > 0 {
markdownDoc += "**请求参数说明**\n\n|参数名|必选|参数方式|类型|说明|\n| :---- | :--- | :----- | :----- | ---------------------------------------- |\n"
for _, parameter := range serviceInterface.Params {
param := fmt.Sprintf("|%s|%t|%s|%s|%s|\n", parameter.Name, parameter.Required, parameter.In, parameter.Type, parameter.Description)
markdownDoc += param
}
}
if len(serviceInterface.Body) > 0 {
markdownDoc += "\n**返回参数说明**\n\n|参数名|类型|说明|\n| :----- | :----- | ------------------------ |\n"
for _, v := range serviceInterface.Body {
param := fmt.Sprintf("|%s|%s|%s|\n", v.Name, v.Type, v.Description)
markdownDoc += param
}
}
markdownDoc += parseSchema(api, serviceInterface.Definitions)
fpath := path.Join(serviceInterface.Tag, strings.ToLower(serviceInterface.OperationID)+".md")
ioutil.WriteFile(fpath, []byte(markdownDoc), 0666)
}
return nil
}
func parseSchema(api *API, defs map[string]Definition) string {
markdownDoc := ""
obj := make(map[string]Definition)
for k, v := range defs {
if len(v.Properties) > 0 {
markdownDoc += fmt.Sprintf("\n**%s 数据结构**\n\n|成员|类型|说明|\n| :----- | :----- | ------------------------ |\n", k)
for k, v := range v.Properties {
if v.MyRef != "" {
v.Type = api.Definitions[v.MyRef].Type + " (" + api.Definitions[v.MyRef].Title + ")"
obj[api.Definitions[v.MyRef].Title] = api.Definitions[v.MyRef]
if _, ok := defs[api.Definitions[v.MyRef].Title]; ok {
delete(obj, api.Definitions[v.MyRef].Title)
}
}
if v.Type == "array" {
if _, ok := v.Items["myRef"]; ok {
v.Type = "array (" + api.Definitions[v.Items["myRef"]].Title + ")"
obj[api.Definitions[v.Items["myRef"]].Title] = api.Definitions[v.Items["myRef"]]
if _, ok := defs[api.Definitions[v.Items["myRef"]].Title]; ok {
delete(obj, api.Definitions[v.Items["myRef"]].Title)
}
}
}
param := fmt.Sprintf("|%s|%s|%s|\n", k, v.Type, v.Description)
markdownDoc += param
}
}
}
if len(obj) == 0 {
return markdownDoc
}
return markdownDoc + parseSchema(api, obj)
}