summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sbin/dhclient/dhclient.c52
-rw-r--r--sbin/dhclient/dhcpd.h3
-rw-r--r--sbin/dhclient/kroute.c45
3 files changed, 47 insertions, 53 deletions
diff --git a/sbin/dhclient/dhclient.c b/sbin/dhclient/dhclient.c
index a2189c2f66d..beda16591f4 100644
--- a/sbin/dhclient/dhclient.c
+++ b/sbin/dhclient/dhclient.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: dhclient.c,v 1.412 2017/04/10 21:47:44 krw Exp $ */
+/* $OpenBSD: dhclient.c,v 1.413 2017/04/11 10:40:14 krw Exp $ */
/*
* Copyright 2004 Henning Brauer <henning@openbsd.org>
@@ -2548,34 +2548,6 @@ apply_ignore_list(char *ignore_list)
}
void
-priv_write_file(char *path, int flags, mode_t mode,
- u_int8_t *contents, size_t sz)
-{
- ssize_t n;
- int fd;
-
- fd = open(path, flags, mode);
- if (fd == -1) {
- log_warn("Couldn't open '%s'", path);
- return;
- }
-
- n = write(fd, contents, sz);
- if (n == -1)
- log_warn("Couldn't write contents to '%s'", path);
- else if ((size_t)n < sz)
- log_warnx("Short contents write to '%s' (%zd vs %zu)", path,
- n, sz);
-
- if (fchown(fd, 0, 0) == -1)
- log_warn("fchown(fd, %d, %d) of '%s' failed", 0, 0, path);
- if (fchmod(fd, mode) == -1)
- log_warn("fchmod(fd, 0x%x) of '%s' failed", mode, path);
-
- close(fd);
-}
-
-void
set_lease_times(struct client_lease *lease)
{
time_t cur_time, time_max;
@@ -2742,28 +2714,6 @@ write_resolv_conf(u_int8_t *contents, size_t sz)
flush_unpriv_ibuf("write_resolv_conf");
}
-void
-priv_write_resolv_conf(struct interface_info *ifi, struct imsg *imsg)
-{
- u_int8_t *contents;
- size_t sz;
-
- if (imsg->hdr.len < IMSG_HEADER_SIZE) {
- log_warnx("short IMSG_WRITE_RESOLV_CONF");
- return;
- }
-
- if (!resolv_conf_priority(ifi))
- return;
-
- contents = imsg->data;
- sz = imsg->hdr.len - IMSG_HEADER_SIZE;
-
- priv_write_file("/etc/resolv.conf",
- O_WRONLY | O_CREAT | O_TRUNC,
- S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH, contents, sz);
-}
-
/*
* add_direct_route is the equivalent of
*
diff --git a/sbin/dhclient/dhcpd.h b/sbin/dhclient/dhcpd.h
index 9f905209af5..ea88b3dfdc0 100644
--- a/sbin/dhclient/dhcpd.h
+++ b/sbin/dhclient/dhcpd.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: dhcpd.h,v 1.169 2017/04/08 20:16:04 krw Exp $ */
+/* $OpenBSD: dhcpd.h,v 1.170 2017/04/11 10:40:14 krw Exp $ */
/*
* Copyright (c) 2004 Henning Brauer <henning@openbsd.org>
@@ -172,6 +172,7 @@ struct dhcp_timeout {
void *arg;
};
+#define _PATH_RESOLV_CONF "/etc/resolv.conf"
#define _PATH_DHCLIENT_CONF "/etc/dhclient.conf"
#define _PATH_DHCLIENT_DB "/var/db/dhclient.leases"
diff --git a/sbin/dhclient/kroute.c b/sbin/dhclient/kroute.c
index 5686aea5a99..543f26b9f2d 100644
--- a/sbin/dhclient/kroute.c
+++ b/sbin/dhclient/kroute.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: kroute.c,v 1.88 2017/04/09 20:44:13 krw Exp $ */
+/* $OpenBSD: kroute.c,v 1.89 2017/04/11 10:40:14 krw Exp $ */
/*
* Copyright 2012 Kenneth R Westerback <krw@openbsd.org>
@@ -18,6 +18,7 @@
#include <sys/ioctl.h>
#include <sys/socket.h>
+#include <sys/stat.h>
#include <sys/sysctl.h>
#include <arpa/inet.h>
@@ -30,6 +31,7 @@
#include <netinet/if_ether.h>
#include <errno.h>
+#include <fcntl.h>
#include <ifaddrs.h>
#include <imsg.h>
#include <limits.h>
@@ -531,6 +533,47 @@ priv_cleanup(struct interface_info *ifi, struct imsg_hup *imsg)
priv_delete_address(ifi, &dimsg);
}
+/*
+ * priv_write_resolv_conf writes out a new resolv.conf.
+ */
+void
+priv_write_resolv_conf(struct interface_info *ifi, struct imsg *imsg)
+{
+ u_int8_t *contents;
+ ssize_t n;
+ size_t sz;
+ int fd;
+
+
+ if (imsg->hdr.len < IMSG_HEADER_SIZE) {
+ log_warnx("short IMSG_WRITE_RESOLV_CONF");
+ return;
+ }
+
+ if (!resolv_conf_priority(ifi))
+ return;
+
+ contents = imsg->data;
+ sz = imsg->hdr.len - IMSG_HEADER_SIZE;
+
+ fd = open(_PATH_RESOLV_CONF, O_WRONLY | O_CREAT | O_TRUNC,
+ S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH);
+
+ if (fd == -1) {
+ log_warn("Couldn't open '%s'", _PATH_RESOLV_CONF);
+ return;
+ }
+
+ n = write(fd, contents, sz);
+ if (n == -1)
+ log_warn("Couldn't write contents to '%s'", _PATH_RESOLV_CONF);
+ else if ((size_t)n < sz)
+ log_warnx("Short contents write to '%s' (%zd vs %zu)",
+ _PATH_RESOLV_CONF, n, sz);
+
+ close(fd);
+}
+
int
resolv_conf_priority(struct interface_info *ifi)
{