aboutsummaryrefslogtreecommitdiff
path: root/lib/ed25519/src/seed.c
diff options
context:
space:
mode:
authorMark Haines <mark.haines@matrix.org>2015-03-03 11:14:50 +0000
committerMark Haines <mark.haines@matrix.org>2015-03-03 11:14:50 +0000
commit3ce450fc1984ac480ae158a40d60e9d42f77f74a (patch)
treeeb120d958eac8361d3760b9ad680fd8dc826d7a3 /lib/ed25519/src/seed.c
parent8bf99544160b1fd787e666b893c5117ab717bc99 (diff)
parent498dfabf9848286be003b42941c323a045d9fa46 (diff)
Merge commit '498dfabf9848286be003b42941c323a045d9fa46' as 'lib/ed25519'
Diffstat (limited to 'lib/ed25519/src/seed.c')
-rw-r--r--lib/ed25519/src/seed.c40
1 files changed, 40 insertions, 0 deletions
diff --git a/lib/ed25519/src/seed.c b/lib/ed25519/src/seed.c
new file mode 100644
index 0000000..25e5182
--- /dev/null
+++ b/lib/ed25519/src/seed.c
@@ -0,0 +1,40 @@
+#include "ed25519.h"
+
+#ifndef ED25519_NO_SEED
+
+#ifdef _WIN32
+#include <Windows.h>
+#include <Wincrypt.h>
+#else
+#include <stdio.h>
+#endif
+
+int ed25519_create_seed(unsigned char *seed) {
+#ifdef _WIN32
+ HCRYPTPROV prov;
+
+ if (!CryptAcquireContext(&prov, NULL, NULL, PROV_RSA_FULL, CRYPT_VERIFYCONTEXT)) {
+ return 1;
+ }
+
+ if (!CryptGenRandom(prov, 32, seed)) {
+ CryptReleaseContext(prov, 0);
+ return 1;
+ }
+
+ CryptReleaseContext(prov, 0);
+#else
+ FILE *f = fopen("/dev/urandom", "rb");
+
+ if (f == NULL) {
+ return 1;
+ }
+
+ fread(seed, 1, 32, f);
+ fclose(f);
+#endif
+
+ return 0;
+}
+
+#endif \ No newline at end of file