mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-01-19 14:13:34 +01:00
41 lines
1.4 KiB
TypeScript
41 lines
1.4 KiB
TypeScript
'use strict';
|
|
|
|
/*
|
|
* A tool for deleting pads from the CLI, because sometimes a brick is required
|
|
* to fix a window.
|
|
*/
|
|
|
|
// 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.
|
|
import path from "node:path";
|
|
|
|
import fs from "node:fs";
|
|
import process from "node:process";
|
|
import axios from "axios";
|
|
|
|
process.on('unhandledRejection', (err) => { throw err; });
|
|
|
|
const settings = require('ep_etherpad-lite/tests/container/loadSettings').loadSettings();
|
|
|
|
axios.defaults.baseURL = `http://${settings.ip}:${settings.port}`;
|
|
|
|
if (process.argv.length !== 3) throw new Error('Use: node deletePad.js $PADID');
|
|
|
|
// get the padID
|
|
const padId = process.argv[2];
|
|
|
|
// get the API Key
|
|
const filePath = path.join(__dirname, '../APIKEY.txt');
|
|
const apikey = fs.readFileSync(filePath, {encoding: 'utf-8'});
|
|
|
|
(async () => {
|
|
let apiVersion = await axios.get('/api/');
|
|
apiVersion = apiVersion.data.currentVersion;
|
|
if (!apiVersion) throw new Error('No version set in API');
|
|
|
|
// Now we know the latest API version, let's delete pad
|
|
const uri = `/api/${apiVersion}/deletePad?apikey=${apikey}&padID=${padId}`;
|
|
const deleteAttempt = await axios.post(uri);
|
|
if (deleteAttempt.data.code === 1) throw new Error(`Error deleting pad ${deleteAttempt.data}`);
|
|
console.log('Deleted pad', deleteAttempt.data);
|
|
})();
|