diff options
author | Warner Losh <imp@FreeBSD.org> | 2000-08-10 22:53:49 +0000 |
---|---|---|
committer | Warner Losh <imp@FreeBSD.org> | 2000-08-10 22:53:49 +0000 |
commit | b1dbe5c2bcae42a0601e445ef37e391b492015e7 (patch) | |
tree | 7e527431501c0cd7d91463ab072f7c0264ea3b33 /usr.bin/keyinfo | |
parent | 0521578550efec99f93e74a78225ebd9f1db32c9 (diff) | |
download | src-test2-b1dbe5c2bcae42a0601e445ef37e391b492015e7.tar.gz src-test2-b1dbe5c2bcae42a0601e445ef37e391b492015e7.zip |
Notes
Diffstat (limited to 'usr.bin/keyinfo')
-rw-r--r-- | usr.bin/keyinfo/Makefile | 11 | ||||
-rw-r--r-- | usr.bin/keyinfo/keyinfo.1 | 4 | ||||
-rw-r--r-- | usr.bin/keyinfo/keyinfo.c | 57 | ||||
-rw-r--r-- | usr.bin/keyinfo/keyinfo.pl | 27 |
4 files changed, 65 insertions, 34 deletions
diff --git a/usr.bin/keyinfo/Makefile b/usr.bin/keyinfo/Makefile index 1fdd57cdf742..dfe130c0fd86 100644 --- a/usr.bin/keyinfo/Makefile +++ b/usr.bin/keyinfo/Makefile @@ -1,11 +1,10 @@ # @(#)Makefile 5.5 (Berkeley) 7/1/90 +# $FreeBSD$ BINMODE=4555 - -MAN1= keyinfo.1 - -beforeinstall: - ${INSTALL} -c -o ${BINOWN} -g ${BINGRP} -m ${BINMODE} \ - ${.CURDIR}/keyinfo.pl ${DESTDIR}${BINDIR}/keyinfo +PROG= keyinfo +LDFLAGS=-lskey -lcrypt -lmd +DPADD= ${LIBSKEY} ${LIBCRYPT} ${LIBMD} +CFLAGS+=-Wall .include <bsd.prog.mk> diff --git a/usr.bin/keyinfo/keyinfo.1 b/usr.bin/keyinfo/keyinfo.1 index 775043736354..5fcae6848cc8 100644 --- a/usr.bin/keyinfo/keyinfo.1 +++ b/usr.bin/keyinfo/keyinfo.1 @@ -27,12 +27,13 @@ Usage example: .sp 0 > keyinfo .sp 0 - 0098 ws91340 + 98 ws91340 .Sh ARGUMENTS .Bl -tag -width indent .It Ar username The S/key user to display the information for. The default is to display S/Key information on the user who invokes the command. +Only the superuser can ask for another user's key information. .El .Sh DIAGNOSTICS .Nm Keyinfo @@ -51,3 +52,4 @@ Rewritten in Perl by .el Joerg Wunsch so it can be made setuid, and the S/Key keys file can be read-protected from the users. +Rewritten in C by Warner Losh. diff --git a/usr.bin/keyinfo/keyinfo.c b/usr.bin/keyinfo/keyinfo.c new file mode 100644 index 000000000000..9213a146aff4 --- /dev/null +++ b/usr.bin/keyinfo/keyinfo.c @@ -0,0 +1,57 @@ +/*- + * Copyright (c) 2000 Warner Losh. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + * + * $FreeBSD$ + */ + +#include <sys/param.h> +#include <stdio.h> +#include <skey.h> +#include <unistd.h> +#include <err.h> + +int +main(int argc, char *argv[]) +{ + struct skey skey; + char *login; + char *name; + int serr; + + login = getlogin(); + if (login == NULL) + errx(1, "Cannot find login name"); + if (getuid() != 0 && argc > 1 && strcmp(login, argv[1]) != 0) + errx(1, "Only superuser may get another user's keys"); + name = argc > 1 ? argv[1] : login; + serr = skeylookup(&skey, name); + if (serr == -1) + err(1, "skeylookup os failure"); + fclose(skey.keyfile); + if (serr != 0) + errx(1, "skeylookup: user %s not found", name); + printf("%d %s\n", skey.n - 1, skey.seed); + return (0); +} diff --git a/usr.bin/keyinfo/keyinfo.pl b/usr.bin/keyinfo/keyinfo.pl deleted file mode 100644 index 8316c5896505..000000000000 --- a/usr.bin/keyinfo/keyinfo.pl +++ /dev/null @@ -1,27 +0,0 @@ -#!/usr/bin/suidperl -# -# Search /etc/skeykeys for the skey string for this user OR user specified -# in 1st parameter. -# -# $FreeBSD$ -# - -die "usage: keyinfo [user]\n" unless $#ARGV < 1; - -open(K, "/etc/skeykeys") || exit 1; - -if ($#ARGV == 0) { - $user = $ARGV[0]; -} else { - $user = (getpwuid($<))[0]; -} - -while (<K>) { - ($id, $seq, $serial) = split; - if ($id eq $user) { - printf "%d %s\n", $seq - 1, $serial; - exit 0; - } -} -exit 1; - |