diff options
| author | flu0r1ne <flu0r1ne@flu0r1ne.net> | 2023-08-26 20:58:33 -0500 | 
|---|---|---|
| committer | flu0r1ne <flu0r1ne@flu0r1ne.net> | 2023-08-26 22:39:35 -0500 | 
| commit | ba286e5d624978f4f53ed5f9154790ef3595922e (patch) | |
| tree | 05a88849f4c9133fc60311ac355a079186073d51 /src/crypto/pubkey.c | |
| parent | c1554d0a1cd337fb1edf23ab0fa4e0e178ced1fc (diff) | |
| download | wg2nd-ba286e5d624978f4f53ed5f9154790ef3595922e.tar.xz wg2nd-ba286e5d624978f4f53ed5f9154790ef3595922e.zip | |
Store private key in a file with the public keyname, get rid of argon2
Diffstat (limited to 'src/crypto/pubkey.c')
| -rw-r--r-- | src/crypto/pubkey.c | 27 | 
1 files changed, 27 insertions, 0 deletions
| diff --git a/src/crypto/pubkey.c b/src/crypto/pubkey.c new file mode 100644 index 0000000..1224b07 --- /dev/null +++ b/src/crypto/pubkey.c @@ -0,0 +1,27 @@ +#include "curve25519.h" +#include "encoding.h" + +int wg_pubkey_base64(char const * privkey, char * base64) { + +	uint8_t key[WG_KEY_LEN] __attribute((aligned(sizeof(uintptr_t)))); + +	int i; +	for(i = 0; privkey[i] && i < WG_KEY_LEN_BASE64 - 1; i++) +		base64[i] = privkey[i]; + +	base64[WG_KEY_LEN_BASE64 - 1] = '\0'; + +	if(i != WG_KEY_LEN_BASE64 - 1 || privkey[i]) { +		return 1; +	} + +	if(!key_from_base64(key, base64)) { +		return 1; +	} + +	curve25519_generate_public(key, key); + +	key_to_base64(base64, key); + +	return 0; +} | 
