From 882aebe80e5ca64d9f2044082b6151f2439bee18 Mon Sep 17 00:00:00 2001 From: Artem Skriabin Date: Fri, 3 Jan 2025 20:30:12 +0200 Subject: [PATCH] Put more info into error if signature len is not 64 --- internal/types/signature_algorithm.go | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/internal/types/signature_algorithm.go b/internal/types/signature_algorithm.go index 8b478df..4d3f235 100644 --- a/internal/types/signature_algorithm.go +++ b/internal/types/signature_algorithm.go @@ -5,6 +5,7 @@ import ( "crypto/ecdsa" "crypto/rsa" "encoding/asn1" + "fmt" "hash" "math/big" @@ -62,7 +63,7 @@ func verifyECDSA(data, sig []byte, publicKey *ecdsa.PublicKey) error { // Handle raw (r || s) signature format if len(sig) != 64 { - return errors.New("invalid ECDSA signature length") + return fmt.Errorf("ECDSA signature length is not 64, but %d, with key %s", len(sig), publicKey.Curve.Params().Name) } r, s := new(big.Int).SetBytes(sig[:32]), new(big.Int).SetBytes(sig[32:])