10 #define TOR_HS_INTRO_H 12 #include "crypto_curve25519.h" 17 HS_INTRO_AUTH_KEY_TYPE_LEGACY0 = 0x00,
18 HS_INTRO_AUTH_KEY_TYPE_LEGACY1 = 0x01,
19 HS_INTRO_AUTH_KEY_TYPE_ED25519 = 0x02,
20 } hs_intro_auth_key_type_t;
24 HS_INTRO_ACK_STATUS_SUCCESS = 0x0000,
25 HS_INTRO_ACK_STATUS_UNKNOWN_ID = 0x0001,
26 HS_INTRO_ACK_STATUS_BAD_FORMAT = 0x0002,
27 HS_INTRO_ACK_STATUS_CANT_RELAY = 0x0003,
28 } hs_intro_ack_status_t;
34 unsigned int is_only_legacy : 1;
42 int hs_intro_received_establish_intro(
or_circuit_t *circ,
43 const uint8_t *request,
45 int hs_intro_received_introduce1(
or_circuit_t *circ,
const uint8_t *request,
51 int hs_intro_circuit_is_suitable_for_establish_intro(
const or_circuit_t *circ);
56 #ifdef HS_INTROPOINT_PRIVATE 58 #include "hs/cell_establish_intro.h" 59 #include "hs/cell_introduce1.h" 63 const uint8_t *circuit_key_material,
64 size_t circuit_key_material_len);
68 unsigned int cell_type,
const void *cell);
70 STATIC
int introduce1_cell_is_legacy(
const uint8_t *request);
72 const uint8_t *request,
size_t request_len);
74 STATIC
int circuit_is_suitable_for_introduce1(
const or_circuit_t *circ);
Definition: hs_intropoint.h:32
Definition: crypto_ed25519.h:23
STATIC void get_auth_key_from_cell(ed25519_public_key_t *auth_key_out, unsigned int cell_type, const void *cell)
Definition: hs_intropoint.c:34
MOCK_DECL(int, router_have_minimum_dir_info,(void))
Definition: container.h:18
Definition: cell_introduce1.h:16
Definition: cell_establish_intro.h:14
STATIC int verify_establish_intro_cell(const trn_cell_establish_intro_t *cell, const uint8_t *circuit_key_material, size_t circuit_key_material_len)
Definition: hs_intropoint.c:71