2018-03-10 15:47:00 +08:00
|
|
|
/*
|
2018-06-04 15:07:24 +08:00
|
|
|
Description: Writes the current config to disk
|
2018-03-10 15:47:00 +08:00
|
|
|
*/
|
|
|
|
|
2020-03-07 01:00:30 +08:00
|
|
|
import * as UAC from '../utility/UAC/_info';
|
2020-03-06 00:49:25 +08:00
|
|
|
|
2018-09-30 14:44:36 +08:00
|
|
|
// module main
|
2020-09-17 13:44:32 +08:00
|
|
|
export async function run({ core, server, socket }) {
|
2018-06-04 15:07:24 +08:00
|
|
|
// increase rate limit chance and ignore if not admin
|
2020-03-06 00:49:25 +08:00
|
|
|
if (!UAC.isAdmin(socket.level)) {
|
2019-11-07 15:35:23 +08:00
|
|
|
return server.police.frisk(socket.address, 20);
|
2018-03-10 15:47:00 +08:00
|
|
|
}
|
|
|
|
|
2018-06-04 15:07:24 +08:00
|
|
|
// attempt save, notify of failure
|
2019-03-19 14:36:21 +08:00
|
|
|
if (!core.configManager.save()) {
|
2018-09-30 14:44:36 +08:00
|
|
|
return server.reply({
|
2020-09-22 13:34:30 +08:00
|
|
|
cmd: 'warn', // @todo Add numeric error code as `id`
|
2019-11-07 15:35:23 +08:00
|
|
|
text: 'Failed to save config, check logs.',
|
|
|
|
}, socket);
|
2018-03-10 15:47:00 +08:00
|
|
|
}
|
|
|
|
|
2020-03-06 00:49:25 +08:00
|
|
|
// return success message to moderators and admins
|
2020-03-13 02:28:20 +08:00
|
|
|
server.broadcast({
|
2018-03-11 14:41:17 +08:00
|
|
|
cmd: 'info',
|
2019-11-07 15:35:23 +08:00
|
|
|
text: 'Config saved!',
|
2020-03-06 00:49:25 +08:00
|
|
|
}, { level: UAC.isModerator });
|
2018-03-10 15:47:00 +08:00
|
|
|
|
2019-11-07 15:35:23 +08:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
export const info = {
|
2018-05-13 18:33:22 +08:00
|
|
|
name: 'saveconfig',
|
2018-09-30 14:44:36 +08:00
|
|
|
description: 'Writes the current config to disk',
|
|
|
|
usage: `
|
2019-11-07 15:35:23 +08:00
|
|
|
API: { cmd: 'saveconfig' }`,
|
2018-05-13 18:33:22 +08:00
|
|
|
};
|