tornado-core/scripts/test_snark.js

62 lines
1.6 KiB
JavaScript
Raw Normal View History

2019-07-12 22:52:10 +02:00
const assert = require('assert');
2019-07-12 18:34:25 +02:00
const snarkjs = require("snarkjs");
const bigInt = snarkjs.bigInt;
const utils = require("./utils");
const merkleTree = require('../lib/MerkleTree');
function generateDeposit() {
let deposit = {
secret: utils.rbigint(31),
nullifier: utils.rbigint(31),
};
const preimage = Buffer.concat([deposit.nullifier.leInt2Buff(32), deposit.secret.leInt2Buff(32)]);
deposit.commitment = utils.pedersenHash(preimage);
return deposit;
}
(async () => {
2019-07-13 13:57:49 +02:00
// === Create 3 deposits ===
2019-07-12 18:34:25 +02:00
const dep1 = generateDeposit();
const dep2 = generateDeposit();
const dep3 = generateDeposit();
const tree = new merkleTree(16);
2019-07-12 18:34:25 +02:00
await tree.insert(dep1.commitment);
await tree.insert(dep2.commitment);
await tree.insert(dep3.commitment);
2019-07-13 13:57:49 +02:00
// === Withdrawing deposit 2 ===
2019-07-12 18:34:25 +02:00
const {root, path_elements, path_index} = await tree.path(1);
// Circuit input
2019-07-12 22:52:10 +02:00
const input = {
2019-07-12 18:34:25 +02:00
// public
root: root,
nullifier: dep2.nullifier,
receiver: utils.rbigint(20),
fee: bigInt(1e17),
// private
secret: dep2.secret,
pathElements: path_elements,
pathIndex: path_index,
2019-07-12 22:52:10 +02:00
};
2019-07-12 18:34:25 +02:00
console.log("Input:\n", input);
console.time("Time");
const proof = await utils.snarkProof(input);
console.log("Proof:\n", proof);
console.timeEnd("Time");
2019-07-12 22:52:10 +02:00
const verify = await utils.snarkVerify(proof);
assert(verify);
// try to cheat with recipient
proof.publicSignals[2] = '0x000000000000000000000000000000000000000000000000000000000000beef';
const verifyScam = await utils.snarkVerify(proof);
assert(!verifyScam);
console.log("Done.");
2019-07-12 18:34:25 +02:00
})();