-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.js
More file actions
54 lines (48 loc) · 1.47 KB
/
index.js
File metadata and controls
54 lines (48 loc) · 1.47 KB
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
const util = require('util');
const sqlite3 = require('sqlite3').verbose();
const Mercury = require('@postlight/mercury-parser');
const dbFile = '/path/to/your/mwi.db';
const landId = 1;
const minRelevance = 5;
const pageNumber = 1; // Page number
const pageLimit = 1000; // Results per page
const pageOffset = pageLimit * (pageNumber - 1);
const db = new sqlite3.Database(dbFile, (err) => {
if (err) throw err;
});
const saveReadable = (id, content) => {
try {
db.run(
'UPDATE expression SET readable = ? WHERE id = ?',
[content, id],
err => {
if (err) {
console.log(util.format('Error : %s on processing expression #%s', err.code, id));
} else {
byteSize = Buffer.from(content).length;
console.log(util.format('Saved %s bytes from expression readable #%s', byteSize, id));
}
}
);
} catch(err) {
console.log(util.format('Error : undefined content for expression #%s', id));
}
};
db.serialize(() => {
const sql = util.format(
'SELECT id, url, readable FROM expression WHERE land_id = %s AND relevance >= %s LIMIT %s OFFSET %s',
landId, minRelevance, pageLimit, pageOffset
);
db.each(sql, (err, row) => {
if (err) throw err;
console.log(util.format('Processing expression #%s', row.id));
Mercury.parse(row.url, {
contentType: 'markdown',
})
.then(result => {
saveReadable(row.id, result.content);
}).catch(err => {
console.log(err);
});
});
});