diff options
-rw-r--r-- | doc/tor-spec.txt | 11 | ||||
-rw-r--r-- | src/or/routerparse.c | 2 |
2 files changed, 9 insertions, 4 deletions
diff --git a/doc/tor-spec.txt b/doc/tor-spec.txt index 4c515f4198..aa54549a02 100644 --- a/doc/tor-spec.txt +++ b/doc/tor-spec.txt @@ -852,9 +852,14 @@ after "directory-signature". This digest is then padded with PKCS.1, and signed with the directory server's signing key. If software encounters an unrecognized keyword in a single router descriptor, -it should reject only that router descriptor, and continue using the -others. If it encounters an unrecognized keyword in the directory header, -it should reject the entire directory. +it MUST reject only that router descriptor, and continue using the +others. Because this mechanism is used to add 'critical' extensions to +future versions of the router descriptor format, implementation should treat +it as a normal occurrence and not, for example, report it to the user as an +error. [Versions of Tor prior to 0.1.1 did this.] + +If software encounters an unrecognized keyword in the directory header, +it SHOULD reject the entire directory. 7.4. Network-status descriptor diff --git a/src/or/routerparse.c b/src/or/routerparse.c index f2a3515af6..65e5e1356f 100644 --- a/src/or/routerparse.c +++ b/src/or/routerparse.c @@ -853,7 +853,7 @@ router_parse_entry_from_string(const char *s, const char *end) goto err; } if ((tok = find_first_by_keyword(tokens, _UNRECOGNIZED))) { - log_fn(LOG_WARN, "Unrecognized keyword '%s'; skipping descriptor.", + log_fn(LOG_INFO, "Unrecognized critical keyword '%s'; skipping descriptor. (It may be from another version of Tor.)", tok->args[0]); goto err; } |