diff options
author | ache <ache@FreeBSD.org> | 2001-06-23 04:48:59 +0000 |
---|---|---|
committer | ache <ache@FreeBSD.org> | 2001-06-23 04:48:59 +0000 |
commit | 49fc10f4a2791c4482d2ac1e61985b2067188a19 (patch) | |
tree | ee71dc9bd3600ff48c51ccd1b37f6fd09e5d863e /contrib/opie | |
parent | 887d4d7595cea78239fca623489ca47d41005ed2 (diff) | |
download | FreeBSD-src-49fc10f4a2791c4482d2ac1e61985b2067188a19.zip FreeBSD-src-49fc10f4a2791c4482d2ac1e61985b2067188a19.tar.gz |
Make the similar changes as in our keyinfo, i.e. allow user to get his own
sequence and allow root to get everybody's one. Before this change user
can't get his own sequence, root required.
Diffstat (limited to 'contrib/opie')
-rw-r--r-- | contrib/opie/opieinfo.c | 26 |
1 files changed, 16 insertions, 10 deletions
diff --git a/contrib/opie/opieinfo.c b/contrib/opie/opieinfo.c index d667a9a..a5d0d57 100644 --- a/contrib/opie/opieinfo.c +++ b/contrib/opie/opieinfo.c @@ -29,6 +29,9 @@ License Agreement applies to this software. Modified at NRL for OPIE 2.0. Written at Bellcore for the S/Key Version 1 software distribution (keyinfo) + +$FreeBSD$ + */ #include "opie_cfg.h" @@ -36,9 +39,6 @@ License Agreement applies to this software. #if HAVE_UNISTD_H #include <unistd.h> #endif /* HAVE_UNISTD_H */ -#if HAVE_PWD_H -#include <pwd.h> -#endif /* HAVE_PWD_H */ #include "opie.h" /* extern char *optarg; */ @@ -46,12 +46,14 @@ extern int errno, optind; static char *getusername FUNCTION_NOARGS { - struct passwd *p = getpwuid(getuid()); - - if (!p) - return getlogin(); + char *login; - return p->pw_name; + login = getlogin(); + if (login == NULL) { + fprintf(stderr, "Cannot find login name\n"); + exit(1); + } + return login; } int main FUNCTION((argc, argv), int argc AND char *argv[]) @@ -71,9 +73,13 @@ int main FUNCTION((argc, argv), int argc AND char *argv[]) } } - if (optind < argc) + if (optind < argc) { + if (getuid() != 0) { + fprintf(stderr, "Only superuser may get another user's keys\n"); + exit(1); + } username = argv[optind]; - else + } else username = getusername(); if ((i = opielookup(&opie, username)) && (i != 2)) { |