router.h 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  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-2012, The Tor Project, Inc. */
  5. /* See LICENSE for licensing information */
  6. /**
  7. * \file router.h
  8. * \brief Header file for router.c.
  9. **/
  10. #ifndef TOR_ROUTER_H
  11. #define TOR_ROUTER_H
  12. crypto_pk_t *get_onion_key(void);
  13. time_t get_onion_key_set_at(void);
  14. void set_server_identity_key(crypto_pk_t *k);
  15. crypto_pk_t *get_server_identity_key(void);
  16. int server_identity_key_is_set(void);
  17. void set_client_identity_key(crypto_pk_t *k);
  18. crypto_pk_t *get_tlsclient_identity_key(void);
  19. int client_identity_key_is_set(void);
  20. authority_cert_t *get_my_v3_authority_cert(void);
  21. crypto_pk_t *get_my_v3_authority_signing_key(void);
  22. authority_cert_t *get_my_v3_legacy_cert(void);
  23. crypto_pk_t *get_my_v3_legacy_signing_key(void);
  24. void dup_onion_keys(crypto_pk_t **key, crypto_pk_t **last);
  25. void rotate_onion_key(void);
  26. crypto_pk_t *init_key_from_file(const char *fname, int generate,
  27. int severity);
  28. void v3_authority_check_key_expiry(void);
  29. #ifdef CURVE25519_ENABLED
  30. di_digest256_map_t *construct_ntor_key_map(void);
  31. void ntor_key_map_free(di_digest256_map_t *map);
  32. #endif
  33. int router_initialize_tls_context(void);
  34. int init_keys(void);
  35. int check_whether_orport_reachable(void);
  36. int check_whether_dirport_reachable(void);
  37. void consider_testing_reachability(int test_or, int test_dir);
  38. void router_orport_found_reachable(void);
  39. void router_dirport_found_reachable(void);
  40. void router_perform_bandwidth_test(int num_circs, time_t now);
  41. int net_is_disabled(void);
  42. int authdir_mode(const or_options_t *options);
  43. int authdir_mode_v1(const or_options_t *options);
  44. int authdir_mode_v2(const or_options_t *options);
  45. int authdir_mode_v3(const or_options_t *options);
  46. int authdir_mode_any_main(const or_options_t *options);
  47. int authdir_mode_any_nonhidserv(const or_options_t *options);
  48. int authdir_mode_handles_descs(const or_options_t *options, int purpose);
  49. int authdir_mode_publishes_statuses(const or_options_t *options);
  50. int authdir_mode_tests_reachability(const or_options_t *options);
  51. int authdir_mode_bridge(const or_options_t *options);
  52. uint16_t router_get_active_listener_port_by_type(int listener_type);
  53. uint16_t router_get_advertised_or_port(const or_options_t *options);
  54. uint16_t router_get_advertised_dir_port(const or_options_t *options,
  55. uint16_t dirport);
  56. int server_mode(const or_options_t *options);
  57. int public_server_mode(const or_options_t *options);
  58. int advertised_server_mode(void);
  59. int proxy_mode(const or_options_t *options);
  60. void consider_publishable_server(int force);
  61. int should_refuse_unknown_exits(const or_options_t *options);
  62. void router_upload_dir_desc_to_dirservers(int force);
  63. void mark_my_descriptor_dirty_if_too_old(time_t now);
  64. void mark_my_descriptor_dirty(const char *reason);
  65. void check_descriptor_bandwidth_changed(time_t now);
  66. void check_descriptor_ipaddress_changed(time_t now);
  67. void router_new_address_suggestion(const char *suggestion,
  68. const dir_connection_t *d_conn);
  69. int router_compare_to_my_exit_policy(const tor_addr_t *addr, uint16_t port);
  70. int router_my_exit_policy_is_reject_star(void);
  71. const routerinfo_t *router_get_my_routerinfo(void);
  72. extrainfo_t *router_get_my_extrainfo(void);
  73. const char *router_get_my_descriptor(void);
  74. const char *router_get_descriptor_gen_reason(void);
  75. int router_digest_is_me(const char *digest);
  76. const uint8_t *router_get_my_id_digest(void);
  77. int router_extrainfo_digest_is_me(const char *digest);
  78. int router_is_me(const routerinfo_t *router);
  79. int router_fingerprint_is_me(const char *fp);
  80. int router_pick_published_address(const or_options_t *options, uint32_t *addr);
  81. int router_rebuild_descriptor(int force);
  82. int router_dump_router_to_string(char *s, size_t maxlen, routerinfo_t *router,
  83. crypto_pk_t *ident_key);
  84. void router_get_prim_orport(const routerinfo_t *router,
  85. tor_addr_port_t *addr_port_out);
  86. void router_get_pref_orport(const routerinfo_t *router,
  87. tor_addr_port_t *addr_port_out);
  88. void router_get_pref_ipv6_orport(const routerinfo_t *router,
  89. tor_addr_port_t *addr_port_out);
  90. int router_ipv6_preferred(const routerinfo_t *router);
  91. int router_has_addr(const routerinfo_t *router, const tor_addr_t *addr);
  92. int router_has_orport(const routerinfo_t *router,
  93. const tor_addr_port_t *orport);
  94. int extrainfo_dump_to_string(char **s, extrainfo_t *extrainfo,
  95. crypto_pk_t *ident_key);
  96. int is_legal_nickname(const char *s);
  97. int is_legal_nickname_or_hexdigest(const char *s);
  98. int is_legal_hexdigest(const char *s);
  99. /**
  100. * Longest allowed output of format_node_description, plus 1 character for
  101. * NUL. This allows space for:
  102. * "$FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF~xxxxxxxxxxxxxxxxxxx at"
  103. * " [ffff:ffff:ffff:ffff:ffff:ffff:255.255.255.255]"
  104. * plus a terminating NUL.
  105. */
  106. #define NODE_DESC_BUF_LEN (MAX_VERBOSE_NICKNAME_LEN+4+TOR_ADDR_BUF_LEN)
  107. const char *format_node_description(char *buf,
  108. const char *id_digest,
  109. int is_named,
  110. const char *nickname,
  111. const tor_addr_t *addr,
  112. uint32_t addr32h);
  113. const char *router_get_description(char *buf, const routerinfo_t *ri);
  114. const char *node_get_description(char *buf, const node_t *node);
  115. const char *routerstatus_get_description(char *buf, const routerstatus_t *rs);
  116. const char *extend_info_get_description(char *buf, const extend_info_t *ei);
  117. const char *router_describe(const routerinfo_t *ri);
  118. const char *node_describe(const node_t *node);
  119. const char *routerstatus_describe(const routerstatus_t *ri);
  120. const char *extend_info_describe(const extend_info_t *ei);
  121. void router_get_verbose_nickname(char *buf, const routerinfo_t *router);
  122. void routerstatus_get_verbose_nickname(char *buf,
  123. const routerstatus_t *router);
  124. void router_reset_warnings(void);
  125. void router_reset_reachability(void);
  126. void router_free_all(void);
  127. const char *router_purpose_to_string(uint8_t p);
  128. uint8_t router_purpose_from_string(const char *s);
  129. smartlist_t *router_get_all_orports(const routerinfo_t *ri);
  130. #ifdef ROUTER_PRIVATE
  131. /* Used only by router.c and test.c */
  132. void get_platform_str(char *platform, size_t len);
  133. #endif
  134. #endif