diff --git a/gnu/usr.bin/yppush/Makefile b/gnu/usr.bin/yppush/Makefile deleted file mode 100644 index 374760aa302c..000000000000 --- a/gnu/usr.bin/yppush/Makefile +++ /dev/null @@ -1,18 +0,0 @@ -# from: @(#)Makefile 5.8 (Berkeley) 7/28/90 -# $Id: Makefile,v 1.7 1995/05/30 05:05:19 rgrimes Exp $ - -PROG= yppush -SRCS= yp_clnt.c yppush.c - -MAN8= yppush.8 -CLEANFILES= yp_clnt.c yp.h - -RPCSRC= ${DESTDIR}/usr/include/rpcsvc/yp.x - -yp_clnt.c: ${RPCSRC} yp.h - rpcgen -l -o ${.TARGET} ${RPCSRC} - -yp.h: ${RPCSRC} - rpcgen -h -o ${.TARGET} ${RPCSRC} - -.include diff --git a/gnu/usr.bin/yppush/yppush.8 b/gnu/usr.bin/yppush/yppush.8 deleted file mode 100644 index 92e140540b02..000000000000 --- a/gnu/usr.bin/yppush/yppush.8 +++ /dev/null @@ -1,115 +0,0 @@ -.\" Copyright (c) 1991, 1993, 1995 -.\" The Regents of the University of California. All rights reserved. -.\" -.\" Redistribution and use in source and binary forms, with or without -.\" modification, are permitted provided that the following conditions -.\" are met: -.\" 1. Redistributions of source code must retain the above copyright -.\" notice, this list of conditions and the following disclaimer. -.\" 2. Redistributions in binary form must reproduce the above copyright -.\" notice, this list of conditions and the following disclaimer in the -.\" documentation and/or other materials provided with the distribution. -.\" 3. All advertising materials mentioning features or use of this software -.\" must display the following acknowledgement: -.\" This product includes software developed by the University of -.\" California, Berkeley and its contributors. -.\" 4. Neither the name of the University nor the names of its contributors -.\" may be used to endorse or promote products derived from this software -.\" without specific prior written permission. -.\" -.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND -.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE -.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL -.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS -.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) -.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY -.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF -.\" SUCH DAMAGE. -.\" -.\" $Id$ -.\" -.Dd February 5, 1995 -.Dt YPPUSH 8 -.Os -.Sh NAME -.Nm yppush -.Nd "force propagation of updated NIS databases" -.Sh SYNOPSIS -.Nm yppush -.Op Fl d Ar domain -.Op Fl v -.Ar mapname -.Op Ar mapname ... -.Sh DESCRIPTION -.Nm yppush -distributes updated NIS databases (or -.Pa maps ) -from an NIS master server to NIS slave servers within an NIS -domain. It is normally only run on the NIS master by -.Pa /var/yp/Makefile -whenever any of the NIS maps are updated. Note that -.Pa /var/yp/Makefile -does not invoke -.Nm yppush -by default: the -.Nm NOPUSH=True -entry in the Makefile must first be commented out -(the default FreeBSD configuration assumes a small network with only -a single NIS server; in such a configuration, -.Nm yppush -is not needed). -.Pp -.Nm yppush -determines the names of the slave servers for a domain by searching the -.Pa ypservers -map. Once it has a complete list of slave servers, it sends a request -to each of them to initiate a map transfer, which is done using -.Xr ypxfr 8 . -Included within each request is the name of the map to be copied -and some special information required by -.Xr ypxfr 8 -to successfully 'callback' to -.Nm yppush -and carry out the transfer. Any status or error messages -.Nm yppush -receives from -.Xr ypxfr 8 -will be printed to stdout. -.Sh OPTIONS -The following options are supported by -.Nm yppush : -.Bl -tag -width flag -.It Fl d Ar domain -Specify a particular domain. The NIS domain of -the host system is used by default. -.It Fl v -Verbose mode: causes -.Nm yppush -to print debugging messages as it runs. -.Sh FILES -.Bl -tag -width Pa -compact -.It Pa /var/yp/[domainname]/ypservers -The NIS ypservers map containing the names of all servers in -a particular NIS domain. -.El -.Sh SEE ALSO -.Xr ypserv 8 , -.Xr ypxfr 8 , -.Xr yp 8 -.Sh BUGS -The mechanism for transfering NIS maps in NIS version 1 is different -that that in NIS version 2. This version of -.Nm yppush -has support for transfering maps to NIS version 1 systems, but this -support has not been tested and is not guaranteed to work. Fortunately, -the majority of systems today use NIS version 2. -.Sh LICENSE -This program is covered by the GNU Public License version 2. -.Sh AUTHOR -Tobias Reber (original Linux version) -.br -Bill Paul (port to FreeBSD and various -changes) diff --git a/gnu/usr.bin/yppush/yppush.c b/gnu/usr.bin/yppush/yppush.c deleted file mode 100644 index aca50af6464a..000000000000 --- a/gnu/usr.bin/yppush/yppush.c +++ /dev/null @@ -1,451 +0,0 @@ -/* - YPS-0.2, NIS-Server for Linux - Copyright (C) 1994 Tobias Reber - - This program is free software; you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation; either version 2 of the License, or - (at your option) any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - - Modified for use with FreeBSD 2.x by Bill Paul (wpaul@ctr.columbia.edu) - - $Id: yppush.c,v 1.6.2.1 1995/06/04 17:15:49 davidg Exp $ -*/ - -#include -#include -#include -#include -#include -#include -#include -#include -/* - * ypclnt.h does not have a definition for struct dom_binding, - * although it is used there. It is defined in yp_prot.h, but - * we cannot use it here. - */ -struct dom_binding { - void * m; -}; -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#ifndef _PATH_YP -#define _PATH_YP "/var/yp/" -#endif - -char *progname; - -#define PERM_SECURE (S_IRUSR|S_IWUSR) -HASHINFO openinfo = { - 4096, /* bsize */ - 32, /* ffactor */ - 256, /* nelem */ - 2048 * 1024, /* cachesize */ - NULL, /* hash */ - 0 /* lorder */ -}; - -#undef MIN -#define MIN(a,b) ((a)<(b)?(a):(b)) - -static char *DomainName=NULL; -static bool_t Verbose=FALSE; - -static char *ThisHost=NULL; - -static char *MapName; -static u_int MapOrderNum; - -static CLIENT *PushClient=NULL; - -static u_int CallbackTransid; -static u_int CallbackProg=0; -static SVCXPRT *CallbackXprt; - -static inline char * -yppush_err_string(enum yppush_status y) { - switch(y) { - case YPPUSH_SUCC: return "Success"; - case YPPUSH_AGE: return "Master's version not newer"; - case YPPUSH_NOMAP: return "Can't find server for map"; - case YPPUSH_NODOM: return "Domain not supported"; - case YPPUSH_RSRC: return "Local resource alloc failure"; - case YPPUSH_RPC: return "RPC failure talking to server"; - case YPPUSH_MADDR: return "Can't get master address"; - case YPPUSH_YPERR: return "YP server/map db error"; - case YPPUSH_BADARGS: return "Request arguments bad"; - case YPPUSH_DBM: return "Local dbm operation failed"; - case YPPUSH_FILE: return "Local file I/O operation failed"; - case YPPUSH_SKEW: return "Map version skew during transfer"; - case YPPUSH_CLEAR: return "Can't send \"Clear\" req to local ypserv"; - case YPPUSH_FORCE: return "No local order number in map use -f flag."; - case YPPUSH_XFRERR: return "ypxfr error"; - case YPPUSH_REFUSED: return "Transfer request refused by ypserv"; - } -} - -#define YPPUSH_XFRRESPPROG ((u_long)0x40000000) -#define YPPUSH_XFRRESPVERS ((u_long)1) - -#define YPPUSHPROC_NULL ((u_long)0) -static inline void * -__yppushproc_null_1(void * req, struct svc_req * rqstp) { - static int resp; - return &resp; -} - -#define YPPUSHPROC_XFRRESP ((u_long)1) -static inline void * -__yppushproc_xfrresp_1(yppushresp_xfr *req, struct svc_req * rqstp) { - static int resp; - - if (req->status!=YPPUSH_SUCC) - fprintf(stderr, "%s: %s\n", progname, yppush_err_string(req->status)); - return &resp; -} - -void -__yppush_xfrrespprog_1( struct svc_req *rqstp, SVCXPRT *transp) -{ - union { - int fill; - } argument; - char *result; - bool_t (*xdr_argument)(XDR *, void *), (*xdr_result)(XDR *, void *); - char *(*local)( void *, struct svc_req *); - - switch (rqstp->rq_proc) { - case YPPUSHPROC_NULL: - xdr_argument = (bool_t (*)(XDR *, void *))xdr_void; - xdr_result = (bool_t (*)(XDR *, void *))xdr_void; - local = (char *(*)( void *, struct svc_req *)) __yppushproc_null_1; - break; - - case YPPUSHPROC_XFRRESP: - xdr_argument = xdr_yppushresp_xfr; - xdr_result = (bool_t (*)(XDR *, void *))xdr_void; - local = (char *(*)( void *, struct svc_req *)) __yppushproc_xfrresp_1; - break; - - default: - svcerr_noproc(transp); - exit(1); - } - bzero((char *)&argument, sizeof(argument)); - if (!svc_getargs(transp, xdr_argument, &argument)) { - svcerr_decode(transp); - exit(1); - } - result = (*local)(&argument, rqstp); - if (result != NULL && !svc_sendreply(transp, xdr_result, result)) { - svcerr_systemerr(transp); - } - if (!svc_freeargs(transp, xdr_argument, &argument)) { - (void)fprintf(stderr, "%s: unable to free arguments\n", progname); - exit(1); - if (rqstp->rq_proc!=YPPUSHPROC_NULL) - exit(0); - } - exit(0); -} - -/* - * This is the rpc server side idle loop - * Wait for input, call server program. - */ - -static void -_svc_run( void) -{ -#ifdef FD_SETSIZE - fd_set readfds; -#else - int readfds; -#endif /* def FD_SETSIZE */ - extern int errno; - struct timeval t; - - t.tv_sec=60; t.tv_usec=0; - - for (;;) { -#ifdef FD_SETSIZE - readfds = svc_fdset; -#else - readfds = svc_fds; -#endif /* def FD_SETSIZE */ - switch (select(_rpc_dtablesize(), &readfds, (void *)0, - (void *)0, &t)) { - case -1: - if (errno == EINTR) { - continue; - } - perror("svc_run: - select failed"); - return; - case 0: - fprintf(stderr, "%s: callback timed out\n", progname); - exit(0); - default: - svc_getreqset(&readfds); - } - } -} - -static void -Usage(void) -{ - fprintf(stderr, "Usage: %s [ -d domain ] [ -v ] mapname ...\n", - progname); - exit(1); -} - -static char * -getHostName( void) -{ - static char hostname[MAXHOSTNAMELEN+1]; - struct hostent *h; - if (gethostname(hostname, sizeof hostname)!=0) { - fprintf(stderr,"%s:", progname); - perror("gethostname"); - return NULL; - } - h=gethostbyname(hostname); - if (h!=NULL) { - strncpy(hostname, h->h_name, sizeof (hostname)-1); - hostname[sizeof (hostname)-1]='\0'; - } - return hostname; -} - -static u_int -getOrderNum( void) -{ - char mapPath[MAXPATHLEN]; - DB *db; - DBT o,d; - int i; - - strcpy(mapPath, _PATH_YP); - strcat(mapPath, DomainName); - strcat(mapPath, "/"); - strcat(mapPath, MapName); - - if ((db = dbopen(mapPath, O_RDWR|O_EXCL, PERM_SECURE, DB_HASH, - &openinfo)) == NULL) { - fprintf(stderr, "%s: %s: cannot open\n", progname, mapPath); - return -1; - } - - o.data="YP_LAST_MODIFIED"; o.size=strlen(o.data); - (db->get)(db,&o,&d,0); - if (d.data==NULL) { - fprintf(stderr, "%s: %s: cannot determine order number\n", - progname, MapName); - return -1; - } - - for (i=0; iclose)(db); - return atoi(d.data); -} - -static void -doPushClient( const char *targetHost) -{ - struct ypreq_xfr req; - static struct timeval tv={0,0}; - - req.map_parms.domain=DomainName; - req.map_parms.map=(char *)MapName; - req.map_parms.peer=ThisHost; - req.map_parms.ordernum=MapOrderNum; - req.transid=CallbackTransid; - req.prog=CallbackProg; - req.port=CallbackXprt->xp_port; - - if (Verbose) - printf("%d: %s(%d@%s) -> %s@%s\n", req.transid, - req.map_parms.map, req.map_parms.ordernum, - req.map_parms.peer, targetHost, - req.map_parms.domain); - switch (clnt_call(PushClient, YPPROC_XFR, xdr_ypreq_xfr, &req, - xdr_void, NULL, tv)) { - case RPC_SUCCESS: - case RPC_TIMEDOUT: - break; - default: - clnt_perror(PushClient, "yppush: cannot call YPPROC_XFR"); - kill(CallbackTransid, SIGTERM); - } - return; -} - -static bool_t -registerServer(void) -{ - int s; - s=RPC_ANYSOCK; - CallbackXprt=svcudp_create(s); - if (CallbackXprt==NULL) { - fprintf(stderr, "%s: Cannot create callback transport.\n", - progname); - return FALSE; - } - for (CallbackProg=0x40000000; CallbackProg<0x5fffffff; CallbackProg++) { - if (svc_register(CallbackXprt, CallbackProg, 1, - __yppush_xfrrespprog_1, IPPROTO_UDP)) - return TRUE; - } - return FALSE; -} - -static bool_t -createClient(const char *targetHost) -{ - PushClient=clnt_create((char *)targetHost, YPPROG, YPVERS, "tcp"); - if (PushClient==NULL) { - clnt_pcreateerror("yppush: cannot create client"); - return FALSE; - } - return TRUE; -} - -static void -doPush( const char *targetHost) -{ - int s; - struct rusage r; - - if (!createClient(targetHost)) - return; - if (!registerServer()) - return; - - switch (CallbackTransid=fork()) { - case -1: - fprintf(stderr, "%s:", progname); - perror("fork"); - exit(1); - case 0: - _svc_run(); - exit(0); - default: - close(CallbackXprt->xp_sock); - doPushClient(targetHost); - wait4(CallbackTransid, &s, 0, &r); - svc_unregister(CallbackProg, 1); - CallbackProg=0; - if (PushClient!=NULL) { - clnt_destroy(PushClient); - PushClient=NULL; - } - } -} - -static int -yppushForeach(int status, const char *inKey, int inKeylen, - const char *inVal, int inVallen, const char *data) -{ - char targetHost[YPMAXPEER+1]; - - if (status!=YP_TRUE) return 0; - memcpy(targetHost, inKey, MIN(sizeof (targetHost)-1, inKeylen)); - targetHost[MIN(sizeof (targetHost)-1, inKeylen)]='\0'; - doPush(targetHost); - return 0; -} - -static void -intrHandler(int sig) -{ - if (CallbackProg!=0) - svc_unregister(CallbackProg, 1); - exit(1); -} - -int -main(int argc, char **argv) -{ - char c; - struct ypall_callback f; - enum ypstat y; - struct sigaction a; - - progname = argv[0]; - - a.sa_handler=intrHandler; - a.sa_mask=0; - sigaction(SIGINT, &a, NULL); - - while((c=getopt(argc, argv, "d:v"))!=EOF) { - switch(c) { - case 'd': - DomainName=optarg; - break; - case 'v': - Verbose=TRUE; - break; - default: - Usage(); - } - } - argc-=optind; - argv+=optind; - if (argc<1) Usage(); - - if (DomainName==NULL) { - if (yp_get_default_domain(&DomainName)!=0) { - fprintf(stderr, "%s: cannot get default domain\n", - progname); - exit(1); - } - } - - ThisHost=getHostName(); - if (ThisHost==NULL) { - fprintf(stderr, "%s: cannot determine local hostname\n", - progname); - exit(1); - } - - while (*argv) { - MapName=*argv++; - MapOrderNum=getOrderNum(); - if (MapOrderNum==0xffffffff) - continue; - f.foreach=yppushForeach; - y=yp_all(DomainName, "ypservers", &f); - if (y && y!=YP_NOMORE) { - fprintf(stderr, "%s: could not read ypservers map: %d %s\n", - progname, y, yperr_string(y)); - exit(1); - } - } - exit(0); -}