From 3975e5bec5517de976e367df2dddc1099daec030 Mon Sep 17 00:00:00 2001 From: KKKIIO Date: Mon, 21 Oct 2024 22:59:52 +0800 Subject: [PATCH] fix: use '&&' for security pair(AND) (#1659) --- README.md | 8 ++++---- README_pt.md | 8 ++++---- README_zh-CN.md | 3 +-- operation.go | 3 ++- operation_test.go | 15 +++++++++++---- parser.go | 2 +- testdata/global_security/main.go | 2 +- 7 files changed, 24 insertions(+), 17 deletions(-) diff --git a/README.md b/README.md index 010c44aea..c70f01fd0 100644 --- a/README.md +++ b/README.md @@ -897,18 +897,18 @@ Each API operation. // @Security ApiKeyAuth ``` -Make it AND condition +Make it OR condition ```go // @Security ApiKeyAuth // @Security OAuth2Application[write, admin] ``` -Make it OR condition +Make it AND condition ```go -// @Security ApiKeyAuth || firebase -// @Security OAuth2Application[write, admin] || APIKeyAuth +// @Security ApiKeyAuth && firebase +// @Security OAuth2Application[write, admin] && APIKeyAuth ``` diff --git a/README_pt.md b/README_pt.md index 060b2c970..a51a040a7 100644 --- a/README_pt.md +++ b/README_pt.md @@ -870,18 +870,18 @@ Cada operação API. // @Security ApiKeyAuth ``` -Faça-o AND condicione-o +Faça-o OR condicione-o ```go // @Security ApiKeyAuth // @Security OAuth2Application[write, admin] ``` -Faça-o OR condição +Faça-o AND condição ```go -// @Security ApiKeyAuth || firebase -// @Security OAuth2Application[write, admin] || APIKeyAuth +// @Security ApiKeyAuth && firebase +// @Security OAuth2Application[write, admin] && APIKeyAuth ``` diff --git a/README_zh-CN.md b/README_zh-CN.md index 24a219c9f..6df3e7764 100644 --- a/README_zh-CN.md +++ b/README_zh-CN.md @@ -732,8 +732,7 @@ type Resp struct { 使用AND条件。 ```go -// @Security ApiKeyAuth -// @Security OAuth2Application[write, admin] +// @Security ApiKeyAuth && OAuth2Application[write, admin] ``` ## 项目相关 diff --git a/operation.go b/operation.go index ba3a05b5f..cbc6ce2cc 100644 --- a/operation.go +++ b/operation.go @@ -50,6 +50,7 @@ var mimeTypeAliases = map[string]string{ } var mimeTypePattern = regexp.MustCompile("^[^/]+/[^/]+$") +var securityPairSepPattern = regexp.MustCompile(`\|\||&&`) // || for compatibility with old version, && for clarity // NewOperation creates a new Operation with default properties. // map[int]Response. @@ -743,7 +744,7 @@ func (operation *Operation) ParseSecurityComment(commentLine string) error { securitySource = commentLine[strings.Index(commentLine, "@Security")+1:] ) - for _, securityOption := range strings.Split(securitySource, "||") { + for _, securityOption := range securityPairSepPattern.Split(securitySource, -1) { securityOption = strings.TrimSpace(securityOption) left, right := strings.Index(securityOption, "["), strings.Index(securityOption, "]") diff --git a/operation_test.go b/operation_test.go index e6bd13e10..0e24d6c9d 100644 --- a/operation_test.go +++ b/operation_test.go @@ -2314,21 +2314,28 @@ func TestParseSecurityCommentSimple(t *testing.T) { }) } -func TestParseSecurityCommentOr(t *testing.T) { +func TestParseSecurityCommentAnd(t *testing.T) { t.Parallel() - comment := `@Security OAuth2Implicit[read, write] || Firebase[]` + comment := `@Security OAuth2Implicit[read, write] && Firebase[]` operation := NewOperation(nil) err := operation.ParseComment(comment, nil) assert.NoError(t, err) - assert.Equal(t, operation.Security, []map[string][]string{ + expect := []map[string][]string{ { "OAuth2Implicit": {"read", "write"}, "Firebase": {""}, }, - }) + } + assert.Equal(t, operation.Security, expect) + + oldVersionComment := `@Security OAuth2Implicit[read, write] || Firebase[]` + operation = NewOperation(nil) + err = operation.ParseComment(oldVersionComment, nil) + assert.NoError(t, err) + assert.Equal(t, operation.Security, expect) } func TestParseMultiDescription(t *testing.T) { diff --git a/parser.go b/parser.go index 9db79fa39..d10003b01 100644 --- a/parser.go +++ b/parser.go @@ -842,7 +842,7 @@ loopline: func parseSecurity(commentLine string) map[string][]string { securityMap := make(map[string][]string) - for _, securityOption := range strings.Split(commentLine, "||") { + for _, securityOption := range securityPairSepPattern.Split(commentLine, -1) { securityOption = strings.TrimSpace(securityOption) left, right := strings.Index(securityOption, "["), strings.Index(securityOption, "]") diff --git a/testdata/global_security/main.go b/testdata/global_security/main.go index 83484bac8..18be6d182 100644 --- a/testdata/global_security/main.go +++ b/testdata/global_security/main.go @@ -14,5 +14,5 @@ package global_security // @scope.write Grants write access // @scope.admin Grants read and write access to administrative information -// @security APIKeyAuth || OAuth2Application +// @security APIKeyAuth && OAuth2Application func main() {}