1
0
mirror of https://github.com/moparisthebest/curl synced 2024-12-22 08:08:50 -05:00

(FTP) a failed upload does not invalidate the control connection

This commit is contained in:
Daniel Stenberg 2006-09-21 20:52:58 +00:00
parent e7d90e08b9
commit ab798fe5ba
4 changed files with 24 additions and 5 deletions

View File

@ -6,6 +6,12 @@
Changelog Changelog
Daniel (21 September 2006)
- Added test case 531 in an attempt to repeat bug report #1561470
(http://curl.haxx.se/bug/view.cgi?id=1561470) that is said to crash when an
FTP upload fails with the multi interface. It did not, but I made a failed
upload still assume the control connection to be fine.
Daniel (20 September 2006) Daniel (20 September 2006)
- Armel Asselin fixed problems when you gave a proxy URL with user name and - Armel Asselin fixed problems when you gave a proxy URL with user name and
empty password or no password at all. Test case 278 and 279 were added to empty password or no password at all. Test case 278 and 279 were added to

View File

@ -21,6 +21,7 @@ This release includes the following changes:
This release includes the following bugfixes: This release includes the following bugfixes:
o (FTP) a failed upload does not invalidate the control connection
o proxy URL with user name and empty password or no password at all now work o proxy URL with user name and empty password or no password at all now work
o fixed a socket state problem with *multi_socket() o fixed a socket state problem with *multi_socket()
o (HTTP) NTLM hostname fix o (HTTP) NTLM hostname fix

View File

@ -2997,6 +2997,7 @@ CURLcode Curl_ftp_done(struct connectdata *conn, CURLcode status)
case CURLE_FTP_PORT_FAILED: case CURLE_FTP_PORT_FAILED:
case CURLE_FTP_COULDNT_SET_BINARY: case CURLE_FTP_COULDNT_SET_BINARY:
case CURLE_FTP_COULDNT_RETR_FILE: case CURLE_FTP_COULDNT_RETR_FILE:
case CURLE_FTP_COULDNT_STOR_FILE:
case CURLE_FTP_ACCESS_DENIED: case CURLE_FTP_ACCESS_DENIED:
/* the connection stays alive fine even though this happened */ /* the connection stays alive fine even though this happened */
/* fall-through */ /* fall-through */
@ -3351,7 +3352,7 @@ CURLcode Curl_ftp_nextconnect(struct connectdata *conn)
result=Curl_setup_transfer(conn, -1, -1, FALSE, NULL, -1, NULL); result=Curl_setup_transfer(conn, -1, -1, FALSE, NULL, -1, NULL);
/* end of transfer */ /* end of transfer */
DEBUGF(infof(data, "DO-MORE phase ends\n")); DEBUGF(infof(data, "DO-MORE phase ends with %d\n", result));
return result; return result;
} }

View File

@ -512,7 +512,15 @@ CURLMcode curl_multi_remove_handle(CURLM *multi_handle,
if(easy->easy_conn) { if(easy->easy_conn) {
/* Set up the association right */ /* Set up the association right */
easy->easy_conn->data = easy->easy_handle; easy->easy_conn->data = easy->easy_handle;
/* Curl_done() clears the conn->data field to lose the association
between the easy handle and the connection */
Curl_done(&easy->easy_conn, easy->result); Curl_done(&easy->easy_conn, easy->result);
if(easy->easy_conn)
/* the connection is still alive, set back the association to enable
the check below to trigger TRUE */
easy->easy_conn->data = easy->easy_handle;
} }
/* If this easy_handle was the last one in charge for one or more /* If this easy_handle was the last one in charge for one or more
@ -528,8 +536,8 @@ CURLMcode curl_multi_remove_handle(CURLM *multi_handle,
Thus, we need to check for all connections in the shared cache that Thus, we need to check for all connections in the shared cache that
points to this handle and are using PROT_CLOSEACTION. If there's any, points to this handle and are using PROT_CLOSEACTION. If there's any,
we need to add this handle to the list of "easy_handls kept around for we need to add this handle to the list of "easy handles kept around for
nice closure". nice connection closures".
*/ */
if(multi_conn_using(multi, easy->easy_handle)) if(multi_conn_using(multi, easy->easy_handle))
/* There's at least one connection using this handle so we must keep /* There's at least one connection using this handle so we must keep
@ -1011,6 +1019,10 @@ static CURLMcode multi_runsingle(struct Curl_multi *multi,
if(CURLE_OK == easy->result) if(CURLE_OK == easy->result)
easy->result = Curl_readwrite_init(easy->easy_conn); easy->result = Curl_readwrite_init(easy->easy_conn);
else
/* Remove ourselves from the send pipeline */
Curl_removeHandleFromPipeline(easy->easy_handle,
easy->easy_conn->send_pipe);
if(CURLE_OK == easy->result) { if(CURLE_OK == easy->result) {
multistate(easy, CURLM_STATE_DO_DONE); multistate(easy, CURLM_STATE_DO_DONE);
@ -1167,10 +1179,9 @@ static CURLMcode multi_runsingle(struct Curl_multi *multi,
break; break;
case CURLM_STATE_COMPLETED: case CURLM_STATE_COMPLETED:
if (easy->easy_handle->state.cancelled) { if (easy->easy_handle->state.cancelled)
/* Go into the CANCELLED state if we were cancelled */ /* Go into the CANCELLED state if we were cancelled */
multistate(easy, CURLM_STATE_CANCELLED); multistate(easy, CURLM_STATE_CANCELLED);
}
/* this is a completed transfer, it is likely to still be connected */ /* this is a completed transfer, it is likely to still be connected */