summaryrefslogtreecommitdiff
path: root/usr.sbin
diff options
context:
space:
mode:
Diffstat (limited to 'usr.sbin')
-rw-r--r--usr.sbin/ypserv/ypxfr/ypxfr.c314
1 files changed, 140 insertions, 174 deletions
diff --git a/usr.sbin/ypserv/ypxfr/ypxfr.c b/usr.sbin/ypserv/ypxfr/ypxfr.c
index 21de65e044a..6962080acb8 100644
--- a/usr.sbin/ypserv/ypxfr/ypxfr.c
+++ b/usr.sbin/ypserv/ypxfr/ypxfr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ypxfr.c,v 1.25 2001/02/05 14:47:17 deraadt Exp $ */
+/* $OpenBSD: ypxfr.c,v 1.26 2001/11/07 19:01:29 deraadt Exp $ */
/*
* Copyright (c) 1994 Mats O Jansson <moj@stacken.kth.se>
@@ -32,7 +32,7 @@
*/
#ifndef LINT
-static char rcsid[] = "$OpenBSD: ypxfr.c,v 1.25 2001/02/05 14:47:17 deraadt Exp $";
+static char rcsid[] = "$OpenBSD: ypxfr.c,v 1.26 2001/11/07 19:01:29 deraadt Exp $";
#endif
#include <sys/types.h>
@@ -68,11 +68,11 @@ extern int (*ypresp_allfn)();
extern void *ypresp_data;
static int
-ypxfr_foreach(status,keystr,keylen,valstr,vallen,data)
-int status,keylen,vallen;
-char *keystr,*valstr,*data;
+ypxfr_foreach(status, keystr, keylen, valstr, vallen, data)
+int status, keylen, vallen;
+char *keystr, *valstr, *data;
{
- datum key,val;
+ datum key, val;
if (status == YP_NOMORE)
return(0);
@@ -85,7 +85,7 @@ char *keystr,*valstr,*data;
val.dptr = valstr;
val.dsize = strlen(valstr);
-
+
ypdb_store(db, key, val, YPDB_INSERT);
return 0;
@@ -102,60 +102,55 @@ u_int32_t *lordernum;
char order[MAX_LAST_LEN+1];
struct stat finfo;
DBM *db;
- datum k,v;
+ datum k, v;
int status;
/* This routine returns YPPUSH_SUCC or YPPUSH_NODOM */
-
+
status = YPPUSH_SUCC;
-
+
snprintf(map_path, sizeof map_path, "%s/%s", YP_DB_PATH, domain);
if (!((stat(map_path, &finfo) == 0) &&
- ((finfo.st_mode & S_IFMT) == S_IFDIR))) {
+ ((finfo.st_mode & S_IFMT) == S_IFDIR))) {
fprintf(stderr, "%s: domain %s not found locally\n",
__progname, domain);
status = YPPUSH_NODOM;
}
- if(status > 0) {
+ if (status > 0) {
snprintf(map_path, sizeof map_path, "%s/%s/%s%s",
YP_DB_PATH, domain, map, YPDB_SUFFIX);
- if(!(stat(map_path, &finfo) == 0)) {
+ if (!(stat(map_path, &finfo) == 0))
status = YPPUSH_NOMAP;
- }
}
-
- if(status > 0) {
+
+ if (status > 0) {
snprintf(map_path, sizeof map_path, "%s/%s/%s",
YP_DB_PATH, domain, map);
db = ypdb_open(map_path, O_RDONLY, 0444);
- if(db == NULL) {
+ if (db == NULL)
status = YPPUSH_DBM;
- }
-
}
-
- if(status > 0) {
+
+ if (status > 0) {
k.dptr = (char *)&order_key;
k.dsize = YP_LAST_LEN;
v = ypdb_fetch(db,k);
ypdb_close(db);
-
+
if (v.dptr == NULL) {
*lordernum = 0;
} else {
- strncpy(order, v.dptr, sizeof order-1);
- order[sizeof order-1] = '\0';
+ strlcpy(order, v.dptr, sizeof order);
*lordernum = (u_int32_t)atol(order);
}
}
- if((status == YPPUSH_NOMAP) || (status == YPPUSH_DBM)) {
+ if (status == YPPUSH_NOMAP || status == YPPUSH_DBM) {
*lordernum = 0;
status = YPPUSH_SUCC;
}
-
return(status);
}
@@ -173,13 +168,11 @@ u_int32_t *rordernum;
status = yp_order_host(client, domain, map, rordernum);
if (status == 0) {
- if(*rordernum <= lordernum) {
+ if (*rordernum <= lordernum)
status = YPPUSH_AGE;
- } else {
+ else
status = YPPUSH_SUCC;
- }
- }
-
+ }
return status;
}
@@ -232,7 +225,7 @@ DBM *db;
u_int32_t ordernum;
{
char datestr[11];
- datum key,val;
+ datum key, val;
char keystr[] = YP_LAST_KEY;
int status;
@@ -240,12 +233,12 @@ u_int32_t ordernum;
key.dptr = keystr;
key.dsize = strlen(keystr);
-
+
val.dptr = datestr;
val.dsize = strlen(datestr);
-
+
status = ypdb_store(db, key, val, YPDB_INSERT);
- if(status >= 0) {
+ if (status >= 0) {
status = YPPUSH_SUCC;
} else {
status = YPPUSH_DBM;
@@ -263,29 +256,28 @@ DBM *db;
char keystr[] = YP_MASTER_KEY;
char *master;
int status;
- datum key,val;
+ datum key, val;
master = NULL;
/* Get MASTER */
status = yp_master_host(client, domain, map, &master);
-
- if(master != NULL) {
- key.dptr = keystr;
- key.dsize = strlen(keystr);
-
- val.dptr = master;
- val.dsize = strlen(master);
-
- status = ypdb_store(db, key, val, YPDB_INSERT);
- if(status >= 0) {
- status = YPPUSH_SUCC;
- } else {
- status = YPPUSH_DBM;
- }
- }
+ if (master != NULL) {
+ key.dptr = keystr;
+ key.dsize = strlen(keystr);
+
+ val.dptr = master;
+ val.dsize = strlen(master);
+
+ status = ypdb_store(db, key, val, YPDB_INSERT);
+ if (status >= 0) {
+ status = YPPUSH_SUCC;
+ } else {
+ status = YPPUSH_DBM;
+ }
+ }
return status;
}
@@ -300,7 +292,7 @@ DBM *db;
char *value;
int vallen;
int status;
- datum k,v;
+ datum k, v;
/* Get INTERDOMAIN */
@@ -308,15 +300,14 @@ DBM *db;
k.dsize = strlen(keystr);
status = yp_match_host(client, domain, map,
- k.dptr, k.dsize, &value, &vallen);
-
- if(status == 0 && value) {
+ k.dptr, k.dsize, &value, &vallen);
+ if (status == 0 && value) {
v.dptr = value;
v.dsize = vallen;
-
- if(v.dptr != NULL) {
- status = ypdb_store(db,k,v,YPDB_INSERT);
- if(status >= 0) {
+
+ if (v.dptr != NULL) {
+ status = ypdb_store(db, k, v, YPDB_INSERT);
+ if (status >= 0) {
status = YPPUSH_SUCC;
} else {
status = YPPUSH_DBM;
@@ -338,7 +329,7 @@ DBM *db;
char *value;
int vallen;
int status;
- datum k,v;
+ datum k, v;
/* Get SECURE */
@@ -346,15 +337,14 @@ DBM *db;
k.dsize = strlen(keystr);
status = yp_match_host(client, domain, map,
- k.dptr, k.dsize, &value, &vallen);
-
- if(status == 0 && value) {
+ k.dptr, k.dsize, &value, &vallen);
+ if (status == 0 && value) {
v.dptr = value;
v.dsize = vallen;
-
- if(v.dptr != NULL) {
- status = ypdb_store(db,k,v,YPDB_INSERT);
- if(status >= 0) {
+
+ if (v.dptr != NULL) {
+ status = ypdb_store(db, k, v, YPDB_INSERT);
+ if (status >= 0) {
status = YPPUSH_SUCC;
} else {
status = YPPUSH_DBM;
@@ -380,13 +370,9 @@ CLIENT *client;
tv.tv_usec = 0;
/* Send CLEAR */
-
- r = clnt_call(client, YPPROC_CLEAR,
- xdr_void, 0, xdr_void, 0, tv);
- if(r != RPC_SUCCESS) {
+ r = clnt_call(client, YPPROC_CLEAR, xdr_void, 0, xdr_void, 0, tv);
+ if (r != RPC_SUCCESS)
clnt_perror(client, "yp_clear: clnt_call");
- }
-
return status;
}
@@ -408,13 +394,9 @@ u_long tid;
resp.xfrstat = status;
/* Send CLEAR */
-
- r = clnt_call(client, 1,
- xdr_ypresp_xfr, &resp, xdr_void, 0, tv);
- if(r != RPC_SUCCESS) {
+ r = clnt_call(client, 1, xdr_ypresp_xfr, &resp, xdr_void, 0, tv);
+ if (r != RPC_SUCCESS)
clnt_perror(client, "yppushresp_xdr: clnt_call");
- }
-
return status;
}
@@ -441,56 +423,56 @@ char *argv[];
u_int32_t ordernum, new_ordernum;
struct ypall_callback callback;
CLIENT *client;
- int status,xfr_status;
+ int status, xfr_status;
int srvport;
-
+
status = YPPUSH_SUCC;
client = NULL;
yp_get_default_domain(&domain);
while ((ch = getopt(argc, argv, "cd:fh:s:C:")) != -1)
- switch (ch) {
- case 'c':
- cflag++;
- break;
- case 'd':
- if (strchr(optarg, '/')) /* Ha ha, we are not listening */
- break;
- domain = optarg;
- break;
- case 'f':
- fflag++;
- break;
- case 'h':
- host = optarg;
- break;
- case 's':
- if (strchr(optarg, '/')) /* Ha ha, we are not listening */
- break;
- srcdomain = optarg;
- break;
- case 'C':
- if (optind + 3 >= argc) {
+ switch (ch) {
+ case 'c':
+ cflag++;
+ break;
+ case 'd':
+ if (strchr(optarg, '/')) /* Ha ha, we are not listening */
+ break;
+ domain = optarg;
+ break;
+ case 'f':
+ fflag++;
+ break;
+ case 'h':
+ host = optarg;
+ break;
+ case 's':
+ if (strchr(optarg, '/')) /* Ha ha, we are not listening */
+ break;
+ srcdomain = optarg;
+ break;
+ case 'C':
+ if (optind + 3 >= argc) {
+ usage++;
+ optind = argc;
+ break;
+ }
+ Cflag++;
+ tid = optarg;
+ prog = argv[optind++];
+ ipadd = argv[optind++];
+ port = argv[optind++];
+ break;
+ default:
+ usage++;
+ break;
+ }
+
+ if (optind + 1 != argc) {
usage++;
- optind = argc;
- break;
- }
- Cflag++;
- tid = optarg;
- prog = argv[optind++];
- ipadd = argv[optind++];
- port = argv[optind++];
- break;
- default:
- usage++;
- break;
- }
-
- if(optind + 1 != argc) {
- usage++;
} else {
- map = argv[optind];
+ map = argv[optind];
}
if (usage) {
@@ -507,7 +489,7 @@ char *argv[];
yplog("ypxfr: Arguments:");
yplog("YP clear to local: %s", (cflag) ? "no" : "yes");
yplog(" Force transfer: %s", (fflag) ? "yes" : "no");
- yplog(" domain: %s", domain);
+ yplog(" domain: %s", domain);
yplog(" host: %s", host);
yplog(" source domain: %s", srcdomain);
yplog(" transid: %s", tid);
@@ -516,7 +498,7 @@ char *argv[];
yplog(" ipadd: %s", ipadd);
yplog(" map: %s", map);
- if(fflag != 0) {
+ if (fflag != 0) {
ordernum = 0;
} else {
status = get_local_ordernum(domain, map, &ordernum);
@@ -524,43 +506,38 @@ char *argv[];
}
if (status > 0) {
-
yplog("Get Master");
if (host == NULL) {
if (srcdomain == NULL) {
- status = yp_master(domain,map,&host);
+ status = yp_master(domain, map, &host);
} else {
- status = yp_master(srcdomain,map,&host);
+ status = yp_master(srcdomain, map, &host);
}
- if(status == 0) {
+ if (status == 0) {
status = YPPUSH_SUCC;
} else {
status = -status;
}
}
- };
+ }
/* XXX this is raceable if portmap has holes! */
if (status > 0) {
-
- yplog("Check for reserved port on host: %s", host);
+ yplog("Check for reserved port on host: %s", host);
- srvport = getrpcport(host,YPPROG,YPVERS,IPPROTO_TCP);
+ srvport = getrpcport(host, YPPROG, YPVERS, IPPROTO_TCP);
if (srvport >= IPPORT_RESERVED)
status = YPPUSH_REFUSED;
-
}
if (status > 0) {
-
- yplog("Connect host: %s", host);
+ yplog("Connect host: %s", host);
- client = yp_bind_host(host,YPPROG,YPVERS,0,1);
+ client = yp_bind_host(host, YPPROG, YPVERS, 0, 1);
status = get_remote_ordernum(client, domain, map,
- ordernum, &new_ordernum);
-
+ ordernum, &new_ordernum);
}
if (status == YPPUSH_SUCC) {
@@ -577,73 +554,62 @@ char *argv[];
close(fd);
if (status > 0) {
- db = create_db(domain,map,tmpmapname);
- if(db == NULL)
+ db = create_db(domain, map, tmpmapname);
+ if (db == NULL)
status = YPPUSH_DBM;
}
/* Add ORDER */
- if(status > 0) {
+ if (status > 0)
status = add_order(db, new_ordernum);
- }
-
+
/* Add MASTER */
- if(status > 0) {
- status = add_master(client,domain,map,db);
- }
-
+ if (status > 0)
+ status = add_master(client, domain, map, db);
+
/* Add INTERDOMAIN */
- if(status > 0) {
- status = add_interdomain(client,domain,map,db);
- }
-
+ if (status > 0)
+ status = add_interdomain(client, domain, map, db);
+
/* Add SECURE */
- if(status > 0) {
- status = add_secure(client,domain,map,db);
- }
-
- if(status > 0) {
- callback.foreach=ypxfr_foreach;
- status = get_map(client,domain,map,&callback);
+ if (status > 0)
+ status = add_secure(client, domain, map, db);
+
+ if (status > 0) {
+ callback.foreach = ypxfr_foreach;
+ status = get_map(client, domain, map, &callback);
}
-
+
/* Close db */
- if(db != NULL) {
+ if (db != NULL)
ypdb_close(db);
- }
/* Rename db */
- if(status > 0) {
- status = install_db(domain,map,tmpmapname);
+ if (status > 0) {
+ status = install_db(domain, map, tmpmapname);
} else {
unlink(tmpmapname);
status = YPPUSH_SUCC;
}
-
}
-
+
xfr_status = status;
- if(client != NULL) {
+ if (client != NULL)
clnt_destroy(client);
- }
/* YP_CLEAR */
- if(!cflag) {
- client = yp_bind_local(YPPROG,YPVERS);
+ if (!cflag) {
+ client = yp_bind_local(YPPROG, YPVERS);
status = send_clear(client);
clnt_destroy(client);
}
- if(Cflag > 0) {
+ if (Cflag > 0) {
/* Send Response */
- client = yp_bind_host(ipadd,
- atoi(prog),
- 1,
- atoi(port),
- 0);
- status = send_reply(client,xfr_status,atoi(tid));
+ client = yp_bind_host(ipadd, atoi(prog), 1, atoi(port), 0);
+ status = send_reply(client, xfr_status, atoi(tid));
clnt_destroy(client);
}