From a69cb0c3ad95ccd945154c6a7a3ee28280789bb5 Mon Sep 17 00:00:00 2001 From: hniksic Date: Thu, 24 Jan 2002 19:34:23 -0800 Subject: [PATCH] [svn] Various IPv6 fixes. Submitted in . --- src/ChangeLog | 13 ++++++++++++- src/connect.c | 45 ++++++++++++++++++++++++++++++++++++--------- src/connect.h | 2 +- src/ftp.h | 2 ++ src/host.c | 16 +++++++++------- src/init.c | 42 +----------------------------------------- src/options.h | 3 +-- 7 files changed, 62 insertions(+), 61 deletions(-) diff --git a/src/ChangeLog b/src/ChangeLog index 115dba6b..e37619fb 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,13 @@ +2002-01-24 Hrvoje Niksic + + * connect.c (resolve_bind_address): New function. + (connect_to_one): Use it. + (bindport): Ditto. + + * init.c: Don't resolve bind-address here. + + * host.c (wget_sockaddr_set_address): Would bug out with ADDR == NULL. + 2002-01-24 Hrvoje Niksic * host.c (lookup_host): Use sizeof(ip4_address) to calculate the @@ -8,7 +18,8 @@ 2002-01-24 Hrvoje Niksic - * source: Integrated IPv6 support by Thomas Lussnig. + * source: Integrated IPv6 support. + Written by Thomas Lussnig . 2002-01-15 Ian Abbott diff --git a/src/connect.c b/src/connect.c index 43ed0083..110f5cef 100644 --- a/src/connect.c +++ b/src/connect.c @@ -1,5 +1,5 @@ /* Establishing and handling network connections. - Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc. + Copyright (C) 1995, 1996, 1997, 2001, 2002 Free Software Foundation, Inc. This file is part of GNU Wget. @@ -48,8 +48,8 @@ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #endif /* HAVE_SYS_SELECT_H */ #include "wget.h" -#include "connect.h" #include "host.h" +#include "connect.h" #ifndef errno extern int errno; @@ -59,6 +59,32 @@ extern int errno; static int msock = -1; static struct sockaddr *addr; +static ip_address bind_address; +static int bind_address_resolved; + +static void +resolve_bind_address (void) +{ + struct address_list *al; + + if (bind_address_resolved || opt.bind_address == NULL) + /* Nothing to do. */ + return; + + al = lookup_host (opt.bind_address, 1); + if (!al) + { + logprintf (LOG_NOTQUIET, + _("Unable to convert `%s' to a bind address. Reverting to ANY.\n"), + opt.bind_address); + return; + } + + address_list_copy_one (al, 0, &bind_address); + address_list_release (al); + bind_address_resolved = 1; +} + /* A kludge, but still better than passing the host name all the way to connect_to_one. */ static const char *connection_host_name; @@ -101,10 +127,13 @@ connect_to_one (ip_address *addr, unsigned short port, int silent) if (sock < 0) goto out; - if (opt.bind_address) + resolve_bind_address (); + if (bind_address_resolved) { /* Bind the client side to the requested address. */ - if (bind (sock, (struct sockaddr *)opt.bind_address, sockaddr_len ())) + wget_sockaddr bsa; + wget_sockaddr_set_address (&bsa, ip_default_family, 0, &bind_address); + if (bind (sock, &bsa.sa, sockaddr_len ())) { close (sock); sock = -1; @@ -218,11 +247,9 @@ bindport (unsigned short *port, int family) (char *)&optval, sizeof (optval)) < 0) return CONSOCKERR; - if (opt.bind_address == NULL) - wget_sockaddr_set_address (&srv, ip_default_family, htons (*port), NULL); - else - srv = *opt.bind_address; - wget_sockaddr_set_port (&srv, *port); + resolve_bind_address (); + wget_sockaddr_set_address (&srv, ip_default_family, htons (*port), + bind_address_resolved ? &bind_address : NULL); if (bind (msock, &srv.sa, sockaddr_len ()) < 0) { CLOSE (msock); diff --git a/src/connect.h b/src/connect.h index 4b637ea0..67bc05b5 100644 --- a/src/connect.h +++ b/src/connect.h @@ -20,7 +20,7 @@ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #ifndef CONNECT_H #define CONNECT_H -struct address_list; +#include "host.h" /* Function declarations */ diff --git a/src/ftp.h b/src/ftp.h index 0da39a36..7e17f29c 100644 --- a/src/ftp.h +++ b/src/ftp.h @@ -23,6 +23,8 @@ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ /* Need it for struct rbuf. */ #include "rbuf.h" +#include "host.h" + /* System types. */ enum stype { diff --git a/src/host.c b/src/host.c index df9655fe..23685f96 100644 --- a/src/host.c +++ b/src/host.c @@ -101,7 +101,7 @@ address_list_get_bounds (struct address_list *al, int *start, int *end) void address_list_copy_one (struct address_list *al, int index, ip_address *ip_store) { - assert (index >= al->faulty && index < al->count && ip_store!=NULL ); + assert (index >= al->faulty && index < al->count); memcpy (ip_store, al->addresses + index, sizeof (ip_address)); } @@ -267,16 +267,18 @@ wget_sockaddr_set_address (wget_sockaddr *sa, { if (ip_family == AF_INET) { - ip4_address addr4; - if (!map_ip_to_ipv4 (addr, &addr4)) - /* should the callers have prevented this? */ - abort (); sa->sin.sin_family = ip_family; sa->sin.sin_port = htons (port); if (addr == NULL) memset (&sa->sin.sin_addr, 0, sizeof(ip4_address)); - else - memcpy (&sa->sin.sin_addr, &addr4, sizeof(ip4_address)); + else + { + ip4_address addr4; + if (!map_ip_to_ipv4 (addr, &addr4)) + /* should the callers have prevented this? */ + abort (); + memcpy (&sa->sin.sin_addr, &addr4, sizeof(ip4_address)); + } return; } #ifdef INET6 diff --git a/src/init.c b/src/init.c index 20bbc6a2..14b5c4b7 100644 --- a/src/init.c +++ b/src/init.c @@ -70,7 +70,6 @@ static int enable_tilde_expansion; #define CMD_DECLARE(func) static int func \ PARAMS ((const char *, const char *, void *)) -CMD_DECLARE (cmd_address); CMD_DECLARE (cmd_boolean); CMD_DECLARE (cmd_bytes); CMD_DECLARE (cmd_directory_vector); @@ -108,7 +107,7 @@ static struct { { "backupconverted", &opt.backup_converted, cmd_boolean }, { "backups", &opt.backups, cmd_number }, { "base", &opt.base_href, cmd_string }, - { "bindaddress", &opt.bind_address, cmd_address }, + { "bindaddress", &opt.bind_address, cmd_string }, { "cache", &opt.allow_cache, cmd_boolean }, { "continue", &opt.always_rest, cmd_boolean }, { "convertlinks", &opt.convert_links, cmd_boolean }, @@ -513,45 +512,6 @@ setval (const char *com, const char *val) static int myatoi PARAMS ((const char *s)); -/* Interpret VAL as an Internet address (a hostname or a dotted-quad - IP address), and write it (in network order) to a malloc-allocated - address. That address gets stored to the memory pointed to by - CLOSURE. COM is ignored, except for error messages. - - #### IMHO it's a mistake to do this kind of work so early in the - process (before any download even started!) opt.bind_address - should simply remember the provided value as a string. Another - function should do the lookup, when needed, and cache the - result. --hniksic */ -static int -cmd_address (const char *com, const char *val, void *closure) -{ - struct address_list *al; - wget_sockaddr sa; - wget_sockaddr **target = (wget_sockaddr **)closure; - - memset (&sa, '\0', sizeof (sa)); - - al = lookup_host (val, 1); - if (!al) - { - fprintf (stderr, _("%s: %s: Cannot convert `%s' to an IP address.\n"), - exec_name, com, val); - return 0; - } - sa.sa.sa_family = ip_default_family; - wget_sockaddr_set_port (&sa, 0); - address_list_copy_one (al, 0, wget_sockaddr_get_addr (&sa)); - address_list_release (al); - - FREE_MAYBE (*target); - - *target = xmalloc (sizeof (sa)); - memcpy (*target, &sa, sizeof (sa)); - - return 1; -} - /* Store the boolean value from VAL to CLOSURE. COM is ignored, except for error messages. */ static int diff --git a/src/options.h b/src/options.h index a07c641e..d3300218 100644 --- a/src/options.h +++ b/src/options.h @@ -19,7 +19,6 @@ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ /* Needed for FDP. */ #include -#include "host.h" struct options { @@ -153,7 +152,7 @@ struct options int page_requisites; /* Whether we need to download all files necessary to display a page properly. */ - wget_sockaddr *bind_address; /* What local IP address to bind to. */ + char *bind_address; /* What local IP address to bind to. */ #ifdef HAVE_SSL char *sslcertfile; /* external client cert to use. */ char *sslcertkey; /* the keyfile for this certificate