passeremo ai cifrari di vernam precondivisi...
LOL
On 30/01/22 09:41, Alberto Cammozzo via nexa wrote:
<https://soatok.blog/2022/01/27/the-controversy-surrounding-hybrid-cryptography/
<https://soatok.blog/2022/01/27/the-controversy-surrounding-hybrid-cryptography/>>
[...]
Why Hybrid Cryptosystems?
At some point in the future (years or decades from now), humanity may build a practical
quantum computer. This will be a complete disaster for all of the cryptography deployed on
the Internet today.
In response to this distant existential threat, cryptographers have been hard at work
designing and attacking algorithms that remain secure even when quantum computers arrive.
These algorithms are classified as post-quantum cryptography (mostly to distinguish it
from techniques that uses quantum computers to facilitate cryptography rather than attack
it, which is “quantum cryptography” and not really worth our time talking about).
Post-quantum cryptography is often abbreviated as “PQ Crypto” or “PQC”.
However, a lot of the post-quantum cryptography designs are relatively new or
comparatively less studied than their classical (pre-quantum) counterparts. Several of the
Round 1 candidates to NIST’s post quantum cryptography project were broken immediately
(PDF). Exploit code referenced in PDF duplicated below.:
#!/usr/bin/env python3
import binascii, struct
def recover_bit(ct, bit):
assert bit < len(ct) // 4000
ts = [struct.unpack('BB', ct[i:i+2]) for i in range(4000*bit, 4000*(bit+1), 2)]
xs, ys = [a for a, b in ts if b == 1], [a for a, b in ts if b == 2]
return sum(xs) / len(xs) >= sum(ys) / len(ys)
def decrypt(ct):
res = sum(recover_bit(ct, b) << b for b in range(len(ct) // 4000))
return int.to_bytes(res, len(ct) // 4000 // 8, 'little')
kat = 0
for l in open('KAT_GuessAgain/GuessAgainEncryptKAT_2000.rsp'):
if l.startswith('msg = '):
# only used for verifying the recovered plaintext.
msg = binascii.unhexlify(l[len('msg = '):].strip())
elif l.startswith('c = '):
ct = binascii.unhexlify(l[len('c = '):].strip())
print('{}attacking known-answer test #{}'.format('\n' * (kat > 0), kat))
print('correct plaintext: {}'.format(binascii.hexlify(msg).decode()))
plain = decrypt(ct)
print('recovered plaintext: {} ({})'.format(binascii.hexlify(plain).decode(),
plain == msg))
kat += 1
More pertinent to our discussions: Rainbow, which was one of the Round 3 Finalists for
post-quantum digital signature algorithms, was discovered in 2020 to be much easier to
attack than previously thought. Specifically, for the third round parameters, the attack
cost was reduced by a factor of 2^{20}, 2^{40}, and 2^{55}.
That security reduction is just a tad bit more concerning than a Round 1 candidate being
totally broken, since NIST had concluded by then that Rainbow was a good signature
algorithm until that attack was discovered. Maybe there are similar attacks just waiting
to be found?
Given that new cryptography is accompanied by less confidence than incumbent cryptography,
hybrid designs are an excellent way to mitigate the risk of attack advancements in
post-quantum cryptography:
If the security of your system requires breaking the cryptography used today AND breaking
one of the new-fangled designs, you’ll always be at least as secure as the stronger algorithm.
Art: Lynx vs Jackalope
Why Is Hybrid Cryptography Controversial?
Despite the risks of greenfield cryptographic algorithms, the NSA has begun recommending a
strictly-PQ approach to cryptography and have explicitly stated that they will not require
hybrid designs.
Another pushback on hybrid cryptography comes from Uri Blumenthal of MIT’s Lincoln Labs on
the IETF CFRG mailing list (the acronym CRQC expands to “Cryptographically-Relevant
Quantum Computer”):
Here are the possibilities and their relation to the usefulness of the Hybrid
approach.
1. CRQC arrived, Classic hold against classic attacks, PQ algorithms hold –
Hybrid is useless.
2. CRQC arrived, Classic hold against classic attacks, PQ algorithms fail –
Hybrid is useless.
3. CRQC arrived, Classic broken against classic attacks, PQ algorithms hold – Hybrid is
useless.
4. CRQC arrived, Classic hold against classic attacks, PQ algorithms broken –
Hybrid useless.
5. CRQC doesn’t arrive, Classic hold against classic attacks, PQ algorithms hold – Hybrid
is useless.
6. CRQC doesn’t arrive, Classic hold against classic attacks, PQ algorithms broken –
Hybrid helps.
7. CRQC doesn’t arrive, Classic broken against classic attacks, PQ algorithms hold –
Hybrid is useless.
8. CRQC doesn’t arrive, Classic broken against classic attacks, PQ algorithms broken –
Hybrid is useless.
Uri Blumenthal, IETF CFRG mailing list, December 2021 (link)
Why Hybrid Is Actually A Damn Good Idea
Art: Scruff Kerfluff
Uri’s risk analysis is, of course, flawed. And I’m not the first to disagree
with him.
First, Uri’s framing sort of implies that each of the 8 possible outputs of these 3
boolean variables are relatively equally likely outcomes.
It’s very tempting to look at this and think, “Wow, that’s a lot of work for something
that only helps in 12.5% of possible outcomes!” Uri didn’t explicitly state this
assumption, and he might not even believe that, but it is a cognitive trap that emerges in
the structure of his argument, so watch your step.
Second, for many candidate algorithms, we’re already in scenario 6 that Uri outlined! It’s
not some hypothetical future, it’s the present state of affairs.
To wit: The advances in cryptanalysis on Rainbow don’t totally break it in a practical
sense, but they do reduce the security by a devastating margin (which will require
significantly larger parameter sets and performance penalties to remedy).
For many post-quantum algorithms, we’re still uncertain about which scenario is most
relevant. But since PQ algorithms are being successfully attacked and a quantum computer
still hasn’t arrived, and classical algorithms are still holding up fine, it’s very clear
that “hybrid helps” is the world we most likely inhabit today, and likely will for many
years (until the existence of quantum computers is finally settled).
Finally, even in other scenarios (which are more relevant for other post-quantum
algorithms), hybrid doesn’t significantly hurt security. It does carry a minor cost to
bandwidth and performance, and it does mean having a larger codebase to review when
compared with jettisoning the algorithms we use today, but I’d argue that the existing
code is relatively low risk compared to new code.
From what I’ve read, the NSA didn’t make as strong an argument as Uri; they said hybrid
would not be required, but didn’t go so far as to attack it.
Hybrid cryptography is a long-term bet that will protect the most users from cryptanalytic
advancements, contrasted with strictly-PQ and no-PQ approaches.
Why The Hybrid Controversy Remains Unsettled
Even if we can all agree that hybrid is the way to go, there’s still significant
disagreement on exactly how to do it.
Hybrid KEMs
There are two schools of thought on hybrid Key Encapsulation Mechanisms (KEMs):
Wrap the post-quantum KEM in the encrypted channel created by the classical KEM.
Use both the post-quantum KEM and classical KEM as inputs to a secure KDF, then use a
single encrypted channel secured by both.
The first option (layered) has the benefit of making migrations smoother. You can begin
with classical cryptography (i.e. ECDHE for TLS ciphersuites), which is what most systems
online support today. Then you can do your post-quantum cryptography inside the existing
channel to create a post-quantum-secure channel. This also lends toward opportunistic
upgrades (which might not be a good idea).
The second option (composite) has the benefit of making the security of your protocol
all-or-nothing: You cannot attack the weak now and the strong part later. The session keys
you’ll derive require attacking both algorithms in order to get access to the plaintext.
Additionally, you only need a single layer. The complexity lies entirely within the
handshake, instead of every packet.
Personally, I think composite is a better option for security than layered.
Hybrid Signatures
There are, additionally, two different schools of thought on hybrid digital signature
algorithms. However, the difference is more subtle than with KEMs.
Require separate classical signatures and post-quantum signatures.
Specify a composite mode that combines the two together and treat it as a
distinct algorithm.
To better illustrate what this looks like, I outlined what a composite hybrid digital
signature algorithm could look like on the CFRG mailing list:
primary_seed := randombytes_buf(64) // store this
ed25519_seed := hash_sha512256(PREFIX_CLASSICAL || primary_seed)
pq_seed := hash_sha512256(PREFIX_POSTQUANTUM || primary_seed)
ed25519_keypair := crypto_sign_seed_keypair(ed25519_seed)
pq_keypair := pqcrypto_sign_seed_keypair(pq_seed)
Your composite public key would be your Ed25519 public key, followed by your post-quantum
public key. Since Ed25519 public keys are always 32 bytes, this is easy to implement securely.
Every composite signature would be an Ed25519 signature concatenated with the post-quantum
signature. Since Ed25519 signatures are always 64 bytes, this leads to a predictable
signature size relative to the post-quantum signature.
The main motivation for preferring a composite hybrid signature over a detached hybrid
signature is to push the hybridization of cryptography lower in the stack so developers
don’t have to think about these details. They just select HYBRIDSIG1 or HYBRIDSIG2 in
their ciphersuite configuration, and cryptographers get to decide what that means.
TL;DR
Hybrid designs of post-quantum crypto are good, and I think composite hybrid designs make
the most sense for both KEMs and signatures.
_______________________________________________
nexa mailing list
[email protected]
https://server-nexa.polito.it/cgi-bin/mailman/listinfo/nexa
_______________________________________________
nexa mailing list
[email protected]
https://server-nexa.polito.it/cgi-bin/mailman/listinfo/nexa