Merge pull request #178 from crazy-max/optional-utf8
Make "OPTS UTF8 ON" optional
This commit is contained in:
commit
c2ee4fa250
13
conn_test.go
13
conn_test.go
@ -75,7 +75,7 @@ func (mock *ftpMock) listen(t *testing.T) {
|
|||||||
// At least one command must have a multiline response
|
// At least one command must have a multiline response
|
||||||
switch cmdParts[0] {
|
switch cmdParts[0] {
|
||||||
case "FEAT":
|
case "FEAT":
|
||||||
mock.proto.Writer.PrintfLine("211-Features:\r\n FEAT\r\n PASV\r\n EPSV\r\n SIZE\r\n211 End")
|
mock.proto.Writer.PrintfLine("211-Features:\r\n FEAT\r\n PASV\r\n EPSV\r\n UTF8\r\n SIZE\r\n211 End")
|
||||||
case "USER":
|
case "USER":
|
||||||
if cmdParts[1] == "anonymous" {
|
if cmdParts[1] == "anonymous" {
|
||||||
mock.proto.Writer.PrintfLine("331 Please send your password")
|
mock.proto.Writer.PrintfLine("331 Please send your password")
|
||||||
@ -196,6 +196,15 @@ func (mock *ftpMock) listen(t *testing.T) {
|
|||||||
mock.proto.Writer.PrintfLine("350 Restarting at %s. Send STORE or RETRIEVE to initiate transfer", cmdParts[1])
|
mock.proto.Writer.PrintfLine("350 Restarting at %s. Send STORE or RETRIEVE to initiate transfer", cmdParts[1])
|
||||||
case "NOOP":
|
case "NOOP":
|
||||||
mock.proto.Writer.PrintfLine("200 NOOP ok.")
|
mock.proto.Writer.PrintfLine("200 NOOP ok.")
|
||||||
|
case "OPTS":
|
||||||
|
if len(cmdParts) != 3 {
|
||||||
|
mock.proto.Writer.PrintfLine("500 wrong number of arguments")
|
||||||
|
break
|
||||||
|
}
|
||||||
|
if (strings.Join(cmdParts[1:], " ")) == "UTF8 ON" {
|
||||||
|
mock.proto.Writer.PrintfLine("200 OK, UTF-8 enabled")
|
||||||
|
break
|
||||||
|
}
|
||||||
case "REIN":
|
case "REIN":
|
||||||
mock.proto.Writer.PrintfLine("220 Logged out")
|
mock.proto.Writer.PrintfLine("220 Logged out")
|
||||||
case "QUIT":
|
case "QUIT":
|
||||||
@ -319,7 +328,7 @@ func openConn(t *testing.T, addr string, options ...DialOption) (*ftpMock, *Serv
|
|||||||
|
|
||||||
// Helper to close a client connected to a mock server
|
// Helper to close a client connected to a mock server
|
||||||
func closeConn(t *testing.T, mock *ftpMock, c *ServerConn, commands []string) {
|
func closeConn(t *testing.T, mock *ftpMock, c *ServerConn, commands []string) {
|
||||||
expected := []string{"FEAT", "USER", "PASS", "TYPE"}
|
expected := []string{"FEAT", "USER", "PASS", "TYPE", "OPTS"}
|
||||||
expected = append(expected, commands...)
|
expected = append(expected, commands...)
|
||||||
expected = append(expected, "QUIT")
|
expected = append(expected, "QUIT")
|
||||||
|
|
||||||
|
12
ftp.go
12
ftp.go
@ -53,6 +53,7 @@ type dialOptions struct {
|
|||||||
explicitTLS bool
|
explicitTLS bool
|
||||||
conn net.Conn
|
conn net.Conn
|
||||||
disableEPSV bool
|
disableEPSV bool
|
||||||
|
disableUTF8 bool
|
||||||
location *time.Location
|
location *time.Location
|
||||||
debugOutput io.Writer
|
debugOutput io.Writer
|
||||||
dialFunc func(network, address string) (net.Conn, error)
|
dialFunc func(network, address string) (net.Conn, error)
|
||||||
@ -176,6 +177,13 @@ func DialWithDisabledEPSV(disabled bool) DialOption {
|
|||||||
}}
|
}}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// DialWithDisabledUTF8 returns a DialOption that configures the ServerConn with UTF8 option disabled
|
||||||
|
func DialWithDisabledUTF8(disabled bool) DialOption {
|
||||||
|
return DialOption{func(do *dialOptions) {
|
||||||
|
do.disableUTF8 = disabled
|
||||||
|
}}
|
||||||
|
}
|
||||||
|
|
||||||
// DialWithLocation returns a DialOption that configures the ServerConn with specified time.Location
|
// DialWithLocation returns a DialOption that configures the ServerConn with specified time.Location
|
||||||
// The location is used to parse the dates sent by the server which are in server's timezone
|
// The location is used to parse the dates sent by the server which are in server's timezone
|
||||||
func DialWithLocation(location *time.Location) DialOption {
|
func DialWithLocation(location *time.Location) DialOption {
|
||||||
@ -280,7 +288,9 @@ func (c *ServerConn) Login(user, password string) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Switch to UTF-8
|
// Switch to UTF-8
|
||||||
err = c.setUTF8()
|
if !c.options.disableUTF8 {
|
||||||
|
err = c.setUTF8()
|
||||||
|
}
|
||||||
|
|
||||||
// If using implicit TLS, make data connections also use TLS
|
// If using implicit TLS, make data connections also use TLS
|
||||||
if c.options.tlsConfig != nil {
|
if c.options.tlsConfig != nil {
|
||||||
|
Loading…
Reference in New Issue
Block a user