From 1f81df2cc26446e1dca006573932ef6927c82915 Mon Sep 17 00:00:00 2001 From: Ken Raeburn Date: Thu, 2 Aug 2001 03:14:07 +0000 Subject: [PATCH] * klist.c: Include k5-int.h and fake-addrinfo.h. (NEED_SOCKETS, FAI_PREFIX, FAI_IMPLEMENTATION): Define macros. (one_addr): Use getnameinfo always. git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@13666 dc483132-0cff-0310-8789-dd5450dbe970 --- src/clients/klist/ChangeLog | 6 +++ src/clients/klist/klist.c | 87 ++++++++++++++++++++++--------------- 2 files changed, 59 insertions(+), 34 deletions(-) diff --git a/src/clients/klist/ChangeLog b/src/clients/klist/ChangeLog index 03608a2ab..e4eedb2ac 100644 --- a/src/clients/klist/ChangeLog +++ b/src/clients/klist/ChangeLog @@ -1,3 +1,9 @@ +2001-08-01 Ken Raeburn + + * klist.c: Include k5-int.h and fake-addrinfo.h. + (NEED_SOCKETS, FAI_PREFIX, FAI_IMPLEMENTATION): Define macros. + (one_addr): Use getnameinfo always. + 2001-07-19 Ken Raeburn * klist.c (one_addr): Pass UNIX address family, not Kerberos diff --git a/src/clients/klist/klist.c b/src/clients/klist/klist.c index 9bae5dda3..331bbbe2d 100644 --- a/src/clients/klist/klist.c +++ b/src/clients/klist/klist.c @@ -649,48 +649,67 @@ show_credential(cred) krb5_free_unparsed_name(kcontext, sname); } +#define NEED_SOCKETS +#include "k5-int.h" /* for ss2sin etc */ +#define FAI_PREFIX klist +#define FAI_IMPLEMENTATION +#include "fake-addrinfo.h" + void one_addr(a) krb5_address *a; { - struct hostent *h = 0; - - if ((a->addrtype == ADDRTYPE_INET && a->length == 4) -#ifdef AF_INET6 - || (a->addrtype == ADDRTYPE_INET6 && a->length == 16) -#endif - ) { - int af = AF_INET; -#ifdef AF_INET6 - if (a->addrtype == ADDRTYPE_INET6) - af = AF_INET6; + struct sockaddr_storage ss; + int err; + char namebuf[NI_MAXHOST]; + + memset (&ss, 0, sizeof (ss)); + + switch (a->addrtype) { + case ADDRTYPE_INET: + if (a->length != 4) { + broken: + printf ("broken address (type %d length %d)", + a->addrtype, a->length); + return; + } + { + struct sockaddr_in *sinp = ss2sin (&ss); + sinp->sin_family = AF_INET; +#ifdef HAVE_SA_LEN + sinp->sin_len = sizeof (struct sockaddr_in); #endif - if (!no_resolve) { - h = gethostbyaddr(a->contents, (int) a->length, af); - if (h) { - printf("%s", h->h_name); - return; - } + memcpy (&sinp->sin_addr, a->contents, 4); } - if (no_resolve || !h) { -#ifdef HAVE_INET_NTOP - char buf[46]; - const char *name = inet_ntop(af, a->contents, buf, sizeof(buf)); - if (name) { - printf ("%s", name); - return; - } -#else - if (a->addrtype == ADDRTYPE_INET) { - printf("%d.%d.%d.%d", a->contents[0], a->contents[1], - a->contents[2], a->contents[3]); - return; - } + break; +#ifdef KRB5_USE_INET6 + case ADDRTYPE_INET6: + if (a->length != 16) + goto broken; + { + struct sockaddr_in6 *sin6p = ss2sin6 (&ss); + sin6p->sin6_family = AF_INET6; +#ifdef HAVE_SA_LEN + sin6p->sin6_len = sizeof (struct sockaddr_in6); #endif - printf("unprintable address (type %d)", a->addrtype); - return; + memcpy (&sin6p->sin6_addr, a->contents, 16); } + break; +#endif + default: + printf ("unknown addrtype %d", a->addrtype); + return; + } + + namebuf[0] = 0; + err = getnameinfo (ss2sa (&ss), socklen (ss2sa (&ss)), + namebuf, sizeof (namebuf), 0, 0, + no_resolve ? NI_NUMERICHOST : 0); + if (err) { + printf ("unprintable address (type %d, error %d %s)", a->addrtype, err, + gai_strerror (err)); + return; } - printf("unknown addr type %d", a->addrtype); + printf ("%s", namebuf); } void -- 2.26.2