| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194 |
- /** BEGIN COPYRIGHT BLOCK
- * This Program is free software; you can redistribute it and/or modify it under
- * the terms of the GNU General Public License as published by the Free Software
- * Foundation; version 2 of the License.
- *
- * This Program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
- * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License along with
- * this Program; if not, write to the Free Software Foundation, Inc., 59 Temple
- * Place, Suite 330, Boston, MA 02111-1307 USA.
- *
- * In addition, as a special exception, Red Hat, Inc. gives You the additional
- * right to link the code of this Program with code not covered under the GNU
- * General Public License ("Non-GPL Code") and to distribute linked combinations
- * including the two, subject to the limitations in this paragraph. Non-GPL Code
- * permitted under this exception must only link to the code of this Program
- * through those well defined interfaces identified in the file named EXCEPTION
- * found in the source code files (the "Approved Interfaces"). The files of
- * Non-GPL Code may instantiate templates or use macros or inline functions from
- * the Approved Interfaces without causing the resulting work to be covered by
- * the GNU General Public License. Only Red Hat, Inc. may make changes or
- * additions to the list of Approved Interfaces. You must obey the GNU General
- * Public License in all respects for all of the Program code and other code used
- * in conjunction with the Program except the Non-GPL Code covered by this
- * exception. If you modify this file, you may extend this exception to your
- * version of the file, but you are not obligated to do so. If you do not wish to
- * provide this exception without modification, you must delete this exception
- * statement from your version and license this file solely under the GPL without
- * exception.
- *
- *
- * Copyright (C) 2001 Sun Microsystems, Inc. Used by permission.
- * Copyright (C) 2005 Red Hat, Inc.
- * All rights reserved.
- * END COPYRIGHT BLOCK **/
- #ifdef HAVE_CONFIG_H
- # include <config.h>
- #endif
- /*
- * dnsdmain.c: DNS domain guessing stuff moved out of dns.c because of the
- * string ball problems
- */
- #include "netsite.h"
- #include <string.h>
- #include <stdio.h>
- #ifdef XP_UNIX
- #include <unistd.h>
- #endif
- #include <ctype.h>
- #include "util.h"
- /* Under NT, this is taken care of by net.h including winsock.h */
- #ifdef XP_UNIX
- #include <netdb.h> /* struct hostent */
- #endif
- extern "C" {
- #include <nspr.h>
- }
- /* This is contained in resolv.h on most systems. */
- #define _PATH_RESCONF "/etc/resolv.conf"
- #ifdef XP_UNIX
- NSPR_BEGIN_EXTERN_C
- #ifdef Linux
- extern int getdomainname(char *, size_t);
- #else
- extern int getdomainname(char *, int);
- #endif /* Linux */
- #if defined(HPUX) || defined (UnixWare) || defined(Linux) || defined(IRIX6_5) || defined(SOLARIS_GCC)
- extern int gethostname (char *name, size_t namelen);
- #else
- #ifndef AIX
- extern int gethostname (char *name, int namelen);
- #endif
- #endif
- NSPR_END_EXTERN_C
- #endif
- /* ---------------------------- dns_guess_domain -------------------------- */
- extern "C" NSAPI_PUBLIC char *dns_guess_domain(char * hname)
- {
- FILE *f;
- char * cp;
- int hnlen;
- char line[256];
- static int dnlen = 0;
- static char * domain = 0;
- PRHostEnt hent;
- char buf[PR_NETDB_BUF_SIZE];
- PRStatus err;
- /* Sanity check */
- if (strchr(hname, '.')) {
- return STRDUP(hname);
- }
- if (dnlen == 0) {
- /* First try a little trick that seems to often work... */
- /*
- * Get the local host name, even it doesn't come back
- * fully qualified.
- */
- line[0] = 0;
- gethostname(line, sizeof(line));
- if (line[0] != 0) {
- /* Is it fully qualified? */
- domain = strchr(line, '.');
- if (domain == 0) {
- /* No, try gethostbyname() */
- err = PR_GetHostByName(line,
- buf,
- PR_NETDB_BUF_SIZE,
- &hent);
- if (err == PR_SUCCESS) {
- /* See if h_name is fully-qualified */
- if (hent.h_name) domain = strchr(hent.h_name, '.');
- /* Otherwise look for a fully qualified alias */
- if ((domain == 0) &&
- (hent.h_aliases && hent.h_aliases[0])) {
- char **p;
- for (p = hent.h_aliases; *p; ++p) {
- domain = strchr(*p, '.');
- if (domain) break;
- }
- }
- }
- }
- }
- /* Still no luck? */
- if (domain == 0) {
- f = fopen(_PATH_RESCONF, "r");
- /* See if there's a domain entry in their resolver configuration */
- if(f) {
- while(fgets(line, sizeof(line), f)) {
- if(!strncasecmp(line, "domain ", 7)) {
- for (cp = &line[7]; *cp && isspace(*cp); ++cp) ;
- if (*cp) {
- domain = cp;
- for (; *cp && !isspace(*cp); ++cp) ;
- *cp = 0;
- }
- break;
- }
- }
- fclose(f);
- }
- }
- #ifndef NO_DOMAINNAME
- if (domain == 0) {
- /* No domain found. Try getdomainname. */
- getdomainname(line, sizeof(line));
- if (line[0] != 0) domain = &line[0];
- }
- #endif
- if (domain != 0) {
- if (domain[0] == '.') ++domain;
- domain = STRDUP(domain);
- dnlen = strlen(domain);
- }
- else dnlen = -1;
- }
- if (domain != 0) {
- hnlen = strlen(hname);
- if ((size_t)(hnlen + dnlen + 2) <= sizeof(line)) {
- strcpy(line, hname);
- line[hnlen] = '.';
- strcpy(&line[hnlen+1], domain);
- return STRDUP(line);
- }
- }
- return 0;
- }
|