2014-05-19 18:18:01 +02:00
|
|
|
/*
|
2019-01-30 11:47:50 +01:00
|
|
|
* This is a repair tool. It extracts all datas of a pad, removes and inserts them again.
|
|
|
|
*/
|
2014-05-19 18:18:01 +02:00
|
|
|
|
2020-11-23 19:21:51 +01:00
|
|
|
console.warn('WARNING: This script must not be used while etherpad is running!');
|
2014-05-19 18:18:01 +02:00
|
|
|
|
2019-01-30 11:47:50 +01:00
|
|
|
if (process.argv.length != 3) {
|
2020-11-23 19:21:51 +01:00
|
|
|
console.error('Use: node bin/repairPad.js $PADID');
|
2014-05-19 18:18:01 +02:00
|
|
|
process.exit(1);
|
|
|
|
}
|
2019-01-30 11:47:50 +01:00
|
|
|
|
|
|
|
// get the padID
|
2020-11-23 19:21:51 +01:00
|
|
|
const padId = process.argv[2];
|
2014-05-19 18:18:01 +02:00
|
|
|
|
2020-11-23 19:21:51 +01:00
|
|
|
const npm = require('../src/node_modules/npm');
|
|
|
|
npm.load({}, async (er) => {
|
2019-01-30 11:47:50 +01:00
|
|
|
if (er) {
|
2020-11-23 19:21:51 +01:00
|
|
|
console.error(`Could not load NPM: ${er}`);
|
2019-01-30 11:47:50 +01:00
|
|
|
process.exit(1);
|
|
|
|
}
|
2014-05-19 18:18:01 +02:00
|
|
|
|
2019-01-30 11:47:50 +01:00
|
|
|
try {
|
|
|
|
// intialize database
|
2020-11-23 19:21:51 +01:00
|
|
|
const settings = require('../src/node/utils/Settings');
|
|
|
|
const db = require('../src/node/db/DB');
|
2019-01-30 11:47:50 +01:00
|
|
|
await db.init();
|
2014-05-19 18:18:01 +02:00
|
|
|
|
2019-01-30 11:47:50 +01:00
|
|
|
// get the pad
|
2020-11-23 19:21:51 +01:00
|
|
|
const padManager = require('../src/node/db/PadManager');
|
|
|
|
const pad = await padManager.getPad(padId);
|
2019-01-30 11:47:50 +01:00
|
|
|
|
|
|
|
// accumulate the required keys
|
2020-11-23 19:21:51 +01:00
|
|
|
const neededDBValues = [`pad:${padId}`];
|
2019-01-30 11:47:50 +01:00
|
|
|
|
|
|
|
// add all authors
|
2020-11-23 19:21:51 +01:00
|
|
|
neededDBValues.push(...pad.getAllAuthors().map((author) => 'globalAuthor:'));
|
2019-01-30 11:47:50 +01:00
|
|
|
|
|
|
|
// add all revisions
|
|
|
|
for (let rev = 0; rev <= pad.head; ++rev) {
|
2020-11-23 19:21:51 +01:00
|
|
|
neededDBValues.push(`pad:${padId}:revs:${rev}`);
|
2014-05-19 18:18:01 +02:00
|
|
|
}
|
2019-01-30 11:47:50 +01:00
|
|
|
|
|
|
|
// add all chat values
|
|
|
|
for (let chat = 0; chat <= pad.chatHead; ++chat) {
|
2020-11-23 19:21:51 +01:00
|
|
|
neededDBValues.push(`pad:${padId}:chat:${chat}`);
|
2014-05-19 18:18:01 +02:00
|
|
|
}
|
2019-01-30 11:47:50 +01:00
|
|
|
|
|
|
|
//
|
|
|
|
// NB: this script doesn't actually does what's documented
|
|
|
|
// since the `value` fields in the following `.forEach`
|
|
|
|
// block are just the array index numbers
|
|
|
|
//
|
|
|
|
// the script therefore craps out now before it can do
|
|
|
|
// any damage.
|
|
|
|
//
|
|
|
|
// See gitlab issue #3545
|
|
|
|
//
|
2020-11-23 19:21:51 +01:00
|
|
|
console.info('aborting [gitlab #3545]');
|
2019-01-30 11:47:50 +01:00
|
|
|
process.exit(1);
|
|
|
|
|
|
|
|
// now fetch and reinsert every key
|
2020-11-23 19:21:51 +01:00
|
|
|
neededDBValues.forEach((key, value) => {
|
|
|
|
console.log(`Key: ${key}, value: ${value}`);
|
2014-05-19 18:18:01 +02:00
|
|
|
db.remove(key);
|
|
|
|
db.set(key, value);
|
|
|
|
});
|
2019-01-30 11:47:50 +01:00
|
|
|
|
2020-11-23 19:21:51 +01:00
|
|
|
console.info('finished');
|
2019-01-30 11:47:50 +01:00
|
|
|
process.exit(0);
|
|
|
|
} catch (er) {
|
2020-11-23 19:21:51 +01:00
|
|
|
if (er.name === 'apierror') {
|
2019-01-30 11:47:50 +01:00
|
|
|
console.error(er);
|
|
|
|
} else {
|
|
|
|
console.trace(er);
|
|
|
|
}
|
2014-05-19 18:18:01 +02:00
|
|
|
}
|
|
|
|
});
|