mirror of
git://sourceware.org/git/glibc.git
synced 2025-01-18 12:16:13 +08:00
169 lines
4.4 KiB
C
169 lines
4.4 KiB
C
/* Copyright (c) 1990, 1991 Sun Microsystems, Inc.
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
#include "rpc/key_prot.h"
|
|
|
|
bool_t
|
|
xdr_keystatus (XDR * xdrs, keystatus * objp)
|
|
{
|
|
if (!INTUSE(xdr_enum) (xdrs, (enum_t *) objp))
|
|
return FALSE;
|
|
|
|
return TRUE;
|
|
}
|
|
INTDEF(xdr_keystatus)
|
|
|
|
bool_t
|
|
xdr_keybuf (XDR * xdrs, keybuf objp)
|
|
{
|
|
if (!INTUSE(xdr_opaque) (xdrs, objp, HEXKEYBYTES))
|
|
return FALSE;
|
|
|
|
return TRUE;
|
|
}
|
|
INTDEF(xdr_keybuf)
|
|
|
|
bool_t
|
|
xdr_netnamestr (XDR * xdrs, netnamestr * objp)
|
|
{
|
|
if (!INTUSE(xdr_string) (xdrs, objp, MAXNETNAMELEN))
|
|
return FALSE;
|
|
|
|
return TRUE;
|
|
}
|
|
INTDEF(xdr_netnamestr)
|
|
|
|
bool_t
|
|
xdr_cryptkeyarg (XDR * xdrs, cryptkeyarg * objp)
|
|
{
|
|
if (!INTUSE(xdr_netnamestr) (xdrs, &objp->remotename))
|
|
return FALSE;
|
|
|
|
if (!INTUSE(xdr_des_block) (xdrs, &objp->deskey))
|
|
return FALSE;
|
|
|
|
return TRUE;
|
|
}
|
|
INTDEF(xdr_cryptkeyarg)
|
|
|
|
bool_t
|
|
xdr_cryptkeyarg2 (XDR * xdrs, cryptkeyarg2 * objp)
|
|
{
|
|
if (!INTUSE(xdr_netnamestr) (xdrs, &objp->remotename))
|
|
return FALSE;
|
|
if (!INTUSE(xdr_netobj) (xdrs, &objp->remotekey))
|
|
return FALSE;
|
|
if (!INTUSE(xdr_des_block) (xdrs, &objp->deskey))
|
|
return FALSE;
|
|
return TRUE;
|
|
}
|
|
INTDEF(xdr_cryptkeyarg2)
|
|
|
|
bool_t
|
|
xdr_cryptkeyres (XDR * xdrs, cryptkeyres * objp)
|
|
{
|
|
if (!INTUSE(xdr_keystatus) (xdrs, &objp->status))
|
|
return FALSE;
|
|
switch (objp->status)
|
|
{
|
|
case KEY_SUCCESS:
|
|
if (!INTUSE(xdr_des_block) (xdrs, &objp->cryptkeyres_u.deskey))
|
|
return FALSE;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
return TRUE;
|
|
}
|
|
INTDEF(xdr_cryptkeyres)
|
|
|
|
bool_t
|
|
xdr_unixcred (XDR * xdrs, unixcred * objp)
|
|
{
|
|
if (!INTUSE(xdr_u_int) (xdrs, &objp->uid))
|
|
return FALSE;
|
|
if (!INTUSE(xdr_u_int) (xdrs, &objp->gid))
|
|
return FALSE;
|
|
if (!INTUSE(xdr_array) (xdrs, (void *) &objp->gids.gids_val,
|
|
(u_int *) & objp->gids.gids_len, MAXGIDS,
|
|
sizeof (u_int), (xdrproc_t) INTUSE(xdr_u_int)))
|
|
return FALSE;
|
|
return TRUE;
|
|
}
|
|
INTDEF(xdr_unixcred)
|
|
|
|
bool_t
|
|
xdr_getcredres (XDR * xdrs, getcredres * objp)
|
|
{
|
|
if (!INTUSE(xdr_keystatus) (xdrs, &objp->status))
|
|
return FALSE;
|
|
switch (objp->status)
|
|
{
|
|
case KEY_SUCCESS:
|
|
if (!INTUSE(xdr_unixcred) (xdrs, &objp->getcredres_u.cred))
|
|
return FALSE;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
return TRUE;
|
|
}
|
|
|
|
bool_t
|
|
xdr_key_netstarg (XDR * xdrs, key_netstarg * objp)
|
|
{
|
|
if (!INTUSE(xdr_keybuf) (xdrs, objp->st_priv_key))
|
|
return FALSE;
|
|
if (!INTUSE(xdr_keybuf) (xdrs, objp->st_pub_key))
|
|
return FALSE;
|
|
if (!INTUSE(xdr_netnamestr) (xdrs, &objp->st_netname))
|
|
return FALSE;
|
|
return TRUE;
|
|
}
|
|
INTDEF(xdr_key_netstarg)
|
|
|
|
bool_t
|
|
xdr_key_netstres (XDR * xdrs, key_netstres * objp)
|
|
{
|
|
if (!INTUSE(xdr_keystatus) (xdrs, &objp->status))
|
|
return FALSE;
|
|
switch (objp->status)
|
|
{
|
|
case KEY_SUCCESS:
|
|
if (!INTUSE(xdr_key_netstarg) (xdrs, &objp->key_netstres_u.knet))
|
|
return FALSE;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
return TRUE;
|
|
}
|
|
INTDEF(xdr_key_netstres)
|