summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorHans Dedecker <hans.dedecker@technicolor.com>2014-01-16 11:33:34 +0100
committerHans Dedecker <hans.dedecker@technicolor.com>2014-01-16 11:33:34 +0100
commitfa3073b32452d78037d2a8ce2e3ea213b3d5f50c (patch)
tree7401745ff5f3eb80c72898e586ab49bb74f71069 /src
parent84cfd09747332071c83de4882daecb9bfb80897b (diff)
parentd59daa0f4027ee70a4650ab8baa40d58d113cd30 (diff)
Merge remote branch 'upstream/master' into bugfixes
Diffstat (limited to 'src')
-rw-r--r--src/dhcpv6-ia.c18
1 files changed, 16 insertions, 2 deletions
diff --git a/src/dhcpv6-ia.c b/src/dhcpv6-ia.c
index 37b7cc8..2e93bd0 100644
--- a/src/dhcpv6-ia.c
+++ b/src/dhcpv6-ia.c
@@ -243,7 +243,14 @@ void dhcpv6_write_statefile(void)
inet_ntop(AF_INET6, &addr, ipbuf, sizeof(ipbuf) - 1);
if (c->length == 128 && c->hostname && i == 0) {
- fprintf(fp, "%s\t%s\n", ipbuf, c->hostname);
+ fputs(ipbuf, fp);
+
+ char b[256];
+ if (dn_expand(iface->search, iface->search + iface->search_len,
+ iface->search, b, sizeof(b)) > 0)
+ fprintf(fp, "\t%s.%s", c->hostname, b);
+
+ fprintf(fp, "\t%s\n", c->hostname);
md5_hash(ipbuf, strlen(ipbuf), &md5);
md5_hash(c->hostname, strlen(c->hostname), &md5);
}
@@ -275,7 +282,14 @@ void dhcpv6_write_statefile(void)
inet_ntop(AF_INET, &addr, ipbuf, sizeof(ipbuf) - 1);
if (c->hostname[0]) {
- fprintf(fp, "%s\t%s\n", ipbuf, c->hostname);
+ fputs(ipbuf, fp);
+
+ char b[256];
+ if (dn_expand(iface->search, iface->search + iface->search_len,
+ iface->search, b, sizeof(b)) > 0)
+ fprintf(fp, "\t%s.%s", c->hostname, b);
+
+ fprintf(fp, "\t%s\n", c->hostname);
md5_hash(ipbuf, strlen(ipbuf), &md5);
md5_hash(c->hostname, strlen(c->hostname), &md5);
}