#include <krb5/krb5.h>
#include <krb5/kadm5_hook_plugin.h>
#include <stdio.h>
#include <assert.h>
static void
log_call(krb5_context context,
const char *function,
int stage,
krb5_principal princ)
{
char *unparsed = NULL;
krb5_error_code ret;
ret = krb5_unparse_name(context, princ, &unparsed);
assert(ret == 0);
printf("%s: stage %s principal %s\n",
function,
(stage == KADM5_HOOK_STAGE_PRECOMMIT) ? "precommit" : "postcommit",
unparsed);
if (unparsed)
krb5_free_unparsed_name(context, unparsed);
}
static kadm5_ret_t
chpass(krb5_context context,
kadm5_hook_modinfo *modinfo,
int stage,
krb5_principal princ, krb5_boolean keepold,
int n_ks_tuple,
krb5_key_salt_tuple *ks_tuple,
const char *newpass)
{
log_call(context, "chpass", stage, princ);
return 0;
}
static kadm5_ret_t
create(krb5_context context,
kadm5_hook_modinfo *modinfo,
int stage,
kadm5_principal_ent_t princ, long mask,
int n_ks_tuple,
krb5_key_salt_tuple *ks_tuple,
const char *newpass)
{
log_call(context, "create", stage, princ->principal);
return 0;
}
static kadm5_ret_t
rename_hook(krb5_context context, kadm5_hook_modinfo *modinfo, int stage,
krb5_principal oprinc, krb5_principal nprinc)
{
log_call(context, "rename", stage, oprinc);
return 0;
}
krb5_error_code
kadm5_hook_test_initvt(krb5_context context, int maj_ver, int min_ver,
krb5_plugin_vtable vtable);
krb5_error_code
kadm5_hook_test_initvt(krb5_context context, int maj_ver, int min_ver,
krb5_plugin_vtable vtable)
{
kadm5_hook_vftable_1 *vt = (kadm5_hook_vftable_1 *) vtable;
if (maj_ver != 1)
return KRB5_PLUGIN_VER_NOTSUPP;
vt->name = "test";
vt->chpass = chpass;
vt->create = create;
vt->rename = rename_hook;
return 0;
}