|
Packit |
fd8b60 |
#include <sys/types.h>
|
|
Packit |
fd8b60 |
#include <krb5.h>
|
|
Packit |
fd8b60 |
#include <gssrpc/rpc.h>
|
|
Packit |
fd8b60 |
#include <kdb.h>
|
|
Packit |
fd8b60 |
#include <kadm5/admin_xdr.h>
|
|
Packit |
fd8b60 |
#include "policy_db.h"
|
|
Packit |
fd8b60 |
#ifdef HAVE_MEMORY_H
|
|
Packit |
fd8b60 |
#include <memory.h>
|
|
Packit |
fd8b60 |
#endif
|
|
Packit |
fd8b60 |
#include <string.h>
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
static int
|
|
Packit |
fd8b60 |
osa_policy_min_vers(osa_policy_ent_t objp)
|
|
Packit |
fd8b60 |
{
|
|
Packit |
fd8b60 |
if (objp->attributes ||
|
|
Packit |
fd8b60 |
objp->max_life ||
|
|
Packit |
fd8b60 |
objp->max_renewable_life ||
|
|
Packit |
fd8b60 |
objp->allowed_keysalts ||
|
|
Packit |
fd8b60 |
objp->n_tl_data)
|
|
Packit |
fd8b60 |
return OSA_ADB_POLICY_VERSION_3;
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
if (objp->pw_max_fail ||
|
|
Packit |
fd8b60 |
objp->pw_failcnt_interval ||
|
|
Packit |
fd8b60 |
objp->pw_lockout_duration)
|
|
Packit |
fd8b60 |
return OSA_ADB_POLICY_VERSION_2;
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
return OSA_ADB_POLICY_VERSION_1;
|
|
Packit |
fd8b60 |
}
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
bool_t
|
|
Packit |
fd8b60 |
xdr_osa_policy_ent_rec(XDR *xdrs, osa_policy_ent_t objp)
|
|
Packit |
fd8b60 |
{
|
|
Packit |
fd8b60 |
switch (xdrs->x_op) {
|
|
Packit |
fd8b60 |
case XDR_ENCODE:
|
|
Packit |
fd8b60 |
objp->version = osa_policy_min_vers(objp);
|
|
Packit |
fd8b60 |
/* fall through */
|
|
Packit |
fd8b60 |
case XDR_FREE:
|
|
Packit |
fd8b60 |
if (!xdr_int(xdrs, &objp->version))
|
|
Packit |
fd8b60 |
return FALSE;
|
|
Packit |
fd8b60 |
break;
|
|
Packit |
fd8b60 |
case XDR_DECODE:
|
|
Packit |
fd8b60 |
if (!xdr_int(xdrs, &objp->version))
|
|
Packit |
fd8b60 |
return FALSE;
|
|
Packit |
fd8b60 |
if (objp->version != OSA_ADB_POLICY_VERSION_1 &&
|
|
Packit |
fd8b60 |
objp->version != OSA_ADB_POLICY_VERSION_2 &&
|
|
Packit |
fd8b60 |
objp->version != OSA_ADB_POLICY_VERSION_3)
|
|
Packit |
fd8b60 |
return FALSE;
|
|
Packit |
fd8b60 |
break;
|
|
Packit |
fd8b60 |
}
|
|
Packit |
fd8b60 |
|
|
Packit |
fd8b60 |
if(!xdr_nullstring(xdrs, &objp->name))
|
|
Packit |
fd8b60 |
return (FALSE);
|
|
Packit |
fd8b60 |
if (!xdr_u_int32(xdrs, &objp->pw_min_life))
|
|
Packit |
fd8b60 |
return (FALSE);
|
|
Packit |
fd8b60 |
if (!xdr_u_int32(xdrs, &objp->pw_max_life))
|
|
Packit |
fd8b60 |
return (FALSE);
|
|
Packit |
fd8b60 |
if (!xdr_u_int32(xdrs, &objp->pw_min_length))
|
|
Packit |
fd8b60 |
return (FALSE);
|
|
Packit |
fd8b60 |
if (!xdr_u_int32(xdrs, &objp->pw_min_classes))
|
|
Packit |
fd8b60 |
return (FALSE);
|
|
Packit |
fd8b60 |
if (!xdr_u_int32(xdrs, &objp->pw_history_num))
|
|
Packit |
fd8b60 |
return (FALSE);
|
|
Packit |
fd8b60 |
if (!xdr_u_int32(xdrs, &objp->policy_refcnt))
|
|
Packit |
fd8b60 |
return (FALSE);
|
|
Packit |
fd8b60 |
if (objp->version > OSA_ADB_POLICY_VERSION_1) {
|
|
Packit |
fd8b60 |
if (!xdr_u_int32(xdrs, &objp->pw_max_fail))
|
|
Packit |
fd8b60 |
return (FALSE);
|
|
Packit |
fd8b60 |
if (!xdr_u_int32(xdrs, &objp->pw_failcnt_interval))
|
|
Packit |
fd8b60 |
return (FALSE);
|
|
Packit |
fd8b60 |
if (!xdr_u_int32(xdrs, &objp->pw_lockout_duration))
|
|
Packit |
fd8b60 |
return (FALSE);
|
|
Packit |
fd8b60 |
}
|
|
Packit |
fd8b60 |
if (objp->version > OSA_ADB_POLICY_VERSION_2) {
|
|
Packit |
fd8b60 |
if (!xdr_u_int32(xdrs, &objp->attributes))
|
|
Packit |
fd8b60 |
return (FALSE);
|
|
Packit |
fd8b60 |
if (!xdr_u_int32(xdrs, &objp->max_life))
|
|
Packit |
fd8b60 |
return (FALSE);
|
|
Packit |
fd8b60 |
if (!xdr_u_int32(xdrs, &objp->max_renewable_life))
|
|
Packit |
fd8b60 |
return (FALSE);
|
|
Packit |
fd8b60 |
if (!xdr_nullstring(xdrs, &objp->allowed_keysalts))
|
|
Packit |
fd8b60 |
return (FALSE);
|
|
Packit |
fd8b60 |
if (!xdr_short(xdrs, &objp->n_tl_data))
|
|
Packit |
fd8b60 |
return (FALSE);
|
|
Packit |
fd8b60 |
if (!xdr_nulltype(xdrs, (void **) &objp->tl_data,
|
|
Packit |
fd8b60 |
xdr_krb5_tl_data))
|
|
Packit |
fd8b60 |
return FALSE;
|
|
Packit |
fd8b60 |
}
|
|
Packit |
fd8b60 |
return (TRUE);
|
|
Packit |
fd8b60 |
}
|