1
0
forked from bip/bip
bip/src/bipmkpw.c

90 lines
1.8 KiB
C
Raw Normal View History

2005-10-09 13:47:20 +02:00
/*
* $Id$
*
* This file is part of the bip project
2008-01-09 23:45:40 +01:00
* Copyright (C) 2004 2005 Arnaud Cornet and Loïc Gomez
2005-10-09 13:47:20 +02:00
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
* See the file "COPYING" for the exact licensing terms.
*/
2005-04-28 10:26:44 +02:00
#include "config.h"
#include <unistd.h>
#include <string.h>
2005-04-28 10:26:44 +02:00
#include <stdio.h>
#include <stdlib.h>
#include <termios.h>
#include <fcntl.h>
#include <errno.h>
2005-04-28 10:26:44 +02:00
#include "util.h"
#include "md5.h"
int conf_log_level;
FILE *conf_global_log_file;
int conf_log_system;
2005-04-28 10:26:44 +02:00
void readpass(char *buffer, int buflen)
{
int ttyfd = open("/dev/tty", O_RDWR);
if (ttyfd == -1) {
fprintf(stderr, "Unable to open tty: %s\n", strerror(errno));
exit(1);
}
2008-12-29 14:04:51 +01:00
struct termios tt, ttback;
memset(&ttback, 0, sizeof(ttback));
if (tcgetattr(ttyfd, &ttback) < 0) {
2008-12-29 14:04:51 +01:00
fprintf(stderr, "tcgetattr failed: %s\n", strerror(errno));
exit(1);
}
2008-12-29 14:04:51 +01:00
memcpy(&tt, &ttback, sizeof(ttback));
tt.c_lflag &= ~(ICANON|ECHO);
if (tcsetattr(ttyfd, TCSANOW, &tt) < 0) {
2008-12-29 14:04:51 +01:00
fprintf(stderr, "tcsetattr failed: %s\n", strerror(errno));
exit(1);
}
2008-12-29 14:04:51 +01:00
write(ttyfd, "Password: ", 10);
2008-12-29 14:04:51 +01:00
int idx = 0;
while (idx < buflen) {
read(ttyfd, buffer+idx, 1);
if (buffer[idx] == '\n') {
buffer[idx] = 0;
break;
}
idx++;
}
2008-12-29 14:04:51 +01:00
write(ttyfd, "\n", 1);
2008-12-29 14:04:51 +01:00
tcsetattr(ttyfd, TCSANOW, &ttback);
close(ttyfd);
}
2005-08-01 13:24:10 +02:00
int main(void)
2005-04-28 10:26:44 +02:00
{
int i;
static char str[256];
2005-04-28 10:26:44 +02:00
unsigned char *md5;
unsigned int seed;
readpass(str, 256);
2008-12-29 14:04:51 +01:00
str[255] = 0;
2005-04-28 10:26:44 +02:00
// the time used to type the pass is entropy
srand(time(NULL));
2005-04-28 10:26:44 +02:00
seed = rand();
2008-12-29 14:04:51 +01:00
2005-04-28 10:26:44 +02:00
md5 = chash_double(str, seed);
for (i = 0; i < 20; i++)
printf("%02x", md5[i]);
printf("\n");
free(md5);
return 0;
}