diff options
author | June McEnroe <june@causal.agency> | 2019-11-04 17:27:13 -0500 |
---|---|---|
committer | June McEnroe <june@causal.agency> | 2019-11-04 17:27:13 -0500 |
commit | 8957cbc53f721786e4b4db674597f79e838186d0 (patch) | |
tree | 92c47eb742a1308c54d5cb734018db2f68a428ff /bounce.c | |
parent | Move base64 to bounce.h (diff) | |
download | pounce-8957cbc53f721786e4b4db674597f79e838186d0.tar.gz pounce-8957cbc53f721786e4b4db674597f79e838186d0.zip |
Hash client passwords with crypt
Diffstat (limited to '')
-rw-r--r-- | bounce.c | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/bounce.c b/bounce.c index 537f539..889ed5b 100644 --- a/bounce.c +++ b/bounce.c @@ -29,6 +29,7 @@ #include <string.h> #include <strings.h> #include <sys/file.h> +#include <sys/random.h> #include <sys/socket.h> #include <sys/stat.h> #include <sysexits.h> @@ -43,6 +44,16 @@ #define SIGINFO SIGUSR2 #endif +static void hashPass(void) { + char *pass = getpass("Password: "); + byte rand[12]; + ssize_t len = getrandom(rand, sizeof(rand), 0); + if (len < 0) err(EX_OSERR, "getrandom"); + char salt[3 + BASE64_SIZE(sizeof(rand))] = "$6$"; + base64(&salt[3], rand, sizeof(rand)); + printf("%s\n", crypt(pass, salt)); +} + static FILE *saveFile; static void saveExit(void) { @@ -190,7 +201,7 @@ int main(int argc, char *argv[]) { const char *away = "pounced :3"; const char *quit = "connection reset by purr"; - const char *Opts = "!A:C:H:K:NP:Q:U:W:a:f:h:j:n:p:r:s:u:vw:"; + const char *Opts = "!A:C:H:K:NP:Q:U:W:a:f:h:j:n:p:r:s:u:vw:x"; const struct option LongOpts[] = { { "insecure", no_argument, NULL, '!' }, { "away", required_argument, NULL, 'A' }, @@ -244,6 +255,7 @@ int main(int argc, char *argv[]) { break; case 'u': user = optarg; break; case 'v': verbose = true; break; case 'w': pass = optarg; + break; case 'x': hashPass(); return EX_OK; break; default: return EX_USAGE; } } |