-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathindex.js
55 lines (45 loc) · 1.79 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
'use strict';
const path = require('path');
const execSync = require('child_process').execSync;
const neo4j = require('neo4j-driver').v1;
const async = require('async');
const LineByLine = require('n-readlines');
const config = require('./config.json');
const driver = neo4j.driver(config.neo4j.bolt, neo4j.auth.basic(config.neo4j.auth.user, config.neo4j.auth.pass));
console.log('Counting lines');
let lines = config.lines;
if (!lines) lines = execSync(`wc -l ${path.resolve(config.file)}`).toString().trim().split(' ')[0];
console.log('Found', lines, 'lines');
const lineReaderSetup = (lineReader) => {
lineReader.total = lines;
lineReader.skip = config.skip || 0;
if (!config.skip) return lineReader;
for (let i = 0; i < config.skip; i++) {
if(i % config.bucket == 0) console.log('Skipping', i, '(', i / config.skip * 100, '%)');
lineReader.next();
}
return lineReader;
};
const makeLineReader = () => lineReaderSetup(new LineByLine(path.resolve(config.file), {readChunk: 1024 * 1024 * 64}));
// db cleanup
const stage0 = require('./stage-0');
// node importer
const stage1 = require('./stage-1');
// simple node relations
const stage2 = require('./stage-2');
// linking claims to outgoing items
const stage3 = require('./stage-3');
async.series([
(cb) => !config.do[0] ? cb() : stage0(driver, cb),
(cb) => !config.do[1] ? cb() : stage1(driver, makeLineReader(), cb),
(cb) => !config.do[2] ? cb() : stage2(driver, makeLineReader(), cb),
(cb) => !config.do[3] ? cb() : stage3(driver, makeLineReader(), cb)
], (err) => {
'use strict';
console.log(err || 'done');
console.log('exiting in 5 sec');
setTimeout(process.exit.bind(process, (err ? 1 : 0)), 5000)
});
process.on('uncaughtException', function (err) {
console.error(err.stack || err);
});