From 6aaa275d087100a454ff8bef68f6160ff9995576 Mon Sep 17 00:00:00 2001 From: jlaffaye Date: Tue, 6 Sep 2011 18:27:30 +0200 Subject: [PATCH] Login() is a function on its own. It allows to try multiple logins without closing the connection. Drop the useless ConnectAnonymous. --- client_test.go | 7 ++++++- ftp.go | 27 ++++++++++----------------- 2 files changed, 16 insertions(+), 18 deletions(-) diff --git a/client_test.go b/client_test.go index dedc0b3..63eea08 100644 --- a/client_test.go +++ b/client_test.go @@ -11,7 +11,12 @@ const ( ) func TestConn(t *testing.T) { - c, err := ConnectAnonymous("localhost:21") + c, err := Connect("localhost:21") + if err != nil { + t.Fatal(err) + } + + err = c.Login("anonymous", "anonymous") if err != nil { t.Fatal(err) } diff --git a/ftp.go b/ftp.go index cde29ab..b291595 100644 --- a/ftp.go +++ b/ftp.go @@ -36,13 +36,13 @@ type response struct { } // Connect to a ftp server and returns a ServerConn handler. -func Connect(host, user, password string) (*ServerConn, os.Error) { - conn, err := textproto.Dial("tcp", host) +func Connect(addr string) (*ServerConn, os.Error) { + conn, err := textproto.Dial("tcp", addr) if err != nil { return nil, err } - a := strings.SplitN(host, ":", 2) + a := strings.SplitN(addr, ":", 2) c := &ServerConn{conn, a[0]} _, _, err = c.conn.ReadCodeLine(StatusReady) @@ -51,26 +51,19 @@ func Connect(host, user, password string) (*ServerConn, os.Error) { return nil, err } + return c, nil +} + +func (c *ServerConn) Login(user, password string) os.Error { c.conn.Cmd("USER %s", user) - _, _, err = c.conn.ReadCodeLine(StatusUserOK) + _, _, err := c.conn.ReadCodeLine(StatusUserOK) if err != nil { - c.Quit() - return nil, err + return err } c.conn.Cmd("PASS %s", password) _, _, err = c.conn.ReadCodeLine(StatusLoggedIn) - if err != nil { - c.Quit() - return nil, err - } - - return c, nil -} - -// Like Connect() but with anonymous credentials. -func ConnectAnonymous(host string) (*ServerConn, os.Error) { - return Connect(host, "anonymous", "anonymous") + return err } // Enter extended passive mode