mirror of
https://github.com/toast-ts/Daggerbot-TS.git
synced 2024-11-17 08:20:58 -05:00
Merge all dev commands into one
This commit is contained in:
parent
5d494fa5f3
commit
fe18ea76a6
@ -7,7 +7,16 @@ import MPDB from './models/MPServer';
|
|||||||
import axios from 'axios';
|
import axios from 'axios';
|
||||||
import moment from 'moment';
|
import moment from 'moment';
|
||||||
import tokens from './tokens.json';
|
import tokens from './tokens.json';
|
||||||
import config from './config.json';
|
|
||||||
|
let importconfig:Config
|
||||||
|
try{
|
||||||
|
importconfig = require('./DB-Beta.config.json')
|
||||||
|
console.log('Using development config : Daggerbot Beta')
|
||||||
|
} catch(e){
|
||||||
|
importconfig = require('./config.json')
|
||||||
|
console.log('Using production config')
|
||||||
|
}
|
||||||
|
|
||||||
export class TClient extends Client {
|
export class TClient extends Client {
|
||||||
invites: Map<any, any>;
|
invites: Map<any, any>;
|
||||||
commands: Discord.Collection<string, any>;
|
commands: Discord.Collection<string, any>;
|
||||||
@ -46,7 +55,7 @@ export class TClient extends Client {
|
|||||||
this.invites = new Map();
|
this.invites = new Map();
|
||||||
this.commands = new Discord.Collection();
|
this.commands = new Discord.Collection();
|
||||||
this.registry = [];
|
this.registry = [];
|
||||||
this.config = config as Config;
|
this.config = importconfig as Config;
|
||||||
this.tokens = tokens as Tokens;
|
this.tokens = tokens as Tokens;
|
||||||
this.YTCache = {
|
this.YTCache = {
|
||||||
'UCQ8k8yTDLITldfWYKDs3xFg': undefined, // Daggerwin
|
'UCQ8k8yTDLITldfWYKDs3xFg': undefined, // Daggerwin
|
||||||
|
@ -1,13 +0,0 @@
|
|||||||
import Discord,{SlashCommandBuilder} from 'discord.js';
|
|
||||||
import { TClient } from 'src/client';
|
|
||||||
export default {
|
|
||||||
async run(client: TClient, interaction: Discord.ChatInputCommandInteraction<'cached'>){
|
|
||||||
if (!client.config.eval.whitelist.includes(interaction.user.id)) return client.youNeedRole(interaction, 'bottech');
|
|
||||||
(client.channels.resolve(client.config.mainServer.channels.console) as Discord.TextChannel).send({content: `Uploaded the current console dump as of <t:${Math.round(Date.now()/1000)}:R>`, files: ['../../.pm2/logs/Daggerbot-out-0.log', '../../.pm2/logs/Daggerbot-error-0.log']})
|
|
||||||
await interaction.reply('It has been uploaded to dev server.')
|
|
||||||
},
|
|
||||||
data: new SlashCommandBuilder()
|
|
||||||
.setName('botlog')
|
|
||||||
.setDescription('Retrieves the log from host and sends it to development server.')
|
|
||||||
.setDMPermission(false)
|
|
||||||
}
|
|
102
src/commands/dev.ts
Normal file
102
src/commands/dev.ts
Normal file
@ -0,0 +1,102 @@
|
|||||||
|
import Discord,{SlashCommandBuilder} from 'discord.js';
|
||||||
|
import { TClient } from 'src/client';
|
||||||
|
import * as util from 'node:util';
|
||||||
|
import {exec} from 'node:child_process';
|
||||||
|
const removeUsername = (text: string)=>{
|
||||||
|
let matchesLeft = true;
|
||||||
|
const array = text.split('\\');
|
||||||
|
while (matchesLeft){
|
||||||
|
let usersIndex = array.indexOf('Users');
|
||||||
|
if (usersIndex<1) matchesLeft = false;
|
||||||
|
else {
|
||||||
|
let usernameIndex = usersIndex+1;
|
||||||
|
if(array[usernameIndex].length == 0) usernameIndex += 1;
|
||||||
|
array[usernameIndex] = '*'.repeat(array[usernameIndex].length);
|
||||||
|
array[usersIndex] = 'Us\u200bers';
|
||||||
|
}
|
||||||
|
} return array.join('\\');
|
||||||
|
};
|
||||||
|
export default {
|
||||||
|
async run(client: TClient, interaction: Discord.ChatInputCommandInteraction<'cached'>) {
|
||||||
|
if (!client.config.eval.whitelist.includes(interaction.user.id)) return client.youNeedRole(interaction, 'bottech');
|
||||||
|
switch (interaction.options.getSubcommand()){
|
||||||
|
case 'eval':
|
||||||
|
if (!client.config.eval.allowed) return interaction.reply({content: 'Eval is disabled.', ephemeral: true});
|
||||||
|
const code = interaction.options.getString('code') as string;
|
||||||
|
let output = 'error';
|
||||||
|
let error = false;
|
||||||
|
try {
|
||||||
|
output = await eval(code);
|
||||||
|
} catch (err: any) {
|
||||||
|
error = true
|
||||||
|
const embed = new client.embed().setColor('#ff0000').setTitle('__Eval__').addFields(
|
||||||
|
{name: 'Input', value: `\`\`\`js\n${code.slice(0, 1010)}\n\`\`\``},
|
||||||
|
{name: 'Output', value: `\`\`\`\n${err}\`\`\``}
|
||||||
|
)
|
||||||
|
interaction.reply({embeds: [embed]}).catch(()=>(interaction.channel as Discord.TextChannel).send({embeds: [embed]})).then(errorEmbedMessage=>{
|
||||||
|
const filter = (x:any)=>x.content === 'stack' && x.author.id === interaction.user.id
|
||||||
|
const messagecollector = (interaction.channel as Discord.TextChannel).createMessageCollector({filter, max: 1, time: 60000});
|
||||||
|
messagecollector.on('collect', collected=>{
|
||||||
|
collected.reply({content: `\`\`\`\n${removeUsername(err.stack)}\n\`\`\``, allowedMentions: {repliedUser: false}});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
if (error) return;
|
||||||
|
if (typeof output == 'object') {
|
||||||
|
output = 'js\n'+util.formatWithOptions({depth: 1}, '%O', output)
|
||||||
|
} else {
|
||||||
|
output = '\n' + String(output);
|
||||||
|
}
|
||||||
|
[client.tokens.token_main,client.tokens.token_beta,client.tokens.token_toast,client.tokens.token_tae].forEach((x)=>{
|
||||||
|
const regexp = new RegExp(x as string,'g');
|
||||||
|
output = output.replace(regexp, ':noblank: No token?');
|
||||||
|
})
|
||||||
|
const embed = new client.embed().setColor(client.config.embedColor).setTitle('__Eval__').addFields(
|
||||||
|
{name: 'Input', value: `\`\`\`js\n${code.slice(0,1010)}\n\`\`\``},
|
||||||
|
{name: 'Output', value: `\`\`\`${removeUsername(output).slice(0,1016)}\n\`\`\``}
|
||||||
|
);
|
||||||
|
interaction.reply({embeds: [embed]}).catch(()=>(interaction.channel as Discord.TextChannel).send({embeds: [embed]}));
|
||||||
|
break
|
||||||
|
case 'logs':
|
||||||
|
interaction.deferReply();
|
||||||
|
(client.channels.resolve(client.config.mainServer.channels.console) as Discord.TextChannel).send({content: `Uploaded the current console dump as of <t:${Math.round(Date.now()/1000)}:R>`, files: [`${process.env.pm2_home}/logs/Daggerbot-out-0.log`, `${process.env.pm2_home}/logs/Daggerbot-error-0.log`]}).then(()=>interaction.editReply('It has been uploaded to dev server.')).catch((e:Error)=>interaction.editReply(`\`${e.message}\``))
|
||||||
|
break
|
||||||
|
case 'restart':
|
||||||
|
client.userLevels.forceSave();
|
||||||
|
interaction.reply(`Uptime before restarting: **${client.formatTime(client.uptime as number, 3, {commas: true, longNames: true})}**`).then(()=>exec('pm2 restart Daggerbot'))
|
||||||
|
break
|
||||||
|
case 'update':
|
||||||
|
const clarkson = await interaction.reply({content: 'Pulling from repository...', fetchReply: true});
|
||||||
|
exec('git pull',(err:Error,stdout)=>{
|
||||||
|
if (err){
|
||||||
|
clarkson.edit(`\`\`\`${removeUsername(err.message)}\`\`\``)
|
||||||
|
} else if (stdout.includes('Already up to date')){
|
||||||
|
clarkson.edit('Bot is already up to date with the repository, did you forgor to push the changes? :skull:')
|
||||||
|
} else {
|
||||||
|
setTimeout(()=>{clarkson.edit(`Uptime before restarting: **${client.formatTime(client.uptime as number, 3, {commas: true, longNames: true})}**`).then(()=>exec('pm2 restart Daggerbot'))},650)
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break
|
||||||
|
}
|
||||||
|
},
|
||||||
|
data: new SlashCommandBuilder()
|
||||||
|
.setName('dev')
|
||||||
|
.setDescription('Developer commands')
|
||||||
|
.setDMPermission(false)
|
||||||
|
.addSubcommand((optt)=>optt
|
||||||
|
.setName('eval')
|
||||||
|
.setDescription('Execute the code to the bot')
|
||||||
|
.addStringOption((opt)=>opt
|
||||||
|
.setName('code')
|
||||||
|
.setDescription('Execute your code')
|
||||||
|
.setRequired(true)))
|
||||||
|
.addSubcommand((optt)=>optt
|
||||||
|
.setName('logs')
|
||||||
|
.setDescription('Retrieve the logs from host and sends it to dev server'))
|
||||||
|
.addSubcommand((optt)=>optt
|
||||||
|
.setName('restart')
|
||||||
|
.setDescription('Restart the bot for technical reasons'))
|
||||||
|
.addSubcommand((optt)=>optt
|
||||||
|
.setName('update')
|
||||||
|
.setDescription('Pull from repository and restart'))
|
||||||
|
}
|
@ -1,65 +0,0 @@
|
|||||||
import Discord,{SlashCommandBuilder} from 'discord.js';
|
|
||||||
import { TClient } from 'src/client';
|
|
||||||
import * as util from 'node:util';
|
|
||||||
const removeUsername = (text: string)=>{
|
|
||||||
let matchesLeft = true;
|
|
||||||
const array = text.split('\\');
|
|
||||||
while (matchesLeft){
|
|
||||||
let usersIndex = array.indexOf('Users');
|
|
||||||
if (usersIndex<1) matchesLeft = false;
|
|
||||||
else {
|
|
||||||
let usernameIndex = usersIndex+1;
|
|
||||||
if(array[usernameIndex].length == 0) usernameIndex += 1;
|
|
||||||
array[usernameIndex] = '*'.repeat(array[usernameIndex].length);
|
|
||||||
array[usersIndex] = 'Us\u200bers';
|
|
||||||
}
|
|
||||||
} return array.join('\\');
|
|
||||||
};
|
|
||||||
export default {
|
|
||||||
async run(client: TClient, interaction: Discord.ChatInputCommandInteraction<'cached'>) {
|
|
||||||
if (!client.config.eval.allowed) return interaction.reply({content: 'Eval is disabled.', ephemeral: true});
|
|
||||||
if (!client.config.eval.whitelist.includes(interaction.user.id)) return interaction.reply({content: 'You\'re not allowed to use this command.', ephemeral: true});
|
|
||||||
const code = interaction.options.getString('code') as string;
|
|
||||||
let output = 'error';
|
|
||||||
let error = false;
|
|
||||||
try {
|
|
||||||
output = await eval(code);
|
|
||||||
} catch (err: any) {
|
|
||||||
error = true
|
|
||||||
const embed = new client.embed().setColor('#ff0000').setTitle('__Eval__').addFields(
|
|
||||||
{name: 'Input', value: `\`\`\`js\n${code.slice(0, 1010)}\n\`\`\``},
|
|
||||||
{name: 'Output', value: `\`\`\`\n${err}\`\`\``}
|
|
||||||
)
|
|
||||||
interaction.reply({embeds: [embed]}).catch(()=>(interaction.channel as Discord.TextChannel).send({embeds: [embed]})).then(errorEmbedMessage=>{
|
|
||||||
const filter = (x:any)=>x.content === 'stack' && x.author.id === interaction.user.id
|
|
||||||
const messagecollector = (interaction.channel as Discord.TextChannel).createMessageCollector({filter, max: 1, time: 60000});
|
|
||||||
messagecollector.on('collect', collected=>{
|
|
||||||
collected.reply({content: `\`\`\`\n${removeUsername(err.stack)}\n\`\`\``, allowedMentions: {repliedUser: false}});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
if (error) return;
|
|
||||||
if (typeof output == 'object') {
|
|
||||||
output = 'js\n'+util.formatWithOptions({depth: 1}, '%O', output)
|
|
||||||
} else {
|
|
||||||
output = '\n' + String(output);
|
|
||||||
}
|
|
||||||
[client.tokens.token_main,client.tokens.token_beta,client.tokens.token_toast,client.tokens.token_tae].forEach((x)=>{
|
|
||||||
const regexp = new RegExp(x as string,'g');
|
|
||||||
output = output.replace(regexp, 'TOKEN_LEAK');
|
|
||||||
})
|
|
||||||
const embed = new client.embed().setColor(client.config.embedColor).setTitle('__Eval__').addFields(
|
|
||||||
{name: 'Input', value: `\`\`\`js\n${code.slice(0,1010)}\n\`\`\``},
|
|
||||||
{name: 'Output', value: `\`\`\`${removeUsername(output).slice(0,1016)}\n\`\`\``}
|
|
||||||
);
|
|
||||||
interaction.reply({embeds: [embed]}).catch(()=>(interaction.channel as Discord.TextChannel).send({embeds: [embed]}))
|
|
||||||
},
|
|
||||||
data: new SlashCommandBuilder()
|
|
||||||
.setName('eval')
|
|
||||||
.setDescription('Run code for debugging purposes')
|
|
||||||
.setDMPermission(false)
|
|
||||||
.addStringOption((opt)=>opt
|
|
||||||
.setName('code')
|
|
||||||
.setDescription('Execute your code')
|
|
||||||
.setRequired(true))
|
|
||||||
}
|
|
@ -1,13 +0,0 @@
|
|||||||
import Discord,{SlashCommandBuilder} from 'discord.js';
|
|
||||||
import { TClient } from 'src/client';
|
|
||||||
export default {
|
|
||||||
async run(client: TClient, interaction: Discord.ChatInputCommandInteraction<'cached'>){
|
|
||||||
if (!client.config.eval.whitelist.includes(interaction.user.id)) return client.youNeedRole(interaction, 'bottech');
|
|
||||||
client.userLevels.forceSave();
|
|
||||||
interaction.reply(`Uptime before restarting: **${client.formatTime(client.uptime as number, 3, {commas: true, longNames: true})}**`).then(()=>require('node:child_process').exec('pm2 restart Daggerbot'))
|
|
||||||
},
|
|
||||||
data: new SlashCommandBuilder()
|
|
||||||
.setName('restart')
|
|
||||||
.setDescription('Restart the bot for technical reasons')
|
|
||||||
.setDMPermission(false)
|
|
||||||
}
|
|
@ -1,24 +0,0 @@
|
|||||||
import Discord,{SlashCommandBuilder} from 'discord.js';
|
|
||||||
import { TClient } from 'src/client';
|
|
||||||
import { exec } from 'node:child_process';
|
|
||||||
export default {
|
|
||||||
async run(client: TClient, interaction: Discord.ChatInputCommandInteraction<'cached'>){
|
|
||||||
if (!client.config.eval.whitelist.includes(interaction.user.id)) return client.youNeedRole(interaction, 'bottech');
|
|
||||||
const msg = await interaction.reply({content: 'Pulling from repository...', fetchReply: true})
|
|
||||||
exec(
|
|
||||||
'git pull',(err:Error,stdout)=>{
|
|
||||||
if (err){
|
|
||||||
msg.edit(`Pull failed:\n\`\`\`${err.message}\`\`\``)
|
|
||||||
} else if (stdout.includes('Already up to date')){
|
|
||||||
msg.edit(`Pull aborted:\nUp to date with the repository`)
|
|
||||||
} else {
|
|
||||||
setTimeout(()=>{msg.edit(`Uptime before restarting: **${client.formatTime(client.uptime as number, 3, {commas: true, longNames: true})}**`).then(()=>require('node:child_process').exec('pm2 restart Daggerbot'))},1000)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
)
|
|
||||||
},
|
|
||||||
data: new SlashCommandBuilder()
|
|
||||||
.setName('update')
|
|
||||||
.setDescription('Pull from repository and restart')
|
|
||||||
.setDMPermission(false)
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user