blst-ts
Typescript wrapper for supranational/blst native bindings, a highly performant BLS12-381 signature library.
Supported Environments
OS / Arch | binary name | Node |
---|
Linux / x64 | linux-x64 | 16, 18, 20, 21 |
Linux / arm64 | linux-arm64 | 16, 18, 20, 21 |
Windows / x64 | win32-x64 | 16, 18, 20, 21 |
macOS / x64 | darwin-x64 | 16, 18, 20, 21 |
macOS / arm64 | darwin-arm64 | 16, 18, 20, 21 |
Usage
yarn add @chainsafe/blst
This library comes with pre-compiled bindings for most platforms. You can check current support in releases. If your platform is not supported, bindings will be compiled from source as a best effort with node-gyp.
import crypto from "crypto";
import {SecretKey, verify, BLST_CONSTANTS} from "@chainsafe/blst";
const msg = Buffer.from("sample-msg");
const sk = SecretKey.fromKeygen(crypto.randomBytes(BLST_CONSTANTS.SECRET_KEY_LENGTH));
const pk = sk.toPublicKey();
const sig = sk.sign(msg);
console.log(verify(msg, pk, sig));
Spec versioning
This library has a hardcoded configuration compatible with Eth2.0 spec:
Setting | value |
---|
PK_IN | G1 |
HASH_OR_ENCODE | true |
DST | BLS_SIG_BLS12381G2_XMD:SHA-256_SSWU_RO_POP_ |
RAND_BITS | 64 |
spec
test vectors
Contributing
Please check out CONTRIBUTING.md for more info on how to use the repo and for architectural details
Release/Publishing
The release process is automatically triggered when a change to the version in package.json is merged to master. See CONTRIBUTING.md for more specifics about how the release and package are built.
License
Apache-2.0