1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-18 14:17:03 +01:00

dirmngr: Fix http.c for sockaddr_storage.

dirmngr/http.c (use_socks): Use sockaddr_storage.
(my_sock_new_for_addr, connect_server): Likewise.

Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
This commit is contained in:
NIIBE Yutaka 2017-04-13 14:46:57 +09:00
parent 892b33bb2c
commit 86dcb03134

View File

@ -2470,13 +2470,13 @@ start_server ()
* This function is basically a copy of the same internal fucntion in * This function is basically a copy of the same internal fucntion in
* Libassuan. */ * Libassuan. */
static int static int
use_socks (struct sockaddr *addr) use_socks (struct sockaddr_storage *addr)
{ {
int mode; int mode;
if (assuan_sock_get_flag (ASSUAN_INVALID_FD, "tor-mode", &mode) || !mode) if (assuan_sock_get_flag (ASSUAN_INVALID_FD, "tor-mode", &mode) || !mode)
return 0; /* Not in Tor mode. */ return 0; /* Not in Tor mode. */
else if (addr->sa_family == AF_INET6) else if (addr->ss_family == AF_INET6)
{ {
struct sockaddr_in6 *addr_in6 = (struct sockaddr_in6 *)addr; struct sockaddr_in6 *addr_in6 = (struct sockaddr_in6 *)addr;
const unsigned char *s; const unsigned char *s;
@ -2491,7 +2491,7 @@ use_socks (struct sockaddr *addr)
return 0; /* This is the loopback address. */ return 0; /* This is the loopback address. */
} }
else if (addr->sa_family == AF_INET) else if (addr->ss_family == AF_INET)
{ {
struct sockaddr_in *addr_in = (struct sockaddr_in *)addr; struct sockaddr_in *addr_in = (struct sockaddr_in *)addr;
@ -2508,7 +2508,7 @@ use_socks (struct sockaddr *addr)
/* Wrapper around assuan_sock_new which takes the domain from an /* Wrapper around assuan_sock_new which takes the domain from an
* address parameter. */ * address parameter. */
static assuan_fd_t static assuan_fd_t
my_sock_new_for_addr (struct sockaddr *addr, int type, int proto) my_sock_new_for_addr (struct sockaddr_storage *addr, int type, int proto)
{ {
int domain; int domain;
@ -2519,7 +2519,7 @@ my_sock_new_for_addr (struct sockaddr *addr, int type, int proto)
domain = AF_INET; domain = AF_INET;
} }
else else
domain = addr->sa_family; domain = addr->ss_family;
return assuan_sock_new (domain, type, proto); return assuan_sock_new (domain, type, proto);
} }
@ -2644,7 +2644,8 @@ connect_server (const char *server, unsigned short port,
} }
anyhostaddr = 1; anyhostaddr = 1;
if (assuan_sock_connect (sock, ai->addr, ai->addrlen)) if (assuan_sock_connect (sock, (struct sockaddr *)ai->addr,
ai->addrlen))
{ {
last_err = gpg_err_make (default_errsource, last_err = gpg_err_make (default_errsource,
gpg_err_code_from_syserror ()); gpg_err_code_from_syserror ());