-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathindex.js
88 lines (82 loc) · 2.21 KB
/
index.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
require('dotenv').config()
const Config = require('./config.js')
const Info = require('./info.js')
const Bit = require('./bit.js')
const Db = require('./db')
const ip = require('ip')
console.log(ip.address())
const daemon = {
run: async function() {
// 1. Initialize
await Db.init(Config.db)
await Bit.init(Db, Info)
// 2. Bootstrap actions depending on first time
const lastSynchronized = await Info.checkpoint()
console.time('Indexing Keys')
if (lastSynchronized === Config.core.from) {
// First time. Try indexing
console.log('Indexing...', new Date())
await Db.block.index()
}
console.timeEnd('Indexing Keys')
if (lastSynchronized !== Config.core.from) {
// Resume
// Rewind one step and start
// so that it can recover even in cases
// where the last run crashed during index
// and the block was not indexed completely.
console.log('Resuming...')
await util.fix(lastSynchronized-1)
}
// 3. Start synchronizing
console.log('Synchronizing...', new Date())
console.time('Initial Sync')
await Bit.run()
console.timeEnd('Initial Sync')
// 4. Start listening
Bit.listen()
}
}
const util = {
run: async function() {
await Db.init(Config.db)
let cmd = process.argv[2]
if (cmd === 'fix') {
let from
if (process.argv.length > 3) {
from = parseInt(process.argv[3])
} else {
from = await Info.checkpoint()
}
await util.fix(from)
process.exit()
} else if (cmd === 'reset') {
await Db.block.reset()
await Db.mempool.reset()
await Info.deleteTip()
process.exit()
} else if (cmd === 'index') {
await Db.block.index()
process.exit()
}
},
fix: async function(from) {
console.log('Restarting from index ', from)
console.time('replace')
await Bit.init(Db, Info)
let content = await Bit.crawl(from)
await Db.block.replace(content, from)
console.log('Block', from, 'fixed.')
await Info.updateTip(from)
console.log('[finished]')
console.timeEnd('replace')
}
}
const start = async function() {
if (process.argv.length > 2) {
util.run()
} else {
daemon.run()
}
}
start()