This module is built with BLS_ETH=1
for Ethereum 2.0 spec.
{G1,G2}::isValidOrder()
bls.multiVerify
to verify all {sigs, pubs, msgs}.setETHmode(bls.ETH_MODE_DRAFT_07)
is default modeThe version v0.4.2
breaks backward compatibility of the entry point.
const bls = require('bls-eth-wasm')
const bls = require('bls-eth-wasm/browser')
<script src="https://herumi.github.io/bls-eth-wasm/browser/bls.js"></script>
Init as the followings:
bls.init(bls.BLS12_381)
(old) The new eth2.0 functions are supported. This mode will be removed in the future.
Init as the followings:
bls.init(bls.BLS12_381)
then, you can use the following functions.
bls-eth-wasm | eth2.0 spec name |
---|---|
SecretKey::sign | Sign |
PublicKey::verify | Verify |
Sign::aggregate | Aggregate |
Sign::fastAggregateVerify | FastAggregateVerify |
Sign::aggregateVerifyNoCheck | AggregateVerify |
The size of message must be 32 byte.
Check functions:
deserialize
check the correctness of the orderdeserialize
check the correctness of the ordersee bls
Install Emscripten.
cd src
git submodule update --init
make
node test.js
see bls-demo.
See browser/readme.md
to make browser/bls.js
.
const bls = require('bls-eth-wasm/browser')
modified new BSD License http://opensource.org/licenses/BSD-3-Clause
MITSUNARI Shigeo(herumi@nifty.com)