2 * Sun RPC is a product of Sun Microsystems, Inc. and is provided for
3 * unrestricted use provided that this legend is included on all tape
4 * media and as a part of the software program in whole or part. Users
5 * may copy or modify Sun RPC without charge, but are not authorized
6 * to license or distribute it to anyone else except as part of a product or
7 * program developed by the user.
9 * SUN RPC IS PROVIDED AS IS WITH NO WARRANTIES OF ANY KIND INCLUDING THE
10 * WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS FOR A PARTICULAR
11 * PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE OR TRADE PRACTICE.
13 * Sun RPC is provided with no support and without any obligation on the
14 * part of Sun Microsystems, Inc. to assist in its use, correction,
15 * modification or enhancement.
17 * SUN MICROSYSTEMS, INC. SHALL HAVE NO LIABILITY WITH RESPECT TO THE
18 * INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY SUN RPC
19 * OR ANY PART THEREOF.
21 * In no event will Sun Microsystems, Inc. be liable for any lost revenue
22 * or profits or other special, indirect and consequential damages, even if
23 * Sun has been advised of the possibility of such damages.
25 * Sun Microsystems, Inc.
27 * Mountain View, California 94043
33 * Copyright (c) 1991, by Sun Microsystems Inc.
37 * This header file defines the interface to the NIS database. All
38 * implementations of the database must export at least these routines.
39 * They must also follow the conventions set herein. See the implementors
40 * guide for specific semantics that are required.
43 #ifndef _RPCSVC_NIS_DB_H
44 #define _RPCSVC_NIS_DB_H
47 /* From: #pragma ident "@(#)nis_db.h 1.8 94/05/03 SMI" */
50 * Note: although the version of <rpcsvc/nis_db.h> shipped with Solaris
51 * 2.5/2.5.x is actually older than this one (according to the ident
52 * string), it contains changes and a few added functions. Those changes
53 * have been hand merged into this file to bring it up to date.
57 #include <rpcsvc/nis.h>
74 typedef enum db_status db_status
;
85 typedef enum db_action db_action
;
87 typedef entry_obj
*entry_object_p
;
90 u_int db_next_desc_len
;
91 char *db_next_desc_val
;
96 db_next_desc nextinfo
;
99 entry_object_p
*objects_val
;
103 typedef struct db_result db_result
;
106 * Prototypes for the database functions.
109 extern bool_t
db_initialize(char *);
110 #ifdef ORIGINAL_DECLS
111 extern bool_t
db_create_table(char *, table_obj
*);
112 extern bool_t
db_destroy_table(char *);
114 extern db_status
db_create_table(char *, table_obj
*);
115 extern db_status
db_destroy_table(char *);
117 extern db_result
*db_first_entry(char *, int, nis_attr
*);
118 extern db_result
*db_next_entry(char *, db_next_desc
*);
119 extern db_result
*db_reset_next_entry(char *, db_next_desc
*);
120 extern db_result
*db_list_entries(char *, int, nis_attr
*);
121 extern db_result
*db_add_entry(char *, int, nis_attr
*, entry_obj
*);
122 extern db_result
*db_remove_entry(char *, int, nis_attr
*);
123 extern db_status
db_checkpoint(char *);
124 extern db_status
db_standby(char *);
125 #ifndef ORIGINAL_DECLS
126 extern db_status
db_table_exists(char *);
127 extern db_status
db_unload_table(char *);
128 extern void db_free_result(db_result
*);
135 #endif /* _RPCSVC_NIS_DB_H */