2020-04-17 20:23:30 +00:00
# bls
2019-08-05 15:48:26 +00:00
2019-08-05 18:11:56 +00:00
[![Build Status ](https://travis-ci.org/ChainSafe/lodestar.svg?branch=master )](https://travis-ci.org/ChainSafe/lodestar)
[![codecov ](https://codecov.io/gh/ChainSafe/lodestar/branch/master/graph/badge.svg )](https://codecov.io/gh/ChainSafe/lodestar)
2020-05-21 17:10:46 +00:00
![ETH2.0_Spec_Version 0.12.0 ](https://img.shields.io/badge/ETH2.0_Spec_Version-0.12.0-2e86c1.svg )
2020-07-03 23:05:24 +00:00
![ES Version ](https://img.shields.io/badge/ES-2017-yellow )
![Node Version ](https://img.shields.io/badge/node-12.x-green )
2019-08-05 15:48:26 +00:00
2020-11-25 15:03:11 +00:00
Javascript library for BLS (Boneh-Lynn-Shacham) signatures and signature aggregation.
## Usage
2020-11-25 16:17:48 +00:00
```bash
yarn add @chainsafe/bls
```
2020-11-29 12:21:31 +00:00
To use native bindings you must install peer dependency `@chainsafe/blst`
```bash
yarn add @chainsafe/bls @chainsafe/blst
```
2020-11-25 16:17:48 +00:00
You must initialize the library once in your application before using it. The result is cached and use across all your imports
2020-11-25 15:03:11 +00:00
```ts
2020-11-25 16:09:44 +00:00
import bls, {init} from "@chainsafe/bls";
2020-11-25 15:03:11 +00:00
2020-11-25 16:09:44 +00:00
(async () => {
await init("herumi");
2020-11-25 15:03:11 +00:00
2020-11-25 16:09:44 +00:00
const secretKey = bls.PrivateKey.fromKeygen();
const publicKey = secretKey.toPublicKey();
const message = new Uint8Array(32);
const signature = secretKey.sign(message);
console.log("Is valid: ", signature.verify(publicKey, message));
})();
2020-11-25 15:03:11 +00:00
```
### Browser
2020-11-25 16:17:48 +00:00
If you are in the browser, import from `/browser` to import directly the WASM version
2020-11-25 15:03:11 +00:00
```ts
import bls from "@chainsafe/bls/browser";
```
### Native bindings only
2020-11-25 16:17:48 +00:00
If you are in NodeJS, import from `/node` to skip browser specific code. Also install peer dependency `@chainsafe/blst` which has the native bindings
```bash
yarn add @chainsafe/bls @chainsafe/blst
```
2020-11-25 15:03:11 +00:00
```ts
import bls from "@chainsafe/bls/node";
```
### Native bindings + WASM fallback
2020-11-25 16:17:48 +00:00
If you want to offer a fallback in NodeJS, first try to load native bindings and then fallback to WASM. Also install peer dependency `@chainsafe/blst` which has the native bindings
```bash
yarn add @chainsafe/bls @chainsafe/blst
```
2020-11-25 15:03:11 +00:00
```ts
import bls from "@chainsafe/bls";
try {
await bls.init("blst-native");
} catch (e) {
await bls.init("herumi");
console.warn("Using WASM");
}
```
The API is identical for all implementations.
## Spec versioning
2019-08-05 15:48:26 +00:00
2020-11-04 17:40:36 +00:00
| Version | Bls spec version |
| ------- | :--------------: |
| 2.x.x | draft #7 |
2020-11-25 15:03:11 +00:00
| 1.x.x | draft #6 |
| 0.3.x | initial version |
2020-05-21 17:10:46 +00:00
2020-11-04 17:40:36 +00:00
> [spec](https://github.com/ethereum/eth2.0-specs/blob/v0.11.1/specs/phase0/beacon-chain.md#bls-signatures)
2019-08-05 15:48:26 +00:00
2020-11-04 17:40:36 +00:00
> [test vectors](https://github.com/ethereum/eth2.0-spec-tests/tree/master/tests/bls)
2020-02-25 08:28:47 +00:00
2020-04-17 20:15:17 +00:00
## License
Apache-2.0