xref: /freebsd/contrib/wpa/wpa_supplicant/wpa_passphrase.c (revision a90b9d0159070121c221b966469c3e36d912bf82)
139beb93cSSam Leffler /*
239beb93cSSam Leffler  * WPA Supplicant - ASCII passphrase to WPA PSK tool
339beb93cSSam Leffler  * Copyright (c) 2003-2005, Jouni Malinen <j@w1.fi>
439beb93cSSam Leffler  *
5f05cddf9SRui Paulo  * This software may be distributed under the terms of the BSD license.
6f05cddf9SRui Paulo  * See README for more details.
739beb93cSSam Leffler  */
839beb93cSSam Leffler 
939beb93cSSam Leffler #include "includes.h"
10*a90b9d01SCy Schubert #include <termios.h>
1139beb93cSSam Leffler 
1239beb93cSSam Leffler #include "common.h"
13e28a4053SRui Paulo #include "crypto/sha1.h"
1439beb93cSSam Leffler 
1539beb93cSSam Leffler 
main(int argc,char * argv[])1639beb93cSSam Leffler int main(int argc, char *argv[])
1739beb93cSSam Leffler {
18*a90b9d01SCy Schubert 	struct termios term;
1939beb93cSSam Leffler 	unsigned char psk[32];
2039beb93cSSam Leffler 	int i;
2139beb93cSSam Leffler 	char *ssid, *passphrase, buf[64], *pos;
2285732ac8SCy Schubert 	size_t len;
2339beb93cSSam Leffler 
2439beb93cSSam Leffler 	if (argc < 2) {
2539beb93cSSam Leffler 		printf("usage: wpa_passphrase <ssid> [passphrase]\n"
2639beb93cSSam Leffler 			"\nIf passphrase is left out, it will be read from "
2739beb93cSSam Leffler 			"stdin\n");
2839beb93cSSam Leffler 		return 1;
2939beb93cSSam Leffler 	}
3039beb93cSSam Leffler 
3139beb93cSSam Leffler 	ssid = argv[1];
3239beb93cSSam Leffler 
3339beb93cSSam Leffler 	if (argc > 2) {
3439beb93cSSam Leffler 		passphrase = argv[2];
3539beb93cSSam Leffler 	} else {
36*a90b9d01SCy Schubert 		bool ctrl_echo;
37*a90b9d01SCy Schubert 
38c1d255d3SCy Schubert 		fprintf(stderr, "# reading passphrase from stdin\n");
39*a90b9d01SCy Schubert 		if (tcgetattr(STDIN_FILENO, &term) < 0) {
40*a90b9d01SCy Schubert 			perror("tcgetattr");
41*a90b9d01SCy Schubert 			return 1;
42*a90b9d01SCy Schubert 		}
43*a90b9d01SCy Schubert 		ctrl_echo = term.c_lflag & ECHO;
44*a90b9d01SCy Schubert 		term.c_lflag &= ~ECHO;
45*a90b9d01SCy Schubert 		if (ctrl_echo && tcsetattr(STDIN_FILENO, TCSANOW, &term) < 0) {
46*a90b9d01SCy Schubert 			perror("tcsetattr:error disabling echo");
47*a90b9d01SCy Schubert 			return 1;
48*a90b9d01SCy Schubert 		}
4939beb93cSSam Leffler 		if (fgets(buf, sizeof(buf), stdin) == NULL) {
50c1d255d3SCy Schubert 			fprintf(stderr, "Failed to read passphrase\n");
5139beb93cSSam Leffler 			return 1;
5239beb93cSSam Leffler 		}
53*a90b9d01SCy Schubert 		term.c_lflag |= ECHO;
54*a90b9d01SCy Schubert 		if (ctrl_echo && tcsetattr(STDIN_FILENO, TCSANOW, &term) < 0) {
55*a90b9d01SCy Schubert 			perror("tcsetattr:error enabling echo");
56*a90b9d01SCy Schubert 			return 1;
57*a90b9d01SCy Schubert 		}
5839beb93cSSam Leffler 		buf[sizeof(buf) - 1] = '\0';
5939beb93cSSam Leffler 		pos = buf;
6039beb93cSSam Leffler 		while (*pos != '\0') {
6139beb93cSSam Leffler 			if (*pos == '\r' || *pos == '\n') {
6239beb93cSSam Leffler 				*pos = '\0';
6339beb93cSSam Leffler 				break;
6439beb93cSSam Leffler 			}
6539beb93cSSam Leffler 			pos++;
6639beb93cSSam Leffler 		}
6739beb93cSSam Leffler 		passphrase = buf;
6839beb93cSSam Leffler 	}
6939beb93cSSam Leffler 
7085732ac8SCy Schubert 	len = os_strlen(passphrase);
7185732ac8SCy Schubert 	if (len < 8 || len > 63) {
72c1d255d3SCy Schubert 		fprintf(stderr, "Passphrase must be 8..63 characters\n");
7339beb93cSSam Leffler 		return 1;
7439beb93cSSam Leffler 	}
7585732ac8SCy Schubert 	if (has_ctrl_char((u8 *) passphrase, len)) {
76c1d255d3SCy Schubert 		fprintf(stderr, "Invalid passphrase character\n");
7785732ac8SCy Schubert 		return 1;
7885732ac8SCy Schubert 	}
7939beb93cSSam Leffler 
80*a90b9d01SCy Schubert 	if (pbkdf2_sha1(passphrase, (u8 *) ssid, os_strlen(ssid), 4096, psk, 32)
81*a90b9d01SCy Schubert 	    != 0) {
82*a90b9d01SCy Schubert 		fprintf(stderr, "Error in pbkdf2_sha1()\n");
83*a90b9d01SCy Schubert 		return 1;
84*a90b9d01SCy Schubert 	}
8539beb93cSSam Leffler 
8639beb93cSSam Leffler 	printf("network={\n");
8739beb93cSSam Leffler 	printf("\tssid=\"%s\"\n", ssid);
8839beb93cSSam Leffler 	printf("\t#psk=\"%s\"\n", passphrase);
8939beb93cSSam Leffler 	printf("\tpsk=");
9039beb93cSSam Leffler 	for (i = 0; i < 32; i++)
9139beb93cSSam Leffler 		printf("%02x", psk[i]);
9239beb93cSSam Leffler 	printf("\n");
9339beb93cSSam Leffler 	printf("}\n");
9439beb93cSSam Leffler 
9539beb93cSSam Leffler 	return 0;
9639beb93cSSam Leffler }
97