From: Ken Raeburn Date: Wed, 14 Mar 2007 01:52:23 +0000 (+0000) Subject: * kadm5_create.c: Include fake-addrinfo.h. X-Git-Tag: krb5-1.7-alpha1~1257 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=f87060d06ed9360385fb143cb54535f600a0cc18;p=krb5.git * kadm5_create.c: Include fake-addrinfo.h. (add_admin_princs): Use getaddrinfo instead of gethostbyname. Report the correct message on getaddrinfo errors, and return EINVAL to caller. ticket: 5257 git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@19226 dc483132-0cff-0310-8789-dd5450dbe970 --- diff --git a/src/kadmin/dbutil/kadm5_create.c b/src/kadmin/dbutil/kadm5_create.c index 878300a6d..ff0d294c5 100644 --- a/src/kadmin/dbutil/kadm5_create.c +++ b/src/kadmin/dbutil/kadm5_create.c @@ -40,6 +40,8 @@ #include #include +#include "fake-addrinfo.h" + #include #include @@ -172,20 +174,33 @@ static int add_admin_princs(void *handle, krb5_context context, char *realm) krb5_error_code ret = 0; char service_name[MAXHOSTNAMELEN + 8]; char localname[MAXHOSTNAMELEN]; - struct hostent *hp; + struct addrinfo *ai, ai_hints; + int gai_error; if (gethostname(localname, MAXHOSTNAMELEN)) { ret = errno; perror("gethostname"); goto clean_and_exit; } - hp = gethostbyname(localname); - if (hp == NULL) { - ret = errno; - perror("gethostbyname"); + memset(&ai_hints, 0, sizeof(ai_hints)); + ai_hints.ai_flags = AI_CANONNAME; + gai_error = getaddrinfo(localname, (char *)NULL, &ai_hints, &ai); + if (gai_error) { + ret = EINVAL; + fprintf(stderr, "getaddrinfo(%s): %s\n", localname, + gai_strerror(gai_error)); + goto clean_and_exit; + } + if (ai->ai_canonname == NULL) { + ret = EINVAL; + fprintf(stderr, + "getaddrinfo(%s): Cannot determine canonical hostname.\n", + localname); + freeaddrinfo(ai); goto clean_and_exit; } - sprintf(service_name, "kadmin/%s", hp->h_name); + sprintf(service_name, "kadmin/%s", ai->ai_canonname); + freeaddrinfo(ai); if ((ret = add_admin_princ(handle, context, service_name, realm,