2021-01-18 09:53:15 +01:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
// As of v14, Node.js does not exit when there is an unhandled Promise rejection. Convert an
|
|
|
|
// unhandled rejection into an uncaught exception, which does cause Node.js to exit.
|
|
|
|
process.on('unhandledRejection', (err) => { throw err; });
|
|
|
|
|
2020-11-23 19:21:51 +01:00
|
|
|
const startTime = Date.now();
|
2013-03-06 18:16:30 +01:00
|
|
|
|
2021-01-18 09:53:15 +01:00
|
|
|
const log = (str) => {
|
|
|
|
console.log(`${(Date.now() - startTime) / 1000}\t${str}`);
|
|
|
|
};
|
|
|
|
|
|
|
|
const unescape = (val) => {
|
|
|
|
// value is a string
|
|
|
|
if (val.substr(0, 1) === "'") {
|
|
|
|
val = val.substr(0, val.length - 1).substr(1);
|
|
|
|
|
|
|
|
return val.replace(/\\[0nrbtZ\\'"]/g, (s) => {
|
|
|
|
switch (s) {
|
|
|
|
case '\\0': return '\0';
|
|
|
|
case '\\n': return '\n';
|
|
|
|
case '\\r': return '\r';
|
|
|
|
case '\\b': return '\b';
|
|
|
|
case '\\t': return '\t';
|
|
|
|
case '\\Z': return '\x1a';
|
|
|
|
default: return s.substr(1);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
// value is a boolean or NULL
|
|
|
|
if (val === 'NULL') {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
if (val === 'true') {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if (val === 'false') {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// value is a number
|
|
|
|
return val;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2020-11-23 19:21:51 +01:00
|
|
|
require('ep_etherpad-lite/node_modules/npm').load({}, (er, npm) => {
|
|
|
|
const fs = require('fs');
|
2013-03-06 18:16:30 +01:00
|
|
|
|
2020-11-23 19:21:51 +01:00
|
|
|
const ueberDB = require('ep_etherpad-lite/node_modules/ueberdb2');
|
|
|
|
const settings = require('ep_etherpad-lite/node/utils/Settings');
|
|
|
|
const log4js = require('ep_etherpad-lite/node_modules/log4js');
|
2013-03-07 13:15:29 +01:00
|
|
|
|
2020-11-23 19:21:51 +01:00
|
|
|
const dbWrapperSettings = {
|
2013-03-07 13:15:29 +01:00
|
|
|
cache: 0,
|
|
|
|
writeInterval: 100,
|
2020-11-23 19:21:51 +01:00
|
|
|
json: false, // data is already json encoded
|
2013-03-07 13:15:29 +01:00
|
|
|
};
|
2021-01-18 09:53:15 +01:00
|
|
|
const db = new ueberDB.database( // eslint-disable-line new-cap
|
|
|
|
settings.dbType,
|
|
|
|
settings.dbSettings,
|
|
|
|
dbWrapperSettings,
|
|
|
|
log4js.getLogger('ueberDB'));
|
2013-03-06 22:08:14 +01:00
|
|
|
|
2020-11-23 19:21:51 +01:00
|
|
|
const sqlFile = process.argv[2];
|
2013-03-06 22:08:14 +01:00
|
|
|
|
2020-11-23 19:21:51 +01:00
|
|
|
// stop if the settings file is not set
|
2021-01-18 09:53:15 +01:00
|
|
|
if (!sqlFile) throw new Error('Use: node importSqlFile.js $SQLFILE');
|
2013-03-06 22:08:14 +01:00
|
|
|
|
2020-11-23 19:21:51 +01:00
|
|
|
log('initializing db');
|
|
|
|
db.init((err) => {
|
|
|
|
// there was an error while initializing the database, output it and stop
|
|
|
|
if (err) {
|
2021-01-18 09:53:15 +01:00
|
|
|
throw err;
|
2020-11-23 19:21:51 +01:00
|
|
|
} else {
|
|
|
|
log('done');
|
2013-03-07 13:15:29 +01:00
|
|
|
|
2020-11-23 19:21:51 +01:00
|
|
|
log('open output file...');
|
|
|
|
const lines = fs.readFileSync(sqlFile, 'utf8').split('\n');
|
2013-03-07 13:15:29 +01:00
|
|
|
|
2020-11-23 19:21:51 +01:00
|
|
|
const count = lines.length;
|
|
|
|
let keyNo = 0;
|
2013-03-07 13:15:29 +01:00
|
|
|
|
2020-11-23 19:21:51 +01:00
|
|
|
process.stdout.write(`Start importing ${count} keys...\n`);
|
|
|
|
lines.forEach((l) => {
|
2021-01-18 09:53:15 +01:00
|
|
|
if (l.substr(0, 27) === 'REPLACE INTO store VALUES (') {
|
2020-11-23 19:21:51 +01:00
|
|
|
const pos = l.indexOf("', '");
|
|
|
|
const key = l.substr(28, pos - 28);
|
|
|
|
let value = l.substr(pos + 3);
|
2013-03-07 13:15:29 +01:00
|
|
|
value = value.substr(0, value.length - 2);
|
2020-11-23 19:21:51 +01:00
|
|
|
console.log(`key: ${key} val: ${value}`);
|
|
|
|
console.log(`unval: ${unescape(value)}`);
|
2013-03-07 13:15:29 +01:00
|
|
|
db.set(key, unescape(value), null);
|
|
|
|
keyNo++;
|
2021-01-18 09:53:15 +01:00
|
|
|
if (keyNo % 1000 === 0) {
|
2020-11-23 19:21:51 +01:00
|
|
|
process.stdout.write(` ${keyNo}/${count}\n`);
|
2013-03-07 13:15:29 +01:00
|
|
|
}
|
2013-03-06 22:28:00 +01:00
|
|
|
}
|
2013-03-07 13:15:29 +01:00
|
|
|
});
|
2020-11-23 19:21:51 +01:00
|
|
|
process.stdout.write('\n');
|
2021-01-18 09:53:15 +01:00
|
|
|
process.stdout.write('done. waiting for db to finish transaction. ' +
|
|
|
|
'depended on dbms this may take some time..\n');
|
2013-03-06 22:08:14 +01:00
|
|
|
|
2021-01-11 09:47:55 +01:00
|
|
|
db.close(() => {
|
2020-11-23 19:21:51 +01:00
|
|
|
log(`finished, imported ${keyNo} keys.`);
|
2013-03-07 13:15:29 +01:00
|
|
|
});
|
|
|
|
}
|
2013-03-06 18:16:30 +01:00
|
|
|
});
|
|
|
|
});
|