You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

87 lines
2.9 KiB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
  1. /*
  2. Copyright 2018 0kims association.
  3. This file is part of zksnark JavaScript library.
  4. zksnark JavaScript library is a free software: you can redistribute it and/or
  5. modify it under the terms of the GNU General Public License as published by the
  6. Free Software Foundation, either version 3 of the License, or (at your option)
  7. any later version.
  8. zksnark JavaScript library is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
  10. or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  11. more details.
  12. You should have received a copy of the GNU General Public License along with
  13. zksnark JavaScript library. If not, see <https://www.gnu.org/licenses/>.
  14. */
  15. const chai = require("chai");
  16. const fs = require("fs");
  17. const path = require("path");
  18. const bigInt = require("../src/bigint.js");
  19. const Circuit = require("../src/circuit.js");
  20. const zkSnark = require("../index.js");
  21. const assert = chai.assert;
  22. function stringifyBigInts(o) {
  23. if ((typeof(o) == "bigint") || (o instanceof bigInt)) {
  24. return o.toString(10);
  25. } else if (Array.isArray(o)) {
  26. return o.map(stringifyBigInts);
  27. } else if (typeof o == "object") {
  28. const res = {};
  29. for (let k in o) {
  30. res[k] = stringifyBigInts(o[k]);
  31. }
  32. return res;
  33. } else {
  34. return o;
  35. }
  36. }
  37. function unstringifyBigInts(o) {
  38. if ((typeof(o) == "string") && (/^[0-9]+$/.test(o) )) {
  39. return bigInt(o);
  40. } else if (Array.isArray(o)) {
  41. return o.map(unstringifyBigInts);
  42. } else if (typeof o == "object") {
  43. const res = {};
  44. for (let k in o) {
  45. res[k] = unstringifyBigInts(o[k]);
  46. }
  47. return res;
  48. } else {
  49. return o;
  50. }
  51. }
  52. describe("zkSnark", () => {
  53. it("Load a circuit, create trusted setup, create a proof and validate it", () => {
  54. const cirDef = JSON.parse(fs.readFileSync(path.join(__dirname, "circuit", "sum.json"), "utf8"));
  55. const cir = new Circuit(cirDef);
  56. const setup = zkSnark.setup(cir);
  57. const strSetup = stringifyBigInts(setup);
  58. fs.writeFileSync("vk_proof.json", JSON.stringify(strSetup.vk_proof), "utf-8");
  59. fs.writeFileSync("vk_verifier.json", JSON.stringify(strSetup.vk_verifier), "utf-8");
  60. /*
  61. const setup = {};
  62. setup.vk_proof = unstringifyBigInts(JSON.parse(fs.readFileSync("vk_proof.json", "utf8")));
  63. setup.vk_verifier = unstringifyBigInts(JSON.parse(fs.readFileSync("vk_verifier.json", "utf8")));
  64. */
  65. const witness = cir.calculateWitness({"a": "33", "b": "34"});
  66. assert.equal(witness[cir.getSignalIdx("main.out")].toString(), "67");
  67. const {proof, publicSignals} = zkSnark.genProof(setup.vk_proof, witness);
  68. assert( zkSnark.isValid(setup.vk_verifier, proof, publicSignals));
  69. }).timeout(10000000);
  70. });