summaryrefslogtreecommitdiff
path: root/usr.bin
diff options
context:
space:
mode:
Diffstat (limited to 'usr.bin')
-rw-r--r--usr.bin/passwd/Makefile4
-rw-r--r--usr.bin/passwd/krb_passwd.c64
-rw-r--r--usr.bin/passwd/local_passwd.c15
-rw-r--r--usr.bin/passwd/passwd.c21
-rw-r--r--usr.bin/passwd/pwd_gensalt.c2
-rw-r--r--usr.bin/passwd/yp_passwd.c56
6 files changed, 70 insertions, 92 deletions
diff --git a/usr.bin/passwd/Makefile b/usr.bin/passwd/Makefile
index 5ee6cddcd11..848669c31d1 100644
--- a/usr.bin/passwd/Makefile
+++ b/usr.bin/passwd/Makefile
@@ -1,4 +1,4 @@
-# $OpenBSD: Makefile,v 1.13 1997/03/26 00:35:32 deraadt Exp $
+# $OpenBSD: Makefile,v 1.14 1997/03/27 00:30:52 weingart Exp $
.include <bsd.own.mk>
@@ -16,7 +16,7 @@ CFLAGS+=-DYP -I${.CURDIR}/../../lib/libc/yp
.include <bsd.own.mk> # For Kerberos
.if defined(KERBEROS5)
-#SRCS+= krb5_passwd.c XXX fix the /tmp/tkt_cpw_%d race first
+#SRCS+= krb5_passwd.c XXX fix the /tmp/tkt_cpw_%d race first + others
CFLAGS+= -DKERBEROS5
DPADD+= ${LIBKRB5} ${LIBCRYPTO}
LDADD+= -lkrb5 -lcrypto
diff --git a/usr.bin/passwd/krb_passwd.c b/usr.bin/passwd/krb_passwd.c
index cd3e1811c3f..b0ec6a5c5d1 100644
--- a/usr.bin/passwd/krb_passwd.c
+++ b/usr.bin/passwd/krb_passwd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: krb_passwd.c,v 1.4 1996/06/26 05:37:46 deraadt Exp $ */
+/* $OpenBSD: krb_passwd.c,v 1.5 1997/03/27 00:30:52 weingart Exp $ */
/*-
* Copyright (c) 1990 The Regents of the University of California.
@@ -35,7 +35,7 @@
#ifndef lint
/*static char sccsid[] = "from: @(#)krb_passwd.c 5.4 (Berkeley) 3/1/91";*/
-static char rcsid[] = "$OpenBSD: krb_passwd.c,v 1.4 1996/06/26 05:37:46 deraadt Exp $";
+static char rcsid[] = "$OpenBSD: krb_passwd.c,v 1.5 1997/03/27 00:30:52 weingart Exp $";
#endif /* not lint */
#ifdef KERBEROS
@@ -50,11 +50,13 @@ static char rcsid[] = "$OpenBSD: krb_passwd.c,v 1.4 1996/06/26 05:37:46 deraadt
#include <netdb.h>
#include <signal.h>
#include <pwd.h>
+#include <err.h>
#include <errno.h>
#include <stdio.h>
#include "kpasswd_proto.h"
#include <string.h>
#include <stdlib.h>
+#include <unistd.h>
#define PROTO "tcp"
@@ -86,36 +88,27 @@ krb_passwd()
(void)signal(SIGTSTP, SIG_IGN);
if (setrlimit(RLIMIT_CORE, &rl) < 0) {
- (void)fprintf(stderr,
- "passwd: setrlimit: %s\n", strerror(errno));
+ warn("setrlimit");
return(1);
}
if ((se = getservbyname(SERVICE, PROTO)) == NULL) {
- (void)fprintf(stderr,
- "passwd: couldn't find entry for service %s/%s\n",
- SERVICE, PROTO);
+ warnx("couldn't find entry for service %s/%s", SERVICE, PROTO);
return(1);
}
if ((rval = krb_get_lrealm(realm,1)) != KSUCCESS) {
- (void)fprintf(stderr,
- "passwd: couldn't get local Kerberos realm: %s\n",
- krb_err_txt[rval]);
+ warnx("couldn't get local Kerberos realm: %s", krb_err_txt[rval]);
return(1);
}
if ((rval = krb_get_krbhst(krbhst, realm, 1)) != KSUCCESS) {
- (void)fprintf(stderr,
- "passwd: couldn't get Kerberos host: %s\n",
- krb_err_txt[rval]);
+ warnx("couldn't get Kerberos host: %s", krb_err_txt[rval]);
return(1);
}
if ((host = gethostbyname(krbhst)) == NULL) {
- (void)fprintf(stderr,
- "passwd: couldn't get host entry for krb host %s\n",
- krbhst);
+ warnx("couldn't get host entry for krb host %s", krbhst);
return(1);
}
@@ -124,12 +117,12 @@ krb_passwd()
sin.sin_port = se->s_port;
if ((sock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP)) < 0) {
- (void)fprintf(stderr, "passwd: socket: %s\n", strerror(errno));
+ warn("socket");
return(1);
}
if (connect(sock, (struct sockaddr *) &sin, sizeof(sin)) < 0) {
- (void)fprintf(stderr, "passwd: connect: %s\n", strerror(errno));
+ warn("connect");
(void)close(sock);
return(1);
}
@@ -151,8 +144,7 @@ krb_passwd()
);
if (rval != KSUCCESS) {
- (void)fprintf(stderr, "passwd: Kerberos sendauth error: %s\n",
- krb_err_txt[rval]);
+ warnx("Kerberos sendauth error: %s", krb_err_txt[rval]);
return(1);
}
@@ -163,8 +155,7 @@ krb_passwd()
if (des_read_pw_string(pass,
sizeof(pass)-1, "Old Kerberos password:", 0)) {
- (void)fprintf(stderr,
- "passwd: error reading old Kerberos password\n");
+ warnx("error reading old Kerberos password");
return(1);
}
@@ -182,11 +173,11 @@ krb_passwd()
if ((rval < 1) || !FD_ISSET(sock, &readfds)) {
if(rval == 0) {
- (void)fprintf(stderr, "passwd: timed out (aborted)\n");
+ warnx("timed out (aborted)");
cleanup();
return(1);
}
- (void)fprintf(stderr, "passwd: select failed (aborted)\n");
+ warnx("select failed (aborted)");
cleanup();
return(1);
}
@@ -195,8 +186,7 @@ krb_passwd()
if (des_read(sock, &proto_data, sizeof(proto_data)) !=
sizeof(proto_data)) {
- (void)fprintf(stderr,
- "passwd: couldn't read verification string (aborted)\n");
+ warnx("couldn't read verification string (aborted)");
cleanup();
return(1);
}
@@ -209,7 +199,7 @@ krb_passwd()
/* don't complain loud if user just hit return */
if (pass == NULL || (!*pass))
return(0);
- (void)fprintf(stderr, "Sorry\n");
+ warnx("Sorry");
return(1);
}
@@ -219,23 +209,20 @@ krb_passwd()
if (des_read_pw_string(pass,
sizeof(pass)-1, "New Kerberos password:", 0)) {
- (void)fprintf(stderr,
- "passwd: error reading new Kerberos password (aborted)\n");
+ warnx("error reading new Kerberos password (aborted)");
cleanup();
return(1);
}
if (des_read_pw_string(password,
sizeof(password)-1, "Retype new Kerberos password:", 0)) {
- (void)fprintf(stderr,
- "passwd: error reading new Kerberos password (aborted)\n");
+ warnx("error reading new Kerberos password (aborted)");
cleanup();
return(1);
}
if (strcmp(password, pass) != 0) {
- (void)fprintf(stderr,
- "passwd: password mismatch (aborted)\n");
+ warnx("password mismatch (aborted)");
cleanup();
return(1);
}
@@ -254,12 +241,11 @@ krb_passwd()
select(sock + 1, &readfds, (fd_set *) 0, (fd_set *) 0, &timeout);
if ((rval < 1) || !FD_ISSET(sock, &readfds)) {
if(rval == 0) {
- (void)fprintf(stderr,
- "passwd: timed out reading ACK (aborted)\n");
+ warnx("timed out reading ACK (aborted)");
cleanup();
exit(1);
}
- (void)fprintf(stderr, "passwd: select failed (aborted)\n");
+ warnx("select failed (aborted)");
cleanup();
exit(1);
}
@@ -277,8 +263,7 @@ send_update(dest, pwd, str)
(void)strncpy(ud.secure_msg, str, _PASSWORD_LEN);
(void)strncpy(ud.pw, pwd, sizeof(ud.pw));
if (des_write(dest, &ud, sizeof(ud)) != sizeof(ud)) {
- (void)fprintf(stderr,
- "passwd: couldn't write pw update (abort)\n");
+ warnx("couldn't write pw update (abort)");
bzero((char *)&ud, sizeof(ud));
cleanup();
exit(1);
@@ -293,8 +278,7 @@ recv_ack(remote)
cc = des_read(remote, buf, sizeof(buf));
if (cc <= 0) {
- (void)fprintf(stderr,
- "passwd: error reading acknowledgement (aborted)\n");
+ warnx("error reading acknowledgement (aborted)");
cleanup();
exit(1);
}
diff --git a/usr.bin/passwd/local_passwd.c b/usr.bin/passwd/local_passwd.c
index f54dc12ab6d..b8b50660feb 100644
--- a/usr.bin/passwd/local_passwd.c
+++ b/usr.bin/passwd/local_passwd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: local_passwd.c,v 1.6 1997/02/16 20:08:56 provos Exp $ */
+/* $OpenBSD: local_passwd.c,v 1.7 1997/03/27 00:30:53 weingart Exp $ */
/*-
* Copyright (c) 1990 The Regents of the University of California.
@@ -35,24 +35,25 @@
#ifndef lint
/*static char sccsid[] = "from: @(#)local_passwd.c 5.5 (Berkeley) 5/6/91";*/
-static char rcsid[] = "$OpenBSD: local_passwd.c,v 1.6 1997/02/16 20:08:56 provos Exp $";
+static char rcsid[] = "$OpenBSD: local_passwd.c,v 1.7 1997/03/27 00:30:53 weingart Exp $";
#endif /* not lint */
#include <sys/types.h>
#include <sys/stat.h>
#include <pwd.h>
+#include <err.h>
#include <errno.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h>
+#include <ctype.h>
#include <fcntl.h>
#include <util.h>
-uid_t uid;
+static uid_t uid;
-char *progname = "passwd";
-char *tempname;
+int
local_passwd(uname)
char *uname;
{
@@ -65,13 +66,13 @@ local_passwd(uname)
extern int use_yp;
if (!use_yp)
#endif
- (void)fprintf(stderr, "passwd: unknown user %s.\n", uname);
+ warnx("unknown user %s.", uname);
return(1);
}
uid = getuid();
if (uid && uid != pw->pw_uid) {
- (void)fprintf(stderr, "passwd: %s\n", strerror(EACCES));
+ warnx("login != uid: %s", strerror(EACCES));
return(1);
}
diff --git a/usr.bin/passwd/passwd.c b/usr.bin/passwd/passwd.c
index a0b984ce6c2..83fa90c9f49 100644
--- a/usr.bin/passwd/passwd.c
+++ b/usr.bin/passwd/passwd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: passwd.c,v 1.5 1997/01/15 23:43:01 millert Exp $ */
+/* $OpenBSD: passwd.c,v 1.6 1997/03/27 00:30:54 weingart Exp $ */
/*
* Copyright (c) 1988 The Regents of the University of California.
@@ -41,7 +41,7 @@ char copyright[] =
#ifndef lint
/*static char sccsid[] = "from: @(#)passwd.c 5.5 (Berkeley) 7/6/91";*/
-static char rcsid[] = "$OpenBSD: passwd.c,v 1.5 1997/01/15 23:43:01 millert Exp $";
+static char rcsid[] = "$OpenBSD: passwd.c,v 1.6 1997/03/27 00:30:54 weingart Exp $";
#endif /* not lint */
#include <stdio.h>
@@ -65,6 +65,14 @@ int use_yp;
int force_yp;
#endif
+
+extern int local_passwd(char *);
+extern int yp_passwd(char *);
+extern int krb_passwd(void);
+void usage(void);
+
+
+int
main(argc, argv)
int argc;
char **argv;
@@ -73,7 +81,6 @@ main(argc, argv)
register int ch;
char *username;
int status = 0;
- char *basename;
#if defined(KERBEROS) || defined(KERBEROS5)
extern char realm[];
@@ -84,10 +91,7 @@ main(argc, argv)
use_yp = _yp_check(NULL);
#endif
- basename = strrchr(argv[0], '/');
- if (basename == NULL)
- basename = argv[0];
-
+ /* Process args and options */
while ((ch = getopt(argc, argv, "lky")) != -1)
switch (ch) {
case 'l': /* change local password file */
@@ -163,7 +167,8 @@ main(argc, argv)
exit(local_passwd(username));
}
-usage()
+void
+usage(void)
{
fprintf(stderr, "usage: passwd [-l] [-k] [-y] user\n");
}
diff --git a/usr.bin/passwd/pwd_gensalt.c b/usr.bin/passwd/pwd_gensalt.c
index 2c7ce64c2c0..a4729cbdc80 100644
--- a/usr.bin/passwd/pwd_gensalt.c
+++ b/usr.bin/passwd/pwd_gensalt.c
@@ -30,10 +30,12 @@
#include <sys/syslimits.h>
#include <stdio.h>
+#include <stdlib.h>
#include <string.h>
#include <err.h>
#include <pwd.h>
#include <util.h>
+#include <time.h>
void to64( char *, long, int n);
diff --git a/usr.bin/passwd/yp_passwd.c b/usr.bin/passwd/yp_passwd.c
index f7bc86c030c..7d56018d9bf 100644
--- a/usr.bin/passwd/yp_passwd.c
+++ b/usr.bin/passwd/yp_passwd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: yp_passwd.c,v 1.7 1997/02/17 10:34:41 provos Exp $ */
+/* $OpenBSD: yp_passwd.c,v 1.8 1997/03/27 00:30:55 weingart Exp $ */
/*
* Copyright (c) 1988 The Regents of the University of California.
@@ -34,17 +34,21 @@
*/
#ifndef lint
/*static char sccsid[] = "from: @(#)yp_passwd.c 1.0 2/2/93";*/
-static char rcsid[] = "$OpenBSD: yp_passwd.c,v 1.7 1997/02/17 10:34:41 provos Exp $";
+static char rcsid[] = "$OpenBSD: yp_passwd.c,v 1.8 1997/03/27 00:30:55 weingart Exp $";
#endif /* not lint */
#ifdef YP
#include <stdio.h>
+#include <stdlib.h>
#include <string.h>
+#include <unistd.h>
#include <netdb.h>
#include <time.h>
#include <pwd.h>
+#include <err.h>
#include <errno.h>
+#include <ctype.h>
#include <rpc/rpc.h>
#include <rpcsvc/yp_prot.h>
#include <rpcsvc/ypclnt.h>
@@ -56,37 +60,29 @@ static char rcsid[] = "$OpenBSD: yp_passwd.c,v 1.7 1997/02/17 10:34:41 provos Ex
#define _PASSWORD_LEN PASS_MAX
#endif
-extern char *progname;
static char *getnewpasswd();
static struct passwd *ypgetpwnam();
static uid_t uid;
char *domain;
-static
+static int
pw_error(name, err, eval)
char *name;
int err, eval;
{
- int sverrno;
+ if(err)
+ warn(name != NULL ? name : "");
- if (err) {
- sverrno = errno;
- (void)fprintf(stderr, "%s: ", progname);
- if (name)
- (void)fprintf(stderr, "%s: ", name);
- (void)fprintf(stderr, "%s\n", strerror(sverrno));
- }
- (void)fprintf(stderr,
- "%s: YP passwd database unchanged\n", progname);
+ warnx("YP passwd database unchanged.");
exit(eval);
}
+int
yp_passwd(username)
char *username;
{
char *master;
- char *pp;
int r, rpcport, status;
struct yppasswd yppasswd;
struct passwd *pw;
@@ -98,9 +94,8 @@ yp_passwd(username)
/*
* Get local domain
*/
- if (r = yp_get_default_domain(&domain)) {
- fprintf(stderr, "%s: can't get local YP domain. Reason: %s\n",
- progname, yperr_string(r));
+ if ((r = yp_get_default_domain(&domain)) != 0) {
+ warnx("can't get local YP domain. Reason: %s", yperr_string(r));
exit(1);
}
@@ -109,9 +104,7 @@ yp_passwd(username)
* the daemon.
*/
if ((r = yp_master(domain, "passwd.byname", &master)) != 0) {
- fprintf(stderr,
- "%s: can't find the master YP server. Reason: %s\n",
- progname, yperr_string(r));
+ warnx("can't find the master YP server. Reason: %s\n", yperr_string(r));
exit(1);
}
@@ -120,10 +113,8 @@ yp_passwd(username)
*/
if ((rpcport = getrpcport(master, YPPASSWDPROG,
YPPASSWDPROC_UPDATE, IPPROTO_UDP)) == 0) {
- fprintf(stderr,
- "%s: master YP server not running yppasswd daemon.\n",
- progname);
- fprintf(stderr, "\tCan't change password.\n");
+ warnx("master YP server not running yppasswd daemon.");
+ warnx("Can't change password.");
exit(1);
}
@@ -131,22 +122,18 @@ yp_passwd(username)
* Be sure the port is priviledged
*/
if (rpcport >= IPPORT_RESERVED) {
- fprintf(stderr, "%s: yppasswd daemon is on an invalid port.\n",
- progname);
+ warnx("yppasswd daemon is on an invalid port.");
exit(1);
}
/* Get user's login identity */
if (!(pw = ypgetpwnam(username))) {
- (void)fprintf(stderr, "%s: unknown user %s.\n",
- progname, username);
+ warnx("unknown user %s.", username);
exit(1);
}
if (uid && uid != pw->pw_uid) {
- fprintf(stderr,
- "%s: you may only change your own password: %s\n",
- progname, strerror(EACCES));
+ warnx("you may only change your own password: %s", strerror(EACCES));
exit(1);
}
@@ -163,7 +150,7 @@ yp_passwd(username)
client = clnt_create(master, YPPASSWDPROG, YPPASSWDVERS, "udp");
if (client==NULL) {
- fprintf(stderr, "cannot contact yppasswdd on %s: Reason: %s\n",
+ warnx("cannot contact yppasswdd on %s: Reason: %s\n",
master, yperr_string(YPERR_YPBIND));
free(yppasswd.newpw.pw_passwd);
return(YPERR_YPBIND);
@@ -174,7 +161,7 @@ yp_passwd(username)
r = clnt_call(client, YPPASSWDPROC_UPDATE,
xdr_yppasswd, &yppasswd, xdr_int, &status, tv);
if (r)
- fprintf(stderr, "%s: rpc to yppasswdd failed.\n", progname);
+ warnx("rpc to yppasswdd failed.");
else if (status) {
printf("Couldn't change YP password.\n");
free(yppasswd.newpw.pw_passwd);
@@ -255,7 +242,6 @@ struct passwd *
interpret(struct passwd *pwent, char *line)
{
register char *p = line;
- register int c;
pwent->pw_passwd = "*";
pwent->pw_uid = 0;