data:image/s3,"s3://crabby-images/3d0af/3d0afd587cb19c447789e031c5bb5d844d22a3ff" alt="Elliptic Curve Digital Signature Algorithm"
Getting your Trinity Audio player ready...
|
This post was first published on Medium.
We have implemented ECDSA signature verification algorithm in Script. It can verify if an arbitrary message is signed by a private key corresponding to a given public key, while OP_CHECKSIG can only verify signatures when the message is the current spending transaction¹. Surprisingly, this is done without introducing any new opcode such as OP_DATASIGVERIFY (aka, OP_CHECKDATASIG) on BCH.
Elliptic Curve Digital Signature Algorithm (ECDSA)
ECDSA is the algorithm used in Bitcoin for signature generation and verification. The verification algorithm is listed below.
data:image/s3,"s3://crabby-images/63d08/63d08b6650713e084a335fa0022d0fd368bab00d" alt=""
Implementation
We have implemented the algorithm as shown below, using the elliptic curve library we released before.
First, we need to extract r and s components from the signature, which is encoded in DER format. Since they are big-endian, we have to convert to little-endian, which is how data is encoded in Script/sCrypt.
data:image/s3,"s3://crabby-images/eeefa/eeefaa8d3352baf3f50f3307159a28999504f38b" alt=""
After r and s are retrieved, we simply run the standard ECDSA verification algorithm.
***
NOTE:
[1] More precisely, it verifies signature against sighash.