[tor-bugs] #30373 [Core Tor/Tor]: Most headers non-compliant with spec

Tor Bug Tracker & Wiki blackhole at torproject.org
Mon May 6 14:02:22 UTC 2019


#30373: Most headers non-compliant with spec
-------------------------------------------+-------------------------------
 Reporter:  irl                            |          Owner:  (none)
     Type:  defect                         |         Status:  new
 Priority:  Medium                         |      Milestone:
Component:  Core Tor/Tor                   |        Version:  Tor:
                                           |  unspecified
 Severity:  Normal                         |     Resolution:
 Keywords:  bandwidth-file-spec, tor-spec  |  Actual Points:
Parent ID:                                 |         Points:  1
 Reviewer:                                 |        Sponsor:
-------------------------------------------+-------------------------------

Comment (by irl):

 Replying to [comment:4 juga]:
 > Replying to [comment:3 irl]:
 > > Replying to [comment:1 juga]:
 > > > Does it sounds fine that we just re-define `Keyword` and
 `KeywordChar` in the bandwidth file to include `_`?.
 > > >
 > > > I think we would need to increment the version though.
 > >
 > > I don't think the version needs changing, this is a "typo fix" in my
 mind. Anyone that has an implementation that works with the current sbws
 files is already complying with the change that we haven't made yet.
 >
 > A complying version is 1.0.0. A parser that is ignoring anything (as it
 should) that contains `_` will still parse the timestamp, which is the
 only required thing in 1.0.0.

 The finite state automaton that I derived from the spec is shown here:

 [[Image(graphviz-c87f837aa8efe0a4df10bd6fa2ac8ca0b38a7e0d.png​)]]

 The spec requires that Keywords have only KeywordChar in them, so
 basically any file with headers *fails* to parse. Where Keywords are
 expected, they are not found. So no, the files with headers are not
 compliant with 1.0.0.

 I think we fix this by fixing the spec though. Clearly everyone managed
 just fine until now with having _ in the headers, and people wrote parsers
 that handle them. The parsers I'm adding to bushel are just super strict,
 and designed to catch issues like this.

 > > Keyword and KeywordChar are already defined, so I wouldn't want to
 cause confusion be re-defining them, even though it's a different spec
 people have ideas in their heads about what these mean.
 > >
 > > Maybe just a new `Key`:
 > >
 > > {{{Key ::= (KeywordChar | "_")+}}}
 >
 > I agree and that sounds good, for some reason i thought we were
 redefining something else, but checked and i don't think so.

 Can you come up with a patch for the spec that replaces Keyword with Key?
 We're essentially just pretending this is the way it was all along,
 because no one implemented the spec as it's defined.

--
Ticket URL: <https://trac.torproject.org/projects/tor/ticket/30373#comment:5>
Tor Bug Tracker & Wiki <https://trac.torproject.org/>
The Tor Project: anonymity online


More information about the tor-bugs mailing list