-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathaudit.js
104 lines (89 loc) · 5.39 KB
/
audit.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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
'use strict';
const bs58 = require('bs58');
const fs = require("fs");
const timestamp = require("unix-timestamp");
const Web3 = require('web3')
require('dotenv').config();
const REAL_FBITS = 40;
const BNJS = require('bn.js');
if (process.env.provider === undefined) {
console.log("please define network provider at .env file");
process.exit(1);
}
const web3 = new Web3(process.env.provider);
const params_json = require("./parameters/production_rinkeby_params.json");
const addresses_json = require("./production_addreseses.json");
var snapshotBlock = params_json.SNAPSHOT_BLOCK;
// IPFS hash for user agreement
var agreementHash = '0x' + bs58.decode(params_json.AGREEMENT_HASH).slice(2).toString('hex');
console.log("agreementHash",agreementHash);
var BN = web3.utils.BN;
async function startAudit() {
const ContinuousLockingToken4Reputation = require("@daostack/migration/contracts/0.0.1-rc.34/ContinuousLocking4Reputation.json").abi;
let continuousLockingToken4Reputation = new web3.eth.Contract(ContinuousLockingToken4Reputation, addresses_json.CONTINUES_LOCKING4REP);
let batchTime = await continuousLockingToken4Reputation.methods.batchTime().call();
if (batchTime.toNumber() !== 2592000) {
console.log("error ! continuousLockingToken4Reputation (batchTime !== 2592000)");
process.exit(1);
}
let startTime = await continuousLockingToken4Reputation.methods.startTime().call();
if (startTime.toNumber() !== timestamp.fromDate(params_json.BOOTSTRAP_START)) {
console.log("error !continuousLockingToken4Reputation.methods.startTime()")
console.log("error !startTime !==",timestamp.fromDate(params_json.BOOTSTRAP_START))
}
var reputationRewardLeft = await continuousLockingToken4Reputation.methods.reputationRewardLeft().call();
if (reputationRewardLeft.toString() !== await web3.utils.toWei(params_json.CONTINUES_LOCKING_REP_ALLOCATION.toString())) {
console.log("error !reputationRewardLeft continuousLockingToken4Reputation ", reputationRewardLeft.toString());
process.exit(1);
}
var repRewardConstA = await continuousLockingToken4Reputation.methods.repRewardConstA().call();
var repRewardConstAJS = new BNJS(repRewardConstA.toString());
if (repRewardConstAJS.shrn(REAL_FBITS).toString() !== await web3.utils.toWei(params_json.CONTINUES_LOCKING_R0.toString() )) {
console.log("error ! continuousLockingToken4Reputation repRewardConstA",repRewardConstAJS.shrn(REAL_FBITS).toString());
process.exit(1);
}
var repRewardConstB = await continuousLockingToken4Reputation.methods.repRewardConstB().call();
var repRewardConstBJS = new BNJS(repRewardConstB.toString());
var realOne = (new BNJS('1')).shln(REAL_FBITS);
var expected = Math.floor((900 * realOne*realOne)/(1000 * realOne));
console.log(expected,repRewardConstB.toString())
if (repRewardConstB.toString() !== expected.toString()) {
//console.log(repRewardConstBJS.mul(1000).shrn(REAL_FBITS).toString());
console.log("error ! continuousLockingToken4Reputation (repRewardConstBJS.toNumber() !== web3.utils.toWei(10000 )) ",await web3.utils.toWei("100000" ));
process.exit(1);
}
console.log("repRewardConstB.toString()",repRewardConstB.toString())
console.log("startTime:",timestamp.fromDate(params_json.BOOTSTRAP_START));
let redeemEnableTime = await continuousLockingToken4Reputation.methods.redeemEnableTime().call();
if (redeemEnableTime.toNumber() !== timestamp.fromDate(params_json.BOOTSTRAP_END)) {
console.log("error !(redeemEnableTime !==",timestamp.fromDate(params_json.BOOTSTRAP_END))
process.exit(1);
}
const ReputationFromToken = require("@daostack/migration/contracts/0.0.1-rc.34/ReputationFromToken.json").abi;
let reputationFromToken = new web3.eth.Contract(ReputationFromToken, addresses_json.RFROMTOKEN);
var tokenContract = await reputationFromToken.methods.tokenContract().call();
const NectarRepAllocation = require("@daostack/migration/contracts/0.0.1-rc.34/NectarRepAllocation.json").abi;
let nectarRepAllocation = new web3.eth.Contract(NectarRepAllocation, tokenContract);
var blockReference = await nectarRepAllocation.methods.blockReference().call();
var reputationReward = await nectarRepAllocation.methods.reputationReward().call();
if (reputationReward.toString() !== await web3.utils.toWei(params_json.SNAPSHOT_REP_ALLOCATION.toString() )) {
console.log("error ! nectarRepAllocation reputationReward",reputationReward.toString());
process.exit(1);
}
console.log("blockReference",blockReference.toNumber());
const Auction4Reputation = require("@daostack/migration/contracts/0.0.1-rc.34/Auction4Reputation.json").abi;
let auction4Reputation = new web3.eth.Contract(Auction4Reputation, addresses_json.AUCTION4REP);
let auctionReputationReward = await auction4Reputation.methods.auctionReputationReward().call();
if (auctionReputationReward.toString() !== await web3.utils.toWei(params_json.GEN_AUCTION_REP_ALLOCATION.toString())) {
console.log("error ! auction4Reputation auctionReputationReward",auctionReputationReward.toString());
process.exit(1);
}
let numberOfAuctions = await auction4Reputation.methods.numberOfAuctions().call();
if (numberOfAuctions.toNumber() !== 10) {
console.log("error ! auction4Reputation numberOfAuctions",numberOfAuctions.toNumber());
process.exit(1);
}
}
module.exports = {
startAudit
}