diff options
author | Denis Vlasenko <vda.linux@googlemail.com> | 2008-02-25 23:24:32 +0000 |
---|---|---|
committer | Denis Vlasenko <vda.linux@googlemail.com> | 2008-02-25 23:24:32 +0000 |
commit | d686482d050da3a71eb9a50617b16d509c78b7c3 (patch) | |
tree | 003bb9f452d2f20f4e1d52c9df6399a86e40e989 /libbb | |
parent | 6f1713f216fef686a68db5ee02232bc67e525c7d (diff) | |
download | busybox-d686482d050da3a71eb9a50617b16d509c78b7c3.tar.gz |
actually add libbb/safe_gethostname.c
Diffstat (limited to 'libbb')
-rw-r--r-- | libbb/safe_gethostname.c | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/libbb/safe_gethostname.c b/libbb/safe_gethostname.c new file mode 100644 index 000000000..1290f4ca7 --- /dev/null +++ b/libbb/safe_gethostname.c @@ -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)); +} |