pad.libre-service.eu-etherpad/bin/deletePad.ts

42 lines
1.4 KiB
TypeScript
Raw Normal View History

'use strict';
2013-02-26 12:44:22 +01:00
/*
* A tool for deleting pads from the CLI, because sometimes a brick is required
* to fix a window.
*/
2013-02-26 12:44:22 +01:00
// 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.
2024-03-15 20:59:28 +01:00
import path from "node:path";
2024-03-13 20:31:29 +01:00
2024-03-15 20:59:28 +01:00
import fs from "node:fs";
import process from "node:process";
2024-03-13 20:31:29 +01:00
import axios from "axios";
process.on('unhandledRejection', (err) => { throw err; });
2024-03-13 20:31:29 +01:00
const settings = require('ep_etherpad-lite/tests/container/loadSettings').loadSettings();
2021-02-03 13:08:43 +01:00
2024-03-13 20:31:29 +01:00
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 () => {
2024-03-13 20:31:29 +01:00
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}`;
2024-03-13 20:31:29 +01:00
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);
})();