Socket
Socket
Sign inDemoInstall

@chainsafe/blst

Package Overview
Dependencies
Maintainers
4
Versions
25
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@chainsafe/blst

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


Version published
Weekly downloads
1.1K
decreased by-19.69%
Maintainers
4
Weekly downloads
 
Created
Source

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.

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 { SecretKey, verify } from "@chainsafe/blst";

const msg = Buffer.from("sample-msg");
const sk = SecretKey.fromKeygen(Buffer.alloc(32, 1));
const pk = sk.toPublicKey();
const sig = sk.sign(msg);

console.log(verify(msg, pk, sig)); // true

This library exposes two types of classes for public keys and signatures: PublicKey & AggregatePublicKey, Signature & AggregateSignature

  • PublicKey: Contains an affine point (x,y). It's the default representation of the point and what you need to serialize to and deserialize from.
  • AggregatePublicKey: Contains a jacobian point (x,y,z). It's optimal to perform aggregation operations.

Spec versioning

This library has a hardcoded configuration compatible with Eth2.0 spec:

Settingvalue
PK_ING1
HASH_OR_ENCODEtrue
DSTBLS_SIG_BLS12381G2_XMD:SHA-256_SSWU_RO_POP_
RAND_BITS64

spec

test vectors

License

Apache-2.0

FAQs

Package last updated on 22 Dec 2020

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc