From 391d019a42a3ef38d3e328c7d9e05e606bd5faad Mon Sep 17 00:00:00 2001 From: vnxme <46669194+vnxme@users.noreply.github.com> Date: Sat, 28 Dec 2024 10:57:32 +0300 Subject: [PATCH] Use random.SystemRandom().randint instead of toyecc.Random.secure_rand_int_between --- mikro.py | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/mikro.py b/mikro.py index 5cede9a3..5dfd50c9 100644 --- a/mikro.py +++ b/mikro.py @@ -1,8 +1,7 @@ - +import random import struct from sha256 import SHA256 from toyecc import AffineCurvePoint, getcurvebyname, FieldElement,ECPrivateKey,ECPublicKey,Tools -from toyecc.Random import secure_rand_int_between MIKRO_BASE64_CHARACTER_TABLE = b'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/' @@ -167,7 +166,7 @@ def mikro_kcdsa_sign(data:bytes,private_key:bytes)->bytes: private_key:ECPrivateKey = ECPrivateKey(Tools.bytestoint_le(private_key), curve) public_key:ECPublicKey = private_key.pubkey while True: - nonce_secret = secure_rand_int_between(1, curve.n - 1) + nonce_secret = random.SystemRandom().randint(1, curve.n - 1) nonce_point = nonce_secret * curve.G nonce = int(nonce_point.x) % curve.n nonce_hash = mikro_sha256(Tools.inttobytes_le(nonce,32))