diff --git a/calcpedersenbases/calcpedersenbases.js b/calcpedersenbases/calcpedersenbases.js index c7ae74c..b24842a 100644 --- a/calcpedersenbases/calcpedersenbases.js +++ b/calcpedersenbases/calcpedersenbases.js @@ -1,14 +1,15 @@ const bn128 = require("snarkjs").bn128; const bigInt = require("snarkjs").bigInt; const createBlakeHash = require("blake-hash"); -const assert = require("assert"); const babyJub = require("../src/babyjub"); function getPoint(S) { const F = bn128.Fr; const h = createBlakeHash("blake256").update(S).digest(); - assert(h.length == 32); + if (h.length != 32) { + throw new Error("Invalid length") + } let sign = false; if (h[31] & 0x80) { @@ -52,7 +53,9 @@ function generatePoint(S) { p = getPoint(S+"_"+sidx); idx++; } - assert(babyJub.inCurve(p), "Point not in curve"); + if (!babyJub.inCurve(p)){ + throw new Error("Point not in curve"); + } return p; } diff --git a/index.js b/index.js index e3d1bb3..de190c3 100644 --- a/index.js +++ b/index.js @@ -1,3 +1,4 @@ exports.smt = require("./src/smt"); exports.eddsa = require("./src/eddsa"); exports.mimc7 = require("./src/mimc7"); +exports.babyJub = require("./src/babyjub"); diff --git a/src/eddsa.js b/src/eddsa.js index f16625d..4991881 100644 --- a/src/eddsa.js +++ b/src/eddsa.js @@ -3,9 +3,7 @@ const bigInt = require("snarkjs").bigInt; const babyJub = require("./babyjub"); const pedersenHash = require("./pedersenHash").hash; const mimc7 = require("./mimc7"); -const crypto = require("crypto"); - -exports.cratePrvKey = cratePrvKey; + exports.prv2pub= prv2pub; exports.sign = sign; exports.signMiMC = signMiMC; @@ -13,12 +11,9 @@ exports.verify = verify; exports.verifyMiMC = verifyMiMC; exports.packSignature = packSignature; exports.unpackSignature = unpackSignature; +exports.pruneBuffer = pruneBuffer; -function cratePrvKey() { - return crypto.randomBytes(32); -} - function pruneBuffer(_buff) { const buff = Buffer.from(_buff); buff[0] = buff[0] & 0xF8; diff --git a/src/evmasm.js b/src/evmasm.js index d68f791..ad4170c 100644 --- a/src/evmasm.js +++ b/src/evmasm.js @@ -3,8 +3,7 @@ // -const Web3 = require("web3"); -const assert = require("assert"); +const Web3Utils = require("web3-utils"); class Contract { constructor() { @@ -39,7 +38,7 @@ class Contract { genLoadedLength = C.code.length; } - return Web3.utils.bytesToHex(C.code.concat(this.code)); + return Web3Utils.bytesToHex(C.code.concat(this.code)); } stop() { this.code.push(0x00); } @@ -141,7 +140,9 @@ class Contract { msize() { this.code.push(0x59); } gas() { this.code.push(0x5a); } label(name) { - assert(typeof this.labels[name] == "undefined", "Label already defined"); + if (typeof this.labels[name] != "undefined") { + throw new Error("Label already defined"); + } this.labels[name] = this.code.length; this.code.push(0x5b); @@ -149,21 +150,24 @@ class Contract { } push(data) { - const d = Web3.utils.hexToBytes(Web3.utils.toHex(data)); - assert(d.length>0); - assert(d.length<=32); + const d = Web3Utils.hexToBytes(Web3Utils.toHex(data)); + if (d.length == 0 || d.length > 32) { + throw new Error("Assertion failed"); + } this.code = this.code.concat([0x5F + d.length], d); } dup(n) { - assert(n>=0); - assert(n<16); + if (n < 0 || n >= 16) { + throw new Error("Assertion failed"); + } this.code.push(0x80 + n); } swap(n) { - assert(n>=1); - assert(n<=16); + if (n < 1 || n > 16) { + throw new Error("Assertion failed"); + } this.code.push(0x8f + n); } diff --git a/src/mimc7.js b/src/mimc7.js index dda4b07..47291d8 100644 --- a/src/mimc7.js +++ b/src/mimc7.js @@ -1,6 +1,6 @@ const bn128 = require("snarkjs").bn128; const bigInt = require("snarkjs").bigInt; -const Web3 = require("web3"); +const Web3Utils = require("web3-utils"); const F = bn128.Fr; const SEED = "mimc"; @@ -8,8 +8,8 @@ const NROUNDS = 91; exports.getIV = (seed) => { if (typeof seed === "undefined") seed = SEED; - const c = Web3.utils.keccak256(seed+"_iv"); - const cn = bigInt(Web3.utils.toBN(c).toString()); + const c = Web3Utils.keccak256(seed+"_iv"); + const cn = bigInt(Web3Utils.toBN(c).toString()); const iv = cn.mod(F.q); return iv; }; @@ -18,13 +18,13 @@ exports.getConstants = (seed, nRounds) => { if (typeof seed === "undefined") seed = SEED; if (typeof nRounds === "undefined") nRounds = NROUNDS; const cts = new Array(nRounds); - let c = Web3.utils.keccak256(SEED); + let c = Web3Utils.keccak256(SEED); for (let i=1; i { const msg = Buffer.from("00010203040506070809", "hex"); -// const prvKey = eddsa.cratePrvKey(); +// const prvKey = crypto.randomBytes(32); const prvKey = Buffer.from("0001020304050607080900010203040506070809000102030405060708090001", "hex");