diff options
Diffstat (limited to 'usr.sbin')
-rw-r--r-- | usr.sbin/smtpd/dns.c | 149 |
1 files changed, 74 insertions, 75 deletions
diff --git a/usr.sbin/smtpd/dns.c b/usr.sbin/smtpd/dns.c index eb2be76d9cf..85e530f0822 100644 --- a/usr.sbin/smtpd/dns.c +++ b/usr.sbin/smtpd/dns.c @@ -1,4 +1,4 @@ -/* $OpenBSD: dns.c,v 1.47 2012/01/11 21:22:26 eric Exp $ */ +/* $OpenBSD: dns.c,v 1.48 2012/04/14 13:31:46 eric Exp $ */ /* * Copyright (c) 2008 Gilles Chehade <gilles@openbsd.org> @@ -126,7 +126,7 @@ dns_query_ptr(struct sockaddr_storage *ss, u_int64_t id) void dns_async(struct imsgev *asker, int type, struct dns *query) { - struct dnssession *dnssession; + struct dnssession *s; if (asr == NULL && (asr = asr_resolver(NULL)) == NULL) { log_warnx("dns_async: cannot create resolver"); @@ -135,7 +135,7 @@ dns_async(struct imsgev *asker, int type, struct dns *query) query->type = type; query->asker = asker; - dnssession = dnssession_init(query); + s = dnssession_init(query); switch (type) { case IMSG_DNS_HOST: @@ -146,32 +146,32 @@ dns_async(struct imsgev *asker, int type, struct dns *query) query->error = DNS_OK; dns_reply(query, IMSG_DNS_HOST); dns_reply(query, IMSG_DNS_HOST_END); - dnssession_destroy(dnssession); + dnssession_destroy(s); return; } - dnssession_mx_insert(dnssession, query->host, 0); + dnssession_mx_insert(s, query->host, 0); stat_increment(STATS_LKA_SESSION_HOST); - dns_asr_dispatch_host(dnssession); + dns_asr_dispatch_host(s); return; case IMSG_DNS_PTR: - dnssession->aq = asr_query_cname(asr, - (struct sockaddr*)&query->ss, query->ss.ss_len); + s->aq = asr_query_cname(asr, (struct sockaddr*)&query->ss, + query->ss.ss_len); stat_increment(STATS_LKA_SESSION_CNAME); - if (dnssession->aq == NULL) { + if (s->aq == NULL) { log_debug("dns_async: asr_query_cname error"); break; } - dns_asr_dispatch_cname(dnssession); + dns_asr_dispatch_cname(s); return; case IMSG_DNS_MX: log_debug("dns: lookup mx \"%s\"", query->host); - dnssession->aq = asr_query_dns(asr, T_MX, C_IN, query->host, 0); + s->aq = asr_query_dns(asr, T_MX, C_IN, query->host, 0); stat_increment(STATS_LKA_SESSION_MX); - if (dnssession->aq == NULL) { + if (s->aq == NULL) { log_debug("dns_async: asr_query_dns error"); break; } - dns_asr_dispatch_mx(dnssession); + dns_asr_dispatch_mx(s); return; default: log_debug("dns_async: bad request"); @@ -179,7 +179,7 @@ dns_async(struct imsgev *asker, int type, struct dns *query) } stat_increment(STATS_LKA_FAILURE); - dnssession_destroy(dnssession); + dnssession_destroy(s); noasr: query->error = DNS_RETRY; dns_reply(query, type != IMSG_DNS_PTR ? IMSG_DNS_HOST_END : type); @@ -192,31 +192,30 @@ dns_reply(struct dns *query, int type) } static void -dns_asr_event_set(struct dnssession *dnssession, struct asr_result *ar) +dns_asr_event_set(struct dnssession *s, struct asr_result *ar) { struct timeval tv = { 0, 0 }; tv.tv_usec = ar->ar_timeout * 1000; - event_set(&dnssession->ev, ar->ar_fd, - ar->ar_cond == ASR_READ ? EV_READ : EV_WRITE, - dns_asr_handler, dnssession); - event_add(&dnssession->ev, &tv); + event_set(&s->ev, ar->ar_fd, + ar->ar_cond == ASR_READ ? EV_READ : EV_WRITE, dns_asr_handler, s); + event_add(&s->ev, &tv); } static void dns_asr_handler(int fd, short event, void *arg) { - struct dnssession *dnssession = arg; + struct dnssession *s = arg; - switch(dnssession->query.type) { + switch(s->query.type) { case IMSG_DNS_HOST: - dns_asr_dispatch_host(dnssession); + dns_asr_dispatch_host(s); break; case IMSG_DNS_PTR: - dns_asr_dispatch_cname(dnssession); + dns_asr_dispatch_cname(s); break; case IMSG_DNS_MX: - dns_asr_dispatch_mx(dnssession); + dns_asr_dispatch_mx(s); break; default: fatalx("bad query type"); @@ -239,9 +238,9 @@ dns_asr_error(int ar_err) } static void -dns_asr_dispatch_mx(struct dnssession *dnssession) +dns_asr_dispatch_mx(struct dnssession *s) { - struct dns *query = &dnssession->query; + struct dns *query = &s->query; struct asr_result ar; struct packed pack; struct header h; @@ -249,15 +248,15 @@ dns_asr_dispatch_mx(struct dnssession *dnssession) struct rr rr; char buf[512]; - if (asr_run(dnssession->aq, &ar) == ASR_COND) { - dns_asr_event_set(dnssession, &ar); + if (asr_run(s->aq, &ar) == ASR_COND) { + dns_asr_event_set(s, &ar); return; } if (ar.ar_err) { query->error = dns_asr_error(ar.ar_err); dns_reply(query, IMSG_DNS_HOST_END); - dnssession_destroy(dnssession); + dnssession_destroy(s); return; } @@ -270,19 +269,19 @@ dns_asr_dispatch_mx(struct dnssession *dnssession) if (RCODE(h.flags) == ERR_NAME) { query->error = DNS_ENONAME; dns_reply(query, IMSG_DNS_HOST_END); - dnssession_destroy(dnssession); + dnssession_destroy(s); return; } if (h.ancount == 0) /* fallback to host if no MX is found. */ - dnssession_mx_insert(dnssession, query->host, 0); + dnssession_mx_insert(s, query->host, 0); for (; h.ancount; h.ancount--) { unpack_rr(&pack, &rr); print_dname(rr.rr.mx.exchange, buf, sizeof(buf)); buf[strlen(buf) - 1] = '\0'; - dnssession_mx_insert(dnssession, buf, rr.rr.mx.preference); + dnssession_mx_insert(s, buf, rr.rr.mx.preference); } free(ar.ar_data); @@ -291,71 +290,71 @@ dns_asr_dispatch_mx(struct dnssession *dnssession) /* Now we have a sorted list of MX to resolve. Simply "turn" this * MX session into a regular host session. */ - dnssession->aq = NULL; - dnssession->query.type = IMSG_DNS_HOST; - dns_asr_dispatch_host(dnssession); + s->aq = NULL; + s->query.type = IMSG_DNS_HOST; + dns_asr_dispatch_host(s); } static void -dns_asr_dispatch_host(struct dnssession *dnssession) +dns_asr_dispatch_host(struct dnssession *s) { - struct dns *query = &dnssession->query; + struct dns *query = &s->query; struct mx *mx; struct asr_result ar; int ret; /* default to notfound, override with retry or ok later */ - if (dnssession->mxcurrent == 0) + if (s->mxcurrent == 0) query->error = DNS_ENOTFOUND; next: /* query all listed hosts in turn */ - while (dnssession->aq == NULL) { - if (dnssession->mxcurrent == dnssession->mxarraysz) { - if (dnssession->mxfound) + while (s->aq == NULL) { + if (s->mxcurrent == s->mxarraysz) { + if (s->mxfound) query->error = DNS_OK; dns_reply(query, IMSG_DNS_HOST_END); - dnssession_destroy(dnssession); + dnssession_destroy(s); return; } - mx = dnssession->mxarray + dnssession->mxcurrent++; - dnssession->aq = asr_query_host(asr, mx->host, AF_UNSPEC); + mx = s->mxarray + s->mxcurrent++; + s->aq = asr_query_host(asr, mx->host, AF_UNSPEC); } - while ((ret = asr_run(dnssession->aq, &ar)) == ASR_YIELD) { + while ((ret = asr_run(s->aq, &ar)) == ASR_YIELD) { free(ar.ar_cname); memcpy(&query->ss, &ar.ar_sa.sa, ar.ar_sa.sa.sa_len); dns_reply(query, IMSG_DNS_HOST); - dnssession->mxfound++; + s->mxfound++; } if (ret == ASR_COND) { - dns_asr_event_set(dnssession, &ar); + dns_asr_event_set(s, &ar); return; } if (dns_asr_error(ar.ar_err) == DNS_RETRY) query->error = DNS_RETRY; - dnssession->aq = NULL; + s->aq = NULL; goto next; } static void -dns_asr_dispatch_cname(struct dnssession *dnssession) +dns_asr_dispatch_cname(struct dnssession *s) { - struct dns *query = &dnssession->query; + struct dns *query = &s->query; struct asr_result ar; - switch (asr_run(dnssession->aq, &ar)) { + switch (asr_run(s->aq, &ar)) { case ASR_COND: - dns_asr_event_set(dnssession, &ar); + dns_asr_event_set(s, &ar); return; case ASR_YIELD: /* Only return the first answer */ query->error = DNS_OK; strlcpy(query->host, ar.ar_cname, sizeof (query->host)); - asr_abort(dnssession->aq); + asr_abort(s->aq); free(ar.ar_cname); break; case ASR_DONE: @@ -363,56 +362,56 @@ dns_asr_dispatch_cname(struct dnssession *dnssession) break; } dns_reply(query, IMSG_DNS_PTR); - dnssession_destroy(dnssession); + dnssession_destroy(s); } static struct dnssession * dnssession_init(struct dns *query) { - struct dnssession *dnssession; + struct dnssession *s; - dnssession = calloc(1, sizeof(struct dnssession)); - if (dnssession == NULL) + s = calloc(1, sizeof(struct dnssession)); + if (s == NULL) fatal("dnssession_init: calloc"); stat_increment(STATS_LKA_SESSION); - dnssession->id = query->id; - dnssession->query = *query; - SPLAY_INSERT(dnstree, &dns_sessions, dnssession); - return dnssession; + s->id = query->id; + s->query = *query; + SPLAY_INSERT(dnstree, &dns_sessions, s); + return (s); } static void -dnssession_destroy(struct dnssession *dnssession) +dnssession_destroy(struct dnssession *s) { stat_decrement(STATS_LKA_SESSION); - SPLAY_REMOVE(dnstree, &dns_sessions, dnssession); - event_del(&dnssession->ev); - free(dnssession); + SPLAY_REMOVE(dnstree, &dns_sessions, s); + event_del(&s->ev); + free(s); } static void -dnssession_mx_insert(struct dnssession *dnssession, const char *host, int prio) +dnssession_mx_insert(struct dnssession *s, const char *host, int prio) { size_t i, j; - for (i = 0; i < dnssession->mxarraysz; i++) - if (prio < dnssession->mxarray[i].prio) + for (i = 0; i < s->mxarraysz; i++) + if (prio < s->mxarray[i].prio) break; if (i == MAX_MX_COUNT) return; - if (dnssession->mxarraysz < MAX_MX_COUNT) - dnssession->mxarraysz++; + if (s->mxarraysz < MAX_MX_COUNT) + s->mxarraysz++; - for (j = dnssession->mxarraysz - 1; j > i; j--) - dnssession->mxarray[j] = dnssession->mxarray[j - 1]; + for (j = s->mxarraysz - 1; j > i; j--) + s->mxarray[j] = s->mxarray[j - 1]; - dnssession->mxarray[i].prio = prio; - strlcpy(dnssession->mxarray[i].host, host, - sizeof (dnssession->mxarray[i].host)); + s->mxarray[i].prio = prio; + strlcpy(s->mxarray[i].host, host, + sizeof (s->mxarray[i].host)); } static int |