Package Exports
- tiny-secp256k1-wasm
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (tiny-secp256k1-wasm) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
tiny-secp256k1-wasm
This library is under heavy development. Currently only supports nodejs environment.
Installation
npm
npm install tiny-secp256k1-wasmyarn
yarn add tiny-secp256k1-wasmDocumentation
isPoint (A)
isPoint :: Buffer -> BoolReturns false if
- Ais not encoded with a sequence tag of- 0x02,- 0x03or- 0x04
- A.xis not in- [1...p - 1]
- A.yis not in- [1...p - 1]
isPointCompressed (A)
isPointCompressed :: Buffer -> BoolReturns false if the signature is not compressed.
isPrivate (d)
isPrivate :: Buffer -> BoolReturns false if
- dis not 256-bit, or
- dis not in- [1..order - 1]
pointAdd (A, B[, compressed])
pointAdd :: Buffer -> Buffer [-> Bool] -> Maybe BufferReturns null if result is at infinity.
Throws:
- Expected Pointif- !isPoint(A)
- Expected Pointif- !isPoint(B)
pointAddScalar (A, tweak[, compressed])
pointAddScalar :: Buffer -> Buffer [-> Bool] -> Maybe BufferReturns null if result is at infinity.
Throws:
- Expected Pointif- !isPoint(A)
- Expected Tweakif- tweakis not in- [0...order - 1]
pointCompress (A, compressed)
pointCompress :: Buffer -> Bool -> BufferThrows:
- Expected Pointif- !isPoint(A)
pointFromScalar (d[, compressed])
pointFromScalar :: Buffer [-> Bool] -> Maybe BufferReturns null if result is at infinity.
Throws:
- Expected Privateif- !isPrivate(d)
pointMultiply (A, tweak[, compressed])
pointMultiply :: Buffer -> Buffer [-> Bool] -> Maybe BufferReturns null if result is at infinity.
Throws:
- Expected Pointif- !isPoint(A)
- Expected Tweakif- tweakis not in- [0...order - 1]
privateAdd (d, tweak)
privateAdd :: Buffer -> Buffer -> Maybe BufferReturns null if result is equal to 0.
Throws:
- Expected Privateif- !isPrivate(d)
- Expected Tweakif- tweakis not in- [0...order - 1]
privateSub (d, tweak)
privateSub :: Buffer -> Buffer -> Maybe BufferReturns null if result is equal to 0.
Throws:
- Expected Privateif- !isPrivate(d)
- Expected Tweakif- tweakis not in- [0...order - 1]
sign (h, d)
sign :: Buffer -> Buffer -> BufferReturns normalized signatures, each of (r, s) values are guaranteed to less than order / 2.
Uses RFC6979.
Throws:
- Expected Privateif- !isPrivate(d)
- Expected Scalarif- his not 256-bit
signWithEntropy (h, d, e)
sign :: Buffer -> Buffer -> Buffer -> BufferReturns normalized signatures, each of (r, s) values are guaranteed to less than order / 2.
Uses RFC6979.
Adds e as Added Entropy to the deterministic k generation.
Throws:
- Expected Privateif- !isPrivate(d)
- Expected Scalarif- his not 256-bit
- Expected Extra Data (32 bytes)if- eis not 256-bit
verify (h, Q, signature[, strict = false])
verify :: Buffer -> Buffer -> Buffer -> BoolReturns false if any of (r, s) values are equal to 0,  or if the signature is rejected.
If strict is true, valid signatures with any of (r, s) values greater than order / 2 are rejected.
Throws:
- Expected Pointif- !isPoint(Q)
- Expected Signatureif- signaturehas any (r, s) values not in range- [0...order - 1]
- Expected Scalarif- his not 256-bit
Credit
This library uses rust-secp256k1 to access the native library secp256k1 by the bitcoin-core developers, including derivatives of its tests and test vectors.
Special thanks go to yuki-js, wg-wasm and beginners channel on the Rust Discord, and #rust-bitcoin on freenode IRC.