From 38b1d9675012815e2c19719ba6ce46c057bb0662 Mon Sep 17 00:00:00 2001 From: Daniel Stenberg Date: Tue, 19 Oct 2004 18:26:35 +0000 Subject: [PATCH] Alexander Krasnostavsky made it possible to make FTP 3rd party transfers with both source and destination being the same host. It can be useful if you want to move a file on a server or similar. --- CHANGES | 4 ++++ lib/transfer.c | 11 +++++++++++ 2 files changed, 15 insertions(+) diff --git a/CHANGES b/CHANGES index 97e4d338f..ebb6a2361 100644 --- a/CHANGES +++ b/CHANGES @@ -7,6 +7,10 @@ Changelog Daniel (19 October 2004) +- Alexander Krasnostavsky made it possible to make FTP 3rd party transfers + with both source and destination being the same host. It can be useful if + you want to move a file on a server or similar. + - Guillaume Arluison added CURLINFO_NUM_CONNECTS to allow an app to figure out how many new connects a previous transfer required. diff --git a/lib/transfer.c b/lib/transfer.c index 935e2cb8e..14512a774 100644 --- a/lib/transfer.c +++ b/lib/transfer.c @@ -2189,6 +2189,7 @@ CURLcode Curl_pretransfersec(struct connectdata *conn) CURLcode status = CURLE_OK; struct SessionHandle *data = conn->data; struct connectdata *sec_conn = NULL; /* secondary connection */ + bool reuse_fresh_tmp = data->set.reuse_fresh; /* update data with source host options */ char *url = aprintf( "%s://%s/", conn->protostr, data->set.source_host); @@ -2204,12 +2205,22 @@ CURLcode Curl_pretransfersec(struct connectdata *conn) data->set.ftpport = data->set.source_port; data->set.userpwd = data->set.source_userpwd; + /* if both remote hosts are the same host - create new connection */ + if (strequal(conn->host.dispname, data->set.source_host)) + /* NOTE: this is restored back to the original value after the connect is + done */ + data->set.reuse_fresh = TRUE; + /* secondary connection */ status = Curl_connect_host(data, &sec_conn); if(CURLE_OK == status) { + sec_conn->sec_conn = NULL; /* important if re-using existing connection + to prevent loop */ sec_conn->data = data; conn->sec_conn = sec_conn; } + data->set.reuse_fresh = reuse_fresh_tmp; + return status; }