On Tue, Jul 06, 2021 at 06:20:49PM +0000, Jacob Champion wrote:
> On Mon, 2021-07-05 at 17:17 +0900, Michael Paquier wrote:
> Each name must be null-terminated, not just null-separated. That way
> the list of names ends with an empty string:
> 
>     name-one\0              <- added by the mechanism
>               name-two\0    <- added by the mechanism
>                         \0  <- added by the framework
> 
> The way it's worded now, I could see some implementers failing to
> terminate the final name because the framework adds a trailing null
> already -- but the framework is terminating the list, not the final
> name.

Good point.  I have used ending with '\0' bytes instead.

>> +     * init()
>> +     *
>> +     * Initializes mechanism-specific state for a connection.  This
>> +     * callback must return a pointer to its allocated state, which will
>> +     * be passed as-is as the first argument to the other callbacks.
>> +     * free() is called to release any state resources.
> 
> Maybe say "The free() callback is called" to differentiate it from
> standard free()?

Yes, that could be confusing.  Switched to your wording instead.

> It's possible for conn->sasl to be NULL here, say if the client has
> channel_binding=require but connects as a user with an MD5 secret. The
> SCRAM TAP tests have one such case.

Indeed.

>> Hmm.  Does the RFCs tell us anything about that?
> 
> Just in general terms:
> 
>>    Each authentication exchange consists of a message from the client to
>>    the server requesting authentication via a particular mechanism,
>>    followed by one or more pairs of challenges from the server and
>>    responses from the client, followed by a message from the server
>>    indicating the outcome of the authentication exchange.  (Note:
>>    exchanges may also be aborted as discussed in Section 3.5.)
> 
> So a challenge must be met with a response, or the exchange must be
> aborted. (And I don't think our protocol implementation provides a
> client abort message; if something goes wrong, we just tear down the
> connection.)

Thanks.  At the same time, section 3.5 also says that the client may
send a message to abort.  So one can interpret that the client has
also the choice to abort without sending a response back to the
server?  Or I am just interpreting incorrectly the use of "may" in
this context?
--
Michael

Attachment: signature.asc
Description: PGP signature

Reply via email to