From 2f3cc90b0f0ad6e9904f7a2be7557ef7fef7dbef Mon Sep 17 00:00:00 2001 From: Jonathan Gray Date: Mon, 25 Sep 2006 10:18:40 +0000 Subject: Support some additional HTTP redirect codes. "looks good" pedro, fgsch, ok otto --- usr.bin/ftp/fetch.c | 27 +++++++++++++++++++++------ 1 file changed, 21 insertions(+), 6 deletions(-) diff --git a/usr.bin/ftp/fetch.c b/usr.bin/ftp/fetch.c index 6d70999605c..bcbb929ec59 100644 --- a/usr.bin/ftp/fetch.c +++ b/usr.bin/ftp/fetch.c @@ -1,4 +1,4 @@ -/* $OpenBSD: fetch.c,v 1.68 2006/07/07 12:00:25 ray Exp $ */ +/* $OpenBSD: fetch.c,v 1.69 2006/09/25 10:18:39 jsg Exp $ */ /* $NetBSD: fetch.c,v 1.14 1997/08/18 10:20:20 lukem Exp $ */ /*- @@ -38,7 +38,7 @@ */ #if !defined(lint) && !defined(SMALL) -static const char rcsid[] = "$OpenBSD: fetch.c,v 1.68 2006/07/07 12:00:25 ray Exp $"; +static const char rcsid[] = "$OpenBSD: fetch.c,v 1.69 2006/09/25 10:18:39 jsg Exp $"; #endif /* not lint and not SMALL */ /* @@ -118,7 +118,7 @@ static int redirect_loop; static int url_get(const char *origline, const char *proxyenv, const char *outfile) { - char pbuf[NI_MAXSERV], hbuf[NI_MAXHOST], *cp, *portnum, *path; + char pbuf[NI_MAXSERV], hbuf[NI_MAXHOST], *cp, *portnum, *path, ststr[4]; char *hosttail, *cause = "unknown", *newline, *host, *port, *buf = NULL; int error, i, isftpurl = 0, isfileurl = 0, isredirect = 0, rval = -1; struct addrinfo hints, *res0, *res; @@ -132,7 +132,7 @@ url_get(const char *origline, const char *proxyenv, const char *outfile) size_t len, wlen; #ifndef SMALL char *sslpath = NULL, *sslhost = NULL; - int ishttpsurl = 0; + int ishttpsurl = 0, status; SSL_CTX *ssl_ctx = NULL; #endif SSL *ssl = NULL; @@ -486,13 +486,28 @@ again: goto improper; else cp++; - if (strncmp(cp, "301", 3) == 0 || strncmp(cp, "302", 3) == 0) { + + strlcpy(ststr, cp, sizeof(ststr)); + status = strtonum(ststr, 200, 307, &errstr); + if (errstr) { + warnx("Error retrieving file: %s", cp); + goto cleanup_url_get; + } + + switch (status) { + case 200: /* OK */ + break; + case 301: /* Moved Permanently */ + case 302: /* Found */ + case 303: /* See Other */ + case 307: /* Temporary Redirect */ isredirect++; if (redirect_loop++ > 10) { warnx("Too many redirections requested"); goto cleanup_url_get; } - } else if (strncmp(cp, "200", 3)) { + break; + default: warnx("Error retrieving file: %s", cp); goto cleanup_url_get; } -- cgit v1.2.3