|
Rex Dieter |
f5488f |
From 147cdce70b22ae7cee9fb4fe123db40952f31c9e Mon Sep 17 00:00:00 2001
|
|
Rex Dieter |
f5488f |
From: David Zeuthen <zeuthen@chromium.org>
|
|
Rex Dieter |
f5488f |
Date: Tue, 5 Mar 2013 11:52:38 -0800
|
|
Rex Dieter |
f5488f |
Subject: [PATCH 8/8] avahi-daemon: add option "host-name-from-machine-id="
|
|
Rex Dieter |
f5488f |
|
|
Rex Dieter |
f5488f |
Signed-off-by: David Zeuthen <zeuthen@chromium.org>
|
|
Rex Dieter |
f5488f |
---
|
|
Rex Dieter |
f5488f |
avahi-daemon/main.c | 33 +++++++++++++++++++++++++++++++++
|
|
Rex Dieter |
f5488f |
man/avahi-daemon.conf.5.xml.in | 6 ++++++
|
|
Rex Dieter |
f5488f |
2 files changed, 39 insertions(+)
|
|
Rex Dieter |
f5488f |
|
|
Rex Dieter |
f5488f |
diff --git a/avahi-daemon/main.c b/avahi-daemon/main.c
|
|
Rex Dieter |
f5488f |
index d46f40a..8c28fd6 100644
|
|
Rex Dieter |
f5488f |
--- a/avahi-daemon/main.c
|
|
Rex Dieter |
f5488f |
+++ b/avahi-daemon/main.c
|
|
Rex Dieter |
f5488f |
@@ -65,6 +65,7 @@
|
|
Rex Dieter |
f5488f |
#include <avahi-core/publish.h>
|
|
Rex Dieter |
f5488f |
#include <avahi-core/dns-srv-rr.h>
|
|
Rex Dieter |
f5488f |
#include <avahi-core/log.h>
|
|
Rex Dieter |
f5488f |
+#include <avahi-core/util.h>
|
|
Rex Dieter |
f5488f |
|
|
Rex Dieter |
f5488f |
#ifdef ENABLE_CHROOT
|
|
Rex Dieter |
f5488f |
#include "chroot.h"
|
|
Rex Dieter |
f5488f |
@@ -576,6 +577,29 @@ static int parse_usec(const char *s, AvahiUsec *u) {
|
|
Rex Dieter |
f5488f |
return 0;
|
|
Rex Dieter |
f5488f |
}
|
|
Rex Dieter |
f5488f |
|
|
Rex Dieter |
f5488f |
+static char *get_machine_id(void) {
|
|
Rex Dieter |
f5488f |
+ int fd;
|
|
Rex Dieter |
f5488f |
+ char buf[32];
|
|
Rex Dieter |
f5488f |
+
|
|
Rex Dieter |
f5488f |
+ fd = open("/etc/machine-id", O_RDONLY|O_CLOEXEC|O_NOCTTY);
|
|
Rex Dieter |
f5488f |
+ if (fd == -1 && errno == ENOENT)
|
|
Rex Dieter |
f5488f |
+ fd = open("/var/lib/dbus/machine-id", O_RDONLY|O_CLOEXEC|O_NOCTTY);
|
|
Rex Dieter |
f5488f |
+ if (fd == -1)
|
|
Rex Dieter |
f5488f |
+ return NULL;
|
|
Rex Dieter |
f5488f |
+
|
|
Rex Dieter |
f5488f |
+ /* File is on a filesystem so we never get EINTR or partial reads */
|
|
Rex Dieter |
f5488f |
+ if (read(fd, buf, sizeof buf) != sizeof buf) {
|
|
Rex Dieter |
f5488f |
+ close(fd);
|
|
Rex Dieter |
f5488f |
+ return NULL;
|
|
Rex Dieter |
f5488f |
+ }
|
|
Rex Dieter |
f5488f |
+ close(fd);
|
|
Rex Dieter |
f5488f |
+
|
|
Rex Dieter |
f5488f |
+ /* Contents can be lower, upper and even mixed case so normalize */
|
|
Rex Dieter |
f5488f |
+ avahi_strdown(buf);
|
|
Rex Dieter |
f5488f |
+
|
|
Rex Dieter |
f5488f |
+ return avahi_strndup(buf, sizeof buf);
|
|
Rex Dieter |
f5488f |
+}
|
|
Rex Dieter |
f5488f |
+
|
|
Rex Dieter |
f5488f |
static int load_config_file(DaemonConfig *c) {
|
|
Rex Dieter |
f5488f |
int r = -1;
|
|
Rex Dieter |
f5488f |
AvahiIniFile *f;
|
|
Rex Dieter |
f5488f |
@@ -631,6 +655,15 @@ static int load_config_file(DaemonConfig *c) {
|
|
Rex Dieter |
f5488f |
c->server_config.use_iff_running = is_yes(p->value);
|
|
Rex Dieter |
f5488f |
else if (strcasecmp(p->key, "disallow-other-stacks") == 0)
|
|
Rex Dieter |
f5488f |
c->server_config.disallow_other_stacks = is_yes(p->value);
|
|
Rex Dieter |
f5488f |
+ else if (strcasecmp(p->key, "host-name-from-machine-id") == 0) {
|
|
Rex Dieter |
f5488f |
+ if (*(p->value) == 'y' || *(p->value) == 'Y') {
|
|
Rex Dieter |
f5488f |
+ char *machine_id = get_machine_id();
|
|
Rex Dieter |
f5488f |
+ if (machine_id != NULL) {
|
|
Rex Dieter |
f5488f |
+ avahi_free(c->server_config.host_name);
|
|
Rex Dieter |
f5488f |
+ c->server_config.host_name = machine_id;
|
|
Rex Dieter |
f5488f |
+ }
|
|
Rex Dieter |
f5488f |
+ }
|
|
Rex Dieter |
f5488f |
+ }
|
|
Rex Dieter |
f5488f |
#ifdef HAVE_DBUS
|
|
Rex Dieter |
f5488f |
else if (strcasecmp(p->key, "enable-dbus") == 0) {
|
|
Rex Dieter |
f5488f |
|
|
Rex Dieter |
f5488f |
diff --git a/man/avahi-daemon.conf.5.xml.in b/man/avahi-daemon.conf.5.xml.in
|
|
Rex Dieter |
f5488f |
index bea7ed5..2d15017 100644
|
|
Rex Dieter |
f5488f |
--- a/man/avahi-daemon.conf.5.xml.in
|
|
Rex Dieter |
f5488f |
+++ b/man/avahi-daemon.conf.5.xml.in
|
|
Rex Dieter |
f5488f |
@@ -40,6 +40,12 @@
|
|
Rex Dieter |
f5488f |
</option>
|
|
Rex Dieter |
f5488f |
|
|
Rex Dieter |
f5488f |
<option>
|
|
Rex Dieter |
f5488f |
+ <opt>host-name-from-machine-id=</opt> Takes a boolean
|
|
Rex Dieter |
f5488f |
+ value ("yes" or "no"). If set to "yes" avahi-daemon
|
|
Rex Dieter |
f5488f |
+ will use the machine-id as name on the LAN.
|
|
Rex Dieter |
f5488f |
+ </option>
|
|
Rex Dieter |
f5488f |
+
|
|
Rex Dieter |
f5488f |
+ <option>
|
|
Rex Dieter |
f5488f |
<opt>domain-name=</opt> Set the default domain name avahi-daemon
|
|
Rex Dieter |
f5488f |
tries to register its host name and services on the LAN in. If
|
|
Rex Dieter |
f5488f |
omitted defaults to ".local".
|
|
Rex Dieter |
f5488f |
--
|
|
Rex Dieter |
f5488f |
1.9.3
|
|
Rex Dieter |
f5488f |
|