Tari Crypto

Coverage Status

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.

Compiling to WebAssembly

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"

If you receive compoiler errors related to clear_on_drop, then add the no_cc or no_cc_nightly feature flags.

Note: Node v10+ is needed for the WASM

Example (Node.js)

```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(); ````

Benchmarks

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"

Change log

v0.11.0

Clients of this generally only need to update the result method to finalize; and obviously make use of the v0.9 digest::Digest trait where necessary.

As a result, the deprecated k12, sha3 and Blake3 objects have been removed. Methods and functins that need a hasher are all generic over Digest.

We retain the convenience wrapper over VarBlake2B to produce 256 bit hashes and implement the necessary sub-traits to support digest::Digest.

v0.10.0

Updated dependencies such that Rust stable 1.53 is now supported. The optimised avx_2 option will NOT rust on stable because there's still an unstable feature on subtle-ng. BUT this feature is actually for doc generation and has been removed from Rust. As soon as subtle-ng merges https://github.com/dalek-cryptography/subtle/pull/85, avx2 will probably be supported on stable as well.

v0.2.0

General

WASM module

Building the C FFI module

To build the C bindings, you can run

make ffi

To build the release version (recommended):

make ffi-release

To run the small demo:

make demo
./bin/demo