JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 1505
  • Score
    100M100P100Q137331F
  • License Apache-2.0

Typescript wrapper for supranational/blst native bindings, a highly performant BLS12-381 signature library

Package Exports

  • @chainsafe/blst
  • @chainsafe/blst/dist/lib/index.js

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 (@chainsafe/blst) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

blst-ts

ETH2.0_Spec_Version 0.12.0 ES Version Node Version

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)); // true

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