2017-03-15 21:13:17 +01:00
|
|
|
/* Copyright (c) 2016-2017, The Tor Project, Inc. */
|
2016-09-05 17:48:15 +02:00
|
|
|
/* See LICENSE for licensing information */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \file hs_circuitmap.h
|
|
|
|
* \brief Header file for hs_circuitmap.c.
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef TOR_HS_CIRCUITMAP_H
|
|
|
|
#define TOR_HS_CIRCUITMAP_H
|
|
|
|
|
2017-01-18 11:01:49 +01:00
|
|
|
typedef HT_HEAD(hs_circuitmap_ht, circuit_t) hs_circuitmap_ht;
|
2016-09-05 17:48:15 +02:00
|
|
|
|
|
|
|
typedef struct hs_token_s hs_token_t;
|
2016-12-14 22:46:54 +01:00
|
|
|
struct or_circuit_t;
|
2017-01-20 12:55:06 +01:00
|
|
|
struct origin_circuit_t;
|
2016-09-05 17:48:15 +02:00
|
|
|
|
|
|
|
/** Public HS circuitmap API: */
|
|
|
|
|
2017-01-20 12:55:06 +01:00
|
|
|
/** Public relay-side API: */
|
|
|
|
|
|
|
|
struct or_circuit_t *
|
|
|
|
hs_circuitmap_get_intro_circ_v3_relay_side(const
|
|
|
|
ed25519_public_key_t *auth_key);
|
|
|
|
struct or_circuit_t *
|
|
|
|
hs_circuitmap_get_intro_circ_v2_relay_side(const uint8_t *digest);
|
|
|
|
struct or_circuit_t *
|
|
|
|
hs_circuitmap_get_rend_circ_relay_side(const uint8_t *cookie);
|
|
|
|
|
|
|
|
void hs_circuitmap_register_rend_circ_relay_side(struct or_circuit_t *circ,
|
|
|
|
const uint8_t *cookie);
|
|
|
|
void hs_circuitmap_register_intro_circ_v2_relay_side(struct or_circuit_t *circ,
|
|
|
|
const uint8_t *digest);
|
|
|
|
void hs_circuitmap_register_intro_circ_v3_relay_side(struct or_circuit_t *circ,
|
2016-09-05 17:48:15 +02:00
|
|
|
const ed25519_public_key_t *auth_key);
|
|
|
|
|
2017-01-20 12:55:06 +01:00
|
|
|
/** Public service-side API: */
|
|
|
|
|
|
|
|
struct origin_circuit_t *
|
|
|
|
hs_circuitmap_get_intro_circ_v3_service_side(const
|
|
|
|
ed25519_public_key_t *auth_key);
|
|
|
|
struct origin_circuit_t *
|
|
|
|
hs_circuitmap_get_intro_circ_v2_service_side(const uint8_t *digest);
|
|
|
|
struct origin_circuit_t *
|
|
|
|
hs_circuitmap_get_rend_circ_service_side(const uint8_t *cookie);
|
2017-07-25 11:05:02 +02:00
|
|
|
struct origin_circuit_t *
|
|
|
|
hs_circuitmap_get_rend_circ_client_side(const uint8_t *cookie);
|
2017-12-08 18:10:07 +01:00
|
|
|
struct origin_circuit_t *
|
|
|
|
hs_circuitmap_get_established_rend_circ_client_side(const uint8_t *cookie);
|
2017-01-20 12:55:06 +01:00
|
|
|
|
|
|
|
void hs_circuitmap_register_intro_circ_v2_service_side(
|
|
|
|
struct origin_circuit_t *circ,
|
|
|
|
const uint8_t *digest);
|
|
|
|
void hs_circuitmap_register_intro_circ_v3_service_side(
|
|
|
|
struct origin_circuit_t *circ,
|
|
|
|
const ed25519_public_key_t *auth_key);
|
|
|
|
void hs_circuitmap_register_rend_circ_service_side(
|
|
|
|
struct origin_circuit_t *circ,
|
|
|
|
const uint8_t *cookie);
|
2017-07-25 11:05:02 +02:00
|
|
|
void hs_circuitmap_register_rend_circ_client_side(
|
|
|
|
struct origin_circuit_t *circ,
|
|
|
|
const uint8_t *cookie);
|
2017-01-20 12:55:06 +01:00
|
|
|
|
2017-01-18 11:01:49 +01:00
|
|
|
void hs_circuitmap_remove_circuit(struct circuit_t *circ);
|
2016-09-05 17:48:15 +02:00
|
|
|
|
|
|
|
void hs_circuitmap_init(void);
|
|
|
|
void hs_circuitmap_free_all(void);
|
|
|
|
|
|
|
|
#ifdef HS_CIRCUITMAP_PRIVATE
|
|
|
|
|
|
|
|
/** Represents the type of HS token. */
|
|
|
|
typedef enum {
|
2017-01-20 12:55:06 +01:00
|
|
|
/** A rendezvous cookie on a relay (128bit)*/
|
|
|
|
HS_TOKEN_REND_RELAY_SIDE,
|
|
|
|
/** A v2 introduction point pubkey on a relay (160bit) */
|
|
|
|
HS_TOKEN_INTRO_V2_RELAY_SIDE,
|
|
|
|
/** A v3 introduction point pubkey on a relay (256bit) */
|
|
|
|
HS_TOKEN_INTRO_V3_RELAY_SIDE,
|
|
|
|
|
|
|
|
/** A rendezvous cookie on a hidden service (128bit)*/
|
|
|
|
HS_TOKEN_REND_SERVICE_SIDE,
|
|
|
|
/** A v2 introduction point pubkey on a hidden service (160bit) */
|
|
|
|
HS_TOKEN_INTRO_V2_SERVICE_SIDE,
|
|
|
|
/** A v3 introduction point pubkey on a hidden service (256bit) */
|
|
|
|
HS_TOKEN_INTRO_V3_SERVICE_SIDE,
|
2017-07-25 11:05:02 +02:00
|
|
|
|
|
|
|
/** A rendezvous cookie on the client side (128bit) */
|
|
|
|
HS_TOKEN_REND_CLIENT_SIDE,
|
2016-09-05 17:48:15 +02:00
|
|
|
} hs_token_type_t;
|
|
|
|
|
|
|
|
/** Represents a token used in the HS protocol. Each such token maps to a
|
|
|
|
* specific introduction or rendezvous circuit. */
|
|
|
|
struct hs_token_s {
|
|
|
|
/* Type of HS token. */
|
|
|
|
hs_token_type_t type;
|
|
|
|
|
|
|
|
/* The size of the token (depends on the type). */
|
|
|
|
size_t token_len;
|
|
|
|
|
|
|
|
/* The token itself. Memory allocated at runtime. */
|
|
|
|
uint8_t *token;
|
|
|
|
};
|
|
|
|
|
2017-09-15 22:24:44 +02:00
|
|
|
#endif /* defined(HS_CIRCUITMAP_PRIVATE) */
|
2016-09-05 17:48:15 +02:00
|
|
|
|
|
|
|
#ifdef TOR_UNIT_TESTS
|
|
|
|
|
|
|
|
hs_circuitmap_ht *get_hs_circuitmap(void);
|
|
|
|
|
|
|
|
#endif /* TOR_UNIT_TESTS */
|
|
|
|
|
2017-09-15 22:24:44 +02:00
|
|
|
#endif /* !defined(TOR_HS_CIRCUITMAP_H) */
|
2016-12-14 21:41:08 +01:00
|
|
|
|