go-zero/tools/goctl/api/spec/fn.go

201 lines
3.9 KiB
Go
Raw Normal View History

2020-07-29 17:11:41 +08:00
package spec
import (
"errors"
"strings"
2020-08-08 16:40:10 +08:00
"github.com/tal-tech/go-zero/core/stringx"
"github.com/tal-tech/go-zero/tools/goctl/util"
2020-07-29 17:11:41 +08:00
)
const (
bodyTagKey = "json"
formTagKey = "form"
2021-03-04 17:13:07 +08:00
pathTagKey = "path"
defaultSummaryKey = "summary"
)
2020-07-29 17:11:41 +08:00
2021-03-04 17:13:07 +08:00
var definedKeys = []string{bodyTagKey, formTagKey, pathTagKey}
2020-07-29 17:11:41 +08:00
// Routes returns all routes in api service
func (s Service) Routes() []Route {
var result []Route
for _, group := range s.Groups {
result = append(result, group.Routes...)
}
return result
}
2021-03-04 17:13:07 +08:00
// Tags returns all tags in Member
2020-12-09 11:16:38 +08:00
func (m Member) Tags() []*Tag {
tags, err := Parse(m.Tag)
if err != nil {
panic(m.Tag + ", " + err.Error())
2020-07-29 17:11:41 +08:00
}
2020-12-09 11:16:38 +08:00
return tags.Tags()
}
// IsOptional returns true if tag is optional
2020-12-09 11:16:38 +08:00
func (m Member) IsOptional() bool {
if !m.IsBodyMember() {
2020-07-29 17:11:41 +08:00
return false
}
2020-12-09 11:16:38 +08:00
tag := m.Tags()
for _, item := range tag {
if item.Key == bodyTagKey {
if stringx.Contains(item.Options, "optional") {
return true
}
2020-07-29 17:11:41 +08:00
}
}
return false
}
// IsOmitEmpty returns true if tag contains omitempty
func (m Member) IsOmitEmpty() bool {
if !m.IsBodyMember() {
return false
}
tag := m.Tags()
for _, item := range tag {
if item.Key == bodyTagKey {
if stringx.Contains(item.Options, "omitempty") {
return true
}
}
}
return false
}
// GetPropertyName returns json tag value
2020-12-09 11:16:38 +08:00
func (m Member) GetPropertyName() (string, error) {
tags := m.Tags()
for _, tag := range tags {
if stringx.Contains(definedKeys, tag.Key) {
if tag.Name == "-" {
2020-07-29 17:11:41 +08:00
return util.Untitle(m.Name), nil
}
2020-12-09 11:16:38 +08:00
return tag.Name, nil
2020-07-29 17:11:41 +08:00
}
}
2020-12-09 11:16:38 +08:00
2020-07-29 17:11:41 +08:00
return "", errors.New("json property name not exist, member: " + m.Name)
}
// GetComment returns comment value of Member
2020-07-29 17:11:41 +08:00
func (m Member) GetComment() string {
return strings.TrimSpace(m.Comment)
2020-07-29 17:11:41 +08:00
}
// IsBodyMember returns true if contains json tag
2020-07-29 17:11:41 +08:00
func (m Member) IsBodyMember() bool {
if m.IsInline {
return true
}
2020-12-09 11:16:38 +08:00
tags := m.Tags()
for _, tag := range tags {
if tag.Key == bodyTagKey {
2020-07-29 17:11:41 +08:00
return true
}
}
return false
}
// IsFormMember returns true if contains form tag
func (m Member) IsFormMember() bool {
if m.IsInline {
return false
}
tags := m.Tags()
for _, tag := range tags {
if tag.Key == formTagKey {
return true
}
}
return false
}
// GetBodyMembers returns all json fields
func (t DefineStruct) GetBodyMembers() []Member {
2020-07-29 17:11:41 +08:00
var result []Member
for _, member := range t.Members {
if member.IsBodyMember() {
result = append(result, member)
}
}
return result
}
// GetFormMembers returns all form fields
func (t DefineStruct) GetFormMembers() []Member {
var result []Member
for _, member := range t.Members {
if member.IsFormMember() {
result = append(result, member)
}
}
return result
}
2021-03-04 17:13:07 +08:00
// GetNonBodyMembers returns all have no tag fields
func (t DefineStruct) GetNonBodyMembers() []Member {
2020-07-29 17:11:41 +08:00
var result []Member
for _, member := range t.Members {
if !member.IsBodyMember() {
result = append(result, member)
}
}
return result
}
// JoinedDoc joins comments and summary value in AtDoc
func (r Route) JoinedDoc() string {
doc := r.AtDoc.Text
if r.AtDoc.Properties != nil {
doc += r.AtDoc.Properties[defaultSummaryKey]
}
doc += strings.Join(r.Docs, " ")
return strings.TrimSpace(doc)
}
2021-03-04 17:13:07 +08:00
// GetAnnotation returns the value by specified key from @server
func (r Route) GetAnnotation(key string) string {
2021-03-04 17:13:07 +08:00
if r.AtServerAnnotation.Properties == nil {
return ""
}
2021-01-15 11:36:37 +08:00
2021-03-04 17:13:07 +08:00
return r.AtServerAnnotation.Properties[key]
}
2021-03-04 17:13:07 +08:00
// GetAnnotation returns the value by specified key from @server
func (g Group) GetAnnotation(key string) string {
if g.Annotation.Properties == nil {
return ""
}
2021-01-15 11:36:37 +08:00
return g.Annotation.Properties[key]
}
// ResponseTypeName returns response type name of route
func (r Route) ResponseTypeName() string {
if r.ResponseType == nil {
return ""
}
return r.ResponseType.Name()
}
// RequestTypeName returns request type name of route
func (r Route) RequestTypeName() string {
if r.RequestType == nil {
return ""
}
return r.RequestType.Name()
}