mirror of
https://github.com/toast-ts/Daggerbot-TS.git
synced 2024-11-17 20:30:58 -05:00
Notify over DM channel regarding I/O issues
This commit is contained in:
parent
11ab143609
commit
17b346042d
16
src/index.ts
16
src/index.ts
@ -8,13 +8,27 @@ import MPModule, {refreshTimerSecs} from './modules/MPModule.js';
|
||||
import UsernameHelper from './helpers/UsernameHelper.js';
|
||||
import {Punishment, RawGatewayPacket, RawMessageDelete, RawMessageUpdate} from 'src/interfaces';
|
||||
import {readFileSync} from 'node:fs';
|
||||
import {execSync} from 'node:child_process';
|
||||
export const disabledChannels = ['548032776830582794', '541677709487505408', '949380187668242483'];
|
||||
|
||||
// Error handler
|
||||
function _(error:Error, type:string) {
|
||||
if (JSON.parse(readFileSync('src/errorBlocklist.json', 'utf8')).includes(error.message)) return;
|
||||
console.error(error);
|
||||
(client.channels.resolve(client.config.dcServer.channels.errors) as Discord.TextChannel | null)?.send({embeds: [new client.embed().setColor('#560000').setTitle('Error caught!').setFooter({text: 'Error type: ' + type}).setDescription(`**Error:**\n\`\`\`${error.message}\`\`\`**Stack:**\n\`\`\`${`${UsernameHelper(error.stack)}`.slice(0, 2500)}\`\`\``)]})
|
||||
(client.channels.resolve(client.config.dcServer.channels.errors) as Discord.TextChannel | null)?.send({embeds: [new client.embed().setColor('#560000').setTitle('Error caught!').setFooter({text: `Error type: ${type}`}).setDescription(`**Error:**\n\`\`\`${error.message}\`\`\`**Stack:**\n\`\`\`${`${UsernameHelper(error.stack)}`.slice(0, 2500)}\`\`\``)]})
|
||||
|
||||
if (error.message.includes('could not fdatasync file')) {
|
||||
client.users.createDM(client.config.whitelist[1]).then(u=>u.send({
|
||||
embeds: [new client.embed()
|
||||
.setColor(client.config.embedColorYellow)
|
||||
.setTitle('Database error')
|
||||
.setDescription('I couldn\'t write to the database due to filesystem issues, shutting down...')
|
||||
.setFields({name: 'Error message', value: `\`\`\`${error.message}\`\`\``})
|
||||
.setFooter({text: `Error type: ${type}`})
|
||||
]
|
||||
}));
|
||||
setTimeout(()=>execSync('pm2 stop 0', {shell: 'bash'}), 5500);
|
||||
}
|
||||
}
|
||||
process.on('unhandledRejection', (error: Error)=>_(error, 'unhandledRejection'));
|
||||
process.on('uncaughtException', (error: Error)=>_(error, 'uncaughtException'));
|
||||
|
Loading…
Reference in New Issue
Block a user