1999-12-02 02:42:23 -05:00
|
|
|
/* Declarations for host.c
|
2009-09-04 03:13:47 -04:00
|
|
|
Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
|
2012-04-13 17:58:46 -04:00
|
|
|
2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012 Free Software Foundation,
|
2011-01-01 07:19:37 -05:00
|
|
|
Inc.
|
1999-12-02 02:42:23 -05:00
|
|
|
|
2001-05-27 15:35:15 -04:00
|
|
|
This file is part of GNU Wget.
|
1999-12-02 02:42:23 -05:00
|
|
|
|
2001-05-27 15:35:15 -04:00
|
|
|
GNU Wget is free software; you can redistribute it and/or modify
|
1999-12-02 02:42:23 -05:00
|
|
|
it under the terms of the GNU General Public License as published by
|
2007-07-10 01:53:22 -04:00
|
|
|
the Free Software Foundation; either version 3 of the License, or
|
2003-10-29 13:23:56 -05:00
|
|
|
(at your option) any later version.
|
1999-12-02 02:42:23 -05:00
|
|
|
|
2001-05-27 15:35:15 -04:00
|
|
|
GNU Wget is distributed in the hope that it will be useful,
|
1999-12-02 02:42:23 -05:00
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
2007-07-10 01:53:22 -04:00
|
|
|
along with Wget. If not, see <http://www.gnu.org/licenses/>.
|
2002-05-17 22:16:36 -04:00
|
|
|
|
2007-11-28 03:05:33 -05:00
|
|
|
Additional permission under GNU GPL version 3 section 7
|
|
|
|
|
|
|
|
If you modify this program, or any covered work, by linking or
|
|
|
|
combining it with the OpenSSL project's OpenSSL library (or a
|
|
|
|
modified version of that library), containing parts covered by the
|
|
|
|
terms of the OpenSSL or SSLeay licenses, the Free Software Foundation
|
|
|
|
grants you additional permission to convey the resulting work.
|
|
|
|
Corresponding Source for a non-source form of such a combination
|
|
|
|
shall include the source code for the parts of OpenSSL used as well
|
|
|
|
as that of the covered work. */
|
1999-12-02 02:42:23 -05:00
|
|
|
|
|
|
|
#ifndef HOST_H
|
|
|
|
#define HOST_H
|
|
|
|
|
2002-02-19 00:25:42 -05:00
|
|
|
#ifdef WINDOWS
|
2010-05-07 06:28:26 -04:00
|
|
|
# include <winsock2.h>
|
2002-02-19 00:25:42 -05:00
|
|
|
#else
|
2008-04-22 17:48:36 -04:00
|
|
|
# ifdef __VMS
|
|
|
|
# include "vms_ip.h"
|
|
|
|
# else /* def __VMS */
|
|
|
|
# include <netdb.h>
|
|
|
|
# endif /* def __VMS [else] */
|
2002-02-19 00:25:42 -05:00
|
|
|
# include <sys/socket.h>
|
|
|
|
# include <netinet/in.h>
|
|
|
|
#ifndef __BEOS__
|
|
|
|
# include <arpa/inet.h>
|
|
|
|
#endif
|
|
|
|
#endif
|
2002-01-24 00:45:54 -05:00
|
|
|
|
2001-11-21 19:24:28 -05:00
|
|
|
struct url;
|
2001-11-26 00:36:33 -05:00
|
|
|
struct address_list;
|
1999-12-02 02:42:23 -05:00
|
|
|
|
2003-10-29 18:13:25 -05:00
|
|
|
/* This struct defines an IP address, tagged with family type. */
|
|
|
|
|
2002-01-24 00:45:54 -05:00
|
|
|
typedef struct {
|
2005-08-10 09:50:08 -04:00
|
|
|
/* Address family, one of AF_INET or AF_INET6. */
|
|
|
|
int family;
|
2003-10-29 18:13:25 -05:00
|
|
|
|
2005-08-10 09:50:08 -04:00
|
|
|
/* The actual data, in the form of struct in_addr or in6_addr: */
|
2003-10-29 13:23:56 -05:00
|
|
|
union {
|
2014-05-26 05:51:58 -04:00
|
|
|
struct in_addr d4; /* IPv4 address */
|
2003-10-29 13:23:56 -05:00
|
|
|
#ifdef ENABLE_IPV6
|
2014-05-26 05:51:58 -04:00
|
|
|
struct in6_addr d6; /* IPv6 address */
|
2005-08-10 09:50:08 -04:00
|
|
|
#endif
|
|
|
|
} data;
|
2003-11-02 18:48:45 -05:00
|
|
|
|
2005-08-10 09:50:08 -04:00
|
|
|
/* Under IPv6 getaddrinfo also returns scope_id. Since it's
|
|
|
|
IPv6-specific it strictly belongs in the above union, but we put
|
|
|
|
it here for simplicity. */
|
|
|
|
#if defined ENABLE_IPV6 && defined HAVE_SOCKADDR_IN6_SCOPE_ID
|
|
|
|
int ipv6_scope;
|
|
|
|
#endif
|
|
|
|
} ip_address;
|
2002-01-24 00:45:54 -05:00
|
|
|
|
2005-08-10 09:50:08 -04:00
|
|
|
/* IP_INADDR_DATA macro returns a void pointer that can be interpreted
|
|
|
|
as a pointer to struct in_addr in IPv4 context or a pointer to
|
|
|
|
struct in6_addr in IPv4 context. This pointer can be passed to
|
|
|
|
functions that work on either, such as inet_ntop. */
|
|
|
|
#define IP_INADDR_DATA(x) ((void *) &(x)->data)
|
2002-01-24 00:45:54 -05:00
|
|
|
|
2003-11-14 20:49:52 -05:00
|
|
|
enum {
|
|
|
|
LH_SILENT = 1,
|
|
|
|
LH_BIND = 2,
|
|
|
|
LH_REFRESH = 4
|
|
|
|
};
|
2005-06-19 18:34:58 -04:00
|
|
|
struct address_list *lookup_host (const char *, int);
|
|
|
|
|
|
|
|
void address_list_get_bounds (const struct address_list *, int *, int *);
|
|
|
|
const ip_address *address_list_address_at (const struct address_list *, int);
|
2005-06-22 15:38:10 -04:00
|
|
|
bool address_list_contains (const struct address_list *, const ip_address *);
|
2005-06-19 18:34:58 -04:00
|
|
|
void address_list_set_faulty (struct address_list *, int);
|
|
|
|
void address_list_set_connected (struct address_list *);
|
2005-06-22 15:38:10 -04:00
|
|
|
bool address_list_connected_p (const struct address_list *);
|
2005-06-19 18:34:58 -04:00
|
|
|
void address_list_release (struct address_list *);
|
|
|
|
|
2005-06-30 16:03:18 -04:00
|
|
|
const char *print_address (const ip_address *);
|
2005-03-04 14:21:02 -05:00
|
|
|
#ifdef ENABLE_IPV6
|
2005-06-22 15:38:10 -04:00
|
|
|
bool is_valid_ipv6_address (const char *, const char *);
|
2005-03-04 14:21:02 -05:00
|
|
|
#endif
|
2001-11-26 00:36:33 -05:00
|
|
|
|
2012-04-13 17:58:46 -04:00
|
|
|
bool is_valid_ip_address (const char *name);
|
|
|
|
|
2005-06-22 15:38:10 -04:00
|
|
|
bool accept_domain (struct url *);
|
|
|
|
bool sufmatch (const char **, const char *);
|
1999-12-02 02:42:23 -05:00
|
|
|
|
2005-06-19 18:34:58 -04:00
|
|
|
void host_cleanup (void);
|
2002-01-24 00:45:54 -05:00
|
|
|
|
1999-12-02 02:42:23 -05:00
|
|
|
#endif /* HOST_H */
|