2021-06-09 12:30:08 +02:00
|
|
|
const { wtns, groth16 } = require('snarkjs')
|
2021-06-06 19:31:32 +02:00
|
|
|
const { utils } = require('ffjavascript')
|
|
|
|
|
|
|
|
const fs = require('fs')
|
|
|
|
const tmp = require('tmp-promise')
|
|
|
|
const util = require('util')
|
|
|
|
const exec = util.promisify(require('child_process').exec)
|
|
|
|
|
2021-06-09 12:30:08 +02:00
|
|
|
const { toFixedHex } = require('./utils')
|
|
|
|
|
|
|
|
async function prove(input, keyBasePath) {
|
2021-06-16 02:31:31 +02:00
|
|
|
const { proof } = await groth16.fullProve(
|
|
|
|
utils.stringifyBigInts(input),
|
|
|
|
`${keyBasePath}.wasm`,
|
|
|
|
`${keyBasePath}.zkey`,
|
|
|
|
)
|
|
|
|
return (
|
|
|
|
'0x' +
|
2021-06-09 12:30:08 +02:00
|
|
|
toFixedHex(proof.pi_a[0]).slice(2) +
|
|
|
|
toFixedHex(proof.pi_a[1]).slice(2) +
|
|
|
|
toFixedHex(proof.pi_b[0][1]).slice(2) +
|
|
|
|
toFixedHex(proof.pi_b[0][0]).slice(2) +
|
|
|
|
toFixedHex(proof.pi_b[1][1]).slice(2) +
|
|
|
|
toFixedHex(proof.pi_b[1][0]).slice(2) +
|
|
|
|
toFixedHex(proof.pi_c[0]).slice(2) +
|
|
|
|
toFixedHex(proof.pi_c[1]).slice(2)
|
2021-06-16 02:31:31 +02:00
|
|
|
)
|
2021-06-09 12:30:08 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function proveZkutil(input, keyBasePath) {
|
2021-06-06 19:31:32 +02:00
|
|
|
input = utils.stringifyBigInts(input)
|
2021-06-08 20:50:34 +02:00
|
|
|
// console.log('input', input)
|
2021-06-06 19:31:32 +02:00
|
|
|
return tmp.dir().then(async (dir) => {
|
|
|
|
dir = dir.path
|
|
|
|
let out
|
|
|
|
|
|
|
|
try {
|
|
|
|
await wtns.debug(
|
|
|
|
utils.unstringifyBigInts(input),
|
|
|
|
`${keyBasePath}.wasm`,
|
|
|
|
`${dir}/witness.wtns`,
|
|
|
|
`${keyBasePath}.sym`,
|
|
|
|
{},
|
|
|
|
console,
|
|
|
|
)
|
|
|
|
const witness = utils.stringifyBigInts(await wtns.exportJson(`${dir}/witness.wtns`))
|
|
|
|
fs.writeFileSync(`${dir}/witness.json`, JSON.stringify(witness, null, 2))
|
|
|
|
|
|
|
|
out = await exec(
|
|
|
|
`zkutil prove -c ${keyBasePath}.r1cs -p ${keyBasePath}.params -w ${dir}/witness.json -r ${dir}/proof.json -o ${dir}/public.json`,
|
|
|
|
)
|
2021-06-08 20:50:34 +02:00
|
|
|
// todo catch inconsistent input during witness generation
|
|
|
|
await exec(`zkutil verify -p ${keyBasePath}.params -r ${dir}/proof.json -i ${dir}/public.json`)
|
2021-06-06 19:31:32 +02:00
|
|
|
} catch (e) {
|
|
|
|
console.log(out, e)
|
|
|
|
throw e
|
|
|
|
}
|
2021-06-09 12:30:08 +02:00
|
|
|
return '0x' + JSON.parse(fs.readFileSync(`${dir}/proof.json`).toString()).proof
|
2021-06-06 19:31:32 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2021-06-16 02:31:31 +02:00
|
|
|
module.exports = { prove, proveZkutil }
|