Home | History | Annotate | Line # | Download | only in yptest
yptest.c revision 1.9.36.1
      1  1.9.36.1  pgoyette /*	$NetBSD: yptest.c,v 1.9.36.1 2017/05/11 02:58:44 pgoyette Exp $	 */
      2       1.1   thorpej 
      3       1.1   thorpej /*
      4       1.1   thorpej  * Copyright (c) 1994 Mats O Jansson <moj (at) stacken.kth.se>
      5       1.1   thorpej  * All rights reserved.
      6       1.1   thorpej  *
      7       1.1   thorpej  * Redistribution and use in source and binary forms, with or without
      8       1.1   thorpej  * modification, are permitted provided that the following conditions
      9       1.1   thorpej  * are met:
     10       1.1   thorpej  * 1. Redistributions of source code must retain the above copyright
     11       1.1   thorpej  *    notice, this list of conditions and the following disclaimer.
     12       1.1   thorpej  * 2. Redistributions in binary form must reproduce the above copyright
     13       1.1   thorpej  *    notice, this list of conditions and the following disclaimer in the
     14       1.1   thorpej  *    documentation and/or other materials provided with the distribution.
     15       1.1   thorpej  *
     16       1.1   thorpej  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
     17       1.1   thorpej  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
     18       1.1   thorpej  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     19       1.1   thorpej  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
     20       1.1   thorpej  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     21       1.1   thorpej  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     22       1.1   thorpej  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     23       1.1   thorpej  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     24       1.1   thorpej  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     25       1.1   thorpej  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     26       1.1   thorpej  * SUCH DAMAGE.
     27       1.1   thorpej  */
     28       1.3     lukem 
     29       1.3     lukem #include <sys/cdefs.h>
     30       1.3     lukem #ifndef lint
     31  1.9.36.1  pgoyette __RCSID("$NetBSD: yptest.c,v 1.9.36.1 2017/05/11 02:58:44 pgoyette Exp $");
     32       1.3     lukem #endif
     33       1.1   thorpej 
     34       1.1   thorpej #include <sys/types.h>
     35       1.1   thorpej #include <err.h>
     36       1.1   thorpej #include <stdio.h>
     37       1.4      matt #include <stdlib.h>
     38       1.1   thorpej #include <string.h>
     39       1.1   thorpej #include <unistd.h>
     40       1.1   thorpej 
     41       1.1   thorpej #include <rpc/rpc.h>
     42       1.1   thorpej #include <rpc/xdr.h>
     43       1.1   thorpej #include <rpcsvc/yp_prot.h>
     44       1.1   thorpej #include <rpcsvc/ypclnt.h>
     45       1.1   thorpej 
     46       1.6       wiz static	int yptest_foreach(int, char *, int, char *, int, char *);
     47       1.1   thorpej 
     48       1.1   thorpej int
     49       1.6       wiz main(int argc, char **argv)
     50       1.1   thorpej {
     51       1.1   thorpej 	char *Domain, *Value, *Key2;
     52       1.8     peter 	const char *Map = "passwd.byname";
     53       1.8     peter 	const char *Key = "root";
     54       1.1   thorpej 	int KeyLen, ValLen, Status, Order;
     55       1.1   thorpej 	struct ypall_callback Callback;
     56       1.1   thorpej 	struct ypmaplist *ypml, *y;
     57       1.1   thorpej 
     58       1.1   thorpej 	if (argc != 1) {
     59       1.5       cgd 		fprintf(stderr, "usage: %s\n", getprogname());
     60       1.1   thorpej 		exit(1);
     61       1.1   thorpej 	}
     62       1.1   thorpej 
     63       1.7     peter 	Status = yp_get_default_domain(&Domain);
     64       1.7     peter 	if (Status != 0) {
     65       1.7     peter 		printf("Can't get YP domain name: %s\n", yperr_string(Status));
     66       1.7     peter 		exit(1);
     67       1.7     peter 	}
     68       1.1   thorpej 
     69       1.1   thorpej 	printf("Test 1: yp_match\n");
     70       1.1   thorpej 	KeyLen = strlen(Key);
     71       1.1   thorpej 	Status = yp_match(Domain, Map, Key, KeyLen, &Value, &ValLen);
     72       1.7     peter 	if (Status == 0)
     73       1.7     peter 		printf("%*.*s\n", ValLen, ValLen, Value);
     74       1.7     peter 	else
     75       1.7     peter 		printf("yp error: %s\n", yperr_string(Status));
     76       1.1   thorpej 
     77       1.1   thorpej 	printf("\nTest 2: yp_first\n");
     78       1.1   thorpej 	Status = yp_first(Domain, Map, &Key2, &KeyLen, &Value, &ValLen);
     79       1.7     peter 	if (Status == 0)
     80       1.7     peter 		printf("%*.*s %*.*s\n", KeyLen, KeyLen, Key2, ValLen, ValLen,
     81       1.7     peter 		    Value);
     82       1.7     peter 	else
     83       1.7     peter 		printf("yp error: %s\n", yperr_string(Status));
     84       1.1   thorpej 
     85       1.1   thorpej 	printf("\nTest 3: yp_next\n");
     86       1.1   thorpej 	while (Status == 0) {
     87       1.1   thorpej 		Status = yp_next(Domain, Map, Key2, KeyLen, &Key2,
     88       1.1   thorpej 		    &KeyLen, &Value, &ValLen);
     89       1.1   thorpej 		if (Status == 0)
     90       1.1   thorpej 			printf("%*.*s %*.*s\n", KeyLen, KeyLen, Key2,
     91       1.1   thorpej 			    ValLen, ValLen, Value);
     92       1.7     peter 		else
     93       1.7     peter 			printf("yp error: %s\n", yperr_string(Status));
     94       1.1   thorpej 	}
     95       1.1   thorpej 
     96       1.1   thorpej 	printf("\nTest 4: yp_master\n");
     97       1.1   thorpej 	Status = yp_master(Domain, Map, &Key2);
     98       1.7     peter 	if (Status == 0)
     99       1.7     peter 		printf("%s\n", Key2);
    100       1.7     peter 	else
    101       1.7     peter 		printf("yp error: %s\n", yperr_string(Status));
    102       1.1   thorpej 
    103       1.1   thorpej 	printf("\nTest 5: yp_order\n");
    104       1.1   thorpej 	Status = yp_order(Domain, Map, &Order);
    105       1.7     peter 	if (Status == 0)
    106       1.7     peter 		printf("%d\n", Order);
    107       1.7     peter 	else
    108       1.7     peter 		printf("yp error: %s\n", yperr_string(Status));
    109       1.1   thorpej 
    110       1.1   thorpej 	printf("\nTest 6: yp_maplist\n");
    111       1.1   thorpej 	ypml = NULL;
    112       1.1   thorpej 	switch (yp_maplist(Domain, &ypml)) {
    113       1.1   thorpej 	case 0:
    114       1.1   thorpej 		for (y = ypml; y;) {
    115       1.1   thorpej 			ypml = y;
    116       1.1   thorpej 			printf("%s\n", ypml->ypml_name);
    117       1.1   thorpej 			y = ypml->ypml_next;
    118       1.1   thorpej 		}
    119       1.7     peter 		break;
    120       1.7     peter 	default:
    121       1.7     peter 		printf("yp error: %s\n", yperr_string(Status));
    122       1.7     peter 		break;
    123       1.1   thorpej 	}
    124       1.1   thorpej 
    125       1.1   thorpej 	printf("\nTest 7: yp_all\n");
    126       1.2   thorpej 	Callback.foreach = yptest_foreach;
    127       1.1   thorpej 	Status = yp_all(Domain, Map, &Callback);
    128       1.7     peter 	if (Status != 0)
    129       1.7     peter 		printf("yp error: %s\n", yperr_string(Status));
    130       1.7     peter 
    131       1.2   thorpej 	exit(0);
    132       1.1   thorpej }
    133       1.1   thorpej 
    134       1.1   thorpej static int
    135       1.6       wiz yptest_foreach(int status, char *key, int keylen, char *val, int vallen,
    136       1.6       wiz 	       char *data)
    137       1.1   thorpej {
    138       1.1   thorpej 
    139       1.1   thorpej 	if (status == YP_NOMORE)
    140       1.1   thorpej 		return 0;
    141       1.1   thorpej 
    142       1.1   thorpej 	/* key avslutas med NUL */
    143       1.1   thorpej 	/* val avslutas med NUL */
    144       1.1   thorpej 	key[keylen] = '\0';
    145       1.1   thorpej 	val[vallen] = '\0';
    146       1.1   thorpej 	printf("%s %s\n", key, val);
    147       1.1   thorpej 	return 0;
    148       1.1   thorpej }
    149