-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathupdate-contract-data.js
60 lines (53 loc) · 2.42 KB
/
update-contract-data.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
const dataFolder = './testvectorgen/contract_data/testdata/v3';
const contractDataBaseFolder = '../contracts/test/validators/v';
const buildFolder = './build/';
const fs = require('fs');
const path = require('path');
const { execSync, execFileSync } = require('child_process');
const files = fs.readdirSync(dataFolder);
let circuitName = null;
let destinationFolder = null;
for (const file of files) {
if (file.includes('state')) {
circuitName = 'stateTransition'
destinationFolder = 'common-data'
} else if (file.includes('sig')) {
circuitName = 'credentialAtomicQuerySigV2OnChain'
destinationFolder = 'sig/data'
} else if (file.includes('mtp')) {
circuitName = 'credentialAtomicQueryMTPV2OnChain'
destinationFolder = 'mtp/data'
} else {
throw new Error('unknown circuit')
}
const buildPath = `./build/${circuitName}/${circuitName}_js/`;
['input.json', 'public.json', 'proof.json'].forEach((f) => {
const p = path.join(`./build/${circuitName}/${circuitName}_js`, f)
fs.existsSync(p) &&
fs.unlinkSync(p);
console.log(`Deleted file: ${p}`);
});
const { inputs } = require(`${dataFolder}/${file}`);
console.log(`Reading file: ${dataFolder}/${file}`);
console.log(`Creating file: ${buildPath}/input.json`);
fs.writeFileSync(`${buildPath}/input.json`, JSON.stringify(inputs), 'utf-8');
const child = execSync(`./generate.sh ${circuitName}`);
console.log(`execution completed`, new TextDecoder().decode(child));
const pub_signals = JSON.parse(fs.readFileSync(`${buildPath}/public.json`).toString());
console.log(pub_signals);
const proof = JSON.parse(fs.readFileSync(`${buildPath}/proof.json`).toString());
console.log('Writing file: ', `${contractDataBaseFolder}/${destinationFolder}/${file}`);
fs.writeFileSync(`${contractDataBaseFolder}/${destinationFolder}/${file}`, JSON.stringify({
pub_signals,
proof
}), 'utf-8');
}
console.log('UPDATE verifiers');
for (const part of ['MTP', 'Sig']) {
const circuitName = `credentialAtomicQuery${part}V2OnChain`;
const contractName = `${buildFolder}${circuitName}/verifier.sol`;
const contractContent = fs.readFileSync(contractName).toString();
const newContractContent = contractContent.replace('pragma solidity ^0.6.11;', 'pragma solidity ^0.8.0;').replace('contract Verifier', 'contract Verifier' + part);
fs.writeFileSync(`../contracts/contracts/lib/verifier${part}.sol`, newContractContent, 'utf-8');
}
console.log('Done');