xref: /freebsd/lib/libc/rpc/key_prot_xdr.c (revision dc36d6f9)
1 /*
2  * Please do not edit this file.
3  * It was generated using rpcgen.
4  */
5 
6 #include "namespace.h"
7 #include <rpc/key_prot.h>
8 #include "un-namespace.h"
9 /*-
10  * SPDX-License-Identifier: BSD-3-Clause
11  *
12  * Copyright (c) 2009, Sun Microsystems, Inc.
13  * All rights reserved.
14  *
15  * Redistribution and use in source and binary forms, with or without
16  * modification, are permitted provided that the following conditions are met:
17  * - Redistributions of source code must retain the above copyright notice,
18  *   this list of conditions and the following disclaimer.
19  * - Redistributions in binary form must reproduce the above copyright notice,
20  *   this list of conditions and the following disclaimer in the documentation
21  *   and/or other materials provided with the distribution.
22  * - Neither the name of Sun Microsystems, Inc. nor the names of its
23  *   contributors may be used to endorse or promote products derived
24  *   from this software without specific prior written permission.
25  *
26  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
27  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
28  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
29  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
30  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
31  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
32  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
33  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
34  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
35  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
36  * POSSIBILITY OF SUCH DAMAGE.
37  */
38 /* Copyright (c)  1990, 1991 Sun Microsystems, Inc. */
39 
40 /*
41  * Compiled from key_prot.x using rpcgen.
42  * DO NOT EDIT THIS FILE!
43  * This is NOT source code!
44  */
45 
46 bool_t
xdr_keystatus(register XDR * xdrs,keystatus * objp)47 xdr_keystatus(register XDR *xdrs, keystatus *objp)
48 {
49 
50 	if (!xdr_enum(xdrs, (enum_t *)objp))
51 		return (FALSE);
52 	return (TRUE);
53 }
54 
55 bool_t
xdr_keybuf(register XDR * xdrs,keybuf objp)56 xdr_keybuf(register XDR *xdrs, keybuf objp)
57 {
58 
59 	if (!xdr_opaque(xdrs, objp, HEXKEYBYTES))
60 		return (FALSE);
61 	return (TRUE);
62 }
63 
64 bool_t
xdr_netnamestr(register XDR * xdrs,netnamestr * objp)65 xdr_netnamestr(register XDR *xdrs, netnamestr *objp)
66 {
67 
68 	if (!xdr_string(xdrs, objp, MAXNETNAMELEN))
69 		return (FALSE);
70 	return (TRUE);
71 }
72 
73 bool_t
xdr_cryptkeyarg(register XDR * xdrs,cryptkeyarg * objp)74 xdr_cryptkeyarg(register XDR *xdrs, cryptkeyarg *objp)
75 {
76 
77 	if (!xdr_netnamestr(xdrs, &objp->remotename))
78 		return (FALSE);
79 	if (!xdr_des_block(xdrs, &objp->deskey))
80 		return (FALSE);
81 	return (TRUE);
82 }
83 
84 bool_t
xdr_cryptkeyarg2(register XDR * xdrs,cryptkeyarg2 * objp)85 xdr_cryptkeyarg2(register XDR *xdrs, cryptkeyarg2 *objp)
86 {
87 
88 	if (!xdr_netnamestr(xdrs, &objp->remotename))
89 		return (FALSE);
90 	if (!xdr_netobj(xdrs, &objp->remotekey))
91 		return (FALSE);
92 	if (!xdr_des_block(xdrs, &objp->deskey))
93 		return (FALSE);
94 	return (TRUE);
95 }
96 
97 bool_t
xdr_cryptkeyres(register XDR * xdrs,cryptkeyres * objp)98 xdr_cryptkeyres(register XDR *xdrs, cryptkeyres *objp)
99 {
100 
101 	if (!xdr_keystatus(xdrs, &objp->status))
102 		return (FALSE);
103 	switch (objp->status) {
104 	case KEY_SUCCESS:
105 		if (!xdr_des_block(xdrs, &objp->cryptkeyres_u.deskey))
106 			return (FALSE);
107 		break;
108 	default:
109 		break;
110 	}
111 	return (TRUE);
112 }
113 
114 bool_t
xdr_unixcred(register XDR * xdrs,unixcred * objp)115 xdr_unixcred(register XDR *xdrs, unixcred *objp)
116 {
117 	u_int **pgids_val;
118 
119 	if (!xdr_u_int(xdrs, &objp->uid))
120 		return (FALSE);
121 	if (!xdr_u_int(xdrs, &objp->gid))
122 		return (FALSE);
123 	pgids_val = &objp->gids.gids_val;
124 	if (!xdr_array(xdrs, (char **) pgids_val, (u_int *) &objp->gids.gids_len, MAXGIDS,
125 		sizeof (u_int), (xdrproc_t) xdr_u_int))
126 		return (FALSE);
127 	return (TRUE);
128 }
129 
130 bool_t
xdr_getcredres(register XDR * xdrs,getcredres * objp)131 xdr_getcredres(register XDR *xdrs, getcredres *objp)
132 {
133 
134 	if (!xdr_keystatus(xdrs, &objp->status))
135 		return (FALSE);
136 	switch (objp->status) {
137 	case KEY_SUCCESS:
138 		if (!xdr_unixcred(xdrs, &objp->getcredres_u.cred))
139 			return (FALSE);
140 		break;
141 	default:
142 		break;
143 	}
144 	return (TRUE);
145 }
146 
147 bool_t
xdr_key_netstarg(register XDR * xdrs,key_netstarg * objp)148 xdr_key_netstarg(register XDR *xdrs, key_netstarg *objp)
149 {
150 
151 	if (!xdr_keybuf(xdrs, objp->st_priv_key))
152 		return (FALSE);
153 	if (!xdr_keybuf(xdrs, objp->st_pub_key))
154 		return (FALSE);
155 	if (!xdr_netnamestr(xdrs, &objp->st_netname))
156 		return (FALSE);
157 	return (TRUE);
158 }
159 
160 bool_t
xdr_key_netstres(register XDR * xdrs,key_netstres * objp)161 xdr_key_netstres(register XDR *xdrs, key_netstres *objp)
162 {
163 
164 	if (!xdr_keystatus(xdrs, &objp->status))
165 		return (FALSE);
166 	switch (objp->status) {
167 	case KEY_SUCCESS:
168 		if (!xdr_key_netstarg(xdrs, &objp->key_netstres_u.knet))
169 			return (FALSE);
170 		break;
171 	default:
172 		break;
173 	}
174 	return (TRUE);
175 }
176