aboutsummaryrefslogtreecommitdiff
path: root/src/or/onion_ntor.h
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2012-12-08 00:52:44 -0500
committerNick Mathewson <nickm@torproject.org>2013-01-03 11:29:48 -0500
commitc46ff3ec79420a6d94207cbe0d4e4d08208ccc4c (patch)
treeaf359a09798445e200e437fe9564e75deee8dc2b /src/or/onion_ntor.h
parent839016ac791de98c02ad7eab50092deedde0ad55 (diff)
downloadtor-c46ff3ec79420a6d94207cbe0d4e4d08208ccc4c.tar.gz
tor-c46ff3ec79420a6d94207cbe0d4e4d08208ccc4c.zip
Add reference implementation for ntor, plus compatibility test
Before I started coding ntor in C, I did another one in Python. Turns out, they interoperate just fine.
Diffstat (limited to 'src/or/onion_ntor.h')
-rw-r--r--src/or/onion_ntor.h19
1 files changed, 19 insertions, 0 deletions
diff --git a/src/or/onion_ntor.h b/src/or/onion_ntor.h
index a5cceb94db..61ff5c0ad3 100644
--- a/src/or/onion_ntor.h
+++ b/src/or/onion_ntor.h
@@ -38,6 +38,25 @@ int onion_skin_ntor_client_handshake(
const uint8_t *handshake_reply,
uint8_t *key_out,
size_t key_out_len);
+
+#ifdef ONION_NTOR_PRIVATE
+
+/** Storage held by a client while waiting for an ntor reply from a server. */
+struct ntor_handshake_state_t {
+ /** Identity digest of the router we're talking to. */
+ uint8_t router_id[DIGEST_LEN];
+ /** Onion key of the router we're talking to. */
+ curve25519_public_key_t pubkey_B;
+
+ /**
+ * Short-lived keypair for use with this handshake.
+ * @{ */
+ curve25519_secret_key_t seckey_x;
+ curve25519_public_key_t pubkey_X;
+ /** @} */
+};
+#endif
+
#endif
#endif