2020-07-29 17:11:41 +08:00
|
|
|
|
package spec
|
|
|
|
|
|
2021-12-30 17:44:15 +08:00
|
|
|
|
// RoutePrefixKey is the prefix keyword for the routes.
|
2021-11-03 20:57:03 +08:00
|
|
|
|
const RoutePrefixKey = "prefix"
|
|
|
|
|
|
2020-07-29 17:11:41 +08:00
|
|
|
|
type (
|
2021-02-26 16:11:47 +08:00
|
|
|
|
// Doc describes document
|
2021-01-11 15:10:51 +08:00
|
|
|
|
Doc []string
|
|
|
|
|
|
2021-02-26 16:11:47 +08:00
|
|
|
|
// Annotation defines key-value
|
2020-07-29 17:11:41 +08:00
|
|
|
|
Annotation struct {
|
|
|
|
|
Properties map[string]string
|
2021-01-11 15:10:51 +08:00
|
|
|
|
}
|
|
|
|
|
|
2021-02-26 16:11:47 +08:00
|
|
|
|
// ApiSyntax describes the syntax grammar
|
2021-01-11 15:10:51 +08:00
|
|
|
|
ApiSyntax struct {
|
|
|
|
|
Version string
|
2021-05-21 10:40:59 +08:00
|
|
|
|
Doc Doc
|
|
|
|
|
Comment Doc
|
2020-07-29 17:11:41 +08:00
|
|
|
|
}
|
|
|
|
|
|
2021-02-26 16:11:47 +08:00
|
|
|
|
// ApiSpec describes a api file
|
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-02-26 16:11:47 +08:00
|
|
|
|
// Import describes api import
|
2021-01-11 15:10:51 +08:00
|
|
|
|
Import struct {
|
2021-05-21 10:40:59 +08:00
|
|
|
|
Value string
|
|
|
|
|
Doc Doc
|
|
|
|
|
Comment Doc
|
2021-01-11 15:10:51 +08:00
|
|
|
|
}
|
|
|
|
|
|
2021-02-26 16:11:47 +08:00
|
|
|
|
// Group defines a set of routing information
|
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
|
|
|
|
}
|
|
|
|
|
|
2021-02-26 16:11:47 +08:00
|
|
|
|
// Info describes info grammar block
|
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
|
|
|
|
}
|
|
|
|
|
|
2021-02-26 16:11:47 +08:00
|
|
|
|
// Member describes the field of a structure
|
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
|
|
|
|
|
}
|
|
|
|
|
|
2021-02-26 16:11:47 +08:00
|
|
|
|
// Route describes api route
|
2020-07-29 17:11:41 +08:00
|
|
|
|
Route struct {
|
2021-03-04 17:13:07 +08:00
|
|
|
|
AtServerAnnotation Annotation
|
|
|
|
|
Method string
|
|
|
|
|
Path string
|
|
|
|
|
RequestType Type
|
|
|
|
|
ResponseType Type
|
|
|
|
|
Docs Doc
|
|
|
|
|
Handler string
|
|
|
|
|
AtDoc AtDoc
|
2021-05-21 10:40:59 +08:00
|
|
|
|
HandlerDoc Doc
|
|
|
|
|
HandlerComment Doc
|
|
|
|
|
Doc Doc
|
|
|
|
|
Comment Doc
|
2020-07-29 17:11:41 +08:00
|
|
|
|
}
|
|
|
|
|
|
2021-02-26 16:11:47 +08:00
|
|
|
|
// Service describes api service
|
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-02-26 16:11:47 +08:00
|
|
|
|
// Type defines api type
|
2021-01-11 15:10:51 +08:00
|
|
|
|
Type interface {
|
|
|
|
|
Name() string
|
2021-05-21 10:40:59 +08:00
|
|
|
|
Comments() []string
|
|
|
|
|
Documents() []string
|
2020-07-29 17:11:41 +08:00
|
|
|
|
}
|
|
|
|
|
|
2021-02-26 16:11:47 +08:00
|
|
|
|
// DefineStruct describes api structure
|
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-02-26 16:11:47 +08:00
|
|
|
|
// PrimitiveType describes the basic golang type, such as bool,int32,int64, ...
|
2021-01-11 15:10:51 +08:00
|
|
|
|
PrimitiveType struct {
|
|
|
|
|
RawName string
|
2020-07-29 17:11:41 +08:00
|
|
|
|
}
|
|
|
|
|
|
2021-02-26 16:11:47 +08:00
|
|
|
|
// MapType describes a map for api
|
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
|
|
|
|
|
2021-02-26 16:11:47 +08:00
|
|
|
|
// ArrayType describes a slice for api
|
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
|
|
|
|
|
2021-02-26 16:11:47 +08:00
|
|
|
|
// InterfaceType describes a interface for api
|
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
|
|
|
|
|
2021-02-26 16:11:47 +08:00
|
|
|
|
// PointerType describes a pointer for api
|
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
|
|
|
|
|
2021-02-26 16:11:47 +08:00
|
|
|
|
// AtDoc describes a metadata for api grammar: @doc(...)
|
2021-01-13 11:54:53 +08:00
|
|
|
|
AtDoc struct {
|
|
|
|
|
Properties map[string]string
|
|
|
|
|
Text string
|
|
|
|
|
}
|
2020-07-29 17:11:41 +08:00
|
|
|
|
)
|