X-Git-Url: http://git.marmaro.de/?a=blobdiff_plain;f=mts%2Fsmtp%2Fhosts.c;h=908e6194d469989546ddb7394cf3644c42974e64;hb=e056446589e2fee53f823e0da1fb34076018c3dd;hp=263bcef374276fcd769fddaf071f2992db845599;hpb=6c42153ad9362cc676ea66563bf400d7511b3b68;p=mmh diff --git a/mts/smtp/hosts.c b/mts/smtp/hosts.c index 263bcef..908e619 100644 --- a/mts/smtp/hosts.c +++ b/mts/smtp/hosts.c @@ -36,8 +36,9 @@ static int init_hs(void); char * OfficialName (char *name) { - char *p, *q, site[BUFSIZ]; - struct hostent *hp; + unsigned char *p; + char *q, site[BUFSIZ]; + struct addrinfo hints, *res; static char buffer[BUFSIZ]; char **r; @@ -48,24 +49,26 @@ OfficialName (char *name) *q = '\0'; q = site; - if (!strcasecmp (LocalName(), site)) + if (!mh_strcasecmp (LocalName(), site)) return LocalName(); -#ifdef HAVE_SETHOSTENT - sethostent (1); -#endif + memset(&hints, 0, sizeof(hints)); + hints.ai_flags = AI_CANONNAME; + hints.ai_family = PF_UNSPEC; - if ((hp = gethostbyname (q))) { - strncpy (buffer, hp->h_name, sizeof(buffer)); + if (getaddrinfo(q, NULL, &hints, &res) == 0) { + strncpy (buffer, res->ai_canonname, sizeof(buffer)); + buffer[sizeof(buffer) - 1] = '\0'; + freeaddrinfo(res); return buffer; } if (hosts.h_name || init_hs ()) { for (h = hosts.h_next; h; h = h->h_next) - if (!strcasecmp (h->h_name, q)) { + if (!mh_strcasecmp (h->h_name, q)) { return h->h_name; } else { for (r = h->h_aliases; *r; r++) - if (!strcasecmp (*r, q)) + if (!mh_strcasecmp (*r, q)) return h->h_name; } } @@ -85,7 +88,8 @@ OfficialName (char *name) static int init_hs (void) { - char *cp, *dp, **q, **r; + unsigned char *cp; + char *dp, **q, **r; char buffer[BUFSIZ], *aliases[NALIASES]; register struct host *h; register FILE *fp;