The decision to use an HTTP proxy for FTP documents belongs in the FTP code

This commit is contained in:
des 2000-07-21 10:46:22 +00:00
parent 2fa9607541
commit c99122fbde
2 changed files with 24 additions and 13 deletions

View File

@ -80,9 +80,6 @@ fetchXGet(struct url *URL, struct url_stat *us, char *flags)
else if (strcasecmp(URL->scheme, "http") == 0)
return fetchXGetHTTP(URL, us, flags);
else if (strcasecmp(URL->scheme, "ftp") == 0) {
if (!direct &&
getenv("FTP_PROXY") == NULL && getenv("HTTP_PROXY") != NULL)
return fetchXGetHTTP(URL, us, flags);
return fetchXGetFTP(URL, us, flags);
} else {
_url_seterr(URL_BAD_SCHEME);
@ -115,9 +112,6 @@ fetchPut(struct url *URL, char *flags)
else if (strcasecmp(URL->scheme, "http") == 0)
return fetchPutHTTP(URL, flags);
else if (strcasecmp(URL->scheme, "ftp") == 0) {
if (!direct &&
getenv("FTP_PROXY") == NULL && getenv("HTTP_PROXY") != NULL)
return fetchPutHTTP(URL, flags);
return fetchPutFTP(URL, flags);
} else {
_url_seterr(URL_BAD_SCHEME);
@ -140,9 +134,6 @@ fetchStat(struct url *URL, struct url_stat *us, char *flags)
else if (strcasecmp(URL->scheme, "http") == 0)
return fetchStatHTTP(URL, us, flags);
else if (strcasecmp(URL->scheme, "ftp") == 0) {
if (!direct &&
getenv("FTP_PROXY") == NULL && getenv("HTTP_PROXY") != NULL)
return fetchStatHTTP(URL, us, flags);
return fetchStatFTP(URL, us, flags);
} else {
_url_seterr(URL_BAD_SCHEME);
@ -165,9 +156,6 @@ fetchList(struct url *URL, char *flags)
else if (strcasecmp(URL->scheme, "http") == 0)
return fetchListHTTP(URL, flags);
else if (strcasecmp(URL->scheme, "ftp") == 0) {
if (!direct &&
getenv("FTP_PROXY") == NULL && getenv("HTTP_PROXY") != NULL)
return fetchListHTTP(URL, flags);
return fetchListFTP(URL, flags);
} else {
_url_seterr(URL_BAD_SCHEME);

View File

@ -594,7 +594,7 @@ _ftp_connect(char *host, int port, char *user, char *pwd, char *flags)
af = AF_INET6;
/* check for proxy */
if (!direct && (p = getenv("FTP_PROXY")) != NULL) {
if (!direct && (p = getenv("FTP_PROXY")) != NULL && *p) {
char c = 0;
#ifdef INET6
@ -762,6 +762,17 @@ _ftp_cached_connect(struct url *url, char *flags)
return cd;
}
/*
* Check to see if we should use an HTTP proxy instead
*/
static int
_ftp_use_http_proxy(void)
{
char *p;
return ((p = getenv("HTTP_PROXY")) && *p && !getenv("FTP_PROXY"));
}
/*
* Get and stat file
*/
@ -769,6 +780,9 @@ FILE *
fetchXGetFTP(struct url *url, struct url_stat *us, char *flags)
{
int cd;
if (_ftp_use_http_proxy())
return fetchXGetHTTP(url, us, flags);
/* connect to server */
if ((cd = _ftp_cached_connect(url, flags)) == NULL)
@ -804,6 +818,9 @@ fetchPutFTP(struct url *url, char *flags)
{
int cd;
if (_ftp_use_http_proxy())
return fetchPutHTTP(url, flags);
/* connect to server */
if ((cd = _ftp_cached_connect(url, flags)) == NULL)
return NULL;
@ -825,6 +842,9 @@ fetchStatFTP(struct url *url, struct url_stat *us, char *flags)
{
int cd;
if (_ftp_use_http_proxy())
return fetchStatHTTP(url, us, flags);
us->size = -1;
us->atime = us->mtime = 0;
@ -847,6 +867,9 @@ extern void warnx(char *, ...);
struct url_ent *
fetchListFTP(struct url *url, char *flags)
{
if (_ftp_use_http_proxy())
return fetchListHTTP(url, flags);
warnx("fetchListFTP(): not implemented");
return NULL;
}