]> git.decadent.org.uk Git - nfs-utils.git/blob - support/rpc/include/rpc/svc_auth.h
Add gss support from citi @ umich
[nfs-utils.git] / support / rpc / include / rpc / svc_auth.h
1 /*      $OpenBSD: svc_auth.h,v 1.2 1997/09/21 10:46:16 niklas Exp $     */
2 /*      $NetBSD: svc_auth.h,v 1.4 1994/10/26 00:57:07 cgd Exp $ */
3
4 /*
5  * Sun RPC is a product of Sun Microsystems, Inc. and is provided for
6  * unrestricted use provided that this legend is included on all tape
7  * media and as a part of the software program in whole or part.  Users
8  * may copy or modify Sun RPC without charge, but are not authorized
9  * to license or distribute it to anyone else except as part of a product or
10  * program developed by the user.
11  *
12  * SUN RPC IS PROVIDED AS IS WITH NO WARRANTIES OF ANY KIND INCLUDING THE
13  * WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS FOR A PARTICULAR
14  * PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE OR TRADE PRACTICE.
15  *
16  * Sun RPC is provided with no support and without any obligation on the
17  * part of Sun Microsystems, Inc. to assist in its use, correction,
18  * modification or enhancement.
19  *
20  * SUN MICROSYSTEMS, INC. SHALL HAVE NO LIABILITY WITH RESPECT TO THE
21  * INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY SUN RPC
22  * OR ANY PART THEREOF.
23  *
24  * In no event will Sun Microsystems, Inc. be liable for any lost revenue
25  * or profits or other special, indirect and consequential damages, even if
26  * Sun has been advised of the possibility of such damages.
27  *
28  * Sun Microsystems, Inc.
29  * 2550 Garcia Avenue
30  * Mountain View, California  94043
31  *
32  *      from: @(#)svc_auth.h 1.6 86/07/16 SMI
33  *      @(#)svc_auth.h  2.1 88/07/29 4.0 RPCSRC
34  */
35
36 /*
37  * svc_auth.h, Service side of rpc authentication.
38  *
39  * Copyright (C) 1984, Sun Microsystems, Inc.
40  */
41
42 #ifndef _RPC_SVCAUTH_H
43 #define _RPC_SVCAUTH_H
44
45 /*
46  * Interface to server-side authentication flavors.
47  */
48 typedef struct {
49         struct svc_auth_ops {
50                 int   (*svc_ah_wrap)();
51                 int   (*svc_ah_unwrap)();
52                 int   (*svc_ah_destroy)();
53         } *svc_ah_ops;
54         caddr_t svc_ah_private;
55 } SVCAUTH;
56
57 #define SVCAUTH_WRAP(auth, xdrs, xfunc, xwhere) \
58      ((*((auth)->svc_ah_ops->svc_ah_wrap))(auth, xdrs, xfunc, xwhere))
59 #define SVCAUTH_UNWRAP(auth, xdrs, xfunc, xwhere) \
60      ((*((auth)->svc_ah_ops->svc_ah_unwrap))(auth, xdrs, xfunc, xwhere))
61 #define SVCAUTH_DESTROY(auth) \
62      ((*((auth)->svc_ah_ops->svc_ah_destroy))(auth))
63
64 /*
65  * Approved way of getting principal of caller
66  */
67 char *svcauth_gss_get_principal __P((SVCAUTH *auth));
68
69 /*
70  * Approved way of setting server principal
71  */
72 bool_t svcauth_gss_set_svc_name __P((gss_name_t name));
73
74 /*
75  * Server side authenticator
76  */
77 __BEGIN_DECLS
78 extern enum auth_stat _authenticate();
79 __END_DECLS
80
81 #endif /* !_RPC_SVCAUTH_H */