-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathmain.js
95 lines (80 loc) · 2.93 KB
/
main.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
'use strict';
// Native Modules
const path = require('path');
const http = require('http');
// NPM Modules
const bitcoinRPC = require('@jskitty/bitcoin-rpc');
// Local Modules
const colour = require('./colours');
// Constants
/** The refresh rate of Cold Pool updates (too low will overload the RPC!) */
const REFRESH_TIME = 10000;
/** The public-facing API port for generic stats */
const API_PORT = 5000;
/** The host interface to open the API on */
const HOSTNAME = '0.0.0.0';
// Initialize market
const args = process.argv.slice(2);
if (args.length !== 4) {
const exec_name = process.argv[0].split(path.sep).pop();
const app_name = process.argv[1].split(path.sep).pop();
return console.log('%s (Bad Arguments)\nInstead try:\n- %s',
colour.red('Invalid Usage'),
colour.yellow(exec_name + ' ' + app_name + ' localhost 51473 user pass')
);
}
// Pretty-fy our params
const host = args[0];
const port = args[1];
const user = args[2];
const pass = args[3];
// Setup RPC daemon
const RPC = new bitcoinRPC(user, pass, host, port);
// Keep track of some numbers, like total Cold Staking, total Delegations, etc
const stats = {
totalPool: 0,
totalDelegations: 0
};
// Boot up the API
const server = http.createServer((req, res) => {
// Serve public stats
if (req.method === 'GET' && req.url === '/api/v1/stats') {
res.statusCode = 200;
res.setHeader('Content-Type', 'application/json');
res.end(JSON.stringify(stats));
} else {
res.statusCode = 404;
res.end('Not Found');
}
});
server.listen(API_PORT, HOSTNAME, () => {
console.log(`${colour.yellow('Server')}: stats hosted at ${colour.green(`http://${HOSTNAME}:${API_PORT}/api/v1/stats`)}`);
});
// Start our eternal delegation scanning
async function checkAndWhitelistDelegations() {
try {
// Fetch any non-whitelisted delegations
const arrDelegations = await RPC.call("listcoldutxos");
// Whitelist and compute stats
let nTempPool = 0;
for (const cDelegation of arrDelegations) {
// Add new delegators to the whitelist
if (cDelegation.whitelisted === "false" && await RPC.call("delegatoradd", cDelegation["coin-owner"])) {
console.log("New Delegation: " + colour.green("address '" + cDelegation["coin-owner"] + "' with '" + cDelegation.amount + "' initial PIV whitelisted!"));
}
// Aggregate pool amount
nTempPool += cDelegation.amount;
}
// Update total pool size
stats.totalPool = nTempPool;
// Update total delegations
stats.totalDelegations = arrDelegations.length;
} catch (e) {
console.log('%s - Retrying in %s...',
colour.red('RPC Failure'),
colour.yellow((REFRESH_TIME / 1000) + 's')
);
}
}
checkAndWhitelistDelegations();
setInterval(checkAndWhitelistDelegations, REFRESH_TIME);