|
@@ -1529,12 +1529,16 @@ BOOL CFtpControlSocket::Send(CString str)
|
|
|
return TRUE;
|
|
|
}
|
|
|
|
|
|
-int CFtpControlSocket::GetReplyCode()
|
|
|
+int CFtpControlSocket::TryGetReplyCode()
|
|
|
{
|
|
|
if (m_RecvBuffer.empty())
|
|
|
return 0;
|
|
|
CStringA str = m_RecvBuffer.front();
|
|
|
- if ((str == "") || (str[0] < '1') || (str[0] > '9'))
|
|
|
+ if (str == "")
|
|
|
+ {
|
|
|
+ return -1;
|
|
|
+ }
|
|
|
+ else if ((str[0] < '1') || (str[0] > '9'))
|
|
|
{
|
|
|
UnicodeString Error = FMTLOAD(FTP_MALFORMED_RESPONSE, (UnicodeString(str)));
|
|
|
LogMessageRaw(FZ_LOG_WARNING, Error.c_str());
|
|
@@ -1546,6 +1550,18 @@ int CFtpControlSocket::GetReplyCode()
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+int CFtpControlSocket::GetReplyCode()
|
|
|
+{
|
|
|
+ int Result = TryGetReplyCode();
|
|
|
+ if (Result < 0)
|
|
|
+ {
|
|
|
+ UnicodeString Error = FMTLOAD(FTP_MALFORMED_RESPONSE, (UnicodeString()));
|
|
|
+ LogMessageRaw(FZ_LOG_WARNING, Error.c_str());
|
|
|
+ Result = 0;
|
|
|
+ }
|
|
|
+ return Result;
|
|
|
+}
|
|
|
+
|
|
|
void CFtpControlSocket::DoClose(int nError /*=0*/)
|
|
|
{
|
|
|
LogMessage(FZ_LOG_INFO, L"Connection closed");
|
|
@@ -2928,7 +2944,13 @@ void CFtpControlSocket::FileTransfer(t_transferfile *transferfile/*=0*/,BOOL bFi
|
|
|
///////////
|
|
|
//Replies//
|
|
|
///////////
|
|
|
- int code = GetReplyCode();
|
|
|
+ int code = TryGetReplyCode();
|
|
|
+ // We do not always expect a response here, particularly when closing transfer connection (FILETRANSFER_WAITFINISH).
|
|
|
+ // The normalization to 0 is probably not needed.
|
|
|
+ if (code < 0)
|
|
|
+ {
|
|
|
+ code = 0;
|
|
|
+ }
|
|
|
switch(m_Operation.nOpState)
|
|
|
{
|
|
|
case FILETRANSFER_PWD:
|