-
Notifications
You must be signed in to change notification settings - Fork 16
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Why SHA256 and not SHA3-256? #10
Comments
One of the big consumers of BLS signatures is the blockchain industry (Dfinity, Eth2, Algorand, Harmony, Cosmos, Chia, and others). The overwhelming application-layer hash function for blockchains is SHA256, and NIST recommends it as the hash function for interoperability. |
I'd like to see the RFC support SHA-3 and SHAKE (and cSHAKE) as well. Otherwise we're probably going to have to write an extension/another RFC later on. (I'd rather have cSHAKE everywhere, but I can understand how some project might want SHA-3 instead) |
Just to be 100% sure I understand the issue: this is a discussion about the ciphersuites that are specified, right? In other words, is it reasonable to interpret this as a request to specify a SHA3--based ciphersuite in addition to the SHA2--based one? (Because, as I'm sure you know, the document is generic with respect to the underlying hash function, meaning that of course you can use SHA-3 if you wish.) Regarding length extension: that seems to be out of scope here, since every use of H (including in the underlying hash-to-curve invocation) is wrapped in HKDF, which in turn is based on HMAC. |
Indeed, it sounds like this is more of a problem on the hash to curve side not providing enough ciphersuites right? |
Yes, exactly, the request is to specify both ciphersuites. |
Great, thanks for the clarification.
I'm not sure I agree that HKDF somehow implies SHA-2. It's a generic construction, and in particular it's one that's completely safe to use with SHA-3. To be sure, there are other ways to use SHA-3 as a KDF. The advantage of specifying HKDF is that we can safely specify one KDF to use with any underlying hash function. As some more background, we discussed this in the context of hash-to-curve (part of the discussion is here: cfrg/draft-irtf-cfrg-hash-to-curve#137; part was offline) and decided that the complexity of supporting multiple hash-based KDFs far outweighed any potential benefit. In particular, even if the computational cost of SHAKE is significantly less than that of HKDF, that does not translate to any improvement in overall cost because the KDF is effectively free compared to the rest of hash-to-curve. So: we can (should) certainly chat about this (I see cfrg/draft-irtf-cfrg-hash-to-curve#165 opens the discussion), but my current thinking (which---of course---could change) is that this is a bad idea. |
Hi @valerini quick question about this: hash_to_curve now supports SHAKE and other constructions (see issue 212 over there for a discussion of why). So now we could pretty easily specify a suite that uses SHAKE and/or SHA-3 for BLS. Here's the question: it seems like we'd definitely want to use SHAKE-128 for hash-to-curve, but what about the hash function Thoughts? The suite would probably be defined like this: BLS_SIG_BLS12381G1_XOF:SHAKE-128_SSWU_RO_NUL_:
where BLS12381G1_XOF:SHAKE-128_SSWU_RO_ is a hash-to-curve suite identical to BLS12381G1_XMD:SHA-256_SSWU_RO_ except that expand_message uses the expand_message_xof variant instantiated with SHAKE-128. Does this seem like it would be reasonable for your use-case? Do you prefer SHA3-256 or SHAKE-128 for H? |
ah also cc @mimoo |
if SHAKE is already used in one place, better to use in the other place instead of SHA-3. BTW if you use cSHAKE then you can add a custom string to separate the two use cases. |
Good point about cSHAKE. In hash-to-curve, we want to be able to support any XOF (not just ones that explicitly support customization / domain separation), so we append a prefix-free-encoded domain separation tag. I believe this captures the difference between SHAKE and cSHAKE (but please let me know if this doesn't seem correct). I'll have to give some more thought to a clear way to define BLS's KeyGen in terms of (c)SHAKE. |
It seems more systems start to move to SHA3, since the keccak family gives a more diverse crypto-toolkit (also protection against length-extension attacks), so some projects find themselves in the situation where they need to support both SHA-3 (for their application) and SHA-2 (to comply with the signature standard, e.g. EdDSA). But support for security critical algorithms is quite complex, so it seems advantageous to keep the security-critical code to the bare minimum if possible, e.g. support one hash function instead of two.
Could you elaborate on what was your rational for choosing SHA-2?
The text was updated successfully, but these errors were encountered: