summaryrefslogtreecommitdiff
path: root/src/feature/nodelist/dirlist.h
blob: 70bbb780d10f5954547cfb4a483b04da999b8154 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/* Copyright (c) 2001-2004, Roger Dingledine.
 * Copyright (c) 2004-2006, Roger Dingledine, Nick Mathewson.
 * Copyright (c) 2007-2020, The Tor Project, Inc. */
/* See LICENSE for licensing information */

/**
 * \file dirlist.h
 * \brief Header file for dirlist.c
 **/

#ifndef TOR_DIRLIST_H
#define TOR_DIRLIST_H

typedef struct auth_dirport_t auth_dirport_t;
/**
 * Different usages for an authority's HTTP directory port.
 *
 * Historically, only legacy ports existed; proposal 330 added multiple types
 * of dirport to better enable authorities to offload work and resist DoS
 * attacks.
 **/
typedef enum auth_dirport_usage_t {
  /** Flag for an authority's dirport that is intended for misc/legacy
   * usage. May be used when no other dirport is available. */
  AUTH_USAGE_LEGACY,
  /** Flag for an authority's dirport that is intended for descriptor uploads
   * only. */
  AUTH_USAGE_UPLOAD,
  /** Flag for an authority's dirport that is intended for voting only */
  AUTH_USAGE_VOTING,
  /** Flag for an authority's dirport that is intended for relay downloads
   * only. */
  AUTH_USAGE_DOWNLOAD,
} auth_dirport_usage_t;

int get_n_authorities(dirinfo_type_t type);
const smartlist_t *router_get_trusted_dir_servers(void);
const smartlist_t *router_get_fallback_dir_servers(void);
smartlist_t *router_get_trusted_dir_servers_mutable(void);
smartlist_t *router_get_fallback_dir_servers_mutable(void);
void mark_all_dirservers_up(smartlist_t *server_list);

dir_server_t *router_get_trusteddirserver_by_digest(const char *d);
dir_server_t *router_get_fallback_dirserver_by_digest(
                                                   const char *digest);
int router_digest_is_fallback_dir(const char *digest);
MOCK_DECL(dir_server_t *, trusteddirserver_get_by_v3_auth_digest,
          (const char *d));

MOCK_DECL(int, router_digest_is_trusted_dir_type,
        (const char *digest, dirinfo_type_t type));

const tor_addr_port_t *trusted_dir_server_get_dirport(const dir_server_t *ds,
                                                  auth_dirport_usage_t usage,
                                                  int addr_family);

bool router_addr_is_trusted_dir_type(const tor_addr_t *addr,
                                     dirinfo_type_t type);
#define router_addr_is_trusted_dir(d) \
  router_addr_is_trusted_dir_type((d), NO_DIRINFO)

#define router_digest_is_trusted_dir(d) \
  router_digest_is_trusted_dir_type((d), NO_DIRINFO)

dir_server_t *trusted_dir_server_new(const char *nickname, const char *address,
                       uint16_t dir_port, uint16_t or_port,
                       const tor_addr_port_t *addrport_ipv6,
                       const char *digest, const char *v3_auth_digest,
                       dirinfo_type_t type, double weight);
void trusted_dir_server_add_dirport(dir_server_t *ds,
                                    auth_dirport_usage_t usage,
                                    const tor_addr_port_t *dirport);
dir_server_t *fallback_dir_server_new(const tor_addr_t *addr,
                                      uint16_t dir_port, uint16_t or_port,
                                      const tor_addr_port_t *addrport_ipv6,
                                      const char *id_digest, double weight);
void dir_server_add(dir_server_t *ent);

void clear_dir_servers(void);
void dirlist_free_all(void);

MOCK_DECL(void, dirlist_add_trusted_dir_addresses, (void));

#endif /* !defined(TOR_DIRLIST_H) */