summaryrefslogtreecommitdiff
path: root/usr.sbin/smtpd/lka.c
diff options
context:
space:
mode:
authorJacek Masiulaniec <jacekm@cvs.openbsd.org>2009-05-19 11:24:25 +0000
committerJacek Masiulaniec <jacekm@cvs.openbsd.org>2009-05-19 11:24:25 +0000
commit6605dde7b156889e10a66d8abc8d4a5e55e400db (patch)
treec91b52ce8d846c48669652cb12baa147db0dd42d /usr.sbin/smtpd/lka.c
parent2d92391cf0aa52d8ad4386b2574fe64618d2178d (diff)
Verify the amount of IMSG payload is exactly as expected; ok gilles@
Diffstat (limited to 'usr.sbin/smtpd/lka.c')
-rw-r--r--usr.sbin/smtpd/lka.c34
1 files changed, 23 insertions, 11 deletions
diff --git a/usr.sbin/smtpd/lka.c b/usr.sbin/smtpd/lka.c
index 10e65eaaed9..2a0ea909437 100644
--- a/usr.sbin/smtpd/lka.c
+++ b/usr.sbin/smtpd/lka.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: lka.c,v 1.46 2009/05/14 15:05:12 eric Exp $ */
+/* $OpenBSD: lka.c,v 1.47 2009/05/19 11:24:24 jacekm Exp $ */
/*
* Copyright (c) 2008 Pierre-Yves Ritschard <pyr@openbsd.org>
@@ -131,11 +131,11 @@ lka_dispatch_parent(int sig, short event, void *p)
switch (imsg.hdr.type) {
case IMSG_PARENT_FORWARD_OPEN: {
int fd;
- struct forward_req *fwreq;
+ struct forward_req *fwreq = imsg.data;
struct lkasession key;
struct lkasession *lkasession;
- fwreq = imsg.data;
+ IMSG_SIZE_CHECK(fwreq);
key.id = fwreq->id;
lkasession = SPLAY_FIND(lkatree, &env->lka_sessions, &key);
@@ -232,9 +232,10 @@ lka_dispatch_mfa(int sig, short event, void *p)
switch (imsg.hdr.type) {
case IMSG_LKA_MAIL: {
- struct submit_status *ss;
+ struct submit_status *ss = imsg.data;
+
+ IMSG_SIZE_CHECK(ss);
- ss = imsg.data;
ss->code = 530;
if (ss->u.path.user[0] == '\0' && ss->u.path.domain[0] == '\0')
@@ -249,13 +250,14 @@ lka_dispatch_mfa(int sig, short event, void *p)
break;
}
case IMSG_LKA_RCPT: {
- struct submit_status *ss;
+ struct submit_status *ss = imsg.data;
struct message message;
struct lkasession *lkasession;
struct forward_req fwreq;
int ret;
- ss = imsg.data;
+ IMSG_SIZE_CHECK(ss);
+
ss->code = 530;
if (IS_RELAY(ss->u.path.rule.r_action)) {
@@ -371,6 +373,8 @@ lka_dispatch_mta(int sig, short event, void *p)
struct secret *query = imsg.data;
char *secret = NULL;
+ IMSG_SIZE_CHECK(query);
+
secret = map_dblookup(env, "secrets", query->host);
log_debug("secret for %s %s", query->host,
@@ -388,9 +392,13 @@ lka_dispatch_mta(int sig, short event, void *p)
}
case IMSG_DNS_A:
- case IMSG_DNS_MX:
- dns_async(env, ibuf, imsg.hdr.type, imsg.data);
+ case IMSG_DNS_MX: {
+ struct dns *query = imsg.data;
+
+ IMSG_SIZE_CHECK(query);
+ dns_async(env, ibuf, imsg.hdr.type, query);
break;
+ }
default:
log_warnx("lka_dispatch_mta: got imsg %d",
@@ -438,9 +446,13 @@ lka_dispatch_smtp(int sig, short event, void *p)
break;
switch (imsg.hdr.type) {
- case IMSG_DNS_PTR:
- dns_async(env, ibuf, IMSG_DNS_PTR, imsg.data);
+ case IMSG_DNS_PTR: {
+ struct dns *query = imsg.data;
+
+ IMSG_SIZE_CHECK(query);
+ dns_async(env, ibuf, IMSG_DNS_PTR, query);
break;
+ }
default:
log_warnx("lka_dispatch_smtp: got imsg %d",
imsg.hdr.type);