ypset.c revision 1.4
11.2Sderaadt/* 21.2Sderaadt * Copyright (c) 1992/3 Theo de Raadt <deraadt@fsa.ca> 31.2Sderaadt * All rights reserved. 41.2Sderaadt * 51.2Sderaadt * Redistribution and use in source and binary forms, with or without 61.2Sderaadt * modification, are permitted provided that the following conditions 71.2Sderaadt * are met: 81.2Sderaadt * 1. Redistributions of source code must retain the above copyright 91.2Sderaadt * notice, this list of conditions and the following disclaimer. 101.2Sderaadt * 2. Redistributions in binary form must reproduce the above copyright 111.2Sderaadt * notice, this list of conditions and the following disclaimer in the 121.2Sderaadt * documentation and/or other materials provided with the distribution. 131.2Sderaadt * 3. The name of the author may not be used to endorse or promote 141.2Sderaadt * products derived from this software without specific prior written 151.2Sderaadt * permission. 161.2Sderaadt * 171.2Sderaadt * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS 181.2Sderaadt * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 191.2Sderaadt * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 201.2Sderaadt * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY 211.2Sderaadt * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 221.2Sderaadt * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 231.2Sderaadt * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 241.2Sderaadt * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 251.2Sderaadt * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 261.2Sderaadt * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 271.2Sderaadt * SUCH DAMAGE. 281.2Sderaadt */ 291.2Sderaadt 301.2Sderaadt#ifndef LINT 311.4Sbrezakstatic char rcsid[] = "ypset.c,v 1.3 1993/06/12 00:02:37 deraadt Exp"; 321.2Sderaadt#endif 331.2Sderaadt 341.1Sderaadt#include <sys/param.h> 351.1Sderaadt#include <sys/types.h> 361.1Sderaadt#include <sys/socket.h> 371.1Sderaadt#include <stdio.h> 381.1Sderaadt#include <netdb.h> 391.1Sderaadt#include <rpc/rpc.h> 401.1Sderaadt#include <rpc/xdr.h> 411.1Sderaadt#include <rpcsvc/yp_prot.h> 421.1Sderaadt#include <rpcsvc/ypclnt.h> 431.4Sbrezak#include <arpa/inet.h> 441.1Sderaadt 451.1Sderaadtextern bool_t xdr_domainname(); 461.1Sderaadt 471.1Sderaadtusage() 481.1Sderaadt{ 491.1Sderaadt fprintf(stderr, "Usage:\n"); 501.1Sderaadt fprintf(stderr, "\typset [-h host ] [-d domain] server\n"); 511.1Sderaadt exit(1); 521.1Sderaadt} 531.1Sderaadt 541.1Sderaadtbind_tohost(sin, dom, server) 551.1Sderaadtstruct sockaddr_in *sin; 561.1Sderaadtchar *dom, *server; 571.1Sderaadt{ 581.1Sderaadt struct ypbind_setdom ypsd; 591.1Sderaadt struct timeval tv; 601.4Sbrezak struct hostent *hp; 611.1Sderaadt CLIENT *client; 621.1Sderaadt int sock, port; 631.1Sderaadt int r; 641.4Sbrezak unsigned long server_addr; 651.1Sderaadt 661.1Sderaadt if( (port=htons(getrpcport(server, YPPROG, YPPROC_NULL, IPPROTO_UDP))) == 0) { 671.1Sderaadt fprintf(stderr, "%s not running ypserv.\n", server); 681.1Sderaadt exit(1); 691.1Sderaadt } 701.1Sderaadt 711.1Sderaadt bzero(&ypsd, sizeof ypsd); 721.4Sbrezak 731.4Sbrezak if( (hp = gethostbyname (server)) != NULL ) { 741.4Sbrezak /* is this the most compatible way?? */ 751.4Sbrezak bcopy (hp->h_addr_list[0], &ypsd.ypsetdom_addr, 761.4Sbrezak sizeof (ypsd.ypsetdom_addr)); 771.4Sbrezak } else if( (long)(server_addr = inet_addr (server)) == -1) { 781.4Sbrezak fprintf(stderr, "can't find address for %s\n", server); 791.4Sbrezak exit(1); 801.4Sbrezak } else 811.4Sbrezak bcopy (&server_addr, &ypsd.ypsetdom_addr, 821.4Sbrezak sizeof (server_addr)); 831.4Sbrezak 841.1Sderaadt strncpy(ypsd.ypsetdom_domain, dom, sizeof ypsd.ypsetdom_domain); 851.4Sbrezak ypsd.ypsetdom_port = port; 861.1Sderaadt ypsd.ypsetdom_vers = YPVERS; 871.1Sderaadt 881.1Sderaadt tv.tv_sec = 15; 891.1Sderaadt tv.tv_usec = 0; 901.1Sderaadt sock = RPC_ANYSOCK; 911.3Sderaadt client = clntudp_create(sin, YPBINDPROG, YPBINDVERS, tv, &sock); 921.1Sderaadt if (client==NULL) { 931.1Sderaadt fprintf(stderr, "can't yp_bind: Reason: %s\n", 941.1Sderaadt yperr_string(YPERR_YPBIND)); 951.1Sderaadt return YPERR_YPBIND; 961.1Sderaadt } 971.1Sderaadt client->cl_auth = authunix_create_default(); 981.1Sderaadt 991.1Sderaadt r = clnt_call(client, YPBINDPROC_SETDOM, 1001.1Sderaadt xdr_ypbind_setdom, &ypsd, xdr_void, NULL, tv); 1011.1Sderaadt if(r) { 1021.1Sderaadt fprintf(stderr, "Sorry, cannot ypset for domain %s on host.\n", dom); 1031.1Sderaadt clnt_destroy(client); 1041.1Sderaadt return YPERR_YPBIND; 1051.1Sderaadt } 1061.1Sderaadt clnt_destroy(client); 1071.1Sderaadt return 0; 1081.1Sderaadt} 1091.1Sderaadt 1101.1Sderaadtint 1111.1Sderaadtmain(argc, argv) 1121.1Sderaadtchar **argv; 1131.1Sderaadt{ 1141.1Sderaadt struct sockaddr_in sin; 1151.1Sderaadt struct hostent *hent; 1161.1Sderaadt extern char *optarg; 1171.1Sderaadt extern int optind; 1181.1Sderaadt char *domainname; 1191.1Sderaadt int c; 1201.1Sderaadt 1211.1Sderaadt yp_get_default_domain(&domainname); 1221.1Sderaadt 1231.1Sderaadt bzero(&sin, sizeof sin); 1241.1Sderaadt sin.sin_family = AF_INET; 1251.1Sderaadt sin.sin_addr.s_addr = htonl(0x7f000001); 1261.1Sderaadt 1271.1Sderaadt while( (c=getopt(argc, argv, "h:d:")) != -1) 1281.1Sderaadt switch(c) { 1291.1Sderaadt case 'd': 1301.1Sderaadt domainname = optarg; 1311.1Sderaadt break; 1321.1Sderaadt case 'h': 1331.1Sderaadt if( (sin.sin_addr.s_addr=inet_addr(optarg)) == -1) { 1341.1Sderaadt hent = gethostbyname(optarg); 1351.1Sderaadt if(hent==NULL) { 1361.1Sderaadt fprintf(stderr, "ypset: host %s unknown\n", 1371.1Sderaadt optarg); 1381.1Sderaadt exit(1); 1391.1Sderaadt } 1401.1Sderaadt bcopy(&hent->h_addr_list[0], &sin.sin_addr, 1411.1Sderaadt sizeof sin.sin_addr); 1421.1Sderaadt } 1431.1Sderaadt break; 1441.1Sderaadt default: 1451.1Sderaadt usage(); 1461.1Sderaadt } 1471.1Sderaadt 1481.1Sderaadt if(optind + 1 != argc ) 1491.1Sderaadt usage(); 1501.1Sderaadt 1511.1Sderaadt if (bind_tohost(&sin, domainname, argv[optind])) 1521.1Sderaadt exit(1); 1531.1Sderaadt exit(0); 1541.1Sderaadt} 155