diff options
-rw-r--r-- | sbin/isakmpd/isakmpd.8 | 14 | ||||
-rw-r--r-- | sbin/isakmpd/ui.c | 42 |
2 files changed, 53 insertions, 3 deletions
diff --git a/sbin/isakmpd/isakmpd.8 b/sbin/isakmpd/isakmpd.8 index ba48b524f0c..82365d2194b 100644 --- a/sbin/isakmpd/isakmpd.8 +++ b/sbin/isakmpd/isakmpd.8 @@ -1,4 +1,4 @@ -.\" $OpenBSD: isakmpd.8,v 1.98 2006/11/29 19:44:50 jmc Exp $ +.\" $OpenBSD: isakmpd.8,v 1.99 2006/11/30 11:24:49 markus Exp $ .\" $EOM: isakmpd.8,v 1.23 2000/05/02 00:30:23 niklas Exp $ .\" .\" Copyright (c) 1998, 1999, 2000, 2001 Niklas Hallqvist. @@ -311,6 +311,14 @@ Available commands are: .Sm on .Xc .It Xo +.Ic C rmv +.Sm off +.Op Ic section +.No : +.Ic tag No = Ic value +.Sm on +.Xc +.It Xo .Ic C rm .Sm off .Op Ic section @@ -355,6 +363,10 @@ unless the value is already in the list. removes a tag in a section. .Sq rms removes an entire section. +.Sq rmv +removes an entry from a list, thus reversing an +.Sq add +operation. .Pp NOTE: Sending .Nm diff --git a/sbin/isakmpd/ui.c b/sbin/isakmpd/ui.c index 40cf43cd847..75a39a8f32a 100644 --- a/sbin/isakmpd/ui.c +++ b/sbin/isakmpd/ui.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ui.c,v 1.51 2006/11/28 09:27:09 markus Exp $ */ +/* $OpenBSD: ui.c,v 1.52 2006/11/30 11:24:49 markus Exp $ */ /* $EOM: ui.c,v 1.43 2000/10/05 09:25:12 niklas Exp $ */ /* @@ -224,7 +224,7 @@ ui_config(char *cmd) struct conf_list_node *vnode; char subcmd[81], section[81], tag[81], value[81], tmp[81]; char *v, *nv; - int trans = 0, items, skip = 0; + int trans = 0, items, skip = 0, ret; FILE *fp; if (sscanf(cmd, "C %80s", subcmd) != 1) @@ -294,6 +294,44 @@ ui_config(char *cmd) (strcasecmp(tag, "Connections") == 0 || strcasecmp(tag, "Passive-connections") == 0)) ui_conn_reinit(); + } else if (strcasecmp(subcmd, "rmv") == 0) { + items = sscanf(cmd, "C %*s [%80[^]]]:%80[^=]=%80s %80s", + section, tag, value, tmp); + if (!(items == 3 || items == 4)) + goto fail; + vlist = conf_get_list(section, tag); + if (vlist) { + nv = v = NULL; + for (vnode = TAILQ_FIRST(&vlist->fields); + vnode; + vnode = TAILQ_NEXT(vnode, link)) { + if (strcmp(vnode->field, value) == 0) + continue; + ret = v ? + asprintf(&nv, "%s,%s", v, vnode->field) : + asprintf(&nv, "%s", vnode->field); + if (v) + free(v); + if (ret == -1) { + log_error("ui_config: malloc() failed"); + if (trans) + conf_end(trans, 0); + return; + } + v = nv; + } + conf_free_list(vlist); + if (nv) { + conf_set(trans, section, tag, nv, 1, 0); + free(nv); + } else { + conf_remove(trans, section, tag); + } + } + if (strcasecmp(section, "Phase 2") == 0 && + (strcasecmp(tag, "Connections") == 0 || + strcasecmp(tag, "Passive-connections") == 0)) + ui_conn_reinit(); } else if (strcasecmp(subcmd, "rm") == 0) { if (sscanf(cmd, "C %*s [%80[^]]]:%80s", section, tag) != 2) goto fail; |