This crate is part of the Tari Cryptocurrency project.
Major features of this library include:
The tari_crypto
crate makes heavy use of the excellent Dalek
libraries. The default implementation for Tari ECC is the Ristretto255 curve.
To build the WebAssembly module, the wasm
feature must be enabled:
$ wasm-pack build . -- --features "wasm"
To generate a module for use in node.js, use this command:
$ wasm-pack build --target nodejs -d tari_js . -- --features "wasm"
```js const keys = KeyRing.new();
// Create new keypair
keys.newkey("Alice");
keys.newkey("Bob");
console.log(${keys.len()} keys in ring
); // 2
console.log("kA = ", keys.privatekey("Alice"));
console.log("PB = ", keys.publickey("Bob"));
keys.free();
````
To run the benchmarks:
$ cargo bench
The benchmarks use Criterion and will produce nice graphs (if you have gnuplot installed)
To run the benchmarks with SIMD instructions:
$ cargo bench --features "avx2"
KeyRing.sign
doesn't take a nonce any more. It's not needed, and why risk someone re-using it?key_utils.sign
to sign keys not in the key ring