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