aboutsummaryrefslogtreecommitdiff
path: root/src/core/crypto/onion_crypto.h
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2021-09-14 15:15:30 -0400
committerMike Perry <mikeperry-git@torproject.org>2022-02-22 19:28:33 +0000
commit244444e8b1ac36bf9148aa656e4eb9e293daa5b4 (patch)
treea4a05af33221374e7b6e254c216bcad08699bbcc /src/core/crypto/onion_crypto.h
parent358ce9a19d522d1e1cf9a119850e924ca106fec5 (diff)
downloadtor-244444e8b1ac36bf9148aa656e4eb9e293daa5b4.tar.gz
tor-244444e8b1ac36bf9148aa656e4eb9e293daa5b4.zip
Add an exported struct to onion handshakes for circuits params
THis will eventually hold the congestion control parameters that we negotiated, plus whatever else is relevant.
Diffstat (limited to 'src/core/crypto/onion_crypto.h')
-rw-r--r--src/core/crypto/onion_crypto.h14
1 files changed, 13 insertions, 1 deletions
diff --git a/src/core/crypto/onion_crypto.h b/src/core/crypto/onion_crypto.h
index bf25552b83..af8dd1f03f 100644
--- a/src/core/crypto/onion_crypto.h
+++ b/src/core/crypto/onion_crypto.h
@@ -22,6 +22,16 @@ typedef struct server_onion_keys_t {
void onion_handshake_state_release(onion_handshake_state_t *state);
+/**
+ * Parameters negotiated as part of a circuit handshake.
+ */
+typedef struct circuit_params_t {
+ /* placeholder field for congestion control algorithm. Right now this
+ * is always set to zero */
+ int cc_algorithm;
+ int cc_window;
+} circuit_params_t;
+
int onion_skin_create(int type,
const extend_info_t *node,
onion_handshake_state_t *state_out,
@@ -33,12 +43,14 @@ int onion_skin_server_handshake(int type,
uint8_t *reply_out,
size_t reply_out_maxlen,
uint8_t *keys_out, size_t key_out_len,
- uint8_t *rend_nonce_out);
+ uint8_t *rend_nonce_out,
+ circuit_params_t *negotiated_params_out);
int onion_skin_client_handshake(int type,
const onion_handshake_state_t *handshake_state,
const uint8_t *reply, size_t reply_len,
uint8_t *keys_out, size_t key_out_len,
uint8_t *rend_authenticator_out,
+ circuit_params_t *negotiated_params_out,
const char **msg_out);
server_onion_keys_t *server_onion_keys_new(void);