- (djm) OpenBSD CVS Sync

- stevesk@cvs.openbsd.org 2002/09/23 20:46:27
     [canohost.c]
     change get_peer_ipaddr() and get_local_ipaddr() to not return NULL for
     non-sockets; fixes a problem passing NULL to snprintf(). ok markus@
This commit is contained in:
Damien Miller 2002-09-25 12:19:08 +10:00
parent 2c961cecb0
commit b2f844dc51
2 changed files with 21 additions and 12 deletions

View File

@ -1,3 +1,10 @@
20020923
- (djm) OpenBSD CVS Sync
- stevesk@cvs.openbsd.org 2002/09/23 20:46:27
[canohost.c]
change get_peer_ipaddr() and get_local_ipaddr() to not return NULL for
non-sockets; fixes a problem passing NULL to snprintf(). ok markus@
20020923 20020923
- (tim) [configure.ac] s/return/exit/ patch by dtucker@zip.com.au - (tim) [configure.ac] s/return/exit/ patch by dtucker@zip.com.au
@ -696,4 +703,4 @@
save auth method before monitor_reset_key_state(); bugzilla bug #284; save auth method before monitor_reset_key_state(); bugzilla bug #284;
ok provos@ ok provos@
$Id: ChangeLog,v 1.2476 2002/09/23 23:54:10 tim Exp $ $Id: ChangeLog,v 1.2477 2002/09/25 02:19:08 djm Exp $

View File

@ -12,7 +12,7 @@
*/ */
#include "includes.h" #include "includes.h"
RCSID("$OpenBSD: canohost.c,v 1.33 2002/07/09 11:56:27 itojun Exp $"); RCSID("$OpenBSD: canohost.c,v 1.34 2002/09/23 20:46:27 stevesk Exp $");
#include "packet.h" #include "packet.h"
#include "xmalloc.h" #include "xmalloc.h"
@ -218,18 +218,12 @@ get_socket_address(int socket, int remote, int flags)
if (remote) { if (remote) {
if (getpeername(socket, (struct sockaddr *)&addr, &addrlen) if (getpeername(socket, (struct sockaddr *)&addr, &addrlen)
< 0) { < 0)
debug("get_socket_ipaddr: getpeername failed: %.100s",
strerror(errno));
return NULL; return NULL;
}
} else { } else {
if (getsockname(socket, (struct sockaddr *)&addr, &addrlen) if (getsockname(socket, (struct sockaddr *)&addr, &addrlen)
< 0) { < 0)
debug("get_socket_ipaddr: getsockname failed: %.100s",
strerror(errno));
return NULL; return NULL;
}
} }
/* Get the address in ascii. */ /* Get the address in ascii. */
if (getnameinfo((struct sockaddr *)&addr, addrlen, ntop, sizeof(ntop), if (getnameinfo((struct sockaddr *)&addr, addrlen, ntop, sizeof(ntop),
@ -243,13 +237,21 @@ get_socket_address(int socket, int remote, int flags)
char * char *
get_peer_ipaddr(int socket) get_peer_ipaddr(int socket)
{ {
return get_socket_address(socket, 1, NI_NUMERICHOST); char *p;
if ((p = get_socket_address(socket, 1, NI_NUMERICHOST)) != NULL)
return p;
return xstrdup("UNKNOWN");
} }
char * char *
get_local_ipaddr(int socket) get_local_ipaddr(int socket)
{ {
return get_socket_address(socket, 0, NI_NUMERICHOST); char *p;
if ((p = get_socket_address(socket, 0, NI_NUMERICHOST)) != NULL)
return p;
return xstrdup("UNKNOWN");
} }
char * char *