Hi Ilari, Please see my comments below.
-----Original Message----- From: ilariliusva...@welho.com <ilariliusva...@welho.com> Sent: Wednesday, July 1, 2020 8:49 PM To: Hannes Tschofenig <hannes.tschofe...@arm.com> Cc: <tls@ietf.org> <tls@ietf.org> Subject: Re: [TLS] draft-ietf-tls-ticketrequests-05 On Wed, Jul 01, 2020 at 04:52:18PM +0000, Hannes Tschofenig wrote: > Hi Tommy, Hi David, Hi Chris, > > I read through the draft and have a few questions. > > 1) Is it really necessary for the client to use two values to > differentiate the tickets it wants with a new session and with > resumption. It feels a bit over-designed. I would just have one value > and that alone would be super useful already. Consider a client that does: - Parallel connections - Does not reuse tickets Such client needs enough tickets to cover the multiple connections in case of fresh handshake (might be 5-10 or so), but only needs to replace the tickets for current connection (1 or 2) in case of resumption. So any single value will result in oversupply or undersupply. [Hannes] The client is probably in the best position to know how many tickets it wants. I don't see the case where it is necessary to distinguish two types of tickets with this extension. I want this to be as simple as possible. > 2) This sentence confuses me: > " > Servers SHOULD NOT send more tickets than requested for the handshake > type selected by the server (resumption or full handshake). > Moreover, servers SHOULD place a limit on the number of tickets they > are willing to send, whether for full handshakes or resumptions, to > save resources. > " > > Shouldn't the sentence say: > " > Servers SHOULD NOT send more tickets than requested for the handshake > type (resumption or full handshake) indicated by the client. > " The server might not want to actually honor request to send 255 tickets. Even if ticket minting is a fast operation, 255 of them might take non- trivial time (and bandwidth). [Hannes] I was trying to point out that there appears to be a bug in the sentence. (at least that's my understanding as a non-English native speaker) > Even then, I believe the sentence should actually say MUST NOT instead > of SHOULD NOT. If the client is already taking the effort to indicate > that it does not want more than a certain number of tickets then it > might have a reason. I am thinking about the case where the client > indicates that it does not want any tickets then it would be strange > for the server expressing support for the extension and still send > tickets. If the client signals 0 tickets for handshake and 0 tickets for resumption, then reasonable interpretation is that client does not support resumption at all, and it is waste of resources to send it any tickets. [Hannes] Correct. This is what I am saying. Currently the text allows the server to still send a ticket even though the client says "don't send it". But how should server interpret client saying it wants 1 ticket for full handshake and 0 tickets for resumption? A reasonable interpretation is that client does support tickets and is is willing to reuse tickets. So if the server is not willing to reuse tickets, the most reasonable action is to send 1 ticket to the client on resumption (if server is willing to reuse tickets, the most reasonable act is not send any tickets on resumption). [Hannes] If the client says it only wants one ticket then he should only get one ticket. If it wants another ticket when it resumes the session then the client can ask for another ticket. Basically, there can be good reasons to send more tickets than requested. Just that most of the time, sending more tickets will lead to oversupply. [Hannes] It would be good to decide who makes the decisions in this process. If we want to give the client the possibility to indicate how much it wants to receive and you can still give the server the ability to send less. Currently, the authors did not decide what they want. > 4) I believe it would make sense to define a ticket flag for the case > where the client does not want to receive any tickets. The sensible way to indicate that is to send (0,0) as requested ticket count. [Hannes] I am suggesting to use the newly defined flags extension draft (see https://tools.ietf.org/html/draft-ietf-tls-tlsflags-02) for this purpose. > 5) If a client sends the ClientTicketRequest extension during the full > handshake is there an expectation that it sends it again in the > resumption exchange? Would you assume that the server memorizes how > many tickets the client wanted across the resumption handshakes? > For example, in the full handshake I use the extension and indicate > that I want 5 tickets. I get two tickets from the server. Then, I run > a resumption handshake without transmitting the extension. Is the > server expected to remember to still send 3 more tickets till the > quota is exhausted? I expect each connection to have its own ticket request counts. [Hannes] I don't think I have read this in the draft. In general, it is unsafe to cache extension values across connections in session. [Hannes] Is it unsafe? In general, resumption is a mechanism to cache data across connections. Sure, one probably can not cause anything bad with this extension, but with things like server_name, very bad stuff can happen if those are not taken from connection handshake. [Hannes] But I am not talking about server_name but instead about how many tickets are left to be sent to the client. > 6) The topic of when to send the tickets is something you mention in > the document and it is indeed an issue. Have you thought about > allowing the client to signal to the server when to send the tickets? > Even making a distinction between "send me all tickets in a batch" and > "send one after the other with some reasonable time in between" would > be helpful. What usecases would there be in spreading tickets in time? [Hannes] If you want to open parallel connections quickly then it makes sense to obtain the tickets in batch. If you do not want to open parallel connections but rather want to use the ticket mechanism to reduce the computational overhead and you are working on a low bandwidth connection then it is better to spread the transmission in time. The latter case would be an IoT scenario while the former is a web scenario. Ciao Hannes -Ilari IMPORTANT NOTICE: The contents of this email and any attachments are confidential and may also be privileged. If you are not the intended recipient, please notify the sender immediately and do not disclose the contents to any other person, use it for any purpose, or store or copy the information in any medium. Thank you. _______________________________________________ TLS mailing list TLS@ietf.org https://www.ietf.org/mailman/listinfo/tls