/* simple password generator by Nelson Minar (minar@reed.edu) * copyright 1991, all rights reserved. * You can use this code as long as my name stays with it. * $Id: mkpasswd.c 499 2003-06-11 00:48:41Z r33d $ */ #define _XOPEN_SOURCE #define _XOPEN_VERSION 4 #define _XOPEN_SOURCE_EXTENDED #include #include #include #include #include int main(int argc, char *argv[]) { static char saltChars[] = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789./"; char salt[3]; char * plaintext; if (argc < 2) { srandom(time(0)); /* may not be the BEST salt, but its close */ salt[0] = saltChars[random() % 64]; salt[1] = saltChars[random() % 64]; salt[2] = 0; } else { salt[0] = argv[1][0]; salt[1] = argv[1][1]; salt[2] = '\0'; if ((strchr(saltChars, salt[0]) == NULL) || (strchr(saltChars, salt[1]) == NULL)) fprintf(stderr, "illegal salt %s\n", salt), exit(1); } plaintext = getpass("plaintext: "); printf("%s\n", crypt(plaintext, salt)); return 0; }