Annotation of src/usr.bin/ypwhich/ypwhich.c, Revision 1.1
1.1 ! deraadt 1: /*
! 2: * Copyright (c) 1992, 1993 Theo de Raadt <deraadt@fsa.ca>
! 3: * All rights reserved.
! 4: *
! 5: * Redistribution and use in source and binary forms, with or without
! 6: * modification, are permitted provided that the following conditions
! 7: * are met:
! 8: * 1. Redistributions of source code must retain the above copyright
! 9: * notice, this list of conditions and the following disclaimer.
! 10: * 2. Redistributions in binary form must reproduce the above copyright
! 11: * notice, this list of conditions and the following disclaimer in the
! 12: * documentation and/or other materials provided with the distribution.
! 13: * 3. All advertising materials mentioning features or use of this software
! 14: * must display the following acknowledgement:
! 15: * This product includes software developed by Theo de Raadt.
! 16: * 4. The name of the author may not be used to endorse or promote
! 17: * products derived from this software without specific prior written
! 18: * permission.
! 19: *
! 20: * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
! 21: * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
! 22: * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
! 23: * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
! 24: * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
! 25: * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
! 26: * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
! 27: * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
! 28: * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
! 29: * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
! 30: * SUCH DAMAGE.
! 31: */
! 32:
! 33: #ifndef LINT
! 34: static char rcsid[] = "$Id: ypwhich.c,v 1.5 1995/05/21 15:42:54 mycroft Exp $";
! 35: #endif
! 36:
! 37: #include <sys/param.h>
! 38: #include <sys/types.h>
! 39: #include <sys/socket.h>
! 40: #include <stdio.h>
! 41: #include <stdlib.h>
! 42: #include <ctype.h>
! 43: #include <netdb.h>
! 44: #include <rpc/rpc.h>
! 45: #include <rpc/xdr.h>
! 46: #include <rpcsvc/yp_prot.h>
! 47: #include <rpcsvc/ypclnt.h>
! 48:
! 49: extern bool_t xdr_domainname();
! 50:
! 51: struct ypalias {
! 52: char *alias, *name;
! 53: } ypaliases[] = {
! 54: { "passwd", "passwd.byname" },
! 55: { "group", "group.byname" },
! 56: { "networks", "networks.byaddr" },
! 57: { "hosts", "hosts.byaddr" },
! 58: { "protocols", "protocols.bynumber" },
! 59: { "services", "services.byname" },
! 60: { "aliases", "mail.aliases" },
! 61: { "ethers", "ethers.byname" },
! 62: };
! 63:
! 64: usage()
! 65: {
! 66: fprintf(stderr, "Usage:\n");
! 67: fprintf(stderr, "\typwhich [-d domain] [[-t] -m [mname] | host]\n");
! 68: fprintf(stderr, "\typwhich -x\n");
! 69: exit(1);
! 70: }
! 71:
! 72:
! 73: /*
! 74: * Like yp_bind except can query a specific host
! 75: */
! 76: bind_host(dom, sin)
! 77: char *dom;
! 78: struct sockaddr_in *sin;
! 79: {
! 80: struct hostent *hent = NULL;
! 81: struct ypbind_resp ypbr;
! 82: struct dom_binding *ysd;
! 83: struct timeval tv;
! 84: CLIENT *client;
! 85: int sock, r;
! 86: u_long ss_addr;
! 87:
! 88: sock = RPC_ANYSOCK;
! 89: tv.tv_sec = 15;
! 90: tv.tv_usec = 0;
! 91: client = clntudp_create(sin, YPBINDPROG, YPBINDVERS, tv, &sock);
! 92: if(client==NULL) {
! 93: fprintf(stderr, "can't clntudp_create: %s\n",
! 94: yperr_string(YPERR_YPBIND));
! 95: return YPERR_YPBIND;
! 96: }
! 97:
! 98: tv.tv_sec = 5;
! 99: tv.tv_usec = 0;
! 100: r = clnt_call(client, YPBINDPROC_DOMAIN,
! 101: xdr_domainname, dom, xdr_ypbind_resp, &ypbr, tv);
! 102: if( r != RPC_SUCCESS) {
! 103: fprintf(stderr, "can't clnt_call: %s\n",
! 104: yperr_string(YPERR_YPBIND));
! 105: clnt_destroy(client);
! 106: return YPERR_YPBIND;
! 107: } else {
! 108: if (ypbr.ypbind_status != YPBIND_SUCC_VAL) {
! 109: fprintf(stderr, "can't yp_bind: Reason: %s\n",
! 110: yperr_string(ypbr.ypbind_status));
! 111: clnt_destroy(client);
! 112: return r;
! 113: }
! 114: }
! 115: clnt_destroy(client);
! 116:
! 117: ss_addr = ypbr.ypbind_respbody.ypbind_bindinfo.ypbind_binding_addr.s_addr;
! 118: /*printf("%08x\n", ss_addr);*/
! 119: hent = gethostbyaddr((char *)&ss_addr, sizeof(ss_addr), AF_INET);
! 120: if (hent)
! 121: printf("%s\n", hent->h_name);
! 122: else
! 123: printf("%s\n", inet_ntoa(ss_addr));
! 124: return 0;
! 125: }
! 126:
! 127: int
! 128: main(argc, argv)
! 129: char **argv;
! 130: {
! 131: char *domainname, *master, *map;
! 132: struct ypmaplist *ypml, *y;
! 133: struct hostent *hent;
! 134: struct sockaddr_in sin;
! 135: int notrans, mode, getmap;
! 136: int c, r, i;
! 137:
! 138: yp_get_default_domain(&domainname);
! 139:
! 140: map = NULL;
! 141: getmap = notrans = mode = 0;
! 142: while( (c=getopt(argc, argv, "xd:mt")) != -1)
! 143: switch(c) {
! 144: case 'x':
! 145: for(i=0; i<sizeof ypaliases/sizeof ypaliases[0]; i++)
! 146: printf("Use \"%s\" for \"%s\"\n",
! 147: ypaliases[i].alias,
! 148: ypaliases[i].name);
! 149: exit(0);
! 150: case 'd':
! 151: domainname = optarg;
! 152: break;
! 153: case 't':
! 154: notrans++;
! 155: break;
! 156: case 'm':
! 157: mode++;
! 158: break;
! 159: default:
! 160: usage();
! 161: }
! 162: argc -= optind;
! 163: argv += optind;
! 164:
! 165: if(mode==0) {
! 166: switch(argc) {
! 167: case 0:
! 168: bzero(&sin, sizeof sin);
! 169: sin.sin_family = AF_INET;
! 170: sin.sin_addr.s_addr = htonl(INADDR_LOOPBACK);
! 171:
! 172: if(bind_host(domainname, &sin))
! 173: exit(1);
! 174: break;
! 175: case 1:
! 176: bzero(&sin, sizeof sin);
! 177: sin.sin_family = AF_INET;
! 178: if (inet_aton(argv[0], &sin.sin_addr) == 0) {
! 179: hent = gethostbyname(argv[0]);
! 180: if(!hent) {
! 181: fprintf(stderr, "ypwhich: host %s unknown\n",
! 182: argv[0]);
! 183: exit(1);
! 184: }
! 185: bcopy((char *)hent->h_addr,
! 186: (char *)&sin.sin_addr, sizeof sin.sin_addr);
! 187: }
! 188: if(bind_host(domainname, &sin))
! 189: exit(1);
! 190: break;
! 191: default:
! 192: usage();
! 193: }
! 194: exit(0);
! 195: }
! 196:
! 197: if( argc > 1)
! 198: usage();
! 199:
! 200: if(argv[0]) {
! 201: map = argv[0];
! 202: for(i=0; (!notrans) && i<sizeof ypaliases/sizeof ypaliases[0]; i++)
! 203: if( strcmp(map, ypaliases[i].alias) == 0)
! 204: map = ypaliases[i].name;
! 205: r = yp_master(domainname, map, &master);
! 206: switch(r) {
! 207: case 0:
! 208: printf("%s\n", master);
! 209: free(master);
! 210: break;
! 211: case YPERR_YPBIND:
! 212: fprintf(stderr, "ypwhich: not running ypbind\n");
! 213: exit(1);
! 214: default:
! 215: fprintf(stderr, "Can't find master for map %s. Reason: %s\n",
! 216: map, yperr_string(r));
! 217: exit(1);
! 218: }
! 219: exit(0);
! 220: }
! 221:
! 222: ypml = NULL;
! 223: r = yp_maplist(domainname, &ypml);
! 224: switch(r) {
! 225: case 0:
! 226: for(y=ypml; y; ) {
! 227: ypml = y;
! 228: r = yp_master(domainname, ypml->ypml_name, &master);
! 229: switch(r) {
! 230: case 0:
! 231: printf("%s %s\n", ypml->ypml_name, master);
! 232: free(master);
! 233: break;
! 234: default:
! 235: fprintf(stderr,
! 236: "YP: can't find the master of %s: Reason: %s\n",
! 237: ypml->ypml_name, yperr_string(r));
! 238: break;
! 239: }
! 240: y = ypml->ypml_next;
! 241: free(ypml);
! 242: }
! 243: break;
! 244: case YPERR_YPBIND:
! 245: fprintf(stderr, "ypwhich: not running ypbind\n");
! 246: exit(1);
! 247: default:
! 248: fprintf(stderr, "Can't get map list for domain %s. Reason: %s\n",
! 249: domainname, yperr_string(r));
! 250: exit(1);
! 251: }
! 252: exit(0);
! 253: }