actually add libbb/safe_gethostname.c
authorDenis Vlasenko <vda.linux@googlemail.com>
Mon, 25 Feb 2008 23:24:32 +0000 (23:24 -0000)
committerDenis Vlasenko <vda.linux@googlemail.com>
Mon, 25 Feb 2008 23:24:32 +0000 (23:24 -0000)
libbb/safe_gethostname.c [new file with mode: 0644]

diff --git a/libbb/safe_gethostname.c b/libbb/safe_gethostname.c
new file mode 100644 (file)
index 0000000..1290f4c
--- /dev/null
@@ -0,0 +1,53 @@
+/* vi: set sw=4 ts=4: */
+/*
+ * Safe gethostname implementation for busybox
+ *
+ * Copyright (C) 2008 Tito Ragusa <farmatito@tiscali.it>
+ *
+ * Licensed under GPLv2 or later, see file LICENSE in this tarball for details.
+ */
+
+/*
+ * SUSv2 guarantees that "Host names are limited to 255 bytes"
+ * POSIX.1-2001 guarantees that "Host names (not including the terminating
+ * null byte) are limited to HOST_NAME_MAX bytes" (64 bytes on my box).
+ *
+ * RFC1123 says:
+ *
+ * The syntax of a legal Internet host name was specified in RFC-952
+ * [DNS:4].  One aspect of host name syntax is hereby changed: the
+ * restriction on the first character is relaxed to allow either a
+ * letter or a digit.  Host software MUST support this more liberal
+ * syntax.
+ *
+ * Host software MUST handle host names of up to 63 characters and
+ * SHOULD handle host names of up to 255 characters.
+ */
+
+#include "libbb.h"
+#include <sys/utsname.h>
+
+/*
+ * On success return the current malloced and NUL terminated hostname.
+ * On error return malloced and NUL terminated string "?".
+ * This is an illegal first character for a hostname.
+ * The returned malloced string must be freed by the caller.
+ */
+char *safe_gethostname(void)
+{
+       struct utsname uts;
+
+       /* The length of the arrays in a struct utsname is unspecified;
+        * the fields are terminated by a null byte.
+        * Note that there is no standard that says that the hostname
+        * set by sethostname(2) is the same string as the nodename field of the
+        * struct returned by uname (indeed, some systems allow a 256-byte host-
+        * name and an 8-byte nodename), but this is true on Linux. The same holds
+        * for setdomainname(2) and the domainname field.
+        */
+       
+       /* Uname can fail only if you pass a bad pointer to it. */
+       uname(&uts);
+
+       return xstrndup(!*(uts.nodename) ? "?" : uts.nodename, sizeof(uts.nodename));
+}