summaryrefslogtreecommitdiff
path: root/src/or
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2016-11-03 10:01:40 -0400
committerNick Mathewson <nickm@torproject.org>2016-11-03 10:01:40 -0400
commitb7a1e793e69e540e0377fa4418810ff1c02d50f9 (patch)
tree6f9505e74e7099eaa7e26a63bd4569f34e0ae81d /src/or
parent1eef543f9d9cde9754897047fb51ac7307b9827a (diff)
downloadtor-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.h4
-rw-r--r--src/or/protover.c2
-rw-r--r--src/or/routerparse.c2
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);