[PATCH] Early request for comments: U2F authentication
    Klaus Keppler 
    kk at keppler-it.de
       
    Mon Dec 15 09:42:01 EST 2014
    
    
  
> I’ve spent some time (together with Christian and Thomas) hacking on
> U2F support in OpenSSH, and I’m happy to provide a first patch — it’s
> not complete, but it should be good enough to get the discussion going
> :). Please see the two attached files for the patch.
This is great - I'm looking forward to it! :)
I've implemented U2F into another (C-based) application these days. 
While searching for some relevant OpenSSL-specific "help" I stumbled 
upon your OpenSSH patch.
I think there's a small bug:
> +	if ((err = EVP_VerifyInit(&mdctx, EVP_ecdsa())) != 1) {
> +		ERR_error_string(ERR_get_error(), errorbuf);
> +		fatal("EVP_VerifyInit() failed: %s (reason: %s)",
> +				errorbuf, ERR_reason_error_string(err));
You should use "EVP_sha256()" instead of "EVP_ecdsa()" here (we have a 
ECDSA signature on the SHA256 hash)
> +	if ((err = EVP_VerifyFinal(&mdctx, walk, restlen, pkey)) == -1) {
> +		ERR_error_string(ERR_get_error(), errorbuf);
> +		error("Verifying the U2F registration signature failed: %s (reason: %s)",
> +				errorbuf, ERR_reason_error_string(err));
> +		goto out;
> +	}
You test EVP_VerifyFinal() only against "-1". This catches OpenSSL 
library errors and such. But if the signature check itself fails, you 
get "0". So, the only valid result here should be "1".
When you change EVP_ecdsa() to EVP_sha256() above, EVP_VerifyFinal() 
should return "1" on valid data.
Best regards
    -Klaus
    
    
More information about the openssh-unix-dev
mailing list