-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathblocktime.js
75 lines (69 loc) · 2.46 KB
/
blocktime.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
const WebSocket = require('ws')
const urljoin = require('url-join')
const config = require('config')
const request = require('request')
let url = 'https://stats.tomochain.com/primus'
let ws = new WebSocket(url)
let blockNumber = 0
let chunk = {
count: 0,
timestamp: 0
}
ws.on('close', () => {
console.log('WS closed!')
process.exit()
})
ws.on('open', function connection() {
console.log('WS connected!')
ws.ping()
})
ws.on('message', connection)
function connection(data) {
let d = JSON.parse(data)
if (d.action === 'block') {
ws.ping()
if (parseInt(d.data.block.number) > blockNumber) {
chunk.count = chunk.count + 1
console.log(d.data.block.number, d.data.block.hash, chunk.count, d.data.block.timestamp, d.data.block.timestamp - chunk.timestamp)
if ((d.data.block.timestamp - chunk.timestamp) > 60) {
if (chunk.timestamp && (chunk.count > 10)) {
console.log('blocktime =', (d.data.block.timestamp - chunk.timestamp) / chunk.count)
stats((d.data.block.timestamp - chunk.timestamp) / chunk.count).catch(e => console.log())
}
chunk.count = 0
chunk.timestamp = d.data.block.timestamp
}
blockNumber = parseInt(d.data.block.number)
}
}
}
const stats = (value) => {
return new Promise((resolve, reject) => {
let url = urljoin(config.get('stats.uri'), 'write', '?db=tomochain')
let username = process.env.STATS_USERNAME || config.get('stats.username')
let password = process.env.STATS_PASSWORD || config.get('stats.password')
let auth = 'Basic ' + Buffer.from(username + ':' + password).toString('base64')
let data = `
blocktime,env=mainnet value=${value}
`
let options = {
method: 'POST',
url: url,
encoding: null,
headers: {
Authorization: auth
},
body: Buffer.from(data, 'utf-8')
}
request(options, (error, response, body) => {
if (error) {
return reject(error)
}
console.log(`Stats ${response.statusCode} blocktime,env=mainnet value=${value}`)
if (response.statusCode !== 200 && response.statusCode !== 201 && response.statusCode !== 204) {
return reject(error)
}
return resolve(body)
})
})
}