aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/src/genkey.c
diff options
context:
space:
mode:
authorJason A. Donenfeld <Jason@zx2c4.com>2017-04-16 01:20:43 +0200
committerJason A. Donenfeld <Jason@zx2c4.com>2017-04-19 18:26:32 +0200
commit755217bd853f2581a8bb420728942cf785afe204 (patch)
treec7f9d39659e43bbbe1c62370787b5ff7c2925593 /src/genkey.c
parentwg: do not use addrconfig with port in gai (diff)
downloadwireguard-tools-755217bd853f2581a8bb420728942cf785afe204.tar.xz
wireguard-tools-755217bd853f2581a8bb420728942cf785afe204.zip
wg: side channel resistant base64
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
Diffstat (limited to 'src/genkey.c')
-rw-r--r--src/genkey.c17
1 files changed, 6 insertions, 11 deletions
diff --git a/src/genkey.c b/src/genkey.c
index d3bc846..bf35aed 100644
--- a/src/genkey.c
+++ b/src/genkey.c
@@ -34,8 +34,8 @@ static inline ssize_t get_random_bytes(uint8_t *out, size_t len)
int genkey_main(int argc, char *argv[])
{
- unsigned char private_key[CURVE25519_POINT_SIZE];
- char private_key_base64[b64_len(CURVE25519_POINT_SIZE)];
+ uint8_t key[WG_KEY_LEN];
+ char base64[WG_KEY_LEN_BASE64];
struct stat stat;
if (argc != 1) {
@@ -46,19 +46,14 @@ int genkey_main(int argc, char *argv[])
if (!fstat(STDOUT_FILENO, &stat) && S_ISREG(stat.st_mode) && stat.st_mode & S_IRWXO)
fputs("Warning: writing to world accessible file.\nConsider setting the umask to 077 and trying again.\n", stderr);
- if (get_random_bytes(private_key, CURVE25519_POINT_SIZE) != CURVE25519_POINT_SIZE) {
+ if (get_random_bytes(key, WG_KEY_LEN) != WG_KEY_LEN) {
perror("getrandom");
return 1;
}
if (argc && !strcmp(argv[0], "genkey"))
- curve25519_normalize_secret(private_key);
+ curve25519_normalize_secret(key);
- if (b64_ntop(private_key, sizeof(private_key), private_key_base64, sizeof(private_key_base64)) != sizeof(private_key_base64) - 1) {
- fprintf(stderr, "%s: Could not convert key to base64\n", PROG_NAME);
- return 1;
- }
-
- puts(private_key_base64);
+ key_to_base64(base64, key);
+ puts(base64);
return 0;
-
}