- From: Mark Nottingham <mnot@mnot.net>
- Date: Fri, 3 Nov 2017 11:34:29 +1100
- To: "Julian F. Reschke" <julian.reschke@gmx.de>
- Cc: HTTP Working Group <ietf-http-wg@w3.org>
> On 31 Oct 2017, at 6:55 pm, Julian Reschke <julian.reschke@gmx.de> wrote: > > On 2017-10-31 00:08, Mark Nottingham wrote: >> On 30 Oct 2017, at 10:13 pm, Julian Reschke <julian.reschke@gmx.de> wrote: >>> >>> On 2017-10-30 05:41, Mark Nottingham wrote: >>>> FYI, an update of Variants. >>>> This one removes the requirement for conneg mechanisms to identify their own response header ("Content-*"), in favour of a central one -- Variant-Key. >>>> Doing so avoids the big problem with Variants-00, where the semantics of a header like Content-Encoding could clash with variants' needs. >>>> So, you now have a response that looks something like: >>>> Vary: Accept-Encoding, Accept-Language >>>> Variants: Accept-Encoding;gzip;br, Accept-Language;fr;en;jp >>>> Variant-Key: gzip,en >>>> ... which roughly translates to "There are gzip, brotli and identity representations of this resource, in French, English and Japanese; THIS representation is the gzip'd English one." >>>> ... >>> >>> >>> Looking at the examples, they seem a bit chatty. Can't we collapse this into a single field, like: >>> >>> Variants: Accept-Encoding;available="gzip br";selected=gzip, Accept-Language;available="fr en jp";selected=en >>> >>> ? (and yes, we could abbreviate the parameter names). >> I considered that, but it seems like making them separate will make at least the Variants header (in the current design) more likely to get a hit in HPACK. Also, even with shorter parameter names, it seems like this approach is actually more verbose, in terms of character counts -- especially when the list gets long. > > Hmmm. > > You get the additional complexity of two header fields potentially out of sync. My gut feeling is that eliminating that problem would be worth a few bytes. I don't see it as a huge problem; if they're out of sync, it implies that the server is very confused about its state. A MUST about values in Variant-Key that aren't in Variants, and one that the MUST be the same length should take care of it. > And if optimizing *that* is the goal, one can of course choose a bit more obscure syntax, such as: > > Accept-Encoding;gzip,gzip,br, Accept-Language;en;fr;en;jp > > (where the first parameter indicates the selected variant) I think that's going to be much more difficult for people to understand; consider how much confusion there is out there about Vary. >>> Also, looking at my made up syntax using whitespace as separator reminds me that picking the separator is tricky, and in particular the semicolon might not work well in all cases. For instance, what if the server was negotiating on "Accept" and take parameters into account? (see example in <https://www.greenbytes.de/tech/webdav/rfc7231.html#rfc.section.5.3.2.p.10>). >>> >>> So, whatever the syntax is we probably need an escaping mechanism for edge cases... >> Yes (and that's another reason for separating the headers, I think). > > Why? The escaping problem exists in both cases... Multiple layers of escaping. >> However, keep in mind that available-values doesn't *have* to be the values sent in the request headers; it can be computed to something else. >> Also, I very much wonder whether including parameters is a good idea for Accept. > > Yes, but that's a separate discussion. I believe it would be good if the draft addressed negotiating on type (no matter whether we think it's a good idea). I agree, but I don't want to put work into it until the draft has a future. Cheers, -- Mark Nottingham https://www.mnot.net/
Received on Friday, 3 November 2017 00:34:57 UTC