2020-07-29 17:11:41 +08:00
|
|
|
|
package spec
|
|
|
|
|
|
|
|
|
|
type (
|
2021-01-11 15:10:51 +08:00
|
|
|
|
Doc []string
|
|
|
|
|
|
2020-07-29 17:11:41 +08:00
|
|
|
|
Annotation struct {
|
|
|
|
|
Properties map[string]string
|
2021-01-11 15:10:51 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ApiSyntax struct {
|
|
|
|
|
Version string
|
2020-07-29 17:11:41 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ApiSpec struct {
|
|
|
|
|
Info Info
|
2021-01-11 15:10:51 +08:00
|
|
|
|
Syntax ApiSyntax
|
|
|
|
|
Imports []Import
|
2020-07-29 17:11:41 +08:00
|
|
|
|
Types []Type
|
|
|
|
|
Service Service
|
|
|
|
|
}
|
|
|
|
|
|
2021-01-11 15:10:51 +08:00
|
|
|
|
Import struct {
|
|
|
|
|
Value string
|
|
|
|
|
}
|
|
|
|
|
|
2020-07-29 17:11:41 +08:00
|
|
|
|
Group struct {
|
2021-01-11 15:10:51 +08:00
|
|
|
|
Annotation Annotation
|
|
|
|
|
Routes []Route
|
2020-07-29 17:11:41 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Info struct {
|
2021-01-11 15:10:51 +08:00
|
|
|
|
// Deprecated: use Properties instead
|
|
|
|
|
Title string
|
|
|
|
|
// Deprecated: use Properties instead
|
|
|
|
|
Desc string
|
|
|
|
|
// Deprecated: use Properties instead
|
2020-07-29 17:11:41 +08:00
|
|
|
|
Version string
|
2021-01-11 15:10:51 +08:00
|
|
|
|
// Deprecated: use Properties instead
|
|
|
|
|
Author string
|
|
|
|
|
// Deprecated: use Properties instead
|
|
|
|
|
Email string
|
|
|
|
|
Properties map[string]string
|
2020-07-29 17:11:41 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Member struct {
|
2021-01-11 15:10:51 +08:00
|
|
|
|
Name string
|
2020-07-29 17:11:41 +08:00
|
|
|
|
// 数据类型字面值,如:string、map[int]string、[]int64、[]*User
|
2021-01-11 15:10:51 +08:00
|
|
|
|
Type Type
|
|
|
|
|
Tag string
|
|
|
|
|
Comment string
|
2020-07-29 17:11:41 +08:00
|
|
|
|
// 成员头顶注释说明
|
2021-01-11 15:10:51 +08:00
|
|
|
|
Docs Doc
|
2020-07-29 17:11:41 +08:00
|
|
|
|
IsInline bool
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Route struct {
|
2021-01-11 15:10:51 +08:00
|
|
|
|
Annotation Annotation
|
2020-07-29 17:11:41 +08:00
|
|
|
|
Method string
|
|
|
|
|
Path string
|
|
|
|
|
RequestType Type
|
|
|
|
|
ResponseType Type
|
2021-01-11 15:10:51 +08:00
|
|
|
|
Docs Doc
|
|
|
|
|
Handler string
|
2021-01-13 11:54:53 +08:00
|
|
|
|
AtDoc AtDoc
|
2020-07-29 17:11:41 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Service struct {
|
2020-11-13 23:01:19 +08:00
|
|
|
|
Name string
|
|
|
|
|
Groups []Group
|
2020-07-29 17:11:41 +08:00
|
|
|
|
}
|
|
|
|
|
|
2021-01-11 15:10:51 +08:00
|
|
|
|
Type interface {
|
|
|
|
|
Name() string
|
2020-07-29 17:11:41 +08:00
|
|
|
|
}
|
|
|
|
|
|
2021-01-11 15:10:51 +08:00
|
|
|
|
DefineStruct struct {
|
|
|
|
|
RawName string
|
|
|
|
|
Members []Member
|
|
|
|
|
Docs Doc
|
2020-07-29 17:11:41 +08:00
|
|
|
|
}
|
2020-09-13 16:17:21 +08:00
|
|
|
|
|
2021-01-11 15:10:51 +08:00
|
|
|
|
// 系统预设基本数据类型 bool int32 int64 float32
|
|
|
|
|
PrimitiveType struct {
|
|
|
|
|
RawName string
|
2020-07-29 17:11:41 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
MapType struct {
|
2021-01-11 15:10:51 +08:00
|
|
|
|
RawName string
|
|
|
|
|
// only support the PrimitiveType
|
2020-07-29 17:11:41 +08:00
|
|
|
|
Key string
|
2021-01-11 15:10:51 +08:00
|
|
|
|
// it can be asserted as PrimitiveType: int、bool、
|
2020-07-29 17:11:41 +08:00
|
|
|
|
// PointerType: *string、*User、
|
2021-01-11 15:10:51 +08:00
|
|
|
|
// MapType: map[${PrimitiveType}]interface、
|
2020-07-29 17:11:41 +08:00
|
|
|
|
// ArrayType:[]int、[]User、[]*User
|
|
|
|
|
// InterfaceType: interface{}
|
|
|
|
|
// Type
|
2021-01-11 15:10:51 +08:00
|
|
|
|
Value Type
|
2020-07-29 17:11:41 +08:00
|
|
|
|
}
|
2021-01-11 15:10:51 +08:00
|
|
|
|
|
2020-07-29 17:11:41 +08:00
|
|
|
|
ArrayType struct {
|
2021-01-11 15:10:51 +08:00
|
|
|
|
RawName string
|
|
|
|
|
Value Type
|
2020-07-29 17:11:41 +08:00
|
|
|
|
}
|
2021-01-11 15:10:51 +08:00
|
|
|
|
|
2020-07-29 17:11:41 +08:00
|
|
|
|
InterfaceType struct {
|
2021-01-11 15:10:51 +08:00
|
|
|
|
RawName string
|
2020-07-29 17:11:41 +08:00
|
|
|
|
}
|
2021-01-11 15:10:51 +08:00
|
|
|
|
|
|
|
|
|
PointerType struct {
|
|
|
|
|
RawName string
|
|
|
|
|
Type Type
|
2020-07-29 17:11:41 +08:00
|
|
|
|
}
|
2021-01-13 11:54:53 +08:00
|
|
|
|
|
|
|
|
|
AtDoc struct {
|
|
|
|
|
Properties map[string]string
|
|
|
|
|
Text string
|
|
|
|
|
}
|
2020-07-29 17:11:41 +08:00
|
|
|
|
)
|