Loading CHANGES +4 −0 Original line number Diff line number Diff line Loading @@ -6,6 +6,10 @@ Changelog Michal Marek (16 Jun 2009) - When doing non-anonymous ftp via http proxies and the password is not provided in the url, add it there (squid needs this). Daniel Stenberg (15 Jun 2009) - Eric Wong's patch: Loading RELEASE-NOTES +1 −0 Original line number Diff line number Diff line Loading @@ -28,6 +28,7 @@ This release includes the following bugfixes: o libcurl-NSS client cert handling segfaults o curl uploading from stdin/pipes now works in non-blocking way so that it continues the downloading even when the read stalls o ftp credentials are added to the url if needed for http proxies This release includes the following known bugs: Loading lib/http.c +36 −22 Original line number Diff line number Diff line Loading @@ -2060,6 +2060,7 @@ CURLcode Curl_http(struct connectdata *conn, bool *done) CURLcode result=CURLE_OK; struct HTTP *http; const char *ppath = data->state.path; bool paste_ftp_userpwd = FALSE; char ftp_typecode[sizeof(";type=?")] = ""; const char *host = conn->host.name; const char *te = ""; /* transfer-encoding */ Loading Loading @@ -2288,9 +2289,9 @@ CURLcode Curl_http(struct connectdata *conn, bool *done) } } ppath = data->change.url; if(checkprefix("ftp://", ppath)) { if (data->set.proxy_transfer_mode) { /* when doing ftp, append ;type=<a|i> if not present */ if(checkprefix("ftp://", ppath) || checkprefix("ftps://", ppath)) { char *p = strstr(ppath, ";type="); if(p && p[6] && p[7] == 0) { switch (Curl_raw_toupper(p[6])) { Loading @@ -2306,6 +2307,8 @@ CURLcode Curl_http(struct connectdata *conn, bool *done) snprintf(ftp_typecode, sizeof(ftp_typecode), ";type=%c", data->set.prefer_ascii ? 'a' : 'i'); } if (conn->bits.user_passwd && !conn->bits.userpwd_in_url) paste_ftp_userpwd = TRUE; } } #endif /* CURL_DISABLE_PROXY */ Loading Loading @@ -2464,10 +2467,23 @@ CURLcode Curl_http(struct connectdata *conn, bool *done) return CURLE_OUT_OF_MEMORY; /* add the main request stuff */ result = add_bufferf(req_buffer, "%s " /* GET/HEAD/POST/PUT */ "%s%s HTTP/%s\r\n" /* path + HTTP version */ /* GET/HEAD/POST/PUT */ result = add_bufferf(req_buffer, "%s ", request); if (result) return result; /* url */ if (paste_ftp_userpwd) result = add_bufferf(req_buffer, "ftp://%s:%s@%s", conn->user, conn->passwd, ppath + sizeof("ftp://") - 1); else result = add_buffer(req_buffer, ppath, strlen(ppath)); if (result) return result; result = add_bufferf(req_buffer, "%s" /* ftp typecode (;type=x) */ " HTTP/%s\r\n" /* HTTP version */ "%s" /* proxyuserpwd */ "%s" /* userpwd */ "%s" /* range */ Loading @@ -2479,8 +2495,6 @@ CURLcode Curl_http(struct connectdata *conn, bool *done) "%s" /* Proxy-Connection */ "%s",/* transfer-encoding */ request, ppath, ftp_typecode, httpstring, conn->allocptr.proxyuserpwd? Loading lib/url.c +1 −0 Original line number Diff line number Diff line Loading @@ -3831,6 +3831,7 @@ static CURLcode parse_url_userpass(struct SessionHandle *data, * set user/passwd, but doing that first adds more cases here :-( */ conn->bits.userpwd_in_url = 1; if(data->set.use_netrc != CURL_NETRC_REQUIRED) { /* We could use the one in the URL */ Loading lib/urldata.h +1 −0 Original line number Diff line number Diff line Loading @@ -625,6 +625,7 @@ struct ConnectBits { EPRT doesn't work we disable it for the forthcoming requests */ bool netrc; /* name+password provided by netrc */ bool userpwd_in_url; /* name+password found in url */ bool done; /* set to FALSE when Curl_do() is called and set to TRUE when Curl_done() is called, to prevent Curl_done() to Loading Loading
CHANGES +4 −0 Original line number Diff line number Diff line Loading @@ -6,6 +6,10 @@ Changelog Michal Marek (16 Jun 2009) - When doing non-anonymous ftp via http proxies and the password is not provided in the url, add it there (squid needs this). Daniel Stenberg (15 Jun 2009) - Eric Wong's patch: Loading
RELEASE-NOTES +1 −0 Original line number Diff line number Diff line Loading @@ -28,6 +28,7 @@ This release includes the following bugfixes: o libcurl-NSS client cert handling segfaults o curl uploading from stdin/pipes now works in non-blocking way so that it continues the downloading even when the read stalls o ftp credentials are added to the url if needed for http proxies This release includes the following known bugs: Loading
lib/http.c +36 −22 Original line number Diff line number Diff line Loading @@ -2060,6 +2060,7 @@ CURLcode Curl_http(struct connectdata *conn, bool *done) CURLcode result=CURLE_OK; struct HTTP *http; const char *ppath = data->state.path; bool paste_ftp_userpwd = FALSE; char ftp_typecode[sizeof(";type=?")] = ""; const char *host = conn->host.name; const char *te = ""; /* transfer-encoding */ Loading Loading @@ -2288,9 +2289,9 @@ CURLcode Curl_http(struct connectdata *conn, bool *done) } } ppath = data->change.url; if(checkprefix("ftp://", ppath)) { if (data->set.proxy_transfer_mode) { /* when doing ftp, append ;type=<a|i> if not present */ if(checkprefix("ftp://", ppath) || checkprefix("ftps://", ppath)) { char *p = strstr(ppath, ";type="); if(p && p[6] && p[7] == 0) { switch (Curl_raw_toupper(p[6])) { Loading @@ -2306,6 +2307,8 @@ CURLcode Curl_http(struct connectdata *conn, bool *done) snprintf(ftp_typecode, sizeof(ftp_typecode), ";type=%c", data->set.prefer_ascii ? 'a' : 'i'); } if (conn->bits.user_passwd && !conn->bits.userpwd_in_url) paste_ftp_userpwd = TRUE; } } #endif /* CURL_DISABLE_PROXY */ Loading Loading @@ -2464,10 +2467,23 @@ CURLcode Curl_http(struct connectdata *conn, bool *done) return CURLE_OUT_OF_MEMORY; /* add the main request stuff */ result = add_bufferf(req_buffer, "%s " /* GET/HEAD/POST/PUT */ "%s%s HTTP/%s\r\n" /* path + HTTP version */ /* GET/HEAD/POST/PUT */ result = add_bufferf(req_buffer, "%s ", request); if (result) return result; /* url */ if (paste_ftp_userpwd) result = add_bufferf(req_buffer, "ftp://%s:%s@%s", conn->user, conn->passwd, ppath + sizeof("ftp://") - 1); else result = add_buffer(req_buffer, ppath, strlen(ppath)); if (result) return result; result = add_bufferf(req_buffer, "%s" /* ftp typecode (;type=x) */ " HTTP/%s\r\n" /* HTTP version */ "%s" /* proxyuserpwd */ "%s" /* userpwd */ "%s" /* range */ Loading @@ -2479,8 +2495,6 @@ CURLcode Curl_http(struct connectdata *conn, bool *done) "%s" /* Proxy-Connection */ "%s",/* transfer-encoding */ request, ppath, ftp_typecode, httpstring, conn->allocptr.proxyuserpwd? Loading
lib/url.c +1 −0 Original line number Diff line number Diff line Loading @@ -3831,6 +3831,7 @@ static CURLcode parse_url_userpass(struct SessionHandle *data, * set user/passwd, but doing that first adds more cases here :-( */ conn->bits.userpwd_in_url = 1; if(data->set.use_netrc != CURL_NETRC_REQUIRED) { /* We could use the one in the URL */ Loading
lib/urldata.h +1 −0 Original line number Diff line number Diff line Loading @@ -625,6 +625,7 @@ struct ConnectBits { EPRT doesn't work we disable it for the forthcoming requests */ bool netrc; /* name+password provided by netrc */ bool userpwd_in_url; /* name+password found in url */ bool done; /* set to FALSE when Curl_do() is called and set to TRUE when Curl_done() is called, to prevent Curl_done() to Loading