Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.bin/ftp Factor the proxy handling code out.



details:   https://anonhg.NetBSD.org/src/rev/5b43ee7ee9fa
branches:  trunk
changeset: 812444:5b43ee7ee9fa
user:      christos <christos%NetBSD.org@localhost>
date:      Tue Dec 15 21:45:21 2015 +0000

description:
Factor the proxy handling code out.

diffstat:

 usr.bin/ftp/fetch.c |  89 +++++++++++++++++++++++++++++-----------------------
 1 files changed, 49 insertions(+), 40 deletions(-)

diffs (129 lines):

diff -r a0891e097554 -r 5b43ee7ee9fa usr.bin/ftp/fetch.c
--- a/usr.bin/ftp/fetch.c       Tue Dec 15 21:01:27 2015 +0000
+++ b/usr.bin/ftp/fetch.c       Tue Dec 15 21:45:21 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: fetch.c,v 1.211 2015/12/15 21:01:27 christos Exp $     */
+/*     $NetBSD: fetch.c,v 1.212 2015/12/15 21:45:21 christos Exp $     */
 
 /*-
  * Copyright (c) 1997-2015 The NetBSD Foundation, Inc.
@@ -37,7 +37,7 @@
 
 #include <sys/cdefs.h>
 #ifndef lint
-__RCSID("$NetBSD: fetch.c,v 1.211 2015/12/15 21:01:27 christos Exp $");
+__RCSID("$NetBSD: fetch.c,v 1.212 2015/12/15 21:45:21 christos Exp $");
 #endif /* not lint */
 
 /*
@@ -605,6 +605,46 @@
        return isproxy;
 }
 
+static int
+handle_proxy(const char *penv, char **host, char **port, char **puser,
+    char **ppass, url_t *urltype)
+{
+       url_t purltype;
+       char *phost, *ppath;
+       char *pport;
+       in_port_t pportnum;
+
+       if (isipv6addr(*host) && strchr(*host, '%') != NULL) {
+               warnx("Scoped address notation `%s' disallowed via web proxy",
+                   *host);
+               return -1;
+       }
+
+       if (parse_url(penv, "proxy URL", &purltype, puser, ppass, &phost,
+           &pport, &pportnum, &ppath) == -1)
+               return -1;
+
+       if ((!IS_HTTP_TYPE(purltype) && purltype != FTP_URL_T) ||
+           EMPTYSTRING(phost) ||
+           (! EMPTYSTRING(ppath) && strcmp(ppath, "/") != 0)) {
+               warnx("Malformed proxy URL `%s'", penv);
+               FREEPTR(phost);
+               FREEPTR(pport);
+               FREEPTR(ppath);
+               return -1;
+       }
+       FREEPTR(ppath);
+
+       FREEPTR(*host);
+       *host = phost;
+       FREEPTR(*port);
+       *port = pport;
+
+       *urltype = purltype;
+
+       return 0;
+}
+
 /*
  * Retrieve URL, via a proxy if necessary, using HTTP.
  * If proxyenv is set, use that for the proxy, otherwise try ftp_proxy or
@@ -763,10 +803,6 @@
                }
                direction = "retrieved";
                if (! EMPTYSTRING(penv)) {                      /* use proxy */
-                       url_t purltype;
-                       char *phost, *ppath;
-                       char *pport;
-                       in_port_t pportnum;
 
                        isproxy = handle_noproxy(host, portnum);
 
@@ -777,45 +813,18 @@
 
                        if (isproxy) {
                                if (restart_point) {
-                                       warnx("Can't restart via proxy URL `%s'",
+                                       warnx(
+                                           "Can't restart via proxy URL `%s'",
                                            penv);
                                        goto cleanup_fetch_url;
                                }
-                               if (parse_url(penv, "proxy URL", &purltype,
-                                   &puser, &ppass, &phost, &pport, &pportnum,
-                                   &ppath) == -1)
+                               if (handle_proxy(penv, &host, &port,
+                                   &puser, &ppass, &urltype) < 0) {
                                        goto cleanup_fetch_url;
-
-                               if ((!IS_HTTP_TYPE(purltype)
-                                    && purltype != FTP_URL_T) ||
-                                   EMPTYSTRING(phost) ||
-                                   (! EMPTYSTRING(ppath)
-                                    && strcmp(ppath, "/") != 0)) {
-                                       warnx("Malformed proxy URL `%s'", penv);
-                                       FREEPTR(phost);
-                                       FREEPTR(pport);
-                                       FREEPTR(ppath);
-                                       goto cleanup_fetch_url;
+                               } else {
+                                   FREEPTR(path);
+                                   path = ftp_strdup(url);
                                }
-                               if (isipv6addr(host) &&
-                                   strchr(host, '%') != NULL) {
-                                       warnx(
-"Scoped address notation `%s' disallowed via web proxy",
-                                           host);
-                                       FREEPTR(phost);
-                                       FREEPTR(pport);
-                                       FREEPTR(ppath);
-                                       goto cleanup_fetch_url;
-                               }
-
-                               FREEPTR(host);
-                               host = phost;
-                               FREEPTR(port);
-                               port = pport;
-                               FREEPTR(path);
-                               path = ftp_strdup(url);
-                               FREEPTR(ppath);
-                               urltype = purltype;
                        }
                } /* ! EMPTYSTRING(penv) */
 



Home | Main Index | Thread Index | Old Index