4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
22 * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
23 * Use is subject to license terms.
26 /* Copyright (c) 1983, 1984, 1985, 1986, 1987, 1988, 1989 AT&T */
27 /* All Rights Reserved */
30 * Portions of this source code were derived from Berkeley 4.3 BSD
31 * under license from the Regents of the University of California.
42 * This contains symbol and structure definitions for modules in the YP server
45 #include <ndbm.h> /* Pull this in first */
54 #include <rpcsvc/yp_prot.h>
55 #include "ypv1_prot.h"
56 #include <rpcsvc/ypclnt.h>
58 typedef void (*PFV
)();
60 typedef unsigned int (*PFU
)();
61 typedef long int (*PFLI
)();
62 typedef unsigned long int (*PFULI
)();
63 typedef short int (*PFSI
)();
64 typedef unsigned short int (*PFUSI
)();
80 * Size of lock hash table
82 * It's for a hash table, hence better if it is prime.
83 * It's also the max number of maps and map locks, used
84 * for initializing shared memory: need to be big enough
85 * (until dynamic shared memory allocation is implemented ?).
89 /* Maximum length of a yp map name in the system v filesystem */
92 #define YPINTERTRY_TIME 10 /* Secs between tries for peer bind */
93 #define YPTOTAL_TIME 30 /* Total secs until timeout */
94 #define YPNOPORT ((unsigned short) 0) /* Out-of-range port value */
96 /* External refs to yp server data structures */
98 extern bool ypinitialization_done
;
99 extern struct timeval ypintertry
;
100 extern struct timeval yptimeout
;
101 extern char myhostname
[];
103 #ifdef MINUS_C_OPTION
104 extern bool multiflag
;
107 /* External ref to logging func */
108 extern void logprintf(char *format
, ...);
110 /* External refs for /var/yp/securenets support */
111 extern void get_secure_nets(char *daemon_name
);
113 /* External refs to yp server-only functions */
114 extern bool ypcheck_map_existence(char *pname
);
115 extern bool ypget_map_master(char **owner
, DBM
*fdb
);
116 extern DBM
*ypset_current_map(char *map
, char *domain
, uint_t
*error
);
117 extern void ypclr_current_map(void);
118 extern bool_t
ypmkfilename(char *domain
, char *map
, char *path
);
119 extern int yplist_maps();
120 extern bool yp_map_access(SVCXPRT
*transp
, uint_t
*error
, DBM
*fdb
);
121 extern bool ypget_map_order(char *map
, char *domain
, uint_t
*order
);
123 extern bool ypcheck_domain();
124 extern datum
dbm_do_nextkey();
125 extern void ypclr_current_map(void);
127 extern void ypdomain(SVCXPRT
*transp
, bool always_respond
);
128 extern void ypmatch(SVCXPRT
*transp
, struct svc_req
*rqstp
);
129 extern void ypfirst(SVCXPRT
*transp
);
130 extern void ypnext(SVCXPRT
*transp
);
131 extern void ypxfr(SVCXPRT
*transp
, int prog
);
132 extern void ypall(SVCXPRT
*transp
);
133 extern void ypmaster(SVCXPRT
*transp
);
134 extern void yporder(SVCXPRT
*transp
);
135 extern void ypmaplist(SVCXPRT
*transp
);
136 extern void ypoldmatch(SVCXPRT
*transp
, struct svc_req
*rqstp
);
137 extern void ypoldfirst(SVCXPRT
*transp
);
138 extern void ypoldnext(SVCXPRT
*transp
);
139 extern void ypoldpoll(SVCXPRT
*transp
);
140 extern void ypoldpush(SVCXPRT
*transp
);
141 extern void ypoldpull(SVCXPRT
*transp
);
142 extern void ypoldget(SVCXPRT
*transp
);
143 extern int yp_matchdns(DBM
*, struct ypreq_key
*, struct ypresp_val
*);
144 extern int yp_oldmatchdns(DBM
*fdb
,
145 struct yprequest
*req
, struct ypresponse
*resp
);
147 extern bool _xdr_ypreqeust(XDR
*xdrs
, struct yprequest
*ps
);
148 extern bool _xdr_ypresponse(XDR
*xdrs
, struct ypresponse
*ps
);
150 extern void setup_resolv(bool *fwding
, int *child
, CLIENT
**client
,
151 char *tp_type
, long prognum
);
152 extern int resolv_req(bool *fwding
, CLIENT
**client
, int *pid
,
153 char *tp
, SVCXPRT
*xprt
, struct ypreq_key
*req
,
157 /* definitions for reading files of lists */
161 struct listofnames
*nextname
;
164 typedef struct listofnames listofnames
;
170 #endif /* __YPSYM_H */