/*++ /* NAME /* get_domainname 3 /* SUMMARY /* network domain name lookup /* SYNOPSIS /* #include /* /* const char *get_domainname() /* DESCRIPTION /* get_domainname() returns the local domain name as obtained /* by stripping the hostname component from the result from /* get_hostname(). The result is the hostname when get_hostname() /* does not return a FQDN form ("foo"), or its result has only two /* components ("foo.com"). /* DIAGNOSTICS /* Fatal errors: no hostname, invalid hostname. /* SEE ALSO /* get_hostname(3) /* LICENSE /* .ad /* .fi /* The Secure Mailer license must be distributed with this software. /* AUTHOR(S) /* Wietse Venema /* IBM T.J. Watson Research /* P.O. Box 704 /* Yorktown Heights, NY 10598, USA /*--*/ /* System library. */ #include #include /* Utility library. */ #include "mymalloc.h" #include "get_hostname.h" #include "get_domainname.h" /* Local stuff. */ static char *my_domain_name; /* get_domainname - look up my domain name */ const char *get_domainname(void) { const char *host; const char *dot; /* * Use the hostname when it is not a FQDN ("foo"), or when the hostname * actually is a domain name ("foo.com"). */ if (my_domain_name == 0) { host = get_hostname(); if ((dot = strchr(host, '.')) == 0 || strchr(dot + 1, '.') == 0) { my_domain_name = mystrdup(host); } else { my_domain_name = mystrdup(dot + 1); } } return (my_domain_name); }