X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;f=utils%2Fgssd%2Fgssd.c;h=40a2b4d7e14d1e2e2256d9ea5950fcde1087fbe7;hb=b695dbb65bb199e3a9ed5a9f780ed2e575061b46;hp=2e6f316dc9e105cecc35c7e55637833287c2a59a;hpb=1e1c7be98749fff054beec4bf67b436b58f6edac;p=nfs-utils.git diff --git a/utils/gssd/gssd.c b/utils/gssd/gssd.c index 2e6f316..40a2b4d 100644 --- a/utils/gssd/gssd.c +++ b/utils/gssd/gssd.c @@ -36,7 +36,9 @@ */ -#include "config.h" +#ifdef HAVE_CONFIG_H +#include +#endif /* HAVE_CONFIG_H */ #include #include @@ -61,6 +63,7 @@ char *ccachesearch[GSSD_MAX_CCACHE_SEARCH + 1]; int use_memcache = 0; int root_uses_machine_creds = 1; unsigned int context_timeout = 0; +char *preferred_realm = NULL; void sig_die(int signal) @@ -83,7 +86,7 @@ sig_hup(int signal) static void usage(char *progname) { - fprintf(stderr, "usage: %s [-f] [-M] [-n] [-v] [-r] [-p pipefsdir] [-k keytab] [-d ccachedir] [-t timeout]\n", + fprintf(stderr, "usage: %s [-f] [-M] [-n] [-v] [-r] [-p pipefsdir] [-k keytab] [-d ccachedir] [-t timeout] [-R preferred realm]\n", progname); exit(1); } @@ -100,7 +103,7 @@ main(int argc, char *argv[]) char *progname; memset(ccachesearch, 0, sizeof(ccachesearch)); - while ((opt = getopt(argc, argv, "fvrmnMp:k:d:t:")) != -1) { + while ((opt = getopt(argc, argv, "fvrmnMp:k:d:t:R:")) != -1) { switch (opt) { case 'f': fg = 1; @@ -138,6 +141,9 @@ main(int argc, char *argv[]) case 't': context_timeout = atoi(optarg); break; + case 'R': + preferred_realm = strdup(optarg); + break; default: usage(argv[0]); break; @@ -150,6 +156,9 @@ main(int argc, char *argv[]) ccachesearch[i++] = strtok(NULL, ":"); } while (ccachesearch[i-1] != NULL && i < GSSD_MAX_CCACHE_SEARCH); + if (preferred_realm == NULL) + gssd_k5_get_default_realm(&preferred_realm); + snprintf(pipefs_nfsdir, sizeof(pipefs_nfsdir), "%s/%s", pipefs_dir, GSSD_SERVICE_NAME); if (pipefs_nfsdir[sizeof(pipefs_nfsdir)-1] != '\0') @@ -162,6 +171,8 @@ main(int argc, char *argv[]) initerr(progname, verbosity, fg); #ifdef HAVE_AUTHGSS_SET_DEBUG_LEVEL + if (verbosity && rpc_verbosity == 0) + rpc_verbosity = verbosity; authgss_set_debug_level(rpc_verbosity); #else if (rpc_verbosity > 0)