118548Sralph /* 221386Sdist * Copyright (c) 1985 Regents of the University of California. 321386Sdist * All rights reserved. The Berkeley software License Agreement 421386Sdist * specifies the terms and conditions for redistribution. 518548Sralph */ 618548Sralph 726633Sdonn #if defined(LIBC_SCCS) && !defined(lint) 8*31112Skarels static char sccsid[] = "@(#)res_init.c 6.6 (Berkeley) 05/12/87"; 926633Sdonn #endif LIBC_SCCS and not lint 1021386Sdist 1118142Sralph #include <sys/types.h> 1218142Sralph #include <sys/socket.h> 1318142Sralph #include <netinet/in.h> 1418142Sralph #include <stdio.h> 1524081Skjd #include <arpa/nameser.h> 1626902Skjd #include <resolv.h> 1718142Sralph 1818142Sralph /* 1924111Skjd * Resolver configuration file. Contains the address of the 2024111Skjd * inital name server to query and the default domain for 2124111Skjd * non fully qualified domain names. 2224111Skjd */ 2324111Skjd 2424111Skjd #ifdef CONFFILE 2525242Skjd char *conffile = CONFFILE; 2624111Skjd #else 2725242Skjd char *conffile = "/etc/resolv.conf"; 2824111Skjd #endif 2924111Skjd 3024111Skjd /* 3118142Sralph * Resolver state default settings 3218142Sralph */ 3325242Skjd 3418142Sralph struct state _res = { 35*31112Skarels RES_TIMEOUT, /* retransmition time interval */ 36*31112Skarels 4, /* number of times to retransmit */ 37*31112Skarels RES_DEFAULT, /* options flags */ 38*31112Skarels 1, /* number of name servers */ 3918142Sralph }; 4018142Sralph 4118142Sralph /* 4224736Sbloom * Set up default settings. If the configuration file exist, the values 4324736Sbloom * there will have precedence. Otherwise, the server address is set to 4424736Sbloom * INADDR_ANY and the default domain name comes from the gethostname(). 4524736Sbloom * 4624736Sbloom * The configuration file should only be used if you want to redefine your 4724736Sbloom * domain or run without a server on your machine. 4824736Sbloom * 4924736Sbloom * Return 0 if completes successfully, -1 on error 5018142Sralph */ 5118142Sralph res_init() 5218142Sralph { 5325242Skjd register FILE *fp; 54*31112Skarels register char *cp, **pp; 55*31112Skarels char buf[BUFSIZ]; 5625242Skjd extern u_long inet_addr(); 5725242Skjd extern char *index(); 5825242Skjd extern char *strcpy(), *strncpy(); 5925242Skjd extern char *getenv(); 6025242Skjd int n = 0; /* number of nameserver records read from file */ 6118142Sralph 6225242Skjd _res.nsaddr.sin_addr.s_addr = INADDR_ANY; 6325242Skjd _res.nsaddr.sin_family = AF_INET; 6425242Skjd _res.nsaddr.sin_port = htons(NAMESERVER_PORT); 6525242Skjd _res.nscount = 1; 6625242Skjd _res.defdname[0] = '\0'; 6718142Sralph 6825242Skjd if ((fp = fopen(conffile, "r")) != NULL) { 6925242Skjd /* read the config file */ 7025242Skjd while (fgets(buf, sizeof(buf), fp) != NULL) { 7125242Skjd /* read default domain name */ 7225242Skjd if (!strncmp(buf, "domain", sizeof("domain") - 1)) { 7325242Skjd cp = buf + sizeof("domain") - 1; 7425242Skjd while (*cp == ' ' || *cp == '\t') 7525242Skjd cp++; 7625242Skjd if (*cp == '\0') 7725242Skjd continue; 7825242Skjd (void)strncpy(_res.defdname, cp, sizeof(_res.defdname)); 7925242Skjd _res.defdname[sizeof(_res.defdname) - 1] = '\0'; 8025242Skjd if ((cp = index(_res.defdname, '\n')) != NULL) 8125242Skjd *cp = '\0'; 8225242Skjd continue; 8325242Skjd } 8425242Skjd /* read nameservers to query */ 8525242Skjd if (!strncmp(buf, "nameserver", 8625242Skjd sizeof("nameserver") - 1) && (n < MAXNS)) { 8725242Skjd cp = buf + sizeof("nameserver") - 1; 8825242Skjd while (*cp == ' ' || *cp == '\t') 8925242Skjd cp++; 9025242Skjd if (*cp == '\0') 9125242Skjd continue; 9225242Skjd _res.nsaddr_list[n].sin_addr.s_addr = inet_addr(cp); 9325242Skjd if (_res.nsaddr_list[n].sin_addr.s_addr == (unsigned)-1) 9425242Skjd _res.nsaddr_list[n].sin_addr.s_addr = INADDR_ANY; 9526902Skjd _res.nsaddr_list[n].sin_family = AF_INET; 9626902Skjd _res.nsaddr_list[n].sin_port = htons(NAMESERVER_PORT); 9726902Skjd if ( ++n >= MAXNS) { 9826902Skjd n = MAXNS; 9925242Skjd #ifdef DEBUG 10026902Skjd if ( _res.options & RES_DEBUG ) 10126902Skjd printf("MAXNS reached, reading resolv.conf\n"); 10225242Skjd #endif DEBUG 10325242Skjd } 10425242Skjd continue; 10525242Skjd } 10625242Skjd } 10725242Skjd if ( n > 1 ) 10825242Skjd _res.nscount = n; 10925242Skjd (void) fclose(fp); 11025242Skjd } 11125242Skjd if (_res.defdname[0] == 0) { 11225242Skjd if (gethostname(buf, sizeof(_res.defdname)) == 0 && 11325242Skjd (cp = index(buf, '.'))) 11425242Skjd (void)strcpy(_res.defdname, cp + 1); 11525242Skjd } 11618142Sralph 11725242Skjd /* Allow user to override the local domain definition */ 11825242Skjd if ((cp = getenv("LOCALDOMAIN")) != NULL) 11925242Skjd (void)strncpy(_res.defdname, cp, sizeof(_res.defdname)); 120*31112Skarels 121*31112Skarels /* find components of local domain that might be searched */ 122*31112Skarels pp = _res.dnsrch; 123*31112Skarels *pp++ = _res.defdname; 124*31112Skarels for (cp = _res.defdname, n = 0; *cp; cp++) 125*31112Skarels if (*cp == '.') 126*31112Skarels n++; 127*31112Skarels cp = _res.defdname; 128*31112Skarels for (; n >= LOCALDOMAINPARTS && pp < _res.dnsrch + MAXDNSRCH; n--) { 129*31112Skarels cp = index(cp, '.'); 130*31112Skarels *pp++ = ++cp; 131*31112Skarels } 13225242Skjd _res.options |= RES_INIT; 13325242Skjd return(0); 13418142Sralph } 135