From 0b8d67411c4498f03a6e4a5793951aae4dd010b4 Mon Sep 17 00:00:00 2001 From: larabr <7375870+larabr@users.noreply.github.com> Date: Thu, 2 Nov 2023 18:59:12 +0100 Subject: [PATCH] Fix ML-KEM sizes --- src/crypto/crypto.js | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/crypto/crypto.js b/src/crypto/crypto.js index f7b6d1157..41edf7945 100644 --- a/src/crypto/crypto.js +++ b/src/crypto/crypto.js @@ -240,7 +240,7 @@ export function parsePublicKeyParams(algo, bytes) { } case enums.publicKey.pqc_mlkem_x25519: { const eccPublicKey = util.readExactSubarray(bytes, read, read + getCurvePayloadSize(enums.publicKey.x25519)); read += eccPublicKey.length; - const mlkemPublicKey = util.readExactSubarray(bytes, read, read + (1184 / 8)); read += mlkemPublicKey.length; + const mlkemPublicKey = util.readExactSubarray(bytes, read, read + 1184); read += mlkemPublicKey.length; return { read, publicParams: { eccPublicKey, mlkemPublicKey } }; } default: @@ -313,7 +313,7 @@ export function parsePrivateKeyParams(algo, bytes, publicParams) { } case enums.publicKey.pqc_mlkem_x25519: { const eccSecretKey = util.readExactSubarray(bytes, read, read + getCurvePayloadSize(enums.publicKey.x25519)); read += eccSecretKey.length; - const mlkemSecretKey = util.readExactSubarray(bytes, read, read + (2400 / 8)); read += mlkemSecretKey.length; + const mlkemSecretKey = util.readExactSubarray(bytes, read, read + 2400); read += mlkemSecretKey.length; return { read, privateParams: { eccSecretKey, mlkemSecretKey } }; } default: @@ -381,7 +381,7 @@ export function parseEncSessionKeyParams(algo, bytes) { } case enums.publicKey.pqc_mlkem_x25519: { const eccCipherText = util.readExactSubarray(bytes, read, read + getCurvePayloadSize(enums.publicKey.x25519)); read += eccCipherText.length; - const mlkemCipherText = util.readExactSubarray(bytes, read, read + (1088 / 8)); read += mlkemCipherText.length; + const mlkemCipherText = util.readExactSubarray(bytes, read, read + 1088); read += mlkemCipherText.length; const C = new ShortByteString(); read += C.read(bytes.subarray(read)); return { eccCipherText, mlkemCipherText, C }; // eccCipherText || mlkemCipherText || len(C) || C }