/* Copyright 2018 0kims association. This file is part of zksnark JavaScript library. zksnark JavaScript library is a free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. zksnark JavaScript library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with zksnark JavaScript library. If not, see . */ const chai = require("chai"); const fs = require("fs"); const path = require("path"); const bigInt = require("../src/bigint.js"); const Circuit = require("../src/circuit.js"); const zkSnark = require("../index.js"); const BN128 = require("../src/bn128.js"); const PolField = require("../src/polfield.js"); const ZqField = require("../src/zqfield.js"); const {stringifyBigInts, unstringifyBigInts} = require("../src/stringifybigint.js"); const bn128 = new BN128(); const PolF = new PolField(new ZqField(bn128.r)); const G1 = bn128.G1; const G2 = bn128.G2; const assert = chai.assert; describe("zkSnark", () => { it("Load a circuit, create trusted setup, create a proof and validate it", () => { const cirDef = JSON.parse(fs.readFileSync(path.join(__dirname, "circuit", "sum.json"), "utf8")); const cir = new Circuit(cirDef); const setup = zkSnark.setup(cir); const strSetup = stringifyBigInts(setup); fs.writeFileSync("vk_proof.json", JSON.stringify(strSetup.vk_proof), "utf-8"); fs.writeFileSync("vk_verifier.json", JSON.stringify(strSetup.vk_verifier), "utf-8"); function polT2S(p) { const p_T = new Array(setup.vk_proof.domainSize).fill(bigInt(0)); for (let c in p) { p_T[c] = p[c]; } return PolF.ifft(p_T); } /* const setup = {}; setup.vk_proof = unstringifyBigInts(JSON.parse(fs.readFileSync("vk_proof.json", "utf8"))); setup.vk_verifier = unstringifyBigInts(JSON.parse(fs.readFileSync("vk_verifier.json", "utf8"))); */ const witness = cir.calculateWitness({"a": "33", "b": "34"}); const {proof, publicSignals} = zkSnark.genProof(setup.vk_proof, witness); /* const polA = new Array(cir.nVars); const polB = new Array(cir.nVars); const polC = new Array(cir.nVars); for (let i=0; i { const cirDef = JSON.parse(fs.readFileSync(path.join(__dirname, "circuit", "sha256_2.json"), "utf8")); const cir = new Circuit(cirDef); console.log("Start setup: "+Date().toString()); const setup = zkSnark.setup(cir); const strSetup = stringifyBigInts(setup); fs.writeFileSync("sha256_2_vk_proof.json", JSON.stringify(strSetup.vk_proof), "utf-8"); fs.writeFileSync("sha256_2_vk_verifier.json", JSON.stringify(strSetup.vk_verifier), "utf-8"); // const setup = {}; // setup.vk_proof = unstringifyBigInts(JSON.parse(fs.readFileSync("vk_proof.json", "utf8"))); // setup.vk_verifier = unstringifyBigInts(JSON.parse(fs.readFileSync("vk_verifier.json", "utf8"))); const witness = cir.calculateWitness({"a": "1", "b": "2"}); // assert.equal(witness[cir.getSignalIdx("main.out")].toString(), "67"); console.log("Start calculating the proof: "+Date().toString()); const {proof, publicSignals} = zkSnark.genProof(setup.vk_proof, witness); console.log("Start verifiying: "+ Date().toString()); assert( zkSnark.isValid(setup.vk_verifier, proof, publicSignals)); }).timeout(10000000); */ });