mirror of
				https://github.com/caddyserver/caddy.git
				synced 2025-10-24 23:39:19 -04:00 
			
		
		
		
	httpcaddyfile: Improve error on matcher declared outside site block (#3431)
This commit is contained in:
		
							parent
							
								
									fae064262d
								
							
						
					
					
						commit
						cc8fb488d3
					
				| @ -54,6 +54,9 @@ func (st ServerType) Setup(inputServerBlocks []caddyfile.ServerBlock, | ||||
| 	originalServerBlocks := make([]serverBlock, 0, len(inputServerBlocks)) | ||||
| 	for i, sblock := range inputServerBlocks { | ||||
| 		for j, k := range sblock.Keys { | ||||
| 			if j == 0 && strings.HasPrefix(k, "@") { | ||||
| 				return nil, warnings, fmt.Errorf("cannot define a matcher outside of a site block: '%s'", k) | ||||
| 			} | ||||
| 			if _, ok := sbKeys[k]; ok { | ||||
| 				return nil, warnings, fmt.Errorf("duplicate site address not allowed: '%s' in %v (site block %d, key %d)", k, sblock.Keys, i, j) | ||||
| 			} | ||||
|  | ||||
| @ -57,6 +57,15 @@ func TestMatcherSyntax(t *testing.T) { | ||||
| 			expectWarn:  false, | ||||
| 			expectError: false, | ||||
| 		}, | ||||
| 		{ | ||||
| 			input: `@matcher { | ||||
| 				path /matcher-not-allowed/outside-of-site-block/* | ||||
| 			} | ||||
| 			http://localhost | ||||
| 			`, | ||||
| 			expectWarn:  false, | ||||
| 			expectError: true, | ||||
| 		}, | ||||
| 	} { | ||||
| 
 | ||||
| 		adapter := caddyfile.Adapter{ | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user