mirror of
				https://github.com/caddyserver/caddy.git
				synced 2025-10-24 23:39:19 -04:00 
			
		
		
		
	httpcaddyfile: Fix incorrect handling of IPv6 bind addresses (#4532)
The `net.JoinHostPort()` function has some naiive logic for handling IPv6, it just checks if the host part has a `:` and if so it wraps the host part with `[ ]` but this causes our network type prefix to get wrapped as well, which is invalid for `caddy.NetworkAddress`. Instead, we can just concatenate the host and port manually here to avoid this side-effect.
This commit is contained in:
		
							parent
							
								
									1a7a78a1f2
								
							
						
					
					
						commit
						93a7a45e7e
					
				| @ -223,7 +223,7 @@ func (st *ServerType) listenerAddrsForServerBlockKey(sblock serverBlock, key str | ||||
| 		if err == nil && addr.IsUnixNetwork() { | ||||
| 			listeners[host] = struct{}{} | ||||
| 		} else { | ||||
| 			listeners[net.JoinHostPort(host, lnPort)] = struct{}{} | ||||
| 			listeners[host+":"+lnPort] = struct{}{} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										29
									
								
								caddytest/integration/caddyfile_adapt/bind_ipv6.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								caddytest/integration/caddyfile_adapt/bind_ipv6.txt
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,29 @@ | ||||
| example.com { | ||||
| 	bind tcp6/[::] | ||||
| } | ||||
| ---------- | ||||
| { | ||||
| 	"apps": { | ||||
| 		"http": { | ||||
| 			"servers": { | ||||
| 				"srv0": { | ||||
| 					"listen": [ | ||||
| 						"tcp6/[::]:443" | ||||
| 					], | ||||
| 					"routes": [ | ||||
| 						{ | ||||
| 							"match": [ | ||||
| 								{ | ||||
| 									"host": [ | ||||
| 										"example.com" | ||||
| 									] | ||||
| 								} | ||||
| 							], | ||||
| 							"terminal": true | ||||
| 						} | ||||
| 					] | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user