/* mkpasswd.c - encrypt the given passwd using salt
*
* Copyright 2013 Ashwini Kumar <ak.ashwini@gmail.com>
* Copyright 2013 Kyungwan Han <asura321@gmail.com>
*
* No Standard
USE_MKPASSWD(NEWTOY(mkpasswd, ">2S:m:P#=0<0", TOYFLAG_USR|TOYFLAG_BIN))
config MKPASSWD
bool "mkpasswd"
default y
help
usage: mkpasswd [-P FD] [-m TYPE] [-S SALT] [PASSWORD] [SALT]
Crypt PASSWORD using crypt(3)
-P FD Read password from file descriptor FD
-m TYPE Encryption method (des, md5, sha256, or sha512; default is des)
-S SALT
*/
#define FOR_mkpasswd
#include "toys.h"
GLOBALS(
long pfd;
char *method;
char *salt;
)
void mkpasswd_main(void)
{
char salt[MAX_SALT_LEN] = {0,};
int i;
if (!TT.method) TT.method = "des";
if (toys.optc == 2) {
if (TT.salt) error_exit("duplicate salt");
TT.salt = toys.optargs[1];
}
if (-1 == (i = get_salt(salt, TT.method))) error_exit("bad -m");
if (TT.salt) {
char *s = TT.salt;
// In C locale, isalnum() means [A-Za-Z0-0]
while (isalnum(*s) || *s == '.' || *s == '/') s++;
if (*s) error_exit("salt not in [./A-Za-z0-9]");
snprintf(salt+i, sizeof(salt)-i, "%s", TT.salt);
}
// Because read_password() doesn't have an fd argument
if (TT.pfd) {
if (dup2(TT.pfd, 0) == -1) perror_exit("fd");
close(TT.pfd);
}
// If we haven't got a password on the command line, read it from tty or FD
if (!*toys.optargs) {
// Prompt and read interactively?
if (isatty(0)) {
if (read_password(toybuf, sizeof(toybuf), "Password: "))
perror_exit("password read failed");
} else {
for (i = 0; i<sizeof(toybuf)-1; i++) {
if (!xread(0, toybuf+i, 1)) break;
if (toybuf[i] == '\n' || toybuf[i] == '\r') break;
}
toybuf[i] = 0;
}
}
// encrypt & print the password
xprintf("%s\n",crypt(*toys.optargs ? *toys.optargs : toybuf, salt));
}