summaryrefslogtreecommitdiff
path: root/usr.sbin/relayd
diff options
context:
space:
mode:
authorReyk Floeter <reyk@cvs.openbsd.org>2007-03-05 11:44:51 +0000
committerReyk Floeter <reyk@cvs.openbsd.org>2007-03-05 11:44:51 +0000
commit8a43381e1bf18930319a64076564129caff97331 (patch)
tree59e42d1a232243fb44738a248af92c6f5c5f08e8 /usr.sbin/relayd
parent83833f0fbdf6d417b7873fcc64ed85c2aee3a00b (diff)
do not strip the header for expect, hash, and log actions.
since we have a tristate in relay_handle_http(), use nicer return codes defined to make it better readble (no function change).
Diffstat (limited to 'usr.sbin/relayd')
-rw-r--r--usr.sbin/relayd/relay.c28
-rw-r--r--usr.sbin/relayd/relayd.h8
2 files changed, 23 insertions, 13 deletions
diff --git a/usr.sbin/relayd/relay.c b/usr.sbin/relayd/relay.c
index dfdf2982634..30d8f0c5b0f 100644
--- a/usr.sbin/relayd/relay.c
+++ b/usr.sbin/relayd/relay.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: relay.c,v 1.15 2007/03/02 11:32:40 reyk Exp $ */
+/* $OpenBSD: relay.c,v 1.16 2007/03/05 11:44:50 reyk Exp $ */
/*
* Copyright (c) 2006, 2007 Reyk Floeter <reyk@openbsd.org>
@@ -798,11 +798,12 @@ relay_handle_http(struct ctl_relay_event *cre, struct protonode *pn,
{
struct session *con = (struct session *)cre->con;
char buf[READ_BUF_SIZE], *ptr;
+ int ret = PN_DROP;
switch (pn->action) {
case NODE_ACTION_APPEND:
if (!header || ((pn->flags & PNFLAG_MARK) && cre->marked == 0))
- return (1);
+ return (PN_PASS);
ptr = pn->value;
if ((pn->flags & PNFLAG_MACRO) &&
(ptr = relay_expand_http(cre, pn->value,
@@ -822,7 +823,7 @@ relay_handle_http(struct ctl_relay_event *cre, struct protonode *pn,
case NODE_ACTION_CHANGE:
case NODE_ACTION_REMOVE:
if (!header || ((pn->flags & PNFLAG_MARK) && cre->marked == 0))
- return (1);
+ return (PN_PASS);
DPRINTF("relay_handle_http: change/remove '%s: %s'",
pk->key, pk->value);
break;
@@ -834,6 +835,7 @@ relay_handle_http(struct ctl_relay_event *cre, struct protonode *pn,
cre->marked++;
cre->nodes[pn->id] = 1;
}
+ ret = PN_PASS;
break;
case NODE_ACTION_FILTER:
DPRINTF("relay_handle_http: filter '%s: %s'",
@@ -847,19 +849,21 @@ relay_handle_http(struct ctl_relay_event *cre, struct protonode *pn,
break;
case NODE_ACTION_HASH:
if ((pn->flags & PNFLAG_MARK) && cre->marked == 0)
- return (1);
+ return (PN_PASS);
DPRINTF("relay_handle_http: hash '%s: %s'",
pn->key, pk->value);
con->outkey = hash32_str(pk->value, con->outkey);
+ ret = PN_PASS;
break;
case NODE_ACTION_LOG:
if ((pn->flags & PNFLAG_MARK) && cre->marked == 0)
- return (1);
+ return (PN_PASS);
DPRINTF("relay_handle_http: log '%s: %s'",
pn->key, pk->value);
+ ret = PN_PASS;
break;
case NODE_ACTION_NONE:
- return (1);
+ return (PN_PASS);
}
if (pn->flags & PNFLAG_LOG) {
bzero(buf, sizeof(buf));
@@ -869,10 +873,10 @@ relay_handle_http(struct ctl_relay_event *cre, struct protonode *pn,
goto fail;
}
- return (0);
+ return (ret);
fail:
relay_close(con, strerror(errno));
- return (-1);
+ return (PN_FAIL);
}
void
@@ -1150,9 +1154,9 @@ relay_read_http(struct bufferevent *bev, void *arg)
cre->tree, &pkv)) == NULL)
continue;
ret = relay_handle_http(cre, pnv, &pkv, 0);
- if (ret == 1)
+ if (ret == PN_PASS)
continue;
- else if (ret == -1) {
+ else if (ret == PN_FAIL) {
free(url);
free(line);
return;
@@ -1162,10 +1166,10 @@ relay_read_http(struct bufferevent *bev, void *arg)
}
ret = relay_handle_http(cre, pn, &pk, header);
- if (ret == 1)
+ if (ret == PN_PASS)
goto next;
free(line);
- if (ret == -1)
+ if (ret == PN_FAIL)
return;
continue;
diff --git a/usr.sbin/relayd/relayd.h b/usr.sbin/relayd/relayd.h
index a8d2300d973..69c9ce08e1d 100644
--- a/usr.sbin/relayd/relayd.h
+++ b/usr.sbin/relayd/relayd.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: relayd.h,v 1.35 2007/02/27 13:38:58 reyk Exp $ */
+/* $OpenBSD: relayd.h,v 1.36 2007/03/05 11:44:50 reyk Exp $ */
/*
* Copyright (c) 2006, 2007 Pierre-Yves Ritschard <pyr@spootnik.org>
@@ -378,6 +378,12 @@ enum nodetype {
#define PNFLAG_LOOKUP_URL 0x08
#define PNFLAG_LOOKUP_COOKIE 0x10
+enum noderesult {
+ PN_DROP = 0,
+ PN_PASS = 1,
+ PN_FAIL = -1
+};
+
struct protonode {
objid_t id;
char *key;