router.h 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  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-2019, 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. #include "lib/testsupport/testsupport.h"
  13. struct curve25519_keypair_t;
  14. struct ed25519_keypair_t;
  15. #define TOR_ROUTERINFO_ERROR_NO_EXT_ADDR (-1)
  16. #define TOR_ROUTERINFO_ERROR_CANNOT_PARSE (-2)
  17. #define TOR_ROUTERINFO_ERROR_NOT_A_SERVER (-3)
  18. #define TOR_ROUTERINFO_ERROR_DIGEST_FAILED (-4)
  19. #define TOR_ROUTERINFO_ERROR_CANNOT_GENERATE (-5)
  20. #define TOR_ROUTERINFO_ERROR_DESC_REBUILDING (-6)
  21. #define TOR_ROUTERINFO_ERROR_INTERNAL_BUG (-7)
  22. MOCK_DECL(crypto_pk_t *,get_onion_key,(void));
  23. time_t get_onion_key_set_at(void);
  24. void set_server_identity_key(crypto_pk_t *k);
  25. MOCK_DECL(crypto_pk_t *,get_server_identity_key,(void));
  26. int server_identity_key_is_set(void);
  27. void set_client_identity_key(crypto_pk_t *k);
  28. crypto_pk_t *get_tlsclient_identity_key(void);
  29. int client_identity_key_is_set(void);
  30. MOCK_DECL(authority_cert_t *, get_my_v3_authority_cert, (void));
  31. crypto_pk_t *get_my_v3_authority_signing_key(void);
  32. authority_cert_t *get_my_v3_legacy_cert(void);
  33. crypto_pk_t *get_my_v3_legacy_signing_key(void);
  34. void dup_onion_keys(crypto_pk_t **key, crypto_pk_t **last);
  35. void expire_old_onion_keys(void);
  36. void rotate_onion_key(void);
  37. void v3_authority_check_key_expiry(void);
  38. int get_onion_key_lifetime(void);
  39. int get_onion_key_grace_period(void);
  40. crypto_pk_t *router_get_rsa_onion_pkey(const char *pkey, size_t pkey_len);
  41. void router_set_rsa_onion_pkey(const crypto_pk_t *pk, char **onion_pkey_out,
  42. size_t *onion_pkey_len);
  43. di_digest256_map_t *construct_ntor_key_map(void);
  44. void ntor_key_map_free_(di_digest256_map_t *map);
  45. #define ntor_key_map_free(map) \
  46. FREE_AND_NULL(di_digest256_map_t, ntor_key_map_free_, (map))
  47. int router_initialize_tls_context(void);
  48. int init_keys(void);
  49. int init_keys_client(void);
  50. uint16_t router_get_active_listener_port_by_type_af(int listener_type,
  51. sa_family_t family);
  52. uint16_t router_get_advertised_or_port(const or_options_t *options);
  53. uint16_t router_get_advertised_or_port_by_af(const or_options_t *options,
  54. sa_family_t family);
  55. uint16_t router_get_advertised_dir_port(const or_options_t *options,
  56. uint16_t dirport);
  57. int router_should_advertise_dirport(const or_options_t *options,
  58. uint16_t dir_port);
  59. void consider_publishable_server(int force);
  60. int should_refuse_unknown_exits(const or_options_t *options);
  61. void router_upload_dir_desc_to_dirservers(int force);
  62. void mark_my_descriptor_dirty_if_too_old(time_t now);
  63. void mark_my_descriptor_dirty(const char *reason);
  64. void check_descriptor_bandwidth_changed(time_t now);
  65. void check_descriptor_ipaddress_changed(time_t now);
  66. int router_has_bandwidth_to_be_dirserver(const or_options_t *options);
  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. MOCK_DECL(int, router_my_exit_policy_is_reject_star,(void));
  71. MOCK_DECL(const routerinfo_t *, router_get_my_routerinfo, (void));
  72. MOCK_DECL(const routerinfo_t *, router_get_my_routerinfo_with_err,(int *err));
  73. extrainfo_t *router_get_my_extrainfo(void);
  74. const char *router_get_my_descriptor(void);
  75. const char *router_get_descriptor_gen_reason(void);
  76. int router_digest_is_me(const char *digest);
  77. const uint8_t *router_get_my_id_digest(void);
  78. int router_extrainfo_digest_is_me(const char *digest);
  79. int router_is_me(const routerinfo_t *router);
  80. MOCK_DECL(int,router_pick_published_address,(const or_options_t *options,
  81. uint32_t *addr,
  82. int cache_only));
  83. int router_build_fresh_descriptor(routerinfo_t **r, extrainfo_t **e);
  84. int router_rebuild_descriptor(int force);
  85. char *router_dump_router_to_string(routerinfo_t *router,
  86. const crypto_pk_t *ident_key,
  87. const crypto_pk_t *tap_key,
  88. const struct curve25519_keypair_t *ntor_keypair,
  89. const struct ed25519_keypair_t *signing_keypair);
  90. char *router_dump_exit_policy_to_string(const routerinfo_t *router,
  91. int include_ipv4,
  92. int include_ipv6);
  93. int extrainfo_dump_to_string(char **s, extrainfo_t *extrainfo,
  94. crypto_pk_t *ident_key,
  95. const struct ed25519_keypair_t *signing_keypair);
  96. const char *routerinfo_err_to_string(int err);
  97. int routerinfo_err_is_transient(int err);
  98. void router_reset_warnings(void);
  99. void router_reset_reachability(void);
  100. void router_free_all(void);
  101. #ifdef ROUTER_PRIVATE
  102. /* Used only by router.c and the unit tests */
  103. STATIC void get_platform_str(char *platform, size_t len);
  104. STATIC int router_write_fingerprint(int hashed);
  105. STATIC smartlist_t *get_my_declared_family(const or_options_t *options);
  106. #ifdef TOR_UNIT_TESTS
  107. extern time_t desc_clean_since;
  108. extern const char *desc_dirty_reason;
  109. void set_server_identity_key_digest_testing(const uint8_t *digest);
  110. MOCK_DECL(STATIC const struct curve25519_keypair_t *,
  111. get_current_curve25519_keypair,(void));
  112. MOCK_DECL(STATIC int,
  113. router_build_fresh_unsigned_routerinfo,(routerinfo_t **ri_out));
  114. STATIC extrainfo_t *router_build_fresh_signed_extrainfo(
  115. const routerinfo_t *ri);
  116. STATIC void router_update_routerinfo_from_extrainfo(routerinfo_t *ri,
  117. const extrainfo_t *ei);
  118. STATIC int router_dump_and_sign_routerinfo_descriptor_body(routerinfo_t *ri);
  119. #endif /* defined(TOR_UNIT_TESTS) */
  120. #endif /* defined(ROUTER_PRIVATE) */
  121. #endif /* !defined(TOR_ROUTER_H) */