Implements timeouts.
Added DialTimeout and Dial functions. Fixes issue #27.
This commit is contained in:
parent
5807e676a3
commit
a9410e3e51
@ -4,6 +4,7 @@ import (
|
|||||||
"bytes"
|
"bytes"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"testing"
|
"testing"
|
||||||
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
@ -12,7 +13,7 @@ const (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func TestConn(t *testing.T) {
|
func TestConn(t *testing.T) {
|
||||||
c, err := Connect("localhost:21")
|
c, err := DialTimeout("localhost:21", 5*time.Second)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
@ -112,8 +113,8 @@ func TestConn(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// ftp.mozilla.org uses multiline 220 response
|
// ftp.mozilla.org uses multiline 220 response
|
||||||
func TestConn2(t *testing.T) {
|
func TestMultiline(t *testing.T) {
|
||||||
c, err := Connect("ftp.mozilla.org:21")
|
c, err := DialTimeout("ftp.mozilla.org:21", 5*time.Second)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
22
ftp.go
22
ftp.go
@ -27,6 +27,7 @@ const (
|
|||||||
type ServerConn struct {
|
type ServerConn struct {
|
||||||
conn *textproto.Conn
|
conn *textproto.Conn
|
||||||
host string
|
host string
|
||||||
|
timeout time.Duration
|
||||||
features map[string]string
|
features map[string]string
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -44,20 +45,33 @@ type response struct {
|
|||||||
c *ServerConn
|
c *ServerConn
|
||||||
}
|
}
|
||||||
|
|
||||||
// Connect initializes the connection to the specified ftp server address.
|
// Connect is an alias to Dial, for backward compatibility
|
||||||
|
func Connect(addr string) (*ServerConn, error) {
|
||||||
|
return Dial(addr)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Dial is like DialTimeout with no timeout
|
||||||
|
func Dial(addr string) (*ServerConn, error) {
|
||||||
|
return DialTimeout(addr, 0)
|
||||||
|
}
|
||||||
|
|
||||||
|
// DialTimeout initializes the connection to the specified ftp server address.
|
||||||
//
|
//
|
||||||
// It is generally followed by a call to Login() as most FTP commands require
|
// It is generally followed by a call to Login() as most FTP commands require
|
||||||
// an authenticated user.
|
// an authenticated user.
|
||||||
func Connect(addr string) (*ServerConn, error) {
|
func DialTimeout(addr string, timeout time.Duration) (*ServerConn, error) {
|
||||||
conn, err := textproto.Dial("tcp", addr)
|
tconn, err := net.DialTimeout("tcp", addr, timeout)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
conn := textproto.NewConn(tconn)
|
||||||
|
|
||||||
a := strings.SplitN(addr, ":", 2)
|
a := strings.SplitN(addr, ":", 2)
|
||||||
c := &ServerConn{
|
c := &ServerConn{
|
||||||
conn: conn,
|
conn: conn,
|
||||||
host: a[0],
|
host: a[0],
|
||||||
|
timeout: timeout,
|
||||||
features: make(map[string]string),
|
features: make(map[string]string),
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -219,7 +233,7 @@ func (c *ServerConn) openDataConn() (net.Conn, error) {
|
|||||||
// Build the new net address string
|
// Build the new net address string
|
||||||
addr := fmt.Sprintf("%s:%d", c.host, port)
|
addr := fmt.Sprintf("%s:%d", c.host, port)
|
||||||
|
|
||||||
conn, err := net.Dial("tcp", addr)
|
conn, err := net.DialTimeout("tcp", addr, c.timeout)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user