summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sbin/dhclient/clparse.c11
-rw-r--r--sbin/dhclient/dhclient.c149
-rw-r--r--sbin/dhclient/dhclient.conf.522
-rw-r--r--sbin/dhclient/dhcpd.h4
-rw-r--r--sbin/dhclient/options.c14
5 files changed, 97 insertions, 103 deletions
diff --git a/sbin/dhclient/clparse.c b/sbin/dhclient/clparse.c
index 9119943c496..877c4330008 100644
--- a/sbin/dhclient/clparse.c
+++ b/sbin/dhclient/clparse.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: clparse.c,v 1.40 2012/08/26 23:33:29 krw Exp $ */
+/* $OpenBSD: clparse.c,v 1.41 2012/10/27 23:08:53 krw Exp $ */
/* Parser for dhclient config and lease files... */
@@ -154,7 +154,8 @@ read_client_leases(void)
void
parse_client_statement(FILE *cfile)
{
- int token, code;
+ u_int8_t ignorelist[256];
+ int token, code, count, i;
switch (next_token(NULL, cfile)) {
case TOK_SEND:
@@ -171,9 +172,9 @@ parse_client_statement(FILE *cfile)
config->default_actions[code] = ACTION_SUPERSEDE;
return;
case TOK_IGNORE:
- code = parse_option_decl(cfile, &config->defaults[0]);
- if (code != -1)
- config->default_actions[code] = ACTION_IGNORE;
+ count = parse_option_list(cfile, ignorelist);
+ for (i = 0; i < count; i++)
+ config->default_actions[ignorelist[i]] = ACTION_IGNORE;
return;
case TOK_APPEND:
code = parse_option_decl(cfile, &config->defaults[0]);
diff --git a/sbin/dhclient/dhclient.c b/sbin/dhclient/dhclient.c
index c1c37ebfd20..9ce6f69e391 100644
--- a/sbin/dhclient/dhclient.c
+++ b/sbin/dhclient/dhclient.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: dhclient.c,v 1.157 2012/10/10 17:44:43 krw Exp $ */
+/* $OpenBSD: dhclient.c,v 1.158 2012/10/27 23:08:53 krw Exp $ */
/*
* Copyright 2004 Henning Brauer <henning@openbsd.org>
@@ -1430,8 +1430,7 @@ write_client_lease(struct client_lease *lease)
if (lease->options[i].len)
fprintf(leaseFile, " option %s %s;\n",
dhcp_options[i].name,
- pretty_print_option(i, lease->options[i].data,
- lease->options[i].len, 1, 1));
+ pretty_print_option(i, &lease->options[i], 1));
t = gmtime(&lease->renewal);
fprintf(leaseFile, " renew %d %d/%d/%d %02d:%02d:%02d;\n",
@@ -1501,9 +1500,9 @@ priv_script_init(char *reason)
void
priv_script_write_params(char *prefix, struct client_lease *lease)
{
- u_int8_t dbuf[1500];
- int i, len = 0;
- char tbuf[128];
+ char buf[256];
+ struct option_data o;
+ int i;
script_set_env(prefix, "ip_address", piaddr(lease->address));
@@ -1535,84 +1534,75 @@ priv_script_write_params(char *prefix, struct client_lease *lease)
if (lease->server_name)
script_set_env(prefix, "server_name",
lease->server_name);
+
for (i = 0; i < 256; i++) {
- u_int8_t *dp = NULL;
-
- if (config->defaults[i].len) {
- if (lease->options[i].len) {
- switch (config->default_actions[i]) {
- case ACTION_IGNORE:
- /* handled below */
- break;
- case ACTION_DEFAULT:
- dp = lease->options[i].data;
- len = lease->options[i].len;
- break;
- case ACTION_SUPERSEDE:
-supersede:
- dp = config->defaults[i].data;
- len = config->defaults[i].len;
- break;
- case ACTION_PREPEND:
- len = config->defaults[i].len +
- lease->options[i].len;
- if (len >= sizeof(dbuf)) {
- warning("no space to %s %s",
- "prepend option",
- dhcp_options[i].name);
- goto supersede;
- }
- dp = dbuf;
- memcpy(dp,
- config->defaults[i].data,
- config->defaults[i].len);
- memcpy(dp +
- config->defaults[i].len,
- lease->options[i].data,
- lease->options[i].len);
- dp[len] = '\0';
- break;
- case ACTION_APPEND:
- len = config->defaults[i].len +
- lease->options[i].len;
- if (len >= sizeof(dbuf)) {
- warning("no space to %s %s",
- "append option",
- dhcp_options[i].name);
- goto supersede;
- }
- dp = dbuf;
- memcpy(dp, lease->options[i].data,
- lease->options[i].len);
- memcpy(dp + lease->options[i].len,
+ if (!dhcp_option_ev_name(buf, sizeof(buf), &dhcp_options[i]))
+ continue;
+
+ switch (config->default_actions[i]) {
+ case ACTION_IGNORE:
+ break;
+
+ case ACTION_DEFAULT:
+ if (lease->options[i].len)
+ script_set_env(prefix, buf,
+ pretty_print_option(i, &lease->options[i],
+ 0));
+ else if (config->defaults[i].len)
+ script_set_env(prefix, buf,
+ pretty_print_option(i, &config->defaults[i],
+ 0));
+ break;
+
+ case ACTION_SUPERSEDE:
+ if (config->defaults[i].len)
+ script_set_env(prefix, buf,
+ pretty_print_option(i, &config->defaults[i],
+ 0));
+ break;
+
+ case ACTION_PREPEND:
+ o.len = config->defaults[i].len + lease->options[i].len;
+ if (o.len > 0) {
+ o.data = calloc(1, o.len);
+ if (o.data == NULL)
+ error("no space to prepend '%s' to %s",
config->defaults[i].data,
- config->defaults[i].len);
- dp[len] = '\0';
- }
- } else {
- dp = config->defaults[i].data;
- len = config->defaults[i].len;
+ dhcp_options[i].name);
+ memcpy(o.data, config->defaults[i].data,
+ config->defaults[i].len);
+ memcpy(o.data + config->defaults[i].len,
+ lease->options[i].data,
+ lease->options[i].len);
+ script_set_env(prefix, buf,
+ pretty_print_option(i, &o, 0));
+ free(o.data);
}
- } else if (lease->options[i].len) {
- len = lease->options[i].len;
- dp = lease->options[i].data;
- } else {
- len = 0;
- }
- if (len && config->default_actions[i] == ACTION_IGNORE) {
- len = 0;
- }
- if (len) {
- char name[256];
+ break;
- if (dhcp_option_ev_name(name, sizeof(name),
- &dhcp_options[i]))
- script_set_env(prefix, name,
- pretty_print_option(i, dp, len, 0, 0));
+ case ACTION_APPEND:
+ o.len = config->defaults[i].len + lease->options[i].len;
+ if (o.len > 0) {
+ o.data = calloc(1, o.len);
+ if (o.data == NULL)
+ error("no space to append '%s' to %s",
+ config->defaults[i].data,
+ dhcp_options[i].name);
+ memcpy(o.data, lease->options[i].data,
+ lease->options[i].len);
+ memcpy(o.data + lease->options[i].len,
+ config->defaults[i].data,
+ config->defaults[i].len);
+ script_set_env(prefix, buf,
+ pretty_print_option(i, &o, 0));
+ free(o.data);
+ }
+ break;
}
}
- snprintf(tbuf, sizeof(tbuf), "%d", (int)lease->expiry);
- script_set_env(prefix, "expiry", tbuf);
+
+ snprintf(buf, sizeof(buf), "%d", (int)lease->expiry);
+ script_set_env(prefix, "expiry", buf);
}
void
@@ -1844,8 +1834,7 @@ check_option(struct client_lease *l, int option)
/* we use this, since this is what gets passed to dhclient-script */
- opbuf = pretty_print_option(option, l->options[option].data,
- l->options[option].len, 0, 0);
+ opbuf = pretty_print_option(option, &l->options[option], 0);
sbuf = option_as_string(option, l->options[option].data,
l->options[option].len);
diff --git a/sbin/dhclient/dhclient.conf.5 b/sbin/dhclient/dhclient.conf.5
index d6da0655414..980b19c7c48 100644
--- a/sbin/dhclient/dhclient.conf.5
+++ b/sbin/dhclient/dhclient.conf.5
@@ -1,4 +1,4 @@
-.\" $OpenBSD: dhclient.conf.5,v 1.23 2012/09/22 20:09:43 jmc Exp $
+.\" $OpenBSD: dhclient.conf.5,v 1.24 2012/10/27 23:08:53 krw Exp $
.\"
.\" Copyright (c) 1997 The Internet Software Consortium.
.\" All rights reserved.
@@ -36,7 +36,7 @@
.\" see ``http://www.isc.org/isc''. To learn more about Vixie
.\" Enterprises, see ``http://www.vix.com''.
.\"
-.Dd $Mdocdate: September 22 2012 $
+.Dd $Mdocdate: October 27 2012 $
.Dt DHCLIENT.CONF 5
.Os
.Sh NAME
@@ -179,6 +179,16 @@ DHCP Options are defined in
.Xr dhcp-options 5 .
.Bl -tag -width Ds
.It Xo
+.Ic ignore Op Ar option
+.Oo , Ar ... option Oc ;
+.Xc
+The
+.Ic ignore
+statement causes the client to discard values provided by the server for
+the specified options.
+Only the option names should be specified in the ignore statement \- not
+option parameters.
+.It Xo
.Ic request Op Ar option
.Oo , Ar ... option Oc ;
.Xc
@@ -244,14 +254,6 @@ in the
.Ic supersede
statement.
.It Xo
-.Ic ignore No { Op Ar option declaration
-.Oo , Ar ... option declaration Oc }
-.Xc
-If for some set of options the client should always ignore the
-value supplied by the server, these values can be defined in the
-.Ic ignore
-statement.
-.It Xo
.Ic prepend No { Op Ar option declaration
.Oo , Ar ... option declaration Oc }
.Xc
diff --git a/sbin/dhclient/dhcpd.h b/sbin/dhclient/dhcpd.h
index d0e7cabce62..3e3450a3202 100644
--- a/sbin/dhclient/dhcpd.h
+++ b/sbin/dhclient/dhcpd.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: dhcpd.h,v 1.81 2012/09/18 09:34:09 krw Exp $ */
+/* $OpenBSD: dhcpd.h,v 1.82 2012/10/27 23:08:53 krw Exp $ */
/*
* Copyright (c) 2004 Henning Brauer <henning@openbsd.org>
@@ -208,7 +208,7 @@ extern struct client_config *config;
/* options.c */
int cons_options(struct option_data *);
-char *pretty_print_option(unsigned int, unsigned char *, int, int, int);
+char *pretty_print_option(unsigned int, struct option_data *, int);
void do_packet(int, unsigned int, struct iaddr, struct hardware *);
/* errwarn.c */
diff --git a/sbin/dhclient/options.c b/sbin/dhclient/options.c
index 6d2eb78c76b..0d635a51486 100644
--- a/sbin/dhclient/options.c
+++ b/sbin/dhclient/options.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: options.c,v 1.41 2012/06/26 14:46:42 krw Exp $ */
+/* $OpenBSD: options.c,v 1.42 2012/10/27 23:08:53 krw Exp $ */
/* DHCP options parsing and reassembly. */
@@ -198,14 +198,16 @@ cons_options(struct option_data *options)
* Format the specified option so that a human can easily read it.
*/
char *
-pretty_print_option(unsigned int code, unsigned char *data, int len,
- int emit_commas, int emit_quotes)
+pretty_print_option(unsigned int code, struct option_data *option,
+ int emit_punct)
{
static char optbuf[32768]; /* XXX */
int hunksize = 0, numhunk = -1, numelem = 0;
char fmtbuf[32], *op = optbuf;
int i, j, k, opleft = sizeof(optbuf);
+ unsigned char *data = option->data;
unsigned char *dp = data;
+ int len = option->len;
struct in_addr foo;
char comma;
@@ -213,7 +215,7 @@ pretty_print_option(unsigned int code, unsigned char *data, int len,
if (code > 255)
error("pretty_print_option: bad code %d", code);
- if (emit_commas)
+ if (emit_punct)
comma = ',';
else
comma = ' ';
@@ -316,7 +318,7 @@ pretty_print_option(unsigned int code, unsigned char *data, int len,
size_t oplen;
switch (fmtbuf[j]) {
case 't':
- if (emit_quotes) {
+ if (emit_punct) {
*op++ = '"';
opleft--;
}
@@ -345,7 +347,7 @@ pretty_print_option(unsigned int code, unsigned char *data, int len,
opleft--;
}
}
- if (emit_quotes) {
+ if (emit_punct) {
*op++ = '"';
opleft--;
}