summaryrefslogtreecommitdiff
path: root/src/ext/ed25519/ref10/ed25519_ref10.h
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2014-08-27 00:18:26 -0400
committerNick Mathewson <nickm@torproject.org>2014-09-25 15:08:31 -0400
commit4caa6fad4c71391ab41e92a32aa58b10b6febe7f (patch)
tree5a4a92ea93940837470b28c52cbecb780687fd27 /src/ext/ed25519/ref10/ed25519_ref10.h
parented48b0fe56df2f719cd7cd274c664f7037f98b75 (diff)
downloadtor-4caa6fad4c71391ab41e92a32aa58b10b6febe7f.tar.gz
tor-4caa6fad4c71391ab41e92a32aa58b10b6febe7f.zip
Add curve25519->ed25519 key conversion per proposal 228
For proposal 228, we need to cross-certify our identity with our curve25519 key, so that we can prove at descriptor-generation time that we own that key. But how can we sign something with a key that is only for doing Diffie-Hellman? By converting it to the corresponding ed25519 point. See the ALL-CAPS warning in the documentation. According to djb (IIUC), it is safe to use these keys in the ways that ntor and prop228 are using them, but it might not be safe if we start providing crazy oracle access. (Unit tests included. What kind of a monster do you take me for?)
Diffstat (limited to 'src/ext/ed25519/ref10/ed25519_ref10.h')
-rw-r--r--src/ext/ed25519/ref10/ed25519_ref10.h5
1 files changed, 5 insertions, 0 deletions
diff --git a/src/ext/ed25519/ref10/ed25519_ref10.h b/src/ext/ed25519/ref10/ed25519_ref10.h
index cd0244f306..da8cea19f0 100644
--- a/src/ext/ed25519/ref10/ed25519_ref10.h
+++ b/src/ext/ed25519/ref10/ed25519_ref10.h
@@ -16,4 +16,9 @@ int ed25519_ref10_sign(
const unsigned char *m,uint64_t mlen,
const unsigned char *sk, const unsigned char *pk);
+/* Added in Tor */
+int ed25519_ref10_pubkey_from_curve25519_pubkey(unsigned char *out,
+ const unsigned char *inp,
+ int signbit);
+
#endif