mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	Implement webhook branch filter (#7791)
* Fix validate() function to handle errors in embedded anon structs * Implement webhook branch filter See #2025, #3998.
This commit is contained in:
		| @@ -10,11 +10,15 @@ import ( | ||||
| 	"strings" | ||||
|  | ||||
| 	"gitea.com/macaron/binding" | ||||
| 	"github.com/gobwas/glob" | ||||
| ) | ||||
|  | ||||
| const ( | ||||
| 	// ErrGitRefName is git reference name error | ||||
| 	ErrGitRefName = "GitRefNameError" | ||||
|  | ||||
| 	// ErrGlobPattern is returned when glob pattern is invalid | ||||
| 	ErrGlobPattern = "GlobPattern" | ||||
| ) | ||||
|  | ||||
| var ( | ||||
| @@ -28,6 +32,7 @@ var ( | ||||
| func AddBindingRules() { | ||||
| 	addGitRefNameBindingRule() | ||||
| 	addValidURLBindingRule() | ||||
| 	addGlobPatternRule() | ||||
| } | ||||
|  | ||||
| func addGitRefNameBindingRule() { | ||||
| @@ -82,6 +87,26 @@ func addValidURLBindingRule() { | ||||
| 	}) | ||||
| } | ||||
|  | ||||
| func addGlobPatternRule() { | ||||
| 	binding.AddRule(&binding.Rule{ | ||||
| 		IsMatch: func(rule string) bool { | ||||
| 			return rule == "GlobPattern" | ||||
| 		}, | ||||
| 		IsValid: func(errs binding.Errors, name string, val interface{}) (bool, binding.Errors) { | ||||
| 			str := fmt.Sprintf("%v", val) | ||||
|  | ||||
| 			if len(str) != 0 { | ||||
| 				if _, err := glob.Compile(str); err != nil { | ||||
| 					errs.Add([]string{name}, ErrGlobPattern, err.Error()) | ||||
| 					return false, errs | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			return true, errs | ||||
| 		}, | ||||
| 	}) | ||||
| } | ||||
|  | ||||
| func portOnly(hostport string) string { | ||||
| 	colon := strings.IndexByte(hostport, ':') | ||||
| 	if colon == -1 { | ||||
|   | ||||
| @@ -26,8 +26,9 @@ type ( | ||||
| 	} | ||||
|  | ||||
| 	TestForm struct { | ||||
| 		BranchName string `form:"BranchName" binding:"GitRefName"` | ||||
| 		URL        string `form:"ValidUrl" binding:"ValidUrl"` | ||||
| 		BranchName  string `form:"BranchName" binding:"GitRefName"` | ||||
| 		URL         string `form:"ValidUrl" binding:"ValidUrl"` | ||||
| 		GlobPattern string `form:"GlobPattern" binding:"GlobPattern"` | ||||
| 	} | ||||
| ) | ||||
|  | ||||
|   | ||||
							
								
								
									
										62
									
								
								modules/validation/glob_pattern_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								modules/validation/glob_pattern_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,62 @@ | ||||
| // Copyright 2019 The Gitea Authors. All rights reserved. | ||||
| // Use of this source code is governed by a MIT-style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| package validation | ||||
|  | ||||
| import ( | ||||
| 	"testing" | ||||
|  | ||||
| 	"gitea.com/macaron/binding" | ||||
| 	"github.com/gobwas/glob" | ||||
| ) | ||||
|  | ||||
| func getGlobPatternErrorString(pattern string) string { | ||||
| 	// It would be unwise to rely on that glob | ||||
| 	// compilation errors don't ever change. | ||||
| 	if _, err := glob.Compile(pattern); err != nil { | ||||
| 		return err.Error() | ||||
| 	} | ||||
| 	return "" | ||||
| } | ||||
|  | ||||
| var globValidationTestCases = []validationTestCase{ | ||||
| 	{ | ||||
| 		description: "Empty glob pattern", | ||||
| 		data: TestForm{ | ||||
| 			GlobPattern: "", | ||||
| 		}, | ||||
| 		expectedErrors: binding.Errors{}, | ||||
| 	}, | ||||
| 	{ | ||||
| 		description: "Valid glob", | ||||
| 		data: TestForm{ | ||||
| 			GlobPattern: "{master,release*}", | ||||
| 		}, | ||||
| 		expectedErrors: binding.Errors{}, | ||||
| 	}, | ||||
|  | ||||
| 	{ | ||||
| 		description: "Invalid glob", | ||||
| 		data: TestForm{ | ||||
| 			GlobPattern: "[a-", | ||||
| 		}, | ||||
| 		expectedErrors: binding.Errors{ | ||||
| 			binding.Error{ | ||||
| 				FieldNames:     []string{"GlobPattern"}, | ||||
| 				Classification: ErrGlobPattern, | ||||
| 				Message:        getGlobPatternErrorString("[a-"), | ||||
| 			}, | ||||
| 		}, | ||||
| 	}, | ||||
| } | ||||
|  | ||||
| func Test_GlobPatternValidation(t *testing.T) { | ||||
| 	AddBindingRules() | ||||
|  | ||||
| 	for _, testCase := range globValidationTestCases { | ||||
| 		t.Run(testCase.description, func(t *testing.T) { | ||||
| 			performValidationTest(t, testCase) | ||||
| 		}) | ||||
| 	} | ||||
| } | ||||
		Reference in New Issue
	
	Block a user