summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoy Marples <uberlord@gentoo.org>2005-07-14 16:23:18 +0000
committerRoy Marples <uberlord@gentoo.org>2005-07-14 16:23:18 +0000
commit3dfb869e011396edbb654b1b6d52ef427797eaef (patch)
treebc621a6370224badb3316a8fbeee34b204b61b93 /net-misc/pump/files
parentFix bug 98836. (diff)
downloadgentoo-2-3dfb869e011396edbb654b1b6d52ef427797eaef.tar.gz
gentoo-2-3dfb869e011396edbb654b1b6d52ef427797eaef.tar.bz2
gentoo-2-3dfb869e011396edbb654b1b6d52ef427797eaef.zip
Integrated Debians pump patchset which fixes a few things.
(Portage version: 2.0.51.22-r1)
Diffstat (limited to 'net-misc/pump/files')
-rw-r--r--net-misc/pump/files/digest-pump-0.8.21-r5 (renamed from net-misc/pump/files/digest-pump-0.8.21-r4)1
-rw-r--r--net-misc/pump/files/pump-0.8.21-gentoo.diff1082
2 files changed, 600 insertions, 483 deletions
diff --git a/net-misc/pump/files/digest-pump-0.8.21-r4 b/net-misc/pump/files/digest-pump-0.8.21-r5
index 10bcdfd4bbd9..0a9f7d804d9f 100644
--- a/net-misc/pump/files/digest-pump-0.8.21-r4
+++ b/net-misc/pump/files/digest-pump-0.8.21-r5
@@ -1 +1,2 @@
MD5 a6925de6cd011605237934a907f8a9c4 pump_0.8.21.orig.tar.gz 79289
+MD5 22e1a2a142117fe41781e5437a03fcdb pump_0.8.21-2.diff.gz 22259
diff --git a/net-misc/pump/files/pump-0.8.21-gentoo.diff b/net-misc/pump/files/pump-0.8.21-gentoo.diff
index 920c6608667a..84999e9af31c 100644
--- a/net-misc/pump/files/pump-0.8.21-gentoo.diff
+++ b/net-misc/pump/files/pump-0.8.21-gentoo.diff
@@ -1,124 +1,108 @@
---- config.c 2002-06-18 18:03:59.000000000 +0100
-+++ config.c 2005-07-13 10:23:35.000000000 +0100
-@@ -200,6 +200,12 @@
- return 1;
- }
- override->flags |= OVERRIDE_FLAG_NONISDOMAIN;
+diff -r -U 0 pump-0.8.21/config.c pump-0.8.21-r5/config.c
+--- pump-0.8.21/config.c 2005-07-14 15:18:08.000000000 +0100
++++ pump-0.8.21-r5/config.c 2005-07-14 15:13:49.000000000 +0100
+@@ -158 +158,18 @@
+- } else if (!strcmp(start, "domainsearch")) {
++ } else if (!strcmp(start, "routemetric")) {
++ poptParseArgvString(rest, &argc, &argv);
++
++ if (argc != 1) {
++ parseError(*lineNum, "routemetric directive expects a "
++ "single argument");
++ return 1;
++ }
++
++ num = strtol(argv[0], &chptr, 0);
++ if (*chptr) {
++ parseError(*lineNum, "routemetric requires a numeric "
++ "argument");
++ return 1;
++ }
++
++ override->routeMetric = num;
++ } else if (!strcmp(start, "etcdir")) {
+@@ -161,3 +178,11 @@
+- if (overrideList != override) {
+- parseError(*lineNum, "domainsearch directive may not occur "
+- "inside of device specification");
++ poptParseArgvString(rest, &argc, &argv);
++
++ if (argc != 1) {
++ parseError(*lineNum, "etcdir directive expects a "
++ "single argument");
++ return 1;
++ }
++
++ len = strlen(argv[0]);
++ if (len >= sizeof(override->etcDir)) {
++ parseError(*lineNum, "etcdir directive is too long");
+@@ -166,0 +192,10 @@
++ /*
++ We don't free this as other configurations may have inherited
++ it. This could be the wrong decision, but leak would be tiny
++ so why worry?
++ */
++ memcpy(override->etcDir, argv[0], len + 1);
++ free(argv);
++ } else if (!strcmp(start, "domainsearch")) {
++ size_t len;
++
+@@ -211,0 +247,6 @@
+ } else if (!strcmp(start, "nontp")) {
+ if (*rest) {
-+ parseError(*lineNum, "unexpected argument to nonisdomain directive");
++ parseError(*lineNum, "unexpected argument to nontp directive");
+ return 1;
+ }
+ override->flags |= OVERRIDE_FLAG_NONTP;
- } else if (!strcmp(start, "script")) {
- if (overrideList != override) {
- parseError(*lineNum, "script directive may not occur "
---- dhcp.c 2004-09-21 16:19:06.000000000 +0100
-+++ dhcp.c 2005-07-13 10:14:12.000000000 +0100
-@@ -203,13 +203,62 @@
- return err;
- }
-
--
- char * pumpDisableInterface(char * device) {
+@@ -222,6 +262,0 @@
+- } else if (!strcmp(start, "noresolvconf")) {
+- if (*rest) {
+- parseError(*lineNum, "unexpected argument to noresolvconf directive");
+- return 1;
+- }
+- override->flags |= OVERRIDE_FLAG_NORESOLVCONF;
+@@ -231,6 +265,0 @@
+- if (overrideList != override) {
+- parseError(*lineNum, "script directive may not occur "
+- "inside of device specification");
+- return 1;
+- }
+-
+Only in pump-0.8.21: debian
+diff -r -U 0 pump-0.8.21/dhcp.c pump-0.8.21-r5/dhcp.c
+--- pump-0.8.21/dhcp.c 2005-07-14 15:18:08.000000000 +0100
++++ pump-0.8.21-r5/dhcp.c 2005-07-14 11:58:49.000000000 +0100
+@@ -205,0 +206 @@
+ struct sockaddr_in * addrp;
- struct ifreq req;
- int s;
-+ struct rtentry route;
-+
-+ /* Instead of downing the interface, we erase the addresses
-+ * This is important as other daemons such as ifplugd and/or
-+ * wpa_supplicant may be using it */
-
- s = socket(AF_INET, SOCK_DGRAM, 0);
+@@ -212,2 +212,0 @@
-
-+
+- memset(&req,0,sizeof(req));
+@@ -214,0 +214 @@
+ memset(&req,0,sizeof(req));
+@@ -215,0 +216,14 @@
++
+ addrp = (struct sockaddr_in *) &req.ifr_addr;
+ addrp->sin_family = AF_INET;
-+ strcpy(req.ifr_name, device);
-+
-+ while(! ioctl(s, SIOCGIFADDR, &req)) {
-+ addrp->sin_addr.s_addr = 0;
-+ if (ioctl(s, SIOCSIFADDR, &req)) {
-+ close(s);
-+ return perrorstr("SIOCSIFADDR");
-+ }
++ addrp->sin_addr.s_addr = 0;
++ if (ioctl(s, SIOCSIFADDR, &req)) {
++ close(s);
++ return perrorstr("SIOCSIFADDR");
+ }
-+
-+ /* Delete the broadcast route that we may have added earlier */
-+ memset(&route, 0, sizeof(route));
-+ memcpy(&route.rt_gateway, addrp, sizeof(*addrp));
-+
-+ addrp->sin_family = AF_INET;
-+ addrp->sin_port = 0;
-+ addrp->sin_addr.s_addr = INADDR_ANY;
-+ memcpy(&route.rt_dst, addrp, sizeof(*addrp));
-+ memcpy(&route.rt_genmask, addrp, sizeof(*addrp));
-+
-+ route.rt_dev = device;
-+ route.rt_flags = RTF_UP;
-+ route.rt_metric = 0;
+
-+ if (ioctl(s, SIOCDELRT, &route)) {
-+ if (errno != EEXIST) {
-+ close(s);
-+ return perrorstr("SIOCADDRT 3");
-+ }
++ if (intf->override.flags & OVERRIDE_FLAG_KEEPUP) {
++ close(s);
++ return NULL;
+ }
+
-+ close(s);
-+ return NULL;
-+}
-+
-+char * pumpDownInterface(char * device) {
-+ struct ifreq req;
-+ int s;
-+
-+ s = socket(AF_INET, SOCK_DGRAM, 0);
-+
- memset(&req,0,sizeof(req));
-
- strcpy(req.ifr_name, device);
-@@ -229,17 +278,18 @@
- return NULL;
- }
-
--char * pumpSetupInterface(struct pumpNetIntf * intf) {
-+char * pumpSetupInterface(struct pumpNetIntf * intf, int metric) {
- char * rc;
- struct sockaddr_in * addrp;
- struct ifreq req;
- struct rtentry route;
- int s;
-
-+ if ((rc = pumpDisableInterface(intf->device))) return rc;
-+
- s = socket(AF_INET, SOCK_DGRAM, 0);
-
- memset(&req,0,sizeof(req));
-- memset(&route,0,sizeof(route));
- /* we have to have basic information to get this far */
- addrp = (struct sockaddr_in *) &req.ifr_addr;
- addrp->sin_family = AF_INET;
-@@ -267,29 +317,45 @@
- if (ioctl(s, SIOCSIFFLAGS, &req))
- return perrorstr("SIOCSIFFLAGS");
-
-- if (!strcmp(intf->device, "lo") || oldKernel()) {
+@@ -285,5 +299,17 @@
+- if (!strcmp(intf->device, "lo")) {
- /* add a route for this network */
- route.rt_dev = intf->device;
- route.rt_flags = RTF_UP;
-+ /* If the we're on a modern kernel and the metric we want is not zero
-+ * then we don't need todo anything else */
-+ if (! oldKernel() && metric == 0) {
-+ return NULL;
-+ }
-+
-+ /* Prepare the route */
-+ memset(&route,0,sizeof(route));
+- route.rt_metric = 0;
+ route.rt_dev = intf->device;
+ route.rt_flags = RTF_UP;
++ route.rt_metric = 0;
+
+ addrp->sin_family = AF_INET;
+ addrp->sin_port = 0;
@@ -126,427 +110,559 @@
+ memcpy(&route.rt_dst, addrp, sizeof(*addrp));
+ addrp->sin_addr = intf->netmask;
+ memcpy(&route.rt_genmask, addrp, sizeof(*addrp));
-+
-+ /* Modern kernels automatically add a default route with a metric of zero
-+ * we need to delete this route and add our own */
-+ if (! oldKernel()) {
- route.rt_metric = 0;
-
++
++ if (strcmp(intf->device,"lo") && intf->override.routeMetric) {
++ if (ioctl(s, SIOCDELRT, &route)) {
++ rc = perrorstr("SIOCDELRT");
++ goto out;
++ }
++ }
+@@ -291,6 +317,3 @@
- addrp->sin_family = AF_INET;
- addrp->sin_port = 0;
- addrp->sin_addr = intf->network;
- memcpy(&route.rt_dst, addrp, sizeof(*addrp));
- addrp->sin_addr = intf->netmask;
- memcpy(&route.rt_genmask, addrp, sizeof(*addrp));
--
-- if (ioctl(s, SIOCADDRT, &route)) {
-- /* the route cannot already exist, as we've taken the device down */
-- return perrorstr("SIOCADDRT 1");
-+ if (ioctl(s, SIOCDELRT, &route)) {
-+ return perrorstr("SIOCADDRT");
- }
- }
-
-+ /* Now add our route */
-+ if (metric > 0) metric++;
-+ route.rt_metric = metric;
-+ if (ioctl(s, SIOCADDRT, &route)) {
-+ return perrorstr("SIOCADDRT 1");
-+ }
-+
- return NULL;
- }
-
++ if (!strcmp(intf->device, "lo") || intf->override.routeMetric) {
++ if (intf->override.routeMetric)
++ route.rt_metric = intf->override.routeMetric + 1;
+@@ -310 +333 @@
-int pumpSetupDefaultGateway(struct in_addr * gw) {
-+int pumpSetupDefaultGateway(struct pumpNetIntf * intf, int metric) {
- struct sockaddr_in addr;
- struct rtentry route;
- int s;
-@@ -303,12 +369,12 @@
- addr.sin_addr.s_addr = INADDR_ANY;
- memcpy(&route.rt_dst, &addr, sizeof(addr));
- memcpy(&route.rt_genmask, &addr, sizeof(addr));
++int pumpSetupDefaultGateway(struct pumpNetIntf * intf) {
+@@ -313,0 +337 @@
++ int i;
+@@ -316,14 +339,0 @@
+-
+- memset(&addr,0,sizeof(addr));
+- memset(&route,0,sizeof(route));
+- addr.sin_family = AF_INET;
+- addr.sin_port = 0;
+- addr.sin_addr.s_addr = INADDR_ANY;
+- memcpy(&route.rt_dst, &addr, sizeof(addr));
+- memcpy(&route.rt_genmask, &addr, sizeof(addr));
- addr.sin_addr = *gw;
-+ addr.sin_addr = intf->gateway;
- memcpy(&route.rt_gateway, &addr, sizeof(addr));
-
- route.rt_flags = RTF_UP | RTF_GATEWAY;
+- memcpy(&route.rt_gateway, &addr, sizeof(addr));
+-
+- route.rt_flags = RTF_UP | RTF_GATEWAY;
- route.rt_metric = 0;
- route.rt_dev = NULL;
-+ route.rt_metric = metric + 1;
-+ route.rt_dev = intf->device;
-
- if (ioctl(s, SIOCADDRT, &route)) {
- syslog(LOG_ERR, "failed to set default route: %s", strerror(errno));
-@@ -1423,7 +1489,7 @@
- char * pumpDhcpRun(char * device, int flags, int reqLease,
- char * reqHostname, struct pumpNetIntf * intf,
- struct pumpOverrideInfo * override) {
-- pumpDhcpClassRun(device, flags, reqLease, reqHostname, NULL, intf,
-+ return pumpDhcpClassRun(device, flags, reqLease, reqHostname, NULL, intf,
- override);
- }
-
---- pump.8 2001-02-01 22:58:16.000000000 +0000
-+++ pump.8 2005-07-13 10:24:33.000000000 +0100
-@@ -43,14 +43,17 @@
- /etc/pump.conf
- -h --hostname=hostname Hostname to request
- -i --interface=iface Interface to configure (normally eth0)
-+-u --keep-up Keep the interface up when releasing it
- -k --kill Kill daemon (and disable all interfaces)
- -l --lease=hours Lease time to request (in hours)
- --lookup-hostname Always look up hostname and domain in DNS
- -r --release Release interface
- -R --renew Force immediate lease renewal
-+ --script=script Script to run when on DHCP actions
- -s --status Display interface status
- -d --no-dns Don't update resolv.conf
- --no-gateway Don't configurate a default route for this interface
-+ --no-ntp Don't update ntp.conf
- --win-client-id Specify a Windows-like client identifier
- -? --help Show this help message
- --usage Display brief usage message
-@@ -111,13 +114,6 @@
- directive may only be used globally.
-
- .TP
--\fBnonisdomain\fR
--Don't set a new NIS domain. Normally \fBpump\fR sets the system's NIS domain
--if an NIS domain is specified by the dhcp server and the current NIS domain
--is empty or \fBlocaldomain\fR.
+@@ -331,4 +341,23 @@
+- if (ioctl(s, SIOCADDRT, &route)) {
+- close(s);
+- syslog(LOG_ERR, "failed to set default route: %s", strerror(errno));
+- return -1;
++ for (i = intf->numGateways - 1; i >= 0; i--) {
++ memset(&addr,0,sizeof(addr));
++ memset(&route,0,sizeof(route));
++ addr.sin_family = AF_INET;
++ addr.sin_port = 0;
++ addr.sin_addr.s_addr = INADDR_ANY;
++ memcpy(&route.rt_dst, &addr, sizeof(addr));
++ memcpy(&route.rt_genmask, &addr, sizeof(addr));
++ addr.sin_addr = intf->gateways[i];
++ memcpy(&route.rt_gateway, &addr, sizeof(addr));
++
++ route.rt_flags = RTF_UP | RTF_GATEWAY;
++ route.rt_dev = intf->device;
++ if (intf->override.routeMetric)
++ route.rt_metric = intf->override.routeMetric + 1;
++ else
++ route.rt_metric = 0;
++
++ if (ioctl(s, SIOCADDRT, &route)) {
++ close(s);
++ syslog(LOG_ERR, "failed to set default route: %s", strerror(errno));
++ return -1;
++ }
+diff -r -U 0 pump-0.8.21/pump.8 pump-0.8.21-r5/pump.8
+--- pump-0.8.21/pump.8 2005-07-14 15:18:08.000000000 +0100
++++ pump-0.8.21-r5/pump.8 2005-07-14 15:10:58.000000000 +0100
+@@ -2,0 +3 @@
++.\" July 2005: Updated by Roy Marples <uberlord@gentoo.org>
+@@ -31,0 +33,2 @@
++.BR "" [ \-m | \-\-route\-metric
++.IR METRIC ]
+@@ -33 +36 @@
+-.BR "" [ \-\-no\-dns "] [" \-\-no\-gateway "] [" \-\-no\-setup "] [" \-\-no\-resolvconf ]
++.BR "" [ \-\-no\-dns "] [" \-\-no\-gateway "] [" \-\- no\-ntp "] [" \-\-no\-setup "]
+@@ -67 +70,2 @@
+-\-d \-\-no\-dns Don't update DNS resolver configuration
++\-e \-\-etc\-dir=\fIDIR\fR Directory to create conf files (normally /etc)
++\-d \-\-no\-dns Don't update resolv.conf
+@@ -69,0 +74 @@
++ \-\-keep\-up Keep the interface up when released
+@@ -74,0 +80 @@
++\-m \-\-route-metric=\fIMETRIC\fR Metric to use on routes (normally 0)
+@@ -76 +82 @@
+- \-\-no\-resolvconf Don't use the \fBresolvconf\fR program to update resolv.conf
++ \-\-no\-ntp Don't update ntp.conf
+@@ -162,0 +169,4 @@
++\fBetcdir\fR \fIETCDIRECTORY\fR
++Store resolv.conf and/or ntp.conf in this directory (normally /etc).
++
++.TP
+@@ -167,2 +177,7 @@
+-As a machine only has a single DNS search path, this directive may
+-only be used globally.
++
++.TP
++\fBkeepup\fR
++Keep the interface up when released.
++Normally \fBpump\fR brings the interface down when it releases its
++lease, but some daemons such as ifplugd or wpa_supplicant still need the
++interface to be up so that they can still work.
+@@ -176 +190,0 @@
-This directive may only be used within a \fBdevice\fR directive.
--
--.TP
- \fBnodns\fR
- Don't create a new /etc/resolv.conf when this interface is configured. This
- directive may only be used within a \fBdevice\fR directive.
-@@ -128,6 +124,18 @@
- can be usefull on machines with multiple ethernet cards.
-
- .TP
-+\fBnonisdomain\fR
-+Don't set a new NIS domain. Normally \fBpump\fR sets the system's NIS domain
-+if an NIS domain is specified by the dhcp server and the current NIS domain
-+is empty or \fBlocaldomain\fR.
-+This directive may only be used within a \fBdevice\fR directive.
+@@ -181 +194,0 @@
+-This directive may only be used within a \fBdevice\fR directive.
+@@ -186 +199,5 @@
+-This can be useful on machines with multiple Ethernet cards.
++This can be useful on machines with multiple devices.
+
+.TP
+\fBnontp\fR
-+Don't create a new /etc/ntp.conf when this interface is configured. This
-+directive may only be used within a \fBdevice\fR directive.
++Don't update /etc/ntp.conf when the interface is configured.
+@@ -191 +208 @@
+-This implies \fBnodns\fR, \fBnonisdomain\fR and \fBnogateway\fR.
++This implies \fBnodns\fR, \fBnonisdomain\fR, \fBnogateway\fR and \fBnontp\fR.
+@@ -196,8 +212,0 @@
+-\fBnoresolvconf\fR
+-Don't use the resolvconf program to update /etc/resolv.conf;
+-instead, update /etc/resolv.conf directly.
+-(This option is only relevant if
+-.B \-\-nodns
+-is not used.)
+-
+-.TP
+@@ -207,0 +217,6 @@
++\fBroutemetric\fR \fIMETRIC\fR
++Metric assigned to each route (normally 0).
++Metric decide a priority when choosing where to route network traffic.
++Lower metrics take a higher priority.
+
+.TP
- \fBretries\fR \fIcount\fR
- Retry each phase of the DHCP process \fIcount\fR times.
-
---- pump.c 2002-06-18 18:03:59.000000000 +0100
-+++ pump.c 2005-07-13 10:12:28.000000000 +0100
-@@ -69,10 +69,16 @@
- int flags;
- int reqLease; /* in seconds */
- char reqHostname[200];
-+ struct {
-+ char resolv[MAX_PATH];
-+ char ntp[MAX_PATH];
-+ } files;
-+ int routeMetric;
- } start;
- int result; /* 0 for success */
- struct {
- char device[20];
+diff -r -U 0 pump-0.8.21/pump.c pump-0.8.21-r5/pump.c
+--- pump-0.8.21/pump.c 2005-07-14 15:18:08.000000000 +0100
++++ pump-0.8.21-r5/pump.c 2005-07-14 15:07:26.000000000 +0100
+@@ -82,0 +83 @@
+ int keepUp;
- } stop;
- struct {
- char device[20];
-@@ -92,13 +98,14 @@
-
- static int openControlSocket(char * configFile, struct pumpOverrideInfo * override);
-
+@@ -100,111 +101,2 @@
-char * readSearchPath(void) {
-+char * readSearchPath(char *file) {
- int fd;
- struct stat sb;
- char * buf;
- char * start;
-
+- int fd;
+- struct stat sb;
+- char * buf;
+- char * start;
+-
- fd = open("/etc/resolv.conf", O_RDONLY);
-+ if (! file) return NULL;
-+ fd = open(file, O_RDONLY);
- if (fd < 0) return NULL;
-
- fstat(fd, &sb);
-@@ -132,8 +139,42 @@
- return NULL;
- }
-
--static void createResolvConf(struct pumpNetIntf * intf, char * domain,
-- int isSearchPath) {
-+void createNtpConf(char *file, struct pumpNetIntf * intf) {
+- if (fd < 0) return NULL;
+-
+- fstat(fd, &sb);
+- buf = alloca(sb.st_size + 2);
+- if (read(fd, buf, sb.st_size) != sb.st_size) return NULL;
+- buf[sb.st_size] = '\n';
+- buf[sb.st_size + 1] = '\0';
+- close(fd);
+-
+- start = buf;
+- while (start && *start) {
+- while (isspace(*start) && (*start != '\n')) start++;
+- if (*start == '\n') {
+- start++;
+- continue;
+- }
+-
+- if (!strncmp("search", start, 6) && isspace(start[6])) {
+- start += 6;
+- while (isspace(*start) && *start != '\n') start++;
+- if (*start == '\n') return NULL;
+-
+- buf = strchr(start, '\n');
+- *buf = '\0';
+- return strdup(start);
+- }
+-
+- while (*start && (*start != '\n')) start++;
+- }
+-
+- return NULL;
+-}
+-
+-static void createResolvConf(struct pumpNetIntf * intf, struct pumpOverrideInfo * override, char * domain) {
+- FILE * f;
+- int i;
+- char * chptr;
+- int resolvconf;
+-
+- /* force a reread of /etc/resolv.conf if we need it again */
+- res_close();
+- endhostent();
+-
+- if (!domain) {
+- domain = readSearchPath();
+- if (domain) {
+- chptr = alloca(strlen(domain) + 1);
+- strcpy(chptr, domain);
+- free(domain);
+- domain = chptr;
+- }
+- }
+-
+- resolvconf = !(override->flags & OVERRIDE_FLAG_NORESOLVCONF);
+- if (resolvconf) {
+- struct stat buf;
+-
+- if (stat("/sbin/resolvconf", &buf) < 0)
+- resolvconf = 0;
+- }
+-
+- if (resolvconf) {
+- char *arg;
+-
+- f = NULL;
+- if (asprintf(&arg, "/sbin/resolvconf -a %s >/dev/null 2>&1", intf->device) >= 0) {
+- f = popen(arg, "w");
+- free(arg);
+- }
+- if (!f) {
+- syslog(LOG_ERR, "error starting resolvconf: %s\n", strerror(errno));
+- return;
+- }
+- } else {
+- f = fopen("/etc/resolv.conf", "w");
+- if (!f) {
+- syslog(LOG_ERR, "error opening resolv.conf: %s\n", strerror(errno));
+- return;
+- }
+- }
+-
+-
+- errno = 0;
+-
+- if (domain)
+- if(fprintf(f, "search %s\n", domain) < 0)
+- syslog(LOG_ERR, "failed to write resolver configuration data\n");
+-
+- for (i = 0; i < intf->numDns; i++)
+- if(fprintf(f, "nameserver %s\n", inet_ntoa(intf->dnsServers[i])) < 0)
+- syslog(LOG_ERR, "failed to write resolver configuration data\n");
+-
+- if (resolvconf) {
+- if(pclose(f) != 0) /* errno not useful on pclose failure */
+- syslog(LOG_ERR, "error running resolvconf\n");
+- } else {
+- if(fclose(f) != 0)
+- syslog(LOG_ERR, "error closing resolv.conf: %s\n", strerror(errno));
+- }
+-
+-}
+-
+-void setupDomain(struct pumpNetIntf * intf,
+- struct pumpOverrideInfo * override) {
++void setupDomain(struct pumpNetIntf * intf) {
++ struct pumpOverrideInfo *o = &intf->override;
+@@ -214 +106 @@
+- if (override->flags & OVERRIDE_FLAG_NONISDOMAIN)
++ if (o->flags & OVERRIDE_FLAG_NONISDOMAIN)
+@@ -242,7 +134,5 @@
+-void setupDns(struct pumpNetIntf * intf, struct pumpOverrideInfo * override) {
+- char * hn, * dn = NULL;
+- struct hostent * he;
+-
+- if (override->flags & OVERRIDE_FLAG_NODNS) {
+- return;
+- }
++void createResolvConf(struct pumpNetIntf * intf, char * domain) {
++ struct pumpOverrideInfo *o = &intf->override;
+ FILE * f;
++ char resolv[1024];
+ int i;
+@@ -250,2 +140,4 @@
+- if (override->searchPath[0]) {
+- createResolvConf(intf, override, override->searchPath);
++ sprintf(resolv, "%s/resolv.conf", o->etcDir);
++ f = fopen(resolv, "w");
++ if (!f) {
++ syslog(LOG_ERR, "cannot create %s: %s", resolv, strerror(errno));
+@@ -254,22 +146,5 @@
+-
+- if (intf->set & PUMP_NETINFO_HAS_DNS) {
+- if (!(intf->set & PUMP_NETINFO_HAS_DOMAIN)) {
+- if (intf->set & PUMP_NETINFO_HAS_HOSTNAME) {
+- hn = intf->hostname;
+- } else {
+- createResolvConf(intf, override, NULL);
+-
+- he = gethostbyaddr((char *) &intf->ip, sizeof(intf->ip),
+- AF_INET);
+- if (he) {
+- hn = he->h_name;
+- } else {
+- hn = NULL;
+- }
+- }
+-
+- if (hn) {
+- dn = strchr(hn, '.');
+- if (dn)
+- dn++;
+- }
++
++ fprintf(f, "# Generated by pump for interface %s\n", intf->device);
++ if (*domain) {
++ if (strchr(domain, ' ')) {
++ fprintf(f, "search %s\n", domain);
+@@ -277 +152 @@
+- dn = intf->domain;
++ fprintf(f, "domain %s\n", domain);
+@@ -278,0 +154 @@
++ }
+@@ -280 +156,2 @@
+- createResolvConf(intf, override, dn);
++ for (i = 0; i < intf->numDns; i++) {
++ fprintf(f, "nameserver %s\n", inet_ntoa(intf->dnsServers[i]));
+@@ -281,0 +159,2 @@
++
++ fclose(f);
+@@ -284,3 +163,4 @@
+-void unsetupDns(struct pumpNetIntf * intf, struct pumpOverrideInfo * override) {
+- struct stat buf;
+- char *arg;
++void setupDns(struct pumpNetIntf * intf) {
++ struct pumpOverrideInfo *o = &intf->override;
++ char * hn, * dn = NULL;
++ struct hostent * he;
+@@ -288,3 +168 @@
+- if (override->flags & OVERRIDE_FLAG_NODNS)
+- return;
+- if (override->flags & OVERRIDE_FLAG_NORESOLVCONF)
++ if (o->flags & OVERRIDE_FLAG_NODNS)
+@@ -292,4 +170,2 @@
+- if (stat("/sbin/resolvconf", &buf) < 0)
+- return;
+- if (asprintf(&arg, "/sbin/resolvconf -d %s", intf->device) < 0) {
+- syslog(LOG_ERR, "failed to release resolvconf: %s", strerror(errno));
+
-+ f = fopen(file, "w");
++ if (!intf->set & PUMP_NETINFO_HAS_DNS)
+@@ -296,0 +173,22 @@
++
++ if (o->searchPath[0]) {
++ dn = o->searchPath;
++ } else if (intf-> set & PUMP_NETINFO_HAS_DOMAIN) {
++ dn = intf->domain;
++ } else if (intf->set & PUMP_NETINFO_HAS_HOSTNAME) {
++ hn = intf->hostname;
++ } else {
++ createResolvConf(intf, NULL);
++
++ he = gethostbyaddr((char *) &intf->ip, sizeof(intf->ip), AF_INET);
++ if (he) {
++ hn = he->h_name;
++ } else {
++ hn = NULL;
++ }
++ }
++
++ if (hn) {
++ dn = strchr(hn, '.');
++ if (dn)
++ dn++;
+@@ -299,3 +197 @@
+- if (system(arg) != 0)
+- syslog(LOG_ERR, "resolvconf -d %s failed", intf->device);
+- free(arg);
++ createResolvConf(intf, dn);
+@@ -304,8 +200,5 @@
+-static void callIfupPost(struct pumpNetIntf* intf) {
+-#ifdef debian
+- /* can/should we call a debian one? */
+- return;
+-#else
+- pid_t child;
+- char * argv[3];
+- char arg[64];
++void setupNtp(struct pumpNetIntf * intf) {
++ struct pumpOverrideInfo *o = &intf->override;
++ FILE * f;
++ char ntp[1024];
++ int i;
+@@ -313,4 +206,2 @@
+- argv[0] = "/etc/sysconfig/network-scripts/ifup-post";
+- snprintf(arg,64,"ifcfg-%s",intf->device);
+- argv[1] = arg;
+- argv[2] = NULL;
++ if (o->flags & OVERRIDE_FLAG_NONTP)
++ return;
+@@ -318,3 +209,2 @@
+- if (!(child = fork())) {
+- /* send the script to init */
+- if (fork()) _exit(0);
++ if (! intf->set & PUMP_NETINFO_HAS_NTPSRVS)
++ return;
+@@ -322 +212,6 @@
+- execvp(argv[0], argv);
++ sprintf(ntp, "%s/ntp.conf", o->etcDir);
++ f = fopen(ntp, "w");
+ if (!f) {
-+ syslog(LOG_ERR, "cannot create %s: %s\n", file,
-+ strerror(errno));
++ syslog(LOG_ERR, "cannot create %s: %s\n", ntp, strerror(errno));
+ return;
+ }
-+
+@@ -324 +219,4 @@
+- syslog(LOG_ERR,"failed to run %s: %s", argv[0], strerror(errno));
+ fprintf(f, "# Generated by pump for interface %s\n", intf->device);
+ fprintf(f, "restrict default noquery notrust nomodify\n"
-+ "restrict 127.0.0.1\n"
-+ "driftfile /var/lib/ntp/ntp.drift\n");
-+
++ "restrict 127.0.0.1\n"
++ "driftfile /var/lib/ntp/ntp.drift\n");
+@@ -326 +224,4 @@
+- _exit(0);
+ for (i = 0; i < intf->numNtp; i++) {
+ fprintf(f, "restrict %s nomodify notrap noquery\n"
+ "server %s\n", inet_ntoa(intf->ntpServers[i]),
+ inet_ntoa(intf->ntpServers[i]));
-+ }
-+
+@@ -329,2 +230 @@
+- waitpid(child, NULL, 0);
+-#endif
+ fclose(f);
-+}
-+
-+void setupNtp(char *file, struct pumpNetIntf * intf, struct pumpOverrideInfo * override) {
-+
-+ if (override->flags & OVERRIDE_FLAG_NONTP)
-+ return;
-+
-+ if (intf->set & PUMP_NETINFO_HAS_NTPSRVS)
-+ createNtpConf(file, intf);
-+}
-+
-+static void createResolvConf(char * file, struct pumpNetIntf * intf,
-+ char * domain, int isSearchPath) {
- FILE * f;
- int i;
- char * chptr;
-@@ -142,7 +183,7 @@
- res_close();
-
- if (!domain) {
-- domain = readSearchPath();
-+ domain = readSearchPath(file);
- if (domain) {
- chptr = alloca(strlen(domain) + 1);
- strcpy(chptr, domain);
-@@ -152,19 +193,21 @@
- }
- }
-
-- f = fopen("/etc/resolv.conf", "w");
-+ f = fopen(file, "w");
- if (!f) {
-- syslog(LOG_ERR, "cannot create /etc/resolv.conf: %s\n",
-+ syslog(LOG_ERR, "cannot create %s: %s\n", file,
- strerror(errno));
- return;
- }
-
-+ fprintf(f, "# Generated by pump for interface %s\n", intf->device);
-+
- if (domain && isSearchPath) {
- fprintf(f, "search %s\n", domain);
- } else if (domain && !strchr(domain, '.')) {
-- fprintf(f, "search %s\n", domain);
-+ fprintf(f, "domain %s\n", domain);
- } else if (domain) {
-- fprintf(f, "search");
-+ fprintf(f, "domain");
- chptr = domain;
- do {
- /* If there is a single . in the search path, write it out
-@@ -240,7 +283,7 @@
- return;
- }
-
--void setupDns(struct pumpNetIntf * intf, struct pumpOverrideInfo * override) {
-+void setupDns(char *file, struct pumpNetIntf * intf, struct pumpOverrideInfo * override) {
- char * hn, * dn = NULL;
- struct hostent * he;
-
-@@ -249,7 +292,7 @@
- }
-
- if (override->searchPath) {
-- createResolvConf(intf, override->searchPath, 1);
-+ createResolvConf(file, intf, override->searchPath, 1);
- return;
- }
-
-@@ -258,7 +301,7 @@
- if (intf->set & PUMP_NETINFO_HAS_HOSTNAME) {
- hn = intf->hostname;
- } else {
-- createResolvConf(intf, NULL, 0);
-+ createResolvConf(file, intf, NULL, 0);
-
- he = gethostbyaddr((char *) &intf->ip, sizeof(intf->ip),
- AF_INET);
-@@ -278,7 +321,7 @@
- dn = intf->domain;
- }
-
-- createResolvConf(intf, dn, 0);
-+ createResolvConf(file, intf, dn, 0);
- }
- }
-
-@@ -360,7 +403,7 @@
- static void runDaemon(int sock, char * configFile, struct pumpOverrideInfo * overrides) {
- int conn;
- struct sockaddr_un addr;
-- int addrLength = sizeof(struct sockaddr_un);
-+ socklen_t addrLength = sizeof(struct sockaddr_un);
- struct command cmd;
- struct pumpNetIntf intf[20];
- int numInterfaces = 0;
-@@ -529,17 +572,20 @@
- intf + numInterfaces, o)) {
- cmd.u.result = 1;
- } else {
-- pumpSetupInterface(intf + numInterfaces);
-+ pumpSetupInterface(intf + numInterfaces,
-+ cmd.u.start.routeMetric);
- i = numInterfaces;
-
- syslog(LOG_INFO, "configured interface %s", intf[i].device);
-
- if ((intf[i].set & PUMP_NETINFO_HAS_GATEWAY) &&
- !(o->flags & OVERRIDE_FLAG_NOGATEWAY))
-- pumpSetupDefaultGateway(&intf[i].gateway);
-+ pumpSetupDefaultGateway(intf + i,
-+ cmd.u.start.routeMetric);
-
-- setupDns(intf + i, o);
-+ setupDns(cmd.u.start.files.resolv, intf + i, o);
- setupDomain(intf + i, o);
-+ setupNtp(cmd.u.start.files.ntp, intf + i, o);
-
- callScript(o->script, PUMP_SCRIPT_NEWLEASE,
- intf + numInterfaces);
-@@ -570,6 +616,7 @@
- cmd.u.result = RESULT_UNKNOWNIFACE;
- else {
- cmd.u.result = pumpDhcpRelease(intf + i);
-+ if (! cmd.u.stop.keepUp) pumpDownInterface(intf[i].device);
- callScript(o->script, PUMP_SCRIPT_DOWN, intf + i);
- if (numInterfaces == 1) {
- cmd.type = CMD_RESULT;
-@@ -808,20 +855,27 @@
- int killDaemon = 0;
- int winId = 0;
- int release = 0, renew = 0, status = 0, lookupHostname = 0, nodns = 0;
+@@ -333 +233 @@
+-static void callScript(char* script,int msg,struct pumpNetIntf* intf) {
++static void callScript(struct pumpNetIntf *intf, int msg) {
+@@ -337,0 +238 @@
++ char * script = intf->override.script;
+@@ -388 +288,0 @@
+-
+@@ -397,4 +297 @@
+- int i;
+-
+- for (i = intf->numGateways - 1; i >= 0; i--)
+- pumpSetupDefaultGateway(&intf->gateways[i]);
++ pumpSetupDefaultGateway(intf);
+@@ -403,8 +300,3 @@
+- setupDns(intf, o);
+- setupDomain(intf, o);
+-
+- callScript(o->script, PUMP_SCRIPT_NEWLEASE, intf);
+-}
+-
+-static void killLease(struct pumpNetIntf *intf) {
+- struct pumpOverrideInfo *o = &intf->override;
++ setupDns(intf);
++ setupDomain(intf);
++ setupNtp(intf);
+@@ -412,2 +304 @@
+- unsetupDns(intf, o);
+- callScript(o->script, PUMP_SCRIPT_DOWN, intf);
++ callScript(intf, PUMP_SCRIPT_NEWLEASE);
+@@ -502 +393 @@
+- killLease(intf + closest);
++ callScript(intf + closest, PUMP_SCRIPT_DOWN);
+@@ -504 +395 @@
+- killLease(intf + closest);
++ callScript(intf + closest, PUMP_SCRIPT_DOWN);
+@@ -511,3 +402 @@
+- callScript(intf[closest].override.script,
+- PUMP_SCRIPT_RENEWAL, &intf[closest]);
+- callIfupPost(&intf[closest]);
++ callScript(&intf[closest], PUMP_SCRIPT_RENEWAL);
+@@ -576 +465 @@
+- killLease(intf + i);
++ callScript(intf + i, PUMP_SCRIPT_DOWN);
+@@ -614,3 +503 @@
+- callScript(intf[i].override.script,
+- PUMP_SCRIPT_RENEWAL, intf + i);
+- callIfupPost(intf + i);
++ callScript(intf + 1, PUMP_SCRIPT_RENEWAL);
+@@ -626,0 +514,2 @@
++ if (cmd.u.stop.keepUp)
++ intf[i].override.flags |= OVERRIDE_FLAG_KEEPUP;
+@@ -628 +517 @@
+- killLease(intf + i);
++ callScript(intf + i, PUMP_SCRIPT_DOWN);
+@@ -922 +810,0 @@
+- int flags = 0;
+@@ -928 +816 @@
- int nogateway = 0, nobootp = 0;
-+ int nogateway = 0, nobootp = 0, nontp=1;
- struct command cmd, response;
- char * configFile = "/etc/pump.conf";
++ int nogateway = 0, nobootp = 0, nontp = 0;
+@@ -930 +818,2 @@
+- int noresolvconf = 0;
++ int routeMetric = 0;
++ int keepUp = 0;
+@@ -933,0 +823,2 @@
+ char * etcDir = "/etc";
-+ int routeMetric = 0, keepUp = 0;
-+ char * script = "";
- struct pumpOverrideInfo * overrides;
- int cont;
- struct poptOption options[] = {
- { "config-file", 'c', POPT_ARG_STRING, &configFile, 0,
- N_("Configuration file to use instead of "
- "/etc/pump.conf") },
++ char * searchPath = NULL;
+@@ -939,0 +831,2 @@
+ { "etc-dir", 'e', POPT_ARG_STRING, &etcDir, 0,
+ N_("Directory to store resolv.conf (normally /etc)") },
- { "hostname", 'h', POPT_ARG_STRING, &hostname, 0,
- N_("Hostname to request"), N_("hostname") },
- { "interface", 'i', POPT_ARG_STRING, &device, 0,
- N_("Interface to configure (normally eth0)"),
- N_("iface") },
+@@ -944,0 +838,2 @@
+ { "keep-up", 'u', POPT_ARG_NONE, &keepUp, 0,
+ N_("Keep the interface up when releasing it") },
- { "kill", 'k', POPT_ARG_NONE, &killDaemon, 0,
- N_("Kill daemon (and disable all interfaces)"), NULL },
- { "lease", 'l', POPT_ARG_INT, &lease_hrs, 0,
-@@ -834,14 +888,20 @@
- N_("Release interface"), NULL },
- { "renew", 'R', POPT_ARG_NONE, &renew, 0,
- N_("Force immediate lease renewal"), NULL },
+@@ -957 +852,3 @@
+- { "verbose", 'v', POPT_ARG_NONE, &verbose, 0,
+ { "route-metric", 'm', POPT_ARG_INT, &routeMetric, 0,
-+ N_("Metric applied to routes (normally 0)") },
-+ { "script", '\0', POPT_ARG_STRING, &script, 0,
-+ N_("Script to run when on DHCP actions") },
- { "status", 's', POPT_ARG_NONE, &status, 0,
- N_("Display interface status"), NULL },
-+ { "no-bootp", '\0', POPT_ARG_NONE, &nobootp, 0,
-+ N_("Ignore non-DHCP BOOTP responses"), NULL },
- { "no-dns", 'd', POPT_ARG_NONE, &nodns, 0,
- N_("Don't update resolv.conf"), NULL },
- { "no-gateway", '\0', POPT_ARG_NONE, &nogateway, 0,
- N_("Don't set a gateway for this interface"), NULL },
-- { "no-bootp", '\0', POPT_ARG_NONE, &nobootp, 0,
-- N_("Ignore non-DHCP BOOTP responses"), NULL },
++ N_("Metric applied to routes (normally 0)"), N_("(metric)") },
++ { "verbose", 'v', POPT_ARG_NONE, &verbose, 0,
+@@ -964,0 +862,2 @@
+ { "no-ntp", '\0', POPT_ARG_NONE, &nontp, 0,
+ N_("Don't update ntp.conf"), NULL },
- { "win-client-ident", '\0', POPT_ARG_NONE, &winId, 0,
- N_("Set the client identifier to match Window's") },
- /*{ "test", 't', POPT_ARG_NONE, &test, 0,
-@@ -889,6 +949,10 @@
- overrides->flags |= OVERRIDE_FLAG_NOBOOTP;
- if (nogateway)
- overrides->flags |= OVERRIDE_FLAG_NOGATEWAY;
-+ if (nontp)
-+ overrides->flags |= OVERRIDE_FLAG_NONTP;
-+ if (strlen(script))
-+ overrides->script = script;
-
- cont = openControlSocket(configFile, overrides);
- if (cont < 0)
-@@ -905,6 +969,7 @@
- } else if (release) {
- cmd.type = CMD_STOPIFACE;
- strcpy(cmd.u.stop.device, device);
-+ cmd.u.stop.keepUp = keepUp;
- } else {
- cmd.type = CMD_STARTIFACE;
- strcpy(cmd.u.start.device, device);
-@@ -914,6 +979,9 @@
- else
- cmd.u.start.reqLease = lease;
- strcpy(cmd.u.start.reqHostname, hostname);
-+ snprintf(cmd.u.start.files.resolv, MAX_PATH, "%s/resolv.conf", etcDir);
-+ snprintf(cmd.u.start.files.ntp, MAX_PATH, "%s/ntp.conf", etcDir);
-+ cmd.u.start.routeMetric = routeMetric;
- }
-
- write(cont, &cmd, sizeof(cmd));
---- pump.h 2003-10-24 20:37:53.000000000 +0100
-+++ pump.h 2005-07-13 09:55:41.000000000 +0100
-@@ -13,6 +13,8 @@
- #define MAX_XFS_SERVERS 3
- #define MAX_XDM_SERVERS 3
-
-+#define MAX_PATH 256
+@@ -967,2 +865,0 @@
+- { "no-resolvconf", '\0', POPT_ARG_NONE, &noresolvconf, 0,
+- N_("Don't set up resolvconf"), NULL },
+@@ -970,0 +868,2 @@
++ { "search-path", 'p', POPT_ARG_STRING, &searchPath, 0,
++ N_("Use this DNS search path instead of the supplied one"), NULL },
+@@ -1016,0 +916,10 @@
++ if (etcDir && strlen(etcDir) + 12 > sizeof(overrides->etcDir)) {
++ fprintf(stderr, _("%s: --etc-dir argument is to long\n"), PROGNAME);
++ return 1;
++ }
+
- #define PUMP_INTFINFO_HAS_IP (1 << 0)
- #define PUMP_INTFINFO_HAS_NETMASK (1 << 1)
- #define PUMP_INTFINFO_HAS_BROADCAST (1 << 2)
-@@ -83,6 +85,7 @@
- #define OVERRIDE_FLAG_NONISDOMAIN (1 << 1)
- #define OVERRIDE_FLAG_NOGATEWAY (1 << 2)
- #define OVERRIDE_FLAG_NOBOOTP (1 << 3)
-+#define OVERRIDE_FLAG_NONTP (1 << 4)
-
- struct pumpOverrideInfo {
- struct pumpNetIntf intf;
-@@ -100,13 +103,14 @@
- char * pumpDhcpRun(char * device, int flags, int lease,
- char * reqHostname, struct pumpNetIntf * intf,
- struct pumpOverrideInfo * override);
--char * pumpSetupInterface(struct pumpNetIntf * intf);
-+char * pumpSetupInterface(struct pumpNetIntf * intf, int metric);
- /* setup an interface for sending a broadcast -- uses all 0's address */
- char * pumpPrepareInterface(struct pumpNetIntf * intf, int s);
- char * pumpDisableInterface(char * device);
-+char * pumpDownInterface(char * device);
- int pumpDhcpRenew(struct pumpNetIntf * intf);
- int pumpDhcpRelease(struct pumpNetIntf * intf);
++ if (searchPath && strlen(searchPath) > sizeof(overrides->searchPath)) {
++ fprintf(stderr, _("%s: --search-path argument is to long\n"), PROGNAME);
++ return 1;
++ }
++
+@@ -1030,7 +938,0 @@
+- if (test)
+- flags = PUMP_FLAG_NODAEMON | PUMP_FLAG_NOCONFIG;
+- if (winId)
+- flags |= PUMP_FLAG_WINCLIENTID;
+- if (lookupHostname)
+- flags |= PUMP_FLAG_FORCEHNLOOKUP;
+-
+@@ -1047,0 +950 @@
++ cmd.u.stop.keepUp = keepUp;
+@@ -1053 +955,0 @@
+- cmd.u.start.flags = flags;
+@@ -1065,0 +968,8 @@
++ if (etcDir)
++ strcpy(o->etcDir, etcDir);
++ if (test)
++ o->flags = PUMP_FLAG_NODAEMON | PUMP_FLAG_NOCONFIG;
++ if (winId)
++ o->flags |= PUMP_FLAG_WINCLIENTID;
++ if (lookupHostname)
++ o->flags |= PUMP_FLAG_FORCEHNLOOKUP;
+@@ -1071,0 +982,2 @@
++ if (nontp)
++ o->flags |= OVERRIDE_FLAG_NONTP;
+@@ -1076,0 +989 @@
++ OVERRIDE_FLAG_NONTP |
+@@ -1078,2 +991,3 @@
+- if (noresolvconf)
+- o->flags |= OVERRIDE_FLAG_NORESOLVCONF;
++ o->routeMetric = routeMetric;
++ if (searchPath)
++ strcpy(o->searchPath, searchPath);
+diff -r -U 0 pump-0.8.21/pump.h pump-0.8.21-r5/pump.h
+--- pump-0.8.21/pump.h 2005-07-14 15:18:08.000000000 +0100
++++ pump-0.8.21-r5/pump.h 2005-07-14 11:54:32.000000000 +0100
+@@ -57 +57,3 @@
+-#define OVERRIDE_FLAG_NORESOLVCONF (1 << 5)
++/* #define OVERRIDE_FLAG_NORESOLVCONF (1 << 5) */
++#define OVERRIDE_FLAG_NONTP (1 << 6)
++#define OVERRIDE_FLAG_KEEPUP (1 << 7)
+@@ -65,0 +68,2 @@
++ char etcDir[1024];
++ int routeMetric;
+@@ -116 +120 @@
-int pumpSetupDefaultGateway(struct in_addr * gw);
-+int pumpSetupDefaultGateway(struct pumpNetIntf * intf, int metric);
- time_t pumpUptime(void);
-
- #define RESULT_OKAY 0
++int pumpSetupDefaultGateway(struct pumpNetIntf * intf);