annotate toys/other/mkpasswd.c @ 1727:c0ef9b7976f0 draft

Use xsignal() instead of signal().
author Rob Landley <rob@landley.net>
date Tue, 10 Mar 2015 11:07:28 -0500
parents def326708e49
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1091
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
1 /* mkpasswd.c - encrypt the given passwd using salt
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
2 *
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
3 * Copyright 2013 Ashwini Kumar <ak.ashwini@gmail.com>
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
4 * Copyright 2013 Kyungwan Han <asura321@gmail.com>
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
5 *
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
6 * No Standard
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
7
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
8 USE_MKPASSWD(NEWTOY(mkpasswd, ">2S:m:P#=0<0", TOYFLAG_USR|TOYFLAG_BIN))
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
9
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
10 config MKPASSWD
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
11 bool "mkpasswd"
1367
def326708e49 Promote mkpasswd from pending to other.
Rob Landley <rob@landley.net>
parents: 1363
diff changeset
12 default y
1091
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
13 help
1363
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
14 usage: mkpasswd [-P FD] [-m TYPE] [-S SALT] [PASSWORD] [SALT]
1091
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
15
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
16 Crypt PASSWORD using crypt(3)
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
17
1363
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
18 -P FD Read password from file descriptor FD
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
19 -m TYPE Encryption method (des, md5, sha256, or sha512; default is des)
1091
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
20 -S SALT
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
21 */
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
22
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
23 #define FOR_mkpasswd
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
24 #include "toys.h"
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
25
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
26 GLOBALS(
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
27 long pfd;
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
28 char *method;
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
29 char *salt;
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
30 )
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
31
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
32 void mkpasswd_main(void)
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
33 {
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
34 char salt[MAX_SALT_LEN] = {0,};
1363
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
35 int i;
1091
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
36
1363
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
37 if (!TT.method) TT.method = "des";
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
38 if (toys.optc == 2) {
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
39 if (TT.salt) error_exit("duplicate salt");
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
40 TT.salt = toys.optargs[1];
1091
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
41 }
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
42
1363
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
43 if (-1 == (i = get_salt(salt, TT.method))) error_exit("bad -m");
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
44 if (TT.salt) {
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
45 char *s = TT.salt;
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
46
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
47 // In C locale, isalnum() means [A-Za-Z0-0]
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
48 while (isalnum(*s) || *s == '.' || *s == '/') s++;
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
49 if (*s) error_exit("salt not in [./A-Za-z0-9]");
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
50
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
51 snprintf(salt+i, sizeof(salt)-i, "%s", TT.salt);
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
52 }
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
53
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
54 // Because read_password() doesn't have an fd argument
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
55 if (TT.pfd) {
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
56 if (dup2(TT.pfd, 0) == -1) perror_exit("fd");
1091
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
57 close(TT.pfd);
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
58 }
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
59
1363
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
60 // If we haven't got a password on the command line, read it from tty or FD
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
61 if (!*toys.optargs) {
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
62 // Prompt and read interactively?
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
63 if (isatty(0)) {
1091
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
64 if (read_password(toybuf, sizeof(toybuf), "Password: "))
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
65 perror_exit("password read failed");
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
66 } else {
1363
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
67 for (i = 0; i<sizeof(toybuf)-1; i++) {
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
68 if (!xread(0, toybuf+i, 1)) break;
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
69 if (toybuf[i] == '\n' || toybuf[i] == '\r') break;
1091
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
70 }
1363
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
71 toybuf[i] = 0;
1091
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
72 }
1363
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
73 }
1091
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
74
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
75 // encrypt & print the password
1363
e65f9a9ba62d Cleanup pass on mkpasswd.c
Rob Landley <rob@landley.net>
parents: 1235
diff changeset
76 xprintf("%s\n",crypt(*toys.optargs ? *toys.optargs : toybuf, salt));
1091
c4d4a6e7473f useradd, groupadd, and mkpasswd submitted by Ashwini Sharma.
Rob Landley <rob@landley.net>
parents:
diff changeset
77 }