diff options
Diffstat (limited to 'src/or/nodelist.h')
-rw-r--r-- | src/or/nodelist.h | 39 |
1 files changed, 38 insertions, 1 deletions
diff --git a/src/or/nodelist.h b/src/or/nodelist.h index 6a77ba6836..3dceb75731 100644 --- a/src/or/nodelist.h +++ b/src/or/nodelist.h @@ -12,7 +12,8 @@ #ifndef _TOR_NODELIST_H #define _TOR_NODELIST_H -node_t *node_get_by_id(const char *identity_digest); +node_t *node_get_mutable_by_id(const char *identity_digest); +const node_t *node_get_by_id(const char *identity_digest); node_t *nodelist_add_routerinfo(routerinfo_t *ri); node_t *nodelist_add_microdesc(microdesc_t *md); void nodelist_set_consensus(networkstatus_t *ns); @@ -24,5 +25,41 @@ void nodelist_purge(void); void nodelist_free_all(void); void nodelist_assert_ok(void); +const node_t *node_get_by_nickname(const char *nickname, int warn_if_unnamed); +void node_get_verbose_nickname(const node_t *node, + char *verbose_name_out); +int node_is_named(const node_t *node); +int node_is_dir(const node_t *node); +int node_has_descriptor(const node_t *node); +int node_get_purpose(const node_t *node); +#define node_is_bridge(node) \ + (node_get_purpose((node)) == ROUTER_PURPOSE_BRIDGE) +int node_is_me(const node_t *node); +int node_exit_policy_rejects_all(const node_t *node); +int node_get_addr(const node_t *node, tor_addr_t *addr_out); +uint32_t node_get_addr_ipv4h(const node_t *node); +int node_allows_single_hop_exits(const node_t *node); +uint16_t node_get_orport(const node_t *node); +const char *node_get_nickname(const node_t *node); +const char *node_get_platform(const node_t *node); +void node_get_address_string(const node_t *node, char *cp, size_t len); +long node_get_declared_uptime(const node_t *node); +time_t node_get_published_on(const node_t *node); + +smartlist_t *nodelist_get_list(void); + +/* XXXX These need to move out of routerlist.c */ +void nodelist_refresh_countries(void); +void node_set_country(node_t *node); +void nodelist_add_node_family(smartlist_t *nodes, const node_t *node); +int nodes_in_same_family(const node_t *node1, const node_t *node2); + +/* This means: implement this code or function or thing, nick! */ +#define UNIMPLEMENTED_NODELIST() \ + while (unimplemented_nodelist_truth) { \ + tor_assert(0); \ + } +extern int unimplemented_nodelist_truth; + #endif |