-
Notifications
You must be signed in to change notification settings - Fork 481
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
Support NIST validation criteria for Edwards points #626
Comments
I like the latter style. Maybe called |
Until this gets implemented, I would like to write code that conforms to the NIST criteria when validating a use curve25519_dalek::edwards::CompressedEdwardsY;
pub fn nist_verify(bytes: [u8; 32]) -> bool {
// MUST ensure `bytes.len() == 32` before calling.
const fn x_is_neg(bytes: &[u8]) -> bool {
bytes[31] > 127
}
// MUST ensure `bytes.len() == 32` before calling.
// MUST ensure `x_is_neg(bytes)` returns `false` as well since we assume the sign bit is not set.
fn y_is_one(bytes: &[u8]) -> bool {
const fn is_zero(byte: &u8) -> bool {
*byte == 0
}
bytes[0] == 1 && bytes[1..].into_iter().all(is_zero)
}
// MUST ensure `bytes.len() == 32` before calling.
// MUST ensure `x_is_neg(bytes)` returns `false` as well since we assume the sign bit is not set.
fn y_is_too_great(bytes: &[u8]) -> bool {
const fn is_255(byte: &u8) -> bool {
*byte == 255
}
bytes[0] > 236 && bytes[31] == 127 && bytes[1..31].into_iter().all(is_255)
}
let slice = bytes.as_slice();
// Ensures x > -1, (x, y) ≠ (0, 1), and y ∈ [0, 2^255 - 20].
!(x_is_neg(slice) || y_is_one(slice) || y_is_too_great(slice))
&& CompressedEdwardsY(bytes)
// Ensures the point is on the curve.
.decompress()
.map_or(false, |point| {
// Ensures the point belongs to the prime order subgroup.
point.is_torsion_free()
})
} |
Removes the previous warning that points are unvalidated: they're validated using the ZIP-215 rules, which allows unreduced y-coordinates. Points are ensured valid by performing decompression, which finds a solution to the curve equation, or returns an error. Adds references to ZIP-215 and #626 which is an issue about potentially adding support for the RFC8032/NIST validation criteria in the future.
Removes the previous warning that points are unvalidated: they're validated using the ZIP-215 rules, which allows unreduced y-coordinates. Points are ensured valid by performing decompression, which finds a solution to the curve equation, or returns an error. Adds references to ZIP-215 and #626 which is an issue about potentially adding support for the RFC8032/NIST validation criteria in the future.
The current implementation uses ZIP-215 rules. We've received requests for stricter validation (#380, #623) which correspond to the NIST validation criteria, namely ensuring that the Edwards y-coordinate doesn't overflow the field modulus, and that the resulting point belongs to the prime order subgroup, which map to the NIST partial and full public key validation rules respectively.
NIST defines public key validation criteria in SP 800-186 Appendix D.1.3: Twisted Edwards Curves:
Some possibilities for APIs:
EdwardsPoint::decompress_nist_partial
/EdwardsPoint::decompress_nist_full
EdwardsPoint::decompress_with(PointValidation::NistPartial)
The text was updated successfully, but these errors were encountered: