2642595e39
* refactor(node-bindings): create src/lib/test folders * feat(node-bindings): update bundle/publish commands * refactor(node-bindings): remove unused files and dependencies * refactor(node-bindings): move fixtures to __fixtures__ * fix(node-bindings): revert format of fixture json file * fix(node-bindings): prettierignore and gitignore * feat(node-bindings): add bindings package * fix(node-bindings): fix test setup path * fix(node-bindings): remove post-build copy action in bindings.gyp * fix(node-bindings): package.json keys * Update contributors --------- Co-authored-by: George Kadianakis <desnacked@riseup.net> |
||
---|---|---|
.. | ||
lib | ||
src | ||
test | ||
.gitignore | ||
.prettierignore | ||
.prettierrc.json | ||
Dockerfile | ||
Makefile | ||
README.md | ||
binding.dist.gyp | ||
binding.gyp | ||
jest.config.js | ||
package.json | ||
tsconfig.build.json | ||
tsconfig.json | ||
yarn.lock |
README.md
This package wraps the c-kzg C code in C++ NAPI bindings which allow it to be imported into a NodeJS program.
Spec: https://github.com/ethereum/consensus-specs/blob/dev/specs/eip4844/polynomial-commitments.md
Usage
Install this library with
yarn add c-kzg
Import from it like any other library
import {
KZGCommitment,
blobToKzgCommitment,
verifyAggregateKzgProof,
loadTrustedSetup,
transformTrustedSetupJSON,
} from "c-kzg";
Requirements
The C and C++ code is compiled by node-gyp on installation. Your environment will need
- A compiler like g++ or clang
make
python3
Contributing
This directory contains the code necessary to generate NodeJS bindings for C-KZG.
The bindings file has the following interface:
loadTrustedSetup: (filePath: string) => SetupHandle;
freeTrustedSetup: (setupHandle: SetupHandle) => void;
blobToKzgCommitment: (blob: Blob, setupHandle: SetupHandle) => KZGCommitment;
computeAggregateKzgProof: (
blobs: Blob[],
setupHandle: SetupHandle
) => KZGProof;
verifyAggregateKzgProof: (
blobs: Blob[],
expectedKzgCommitments: KZGCommitment[],
kzgAggregatedProof: KZGProof,
setupHandle: SetupHandle
) => boolean;
But this library wraps it in module with manages the setupHandle internally.
First,
npm install -g yarn
if you don't have it.
Install the blst submodule
git submodule update --init
Build blst and c_kzg_4844.c
cd src && make blst lib
Generate NodeJS bindings and run the TypeScript tests against them
cd ../bindings/node.js && yarn install && make test
After doing this once, you can re-build (if necessary) and re-run the tests with
make build test
After making changes, regenerate the distributable JS and type defs
make bundle