2e322d3796
with the explicit permission of Sun Microsystems in 2009.
178 lines
4.3 KiB
C
178 lines
4.3 KiB
C
/*
|
|
* Please do not edit this file.
|
|
* It was generated using rpcgen.
|
|
*/
|
|
|
|
#include "namespace.h"
|
|
#include <rpc/key_prot.h>
|
|
#include "un-namespace.h"
|
|
/*-
|
|
* Copyright (c) 2009, Sun Microsystems, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions are met:
|
|
* - Redistributions of source code must retain the above copyright notice,
|
|
* this list of conditions and the following disclaimer.
|
|
* - Redistributions in binary form must reproduce the above copyright notice,
|
|
* this list of conditions and the following disclaimer in the documentation
|
|
* and/or other materials provided with the distribution.
|
|
* - Neither the name of Sun Microsystems, Inc. nor the names of its
|
|
* contributors may be used to endorse or promote products derived
|
|
* from this software without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
*/
|
|
/* Copyright (c) 1990, 1991 Sun Microsystems, Inc. */
|
|
|
|
/* #pragma ident "@(#)key_prot.x 1.7 94/04/29 SMI" */
|
|
#include <sys/cdefs.h>
|
|
__FBSDID("$FreeBSD$");
|
|
|
|
/*
|
|
* Compiled from key_prot.x using rpcgen.
|
|
* DO NOT EDIT THIS FILE!
|
|
* This is NOT source code!
|
|
*/
|
|
|
|
bool_t
|
|
xdr_keystatus(register XDR *xdrs, keystatus *objp)
|
|
{
|
|
|
|
if (!xdr_enum(xdrs, (enum_t *)objp))
|
|
return (FALSE);
|
|
return (TRUE);
|
|
}
|
|
|
|
bool_t
|
|
xdr_keybuf(register XDR *xdrs, keybuf objp)
|
|
{
|
|
|
|
if (!xdr_opaque(xdrs, objp, HEXKEYBYTES))
|
|
return (FALSE);
|
|
return (TRUE);
|
|
}
|
|
|
|
bool_t
|
|
xdr_netnamestr(register XDR *xdrs, netnamestr *objp)
|
|
{
|
|
|
|
if (!xdr_string(xdrs, objp, MAXNETNAMELEN))
|
|
return (FALSE);
|
|
return (TRUE);
|
|
}
|
|
|
|
bool_t
|
|
xdr_cryptkeyarg(register XDR *xdrs, cryptkeyarg *objp)
|
|
{
|
|
|
|
if (!xdr_netnamestr(xdrs, &objp->remotename))
|
|
return (FALSE);
|
|
if (!xdr_des_block(xdrs, &objp->deskey))
|
|
return (FALSE);
|
|
return (TRUE);
|
|
}
|
|
|
|
bool_t
|
|
xdr_cryptkeyarg2(register XDR *xdrs, cryptkeyarg2 *objp)
|
|
{
|
|
|
|
if (!xdr_netnamestr(xdrs, &objp->remotename))
|
|
return (FALSE);
|
|
if (!xdr_netobj(xdrs, &objp->remotekey))
|
|
return (FALSE);
|
|
if (!xdr_des_block(xdrs, &objp->deskey))
|
|
return (FALSE);
|
|
return (TRUE);
|
|
}
|
|
|
|
bool_t
|
|
xdr_cryptkeyres(register XDR *xdrs, cryptkeyres *objp)
|
|
{
|
|
|
|
if (!xdr_keystatus(xdrs, &objp->status))
|
|
return (FALSE);
|
|
switch (objp->status) {
|
|
case KEY_SUCCESS:
|
|
if (!xdr_des_block(xdrs, &objp->cryptkeyres_u.deskey))
|
|
return (FALSE);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
return (TRUE);
|
|
}
|
|
|
|
bool_t
|
|
xdr_unixcred(register XDR *xdrs, unixcred *objp)
|
|
{
|
|
u_int **pgids_val;
|
|
|
|
if (!xdr_u_int(xdrs, &objp->uid))
|
|
return (FALSE);
|
|
if (!xdr_u_int(xdrs, &objp->gid))
|
|
return (FALSE);
|
|
pgids_val = &objp->gids.gids_val;
|
|
if (!xdr_array(xdrs, (char **) pgids_val, (u_int *) &objp->gids.gids_len, MAXGIDS,
|
|
sizeof (u_int), (xdrproc_t) xdr_u_int))
|
|
return (FALSE);
|
|
return (TRUE);
|
|
}
|
|
|
|
bool_t
|
|
xdr_getcredres(register XDR *xdrs, getcredres *objp)
|
|
{
|
|
|
|
if (!xdr_keystatus(xdrs, &objp->status))
|
|
return (FALSE);
|
|
switch (objp->status) {
|
|
case KEY_SUCCESS:
|
|
if (!xdr_unixcred(xdrs, &objp->getcredres_u.cred))
|
|
return (FALSE);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
return (TRUE);
|
|
}
|
|
|
|
bool_t
|
|
xdr_key_netstarg(register XDR *xdrs, key_netstarg *objp)
|
|
{
|
|
|
|
if (!xdr_keybuf(xdrs, objp->st_priv_key))
|
|
return (FALSE);
|
|
if (!xdr_keybuf(xdrs, objp->st_pub_key))
|
|
return (FALSE);
|
|
if (!xdr_netnamestr(xdrs, &objp->st_netname))
|
|
return (FALSE);
|
|
return (TRUE);
|
|
}
|
|
|
|
bool_t
|
|
xdr_key_netstres(register XDR *xdrs, key_netstres *objp)
|
|
{
|
|
|
|
if (!xdr_keystatus(xdrs, &objp->status))
|
|
return (FALSE);
|
|
switch (objp->status) {
|
|
case KEY_SUCCESS:
|
|
if (!xdr_key_netstarg(xdrs, &objp->key_netstres_u.knet))
|
|
return (FALSE);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
return (TRUE);
|
|
}
|