entrynodes.h 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. /* Copyright (c) 2001 Matej Pfajfar.
  2. * Copyright (c) 2001-2004, Roger Dingledine.
  3. * Copyright (c) 2004-2006, Roger Dingledine, Nick Mathewson.
  4. * Copyright (c) 2007-2016, The Tor Project, Inc. */
  5. /* See LICENSE for licensing information */
  6. /**
  7. * \file entrynodes.h
  8. * \brief Header file for circuitbuild.c.
  9. **/
  10. #ifndef TOR_ENTRYNODES_H
  11. #define TOR_ENTRYNODES_H
  12. #if 1
  13. /* XXXX NM I would prefer that all of this stuff be private to
  14. * entrynodes.c. */
  15. /* Forward declare for guard_selection_t; entrynodes.c has the real struct */
  16. typedef struct guard_selection_s guard_selection_t;
  17. /** An entry_guard_t represents our information about a chosen long-term
  18. * first hop, known as a "helper" node in the literature. We can't just
  19. * use a node_t, since we want to remember these even when we
  20. * don't have any directory info. */
  21. typedef struct entry_guard_t {
  22. char nickname[MAX_NICKNAME_LEN+1];
  23. char identity[DIGEST_LEN];
  24. time_t chosen_on_date; /**< Approximately when was this guard added?
  25. * "0" if we don't know. */
  26. char *chosen_by_version; /**< What tor version added this guard? NULL
  27. * if we don't know. */
  28. unsigned int made_contact : 1; /**< 0 if we have never connected to this
  29. * router, 1 if we have. */
  30. unsigned int can_retry : 1; /**< Should we retry connecting to this entry,
  31. * in spite of having it marked as unreachable?*/
  32. unsigned int path_bias_noticed : 1; /**< Did we alert the user about path
  33. * bias for this node already? */
  34. unsigned int path_bias_warned : 1; /**< Did we alert the user about path bias
  35. * for this node already? */
  36. unsigned int path_bias_extreme : 1; /**< Did we alert the user about path
  37. * bias for this node already? */
  38. unsigned int path_bias_disabled : 1; /**< Have we disabled this node because
  39. * of path bias issues? */
  40. unsigned int path_bias_use_noticed : 1; /**< Did we alert the user about path
  41. * use bias for this node already? */
  42. unsigned int path_bias_use_extreme : 1; /**< Did we alert the user about path
  43. * use bias for this node already? */
  44. unsigned int is_dir_cache : 1; /**< Is this node a directory cache? */
  45. time_t bad_since; /**< 0 if this guard is currently usable, or the time at
  46. * which it was observed to become (according to the
  47. * directory or the user configuration) unusable. */
  48. time_t unreachable_since; /**< 0 if we can connect to this guard, or the
  49. * time at which we first noticed we couldn't
  50. * connect to it. */
  51. time_t last_attempted; /**< 0 if we can connect to this guard, or the time
  52. * at which we last failed to connect to it. */
  53. /**
  54. * @name circpathbias fields
  55. *
  56. * These fields are used in circpathbias.c to try to detect entry
  57. * nodes that are failing circuits at a suspicious frequency.
  58. */
  59. /**@{*/
  60. double circ_attempts; /**< Number of circuits this guard has "attempted" */
  61. double circ_successes; /**< Number of successfully built circuits using
  62. * this guard as first hop. */
  63. double successful_circuits_closed; /**< Number of circuits that carried
  64. * streams successfully. */
  65. double collapsed_circuits; /**< Number of fully built circuits that were
  66. * remotely closed before any streams were
  67. * attempted. */
  68. double unusable_circuits; /**< Number of circuits for which streams were
  69. * attempted, but none succeeded. */
  70. double timeouts; /**< Number of 'right-censored' circuit timeouts for this
  71. * guard. */
  72. double use_attempts; /**< Number of circuits we tried to use with streams */
  73. double use_successes; /**< Number of successfully used circuits using
  74. * this guard as first hop. */
  75. /**@}*/
  76. } entry_guard_t;
  77. entry_guard_t *entry_guard_get_by_id_digest_for_guard_selection(
  78. guard_selection_t *gs, const char *digest);
  79. entry_guard_t *entry_guard_get_by_id_digest(const char *digest);
  80. void entry_guards_changed_for_guard_selection(guard_selection_t *gs);
  81. void entry_guards_changed(void);
  82. guard_selection_t * get_guard_selection_info(void);
  83. const smartlist_t *get_entry_guards_for_guard_selection(
  84. guard_selection_t *gs);
  85. const smartlist_t *get_entry_guards(void);
  86. int num_live_entry_guards_for_guard_selection(
  87. guard_selection_t *gs,
  88. int for_directory);
  89. int num_live_entry_guards(int for_directory);
  90. #endif
  91. #ifdef ENTRYNODES_PRIVATE
  92. STATIC const node_t *add_an_entry_guard(guard_selection_t *gs,
  93. const node_t *chosen,
  94. int reset_status, int prepend,
  95. int for_discovery, int for_directory);
  96. STATIC int populate_live_entry_guards(smartlist_t *live_entry_guards,
  97. const smartlist_t *all_entry_guards,
  98. const node_t *chosen_exit,
  99. dirinfo_type_t dirinfo_type,
  100. int for_directory,
  101. int need_uptime, int need_capacity);
  102. STATIC int decide_num_guards(const or_options_t *options, int for_directory);
  103. STATIC void entry_guards_set_from_config(guard_selection_t *gs,
  104. const or_options_t *options);
  105. /** Flags to be passed to entry_is_live() to indicate what kind of
  106. * entry nodes we are looking for. */
  107. typedef enum {
  108. ENTRY_NEED_UPTIME = 1<<0,
  109. ENTRY_NEED_CAPACITY = 1<<1,
  110. ENTRY_ASSUME_REACHABLE = 1<<2,
  111. ENTRY_NEED_DESCRIPTOR = 1<<3,
  112. } entry_is_live_flags_t;
  113. STATIC const node_t *entry_is_live(const entry_guard_t *e,
  114. entry_is_live_flags_t flags,
  115. const char **msg);
  116. STATIC int entry_is_time_to_retry(const entry_guard_t *e, time_t now);
  117. #endif
  118. void remove_all_entry_guards_for_guard_selection(guard_selection_t *gs);
  119. void remove_all_entry_guards(void);
  120. void entry_guards_compute_status_for_guard_selection(
  121. guard_selection_t *gs, const or_options_t *options, time_t now);
  122. void entry_guards_compute_status(const or_options_t *options, time_t now);
  123. int entry_guard_register_connect_status_for_guard_selection(
  124. guard_selection_t *gs, const char *digest, int succeeded,
  125. int mark_relay_status, time_t now);
  126. int entry_guard_register_connect_status(const char *digest, int succeeded,
  127. int mark_relay_status, time_t now);
  128. void entry_nodes_should_be_added_for_guard_selection(guard_selection_t *gs);
  129. void entry_nodes_should_be_added(void);
  130. int entry_list_is_constrained(const or_options_t *options);
  131. const node_t *choose_random_entry(cpath_build_state_t *state);
  132. const node_t *choose_random_dirguard(dirinfo_type_t t);
  133. int entry_guards_parse_state_for_guard_selection(
  134. guard_selection_t *gs, or_state_t *state, int set, char **msg);
  135. int entry_guards_parse_state(or_state_t *state, int set, char **msg);
  136. void entry_guards_update_state(or_state_t *state);
  137. int getinfo_helper_entry_guards(control_connection_t *conn,
  138. const char *question, char **answer,
  139. const char **errmsg);
  140. int is_node_used_as_guard_for_guard_selection(guard_selection_t *gs,
  141. const node_t *node);
  142. MOCK_DECL(int, is_node_used_as_guard, (const node_t *node));
  143. void mark_bridge_list(void);
  144. void sweep_bridge_list(void);
  145. int addr_is_a_configured_bridge(const tor_addr_t *addr, uint16_t port,
  146. const char *digest);
  147. int extend_info_is_a_configured_bridge(const extend_info_t *ei);
  148. int routerinfo_is_a_configured_bridge(const routerinfo_t *ri);
  149. int node_is_a_configured_bridge(const node_t *node);
  150. void learned_router_identity(const tor_addr_t *addr, uint16_t port,
  151. const char *digest,
  152. const ed25519_public_key_t *ed_id);
  153. struct bridge_line_t;
  154. void bridge_add_from_config(struct bridge_line_t *bridge_line);
  155. void retry_bridge_descriptor_fetch_directly(const char *digest);
  156. void fetch_bridge_descriptors(const or_options_t *options, time_t now);
  157. void learned_bridge_descriptor(routerinfo_t *ri, int from_cache);
  158. int any_bridge_descriptors_known(void);
  159. int entries_known_but_down(const or_options_t *options);
  160. void entries_retry_all(const or_options_t *options);
  161. const smartlist_t *get_socks_args_by_bridge_addrport(const tor_addr_t *addr,
  162. uint16_t port);
  163. int any_bridges_dont_support_microdescriptors(void);
  164. void entry_guards_free_all(void);
  165. const char *find_transport_name_by_bridge_addrport(const tor_addr_t *addr,
  166. uint16_t port);
  167. struct transport_t;
  168. int get_transport_by_bridge_addrport(const tor_addr_t *addr, uint16_t port,
  169. const struct transport_t **transport);
  170. MOCK_DECL(int, transport_is_needed, (const char *transport_name));
  171. int validate_pluggable_transports_config(void);
  172. double pathbias_get_close_success_count(entry_guard_t *guard);
  173. double pathbias_get_use_success_count(entry_guard_t *guard);
  174. /** Contains the bandwidth of a relay as a guard and as a non-guard
  175. * after the guardfraction has been considered. */
  176. typedef struct guardfraction_bandwidth_t {
  177. /** Bandwidth as a guard after guardfraction has been considered. */
  178. int guard_bw;
  179. /** Bandwidth as a non-guard after guardfraction has been considered. */
  180. int non_guard_bw;
  181. } guardfraction_bandwidth_t;
  182. int should_apply_guardfraction(const networkstatus_t *ns);
  183. void
  184. guard_get_guardfraction_bandwidth(guardfraction_bandwidth_t *guardfraction_bw,
  185. int orig_bandwidth,
  186. uint32_t guardfraction_percentage);
  187. MOCK_DECL(smartlist_t *, list_bridge_identities, (void));
  188. MOCK_DECL(download_status_t *, get_bridge_dl_status_by_id,
  189. (const char *digest));
  190. #endif