Skip to content

Typescript wrapper for https://github.com/supranational/blst native bindings, a highly performant BLS12-381 signature library

License

Notifications You must be signed in to change notification settings

ChainSafe/blst-ts

Folders and files

NameName
Last commit message
Last commit date

Latest commit

1c0711b · Oct 29, 2024
Jul 26, 2024
Oct 22, 2024
Jul 22, 2024
Jun 1, 2023
Oct 29, 2024
Oct 29, 2024
Oct 29, 2024
Jan 6, 2024
Jul 22, 2024
Jul 22, 2024
Nov 28, 2020
Jul 22, 2024
Apr 5, 2021
Jul 22, 2024
Oct 22, 2024
Jul 22, 2024
Jul 22, 2024
Jul 22, 2024
Oct 29, 2024
Oct 29, 2024
Oct 29, 2024
Jul 22, 2024
Jul 22, 2024
Jul 22, 2024
Jul 22, 2024

Repository files navigation

blst-ts

ETH2.0_Spec_Version 1.4.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

This library exposes a classes for secret keys, public keys and signatures: SecretKey, PublicKey & Signature

The PublicKey and Signature contain an affine point (x,y) encoding of P1 in G1 and P2 in G2 respectively.

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

Release

The release process is automatically triggered when the master branch has the version in package.json updated.

To create a new release:

  1. Increment the project version in package.json
    • A pre-release can be published by ensuring that the project version is appended with non-numeric characters, eg: -beta
  2. run yarn run version
  3. merge a commit with these changes
  4. CI will run and result in a new release being published

License

Apache-2.0