Merge branch 'stacktic-ipv6'
This commit is contained in:
		
						commit
						aae10f216b
					
				| @ -139,3 +139,23 @@ func TestMultiline(t *testing.T) { | |||||||
| 
 | 
 | ||||||
| 	c.Quit() | 	c.Quit() | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | // antioche.antioche.eu.org with IPv6 | ||||||
|  | func TestConnIPv6(t *testing.T) { | ||||||
|  | 	c, err := Connect("[2001:660:3302:282a:204:75ff:fe9f:9e11]:21") | ||||||
|  | 	if err != nil { | ||||||
|  | 		t.Fatal(err) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	err = c.Login("anonymous", "anonymous") | ||||||
|  | 	if err != nil { | ||||||
|  | 		t.Fatal(err) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	_, err = c.List(".") | ||||||
|  | 	if err != nil { | ||||||
|  | 		t.Error(err) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	c.Quit() | ||||||
|  | } | ||||||
|  | |||||||
							
								
								
									
										22
									
								
								ftp.go
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								ftp.go
									
									
									
									
									
								
							| @ -4,7 +4,6 @@ package ftp | |||||||
| import ( | import ( | ||||||
| 	"bufio" | 	"bufio" | ||||||
| 	"errors" | 	"errors" | ||||||
| 	"fmt" |  | ||||||
| 	"io" | 	"io" | ||||||
| 	"net" | 	"net" | ||||||
| 	"net/textproto" | 	"net/textproto" | ||||||
| @ -67,10 +66,14 @@ func DialTimeout(addr string, timeout time.Duration) (*ServerConn, error) { | |||||||
| 
 | 
 | ||||||
| 	conn := textproto.NewConn(tconn) | 	conn := textproto.NewConn(tconn) | ||||||
| 
 | 
 | ||||||
| 	a := strings.SplitN(addr, ":", 2) | 	host, _, err := net.SplitHostPort(addr) | ||||||
|  | 	if err != nil { | ||||||
|  | 		conn.Close() | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
| 	c := &ServerConn{ | 	c := &ServerConn{ | ||||||
| 		conn:     conn, | 		conn:     conn, | ||||||
| 		host:     a[0], | 		host:     host, | ||||||
| 		timeout:  timeout, | 		timeout:  timeout, | ||||||
| 		features: make(map[string]string), | 		features: make(map[string]string), | ||||||
| 	} | 	} | ||||||
| @ -218,20 +221,19 @@ func (c *ServerConn) openDataConn() (net.Conn, error) { | |||||||
| 	//  else -> PASV | 	//  else -> PASV | ||||||
| 	_, nat6Supported := c.features["nat6"] | 	_, nat6Supported := c.features["nat6"] | ||||||
| 	_, epsvSupported := c.features["EPSV"] | 	_, epsvSupported := c.features["EPSV"] | ||||||
| 	if nat6Supported || epsvSupported { | 
 | ||||||
|  | 	if !nat6Supported && !epsvSupported { | ||||||
|  | 		port, _ = c.pasv() | ||||||
|  | 	} | ||||||
|  | 	if port == 0 { | ||||||
| 		port, err = c.epsv() | 		port, err = c.epsv() | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			return nil, err | 			return nil, err | ||||||
| 		} | 		} | ||||||
| 	} else { |  | ||||||
| 		port, err = c.pasv() |  | ||||||
| 		if err != nil { |  | ||||||
| 			return nil, err |  | ||||||
| 		} |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Build the new net address string | 	// Build the new net address string | ||||||
| 	addr := fmt.Sprintf("%s:%d", c.host, port) | 	addr := net.JoinHostPort(c.host, strconv.Itoa(port)) | ||||||
| 
 | 
 | ||||||
| 	conn, err := net.DialTimeout("tcp", addr, c.timeout) | 	conn, err := net.DialTimeout("tcp", addr, c.timeout) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user