root/usr/src/cmd/krb5/kadmin/cli/kadmin_rmt.c
/*
 * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
 * Use is subject to license terms.
 */


/*
 * Contains remote client specific code.
 */

#include <stdio.h>
#include <stdlib.h>
#include <libintl.h>
#include <k5-int.h>
#include <krb5.h>

extern void *handle;

void
usage(char *whoami)
{
        fprintf(stderr,
            "%s: %s [-r realm] [-p principal] [-q query] "
            "[-s admin_server[:port]] [[-c ccache]|[-k [-t keytab]]"
            "|[-w password]]\n",
            gettext("Usage"), whoami);
        exit(1);
}


/*
 * Debugging function - for remote admin client
 */
/* ARGSUSED */
void
debugEnable(int displayMsgs)
{

#ifdef DEBUG
        /* Solaris Kerberos: not supported */
        /* debugDisplaySS(displayMsgs); */
#endif
}

void
kadmin_getprivs(argc, argv)
    int argc;
    char *argv[];
{
    static char *privs[] = {"GET", "ADD", "MODIFY", "DELETE", "LIST", "CHANGE"};
    krb5_error_code retval;
    int i;
    long plist;

    if (argc != 1) {
        fprintf(stderr, "%s: get_privs\n", gettext("usage"));
        return;
    }
    retval = kadm5_get_privs(handle, &plist);
    if (retval) {
        com_err("get_privs", retval,
                    gettext("while retrieving privileges"));
        return;
    }
    printf(gettext("current privileges:"));
    for (i = 0; i < sizeof (privs) / sizeof (char *); i++) {
        if (plist & 1 << i)
            printf(" %s", gettext(privs[i]));
    }
    printf("\n");
}