diff options
author | Nick Mathewson <nickm@torproject.org> | 2016-11-03 10:01:40 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2016-11-03 10:01:40 -0400 |
commit | b7a1e793e69e540e0377fa4418810ff1c02d50f9 (patch) | |
tree | 6f9505e74e7099eaa7e26a63bd4569f34e0ae81d /src/or | |
parent | 1eef543f9d9cde9754897047fb51ac7307b9827a (diff) | |
download | tor-b7a1e793e69e540e0377fa4418810ff1c02d50f9.tar.gz tor-b7a1e793e69e540e0377fa4418810ff1c02d50f9.zip |
Declare a LINKAUTH subprotocol version for #15055 (ed link handshake)
Closes ticket 20552.
Diffstat (limited to 'src/or')
-rw-r--r-- | src/or/or.h | 4 | ||||
-rw-r--r-- | src/or/protover.c | 2 | ||||
-rw-r--r-- | src/or/routerparse.c | 2 |
3 files changed, 7 insertions, 1 deletions
diff --git a/src/or/or.h b/src/or/or.h index d305eac543..a8664bbe90 100644 --- a/src/or/or.h +++ b/src/or/or.h @@ -2247,6 +2247,10 @@ typedef struct routerstatus_t { * accept EXTEND2 cells */ unsigned int supports_extend2_cells:1; + /** True iff this router has a protocol list that allows it to negotiate + * ed25519 identity keys on a link handshake. */ + unsigned int supports_ed25519_link_handshake:1; + unsigned int has_bandwidth:1; /**< The vote/consensus had bw info */ unsigned int has_exitsummary:1; /**< The vote/consensus had exit summaries */ unsigned int bw_is_unmeasured:1; /**< This is a consensus entry, with diff --git a/src/or/protover.c b/src/or/protover.c index 335be29e61..ff8948bafd 100644 --- a/src/or/protover.c +++ b/src/or/protover.c @@ -292,7 +292,7 @@ protover_get_supported_protocols(void) "HSIntro=3 " "HSRend=1-2 " "Link=1-4 " - "LinkAuth=1 " + "LinkAuth=1,3 " "Microdesc=1-2 " "Relay=1-2"; } diff --git a/src/or/routerparse.c b/src/or/routerparse.c index cb2bc72d0c..95bc6837b6 100644 --- a/src/or/routerparse.c +++ b/src/or/routerparse.c @@ -2962,6 +2962,8 @@ routerstatus_parse_entry_from_string(memarea_t *area, rs->protocols_known = 1; rs->supports_extend2_cells = protocol_list_supports_protocol(tok->args[0], PRT_RELAY, 2); + rs->supports_ed25519_link_handshake = + protocol_list_supports_protocol(tok->args[0], PRT_LINKAUTH, 3); } if ((tok = find_opt_by_keyword(tokens, K_V))) { tor_assert(tok->n_args == 1); |