xref: /onnv-gate/usr/src/uts/common/rpc/rpcsec_defs.h (revision 0:68f95e015346)
1*0Sstevel@tonic-gate /*
2*0Sstevel@tonic-gate  * CDDL HEADER START
3*0Sstevel@tonic-gate  *
4*0Sstevel@tonic-gate  * The contents of this file are subject to the terms of the
5*0Sstevel@tonic-gate  * Common Development and Distribution License, Version 1.0 only
6*0Sstevel@tonic-gate  * (the "License").  You may not use this file except in compliance
7*0Sstevel@tonic-gate  * with the License.
8*0Sstevel@tonic-gate  *
9*0Sstevel@tonic-gate  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10*0Sstevel@tonic-gate  * or http://www.opensolaris.org/os/licensing.
11*0Sstevel@tonic-gate  * See the License for the specific language governing permissions
12*0Sstevel@tonic-gate  * and limitations under the License.
13*0Sstevel@tonic-gate  *
14*0Sstevel@tonic-gate  * When distributing Covered Code, include this CDDL HEADER in each
15*0Sstevel@tonic-gate  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16*0Sstevel@tonic-gate  * If applicable, add the following below this CDDL HEADER, with the
17*0Sstevel@tonic-gate  * fields enclosed by brackets "[]" replaced with your own identifying
18*0Sstevel@tonic-gate  * information: Portions Copyright [yyyy] [name of copyright owner]
19*0Sstevel@tonic-gate  *
20*0Sstevel@tonic-gate  * CDDL HEADER END
21*0Sstevel@tonic-gate  */
22*0Sstevel@tonic-gate /*
23*0Sstevel@tonic-gate  * Copyright (c) 1996,1997-1998 by Sun Microsystems, Inc.
24*0Sstevel@tonic-gate  * All rights reserved.
25*0Sstevel@tonic-gate  */
26*0Sstevel@tonic-gate 
27*0Sstevel@tonic-gate #ifndef	_RPCSEC_DEFS_H
28*0Sstevel@tonic-gate #define	_RPCSEC_DEFS_H
29*0Sstevel@tonic-gate 
30*0Sstevel@tonic-gate #pragma ident	"%Z%%M%	%I%	%E% SMI"
31*0Sstevel@tonic-gate 
32*0Sstevel@tonic-gate /*
33*0Sstevel@tonic-gate  * Copyright 1993 OpenVision Technologies, Inc., All Rights Reserved.
34*0Sstevel@tonic-gate  *
35*0Sstevel@tonic-gate  * $Id: auth_gssapi.h,v 1.11 1994/10/27 12:39:14 jik Exp $
36*0Sstevel@tonic-gate  */
37*0Sstevel@tonic-gate 
38*0Sstevel@tonic-gate #ifndef _KERNEL
39*0Sstevel@tonic-gate #include <libintl.h>
40*0Sstevel@tonic-gate #include <locale.h>
41*0Sstevel@tonic-gate #endif
42*0Sstevel@tonic-gate #include <gssapi/gssapi.h>
43*0Sstevel@tonic-gate #include <rpc/types.h>
44*0Sstevel@tonic-gate 
45*0Sstevel@tonic-gate #ifdef	__cplusplus
46*0Sstevel@tonic-gate extern "C" {
47*0Sstevel@tonic-gate #endif
48*0Sstevel@tonic-gate 
49*0Sstevel@tonic-gate #ifdef _KERNEL
50*0Sstevel@tonic-gate 
51*0Sstevel@tonic-gate #if defined(DEBUG) && !defined(RPCGSS_DEBUG)
52*0Sstevel@tonic-gate #define	RPCGSS_DEBUG
53*0Sstevel@tonic-gate #endif
54*0Sstevel@tonic-gate 
55*0Sstevel@tonic-gate #ifdef RPCGSS_DEBUG
56*0Sstevel@tonic-gate extern uint_t rpcgss_log;
57*0Sstevel@tonic-gate 
58*0Sstevel@tonic-gate #define	RPCGSS_LOG1(A, B, C, D) \
59*0Sstevel@tonic-gate 	((void)((rpcgss_log) && (rpcgss_log & (A)) && (printf((B), \
60*0Sstevel@tonic-gate 	    (C), (D)), TRUE)))
61*0Sstevel@tonic-gate #define	RPCGSS_LOG(A, B, C) \
62*0Sstevel@tonic-gate 	((void)((rpcgss_log) && (rpcgss_log & (A)) && (printf((B), (C)), TRUE)))
63*0Sstevel@tonic-gate #define	RPCGSS_LOG0(A, B)   \
64*0Sstevel@tonic-gate 	((void)((rpcgss_log) && (rpcgss_log & (A)) && (printf(B), TRUE)))
65*0Sstevel@tonic-gate #else
66*0Sstevel@tonic-gate #define	RPCGSS_LOG1(A, B, C, D)
67*0Sstevel@tonic-gate #define	RPCGSS_LOG(A, B, C)
68*0Sstevel@tonic-gate #define	RPCGSS_LOG0(A, B)
69*0Sstevel@tonic-gate #endif
70*0Sstevel@tonic-gate 
71*0Sstevel@tonic-gate #else /* _KERNEL */
72*0Sstevel@tonic-gate 
73*0Sstevel@tonic-gate extern bool_t locale_set;
74*0Sstevel@tonic-gate #if !defined(TEXT_DOMAIN)
75*0Sstevel@tonic-gate #define	TEXT_DOMAIN "SUNW_OST_OSCMD"
76*0Sstevel@tonic-gate #endif
77*0Sstevel@tonic-gate 
78*0Sstevel@tonic-gate #endif /* _KERNEL */
79*0Sstevel@tonic-gate 
80*0Sstevel@tonic-gate 
81*0Sstevel@tonic-gate typedef struct _rpc_gss_creds {
82*0Sstevel@tonic-gate 	uint_t version;
83*0Sstevel@tonic-gate 	uint_t gss_proc;
84*0Sstevel@tonic-gate 	uint_t seq_num;
85*0Sstevel@tonic-gate 	rpc_gss_service_t service;
86*0Sstevel@tonic-gate 	gss_buffer_desc ctx_handle;
87*0Sstevel@tonic-gate } rpc_gss_creds;
88*0Sstevel@tonic-gate 
89*0Sstevel@tonic-gate typedef gss_buffer_desc rpc_gss_init_arg;
90*0Sstevel@tonic-gate 
91*0Sstevel@tonic-gate typedef struct _rpc_gss_init_res {
92*0Sstevel@tonic-gate 	gss_buffer_desc ctx_handle;
93*0Sstevel@tonic-gate 	OM_uint32 gss_major, gss_minor;
94*0Sstevel@tonic-gate 	OM_uint32 seq_window;
95*0Sstevel@tonic-gate 	gss_buffer_desc token;
96*0Sstevel@tonic-gate } rpc_gss_init_res;
97*0Sstevel@tonic-gate 
98*0Sstevel@tonic-gate 
99*0Sstevel@tonic-gate /*
100*0Sstevel@tonic-gate  * Convenience macros.
101*0Sstevel@tonic-gate  */
102*0Sstevel@tonic-gate 
103*0Sstevel@tonic-gate #define	GSS_COPY_BUFFER(dest, src) { \
104*0Sstevel@tonic-gate 	(dest).length = (src).length; \
105*0Sstevel@tonic-gate 	(dest).value = (src).value; }
106*0Sstevel@tonic-gate 
107*0Sstevel@tonic-gate #define	GSS_DUP_BUFFER(dest, src) { \
108*0Sstevel@tonic-gate 	(dest).length = (src).length; \
109*0Sstevel@tonic-gate 	(dest).value = (void *) mem_alloc((dest).length); \
110*0Sstevel@tonic-gate 	bcopy((src).value, (dest).value, (dest).length); }
111*0Sstevel@tonic-gate 
112*0Sstevel@tonic-gate #define	GSS_BUFFERS_EQUAL(b1, b2) (((b1).length == (b2).length) && \
113*0Sstevel@tonic-gate 			(bcmp((b1).value, (b2).value, (b1.length)) == 0))
114*0Sstevel@tonic-gate 
115*0Sstevel@tonic-gate #define	GSS_OIDS_EQUAL(o1, o2) \
116*0Sstevel@tonic-gate 	((((gss_OID)(o1))->length == ((gss_OID)(o2))->length) && \
117*0Sstevel@tonic-gate 		(bcmp(((gss_OID)(o1))->elements, ((gss_OID)(o2))->elements, \
118*0Sstevel@tonic-gate 			((gss_OID)(o1))->length) == 0))
119*0Sstevel@tonic-gate 
120*0Sstevel@tonic-gate #define	MAX_GSS_NAME			128
121*0Sstevel@tonic-gate 
122*0Sstevel@tonic-gate /*
123*0Sstevel@tonic-gate  * Private interfaces for user and kernel space.
124*0Sstevel@tonic-gate  */
125*0Sstevel@tonic-gate bool_t __xdr_gss_buf();
126*0Sstevel@tonic-gate bool_t __xdr_rpc_gss_creds();
127*0Sstevel@tonic-gate bool_t __xdr_rpc_gss_init_arg();
128*0Sstevel@tonic-gate bool_t __xdr_rpc_gss_init_res();
129*0Sstevel@tonic-gate 
130*0Sstevel@tonic-gate bool_t __rpc_gss_wrap_data();
131*0Sstevel@tonic-gate bool_t __rpc_gss_unwrap_data();
132*0Sstevel@tonic-gate 
133*0Sstevel@tonic-gate #ifdef	_KERNEL
134*0Sstevel@tonic-gate /*
135*0Sstevel@tonic-gate  * kernel-level RPCSEC_GSS definitions.
136*0Sstevel@tonic-gate  */
137*0Sstevel@tonic-gate 
138*0Sstevel@tonic-gate void __rpc_gss_dup_oid(gss_OID, gss_OID *);
139*0Sstevel@tonic-gate bool_t __rpc_gss_oids_equal(gss_OID oid1, gss_OID oid2);
140*0Sstevel@tonic-gate void rpc_gss_display_status(OM_uint32 major, OM_uint32 minor,
141*0Sstevel@tonic-gate 			    rpc_gss_OID mechanism, uid_t uid,
142*0Sstevel@tonic-gate 			    char *function_name);
143*0Sstevel@tonic-gate #else
144*0Sstevel@tonic-gate /*
145*0Sstevel@tonic-gate  * user-level RPCSEC_GSS definitions.
146*0Sstevel@tonic-gate  */
147*0Sstevel@tonic-gate 
148*0Sstevel@tonic-gate #define	MAX_MECH_OID_PAIRS		32
149*0Sstevel@tonic-gate 
150*0Sstevel@tonic-gate typedef struct _rpc_gss_name {
151*0Sstevel@tonic-gate 	char *name;
152*0Sstevel@tonic-gate 	rpc_gss_OID type;
153*0Sstevel@tonic-gate } rpc_gss_name;
154*0Sstevel@tonic-gate 
155*0Sstevel@tonic-gate #ifdef	_REENTRANT
156*0Sstevel@tonic-gate extern rpc_gss_error_t	*__rpc_gss_err();
157*0Sstevel@tonic-gate #define	rpc_gss_err	(*(__rpc_gss_err()))
158*0Sstevel@tonic-gate #else
159*0Sstevel@tonic-gate extern rpc_gss_error_t rpc_gss_err;
160*0Sstevel@tonic-gate #endif	/* _REENTRANT */
161*0Sstevel@tonic-gate 
162*0Sstevel@tonic-gate /*
163*0Sstevel@tonic-gate  * Private interfaces in user space.
164*0Sstevel@tonic-gate  */
165*0Sstevel@tonic-gate bool_t __rpc_gss_qop_to_num();
166*0Sstevel@tonic-gate char *__rpc_gss_num_to_qop();
167*0Sstevel@tonic-gate bool_t __rpc_gss_mech_to_oid();
168*0Sstevel@tonic-gate char *__rpc_gss_oid_to_mech();
169*0Sstevel@tonic-gate bool_t __rpc_gss_svc_to_num();
170*0Sstevel@tonic-gate char *__rpc_gss_num_to_svc();
171*0Sstevel@tonic-gate 
172*0Sstevel@tonic-gate void __rpc_gss_xdrdynamic_create();
173*0Sstevel@tonic-gate caddr_t __rpc_gss_xdrdynamic_getdata();
174*0Sstevel@tonic-gate 
175*0Sstevel@tonic-gate bool_t __rpcsec_init();
176*0Sstevel@tonic-gate rpc_gss_OID __get_gss_oid();
177*0Sstevel@tonic-gate void __rpc_gss_bind_error();
178*0Sstevel@tonic-gate int __find_max_data_length(rpc_gss_service_t service, gss_ctx_id_t context,
179*0Sstevel@tonic-gate 	OM_uint32 qop, int max_tp_unit_len);
180*0Sstevel@tonic-gate 
181*0Sstevel@tonic-gate #endif /* _KERNEL */
182*0Sstevel@tonic-gate 
183*0Sstevel@tonic-gate #ifdef	__cplusplus
184*0Sstevel@tonic-gate }
185*0Sstevel@tonic-gate #endif
186*0Sstevel@tonic-gate 
187*0Sstevel@tonic-gate #endif	/* _RPCSEC_DEFS_H */
188