falcon512-js
v2.0.2
Published
Optimized Falcon-512 signature scheme for JS/WebAssembly (node + web)
Downloads
427
Maintainers
Readme
Falcon512 JS Library
Efficient Falcon-512 post-quantum safe digital signature algorithm commonJS lib using WebAssembly.
This library wraps the original Falcon-512 C implementation compiled to WebAssembly via Emscripten. It exposes a simple Node.js class interface to sign and verify data using Falcon512 (compressed sig type).
Requirements
Node.js
Usage
API
- Falcon512.instance(): async singleton loader.
- genkeys(seed?): generate Falcon512 key pair (optionally provide seed).
- sign(privateKey, message, seed?): sign data.
- verify(publicKey, signature, message): verify data.
Example usage
const crypto = require("crypto");
const { Falcon512 } = require("./index.js");
(async () => {
const falcon = await Falcon512.instance();
// Generate keypair
const { sk, pk } = falcon.genkeys();
// Sign data
const message = crypto.randomBytes(32);
const signature = falcon.sign(sk, message);
// Verify
const valid = falcon.verify(pk, signature, message);
console.log("Valid signature:", valid);
})();Development
Requirements
python(>= 3.8)emcc(4.0.10) (Emscripten compiler) to build the WASM module
Installing Emscripten
git clone https://github.com/emscripten-core/emsdk.git
cd emsdk
./emsdk install latest
./emsdk activate latest
source ./emsdk_env.shBuilding WebAssembly
npm run buildBenchmarks
📊 Falcon512 Keygen
- Bench: 1000 runs, 9092.262 ms total
- Avg per call: 9.092262 ms
- Calls/sec: 109.98 ops/sec
📊 Falcon512 Sign
- Bench: 1000 runs, 412.513 ms total
- Avg per call: 0.412513 ms
- Calls/sec: 2424.16 ops/sec
📊 Falcon512 Verify
- Bench: 1000 runs, 38.885 ms total
- Avg per call: 0.038885 ms
- Calls/sec: 25717.08 ops/sec
Note: Results may differ depending on the execution environment, you can run your own benchmarks following below instructions.
npm run benchmarkDisclaimer
This codebase is not audited. Use at your own risk.
Credits
- Falcon512 spec: https://falcon-sign.info/
- Emscripten: https://emscripten.org
- GramThanos: https://github.com/GramThanos/falcon.js
