Slash command preparations
This commit is contained in:
		
							parent
							
								
									a438fe26df
								
							
						
					
					
						commit
						f996180fa9
					
				
					 20 changed files with 136 additions and 34 deletions
				
			
		| 
						 | 
					@ -1,35 +1,49 @@
 | 
				
			||||||
class Command {
 | 
					class Command {
 | 
				
			||||||
  constructor(client, cluster, worker, ipc, message, args, content, specialArgs) {
 | 
					  constructor(client, cluster, worker, ipc, options) {
 | 
				
			||||||
    this.client = client;
 | 
					    this.client = client;
 | 
				
			||||||
    this.cluster = cluster;
 | 
					    this.cluster = cluster;
 | 
				
			||||||
    this.worker = worker;
 | 
					    this.worker = worker;
 | 
				
			||||||
    this.ipc = ipc;
 | 
					    this.ipc = ipc;
 | 
				
			||||||
    this.message = message;
 | 
					    this.type = options.type;
 | 
				
			||||||
    this.args = args;
 | 
					    this.args = options.args;
 | 
				
			||||||
    this.content = content;
 | 
					    if (options.type === "classic") {
 | 
				
			||||||
    this.specialArgs = specialArgs;
 | 
					      this.message = options.message;
 | 
				
			||||||
    this.reference = {
 | 
					      this.content = options.content;
 | 
				
			||||||
      messageReference: {
 | 
					      this.specialArgs = options.specialArgs;
 | 
				
			||||||
        channelID: this.message.channel.id,
 | 
					      this.reference = {
 | 
				
			||||||
        messageID: this.message.id,
 | 
					        messageReference: {
 | 
				
			||||||
        guildID: this.message.channel.guild ? this.message.channel.guild.id : undefined,
 | 
					          channelID: this.message.channel.id,
 | 
				
			||||||
        failIfNotExists: false
 | 
					          messageID: this.message.id,
 | 
				
			||||||
      },
 | 
					          guildID: this.message.channel.guild ? this.message.channel.guild.id : undefined,
 | 
				
			||||||
      allowedMentions: {
 | 
					          failIfNotExists: false
 | 
				
			||||||
        repliedUser: false
 | 
					        },
 | 
				
			||||||
      }
 | 
					        allowedMentions: {
 | 
				
			||||||
    };
 | 
					          repliedUser: false
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      };
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					      this.interaction = options.interaction;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  async run() {
 | 
					  async run() {
 | 
				
			||||||
    return "It works!";
 | 
					    return "It works!";
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  async acknowledge() {
 | 
				
			||||||
 | 
					    if (this.type === "classic") {
 | 
				
			||||||
 | 
					      await this.message.channel.sendTyping();
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					      await this.interaction.acknowledge();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  static description = "No description found";
 | 
					  static description = "No description found";
 | 
				
			||||||
  static aliases = [];
 | 
					  static aliases = [];
 | 
				
			||||||
  static arguments = [];
 | 
					  static arguments = [];
 | 
				
			||||||
  static flags = [];
 | 
					  static flags = [];
 | 
				
			||||||
  static requires = [];
 | 
					  static requires = [];
 | 
				
			||||||
 | 
					  static slashAllowed = true;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export default Command;
 | 
					export default Command;
 | 
				
			||||||
| 
						 | 
					@ -96,7 +96,7 @@ class ImageCommand extends Command {
 | 
				
			||||||
    if (magickParams.params.type === "image/gif") {
 | 
					    if (magickParams.params.type === "image/gif") {
 | 
				
			||||||
      status = await this.processMessage(this.message);
 | 
					      status = await this.processMessage(this.message);
 | 
				
			||||||
    } else {
 | 
					    } else {
 | 
				
			||||||
      this.client.sendChannelTyping(this.message.channel.id);
 | 
					      this.acknowledge();
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    try {
 | 
					    try {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -3,7 +3,7 @@ import Command from "../../classes/command.js";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class AncientCommand extends Command {
 | 
					class AncientCommand extends Command {
 | 
				
			||||||
  async run() {
 | 
					  async run() {
 | 
				
			||||||
    this.client.sendChannelTyping(this.message.channel.id);
 | 
					    this.acknowledge();
 | 
				
			||||||
    const controller = new AbortController(); // eslint-disable-line no-undef
 | 
					    const controller = new AbortController(); // eslint-disable-line no-undef
 | 
				
			||||||
    const timeout = setTimeout(() => {
 | 
					    const timeout = setTimeout(() => {
 | 
				
			||||||
      controller.abort();
 | 
					      controller.abort();
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -3,7 +3,7 @@ import Command from "../../classes/command.js";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class BirdCommand extends Command {
 | 
					class BirdCommand extends Command {
 | 
				
			||||||
  async run() {
 | 
					  async run() {
 | 
				
			||||||
    this.client.sendChannelTyping(this.message.channel.id);
 | 
					    this.acknowledge();
 | 
				
			||||||
    const imageData = await fetch("http://shibe.online/api/birds");
 | 
					    const imageData = await fetch("http://shibe.online/api/birds");
 | 
				
			||||||
    const json = await imageData.json();
 | 
					    const json = await imageData.json();
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -3,7 +3,7 @@ import Command from "../../classes/command.js";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class CatCommand extends Command {
 | 
					class CatCommand extends Command {
 | 
				
			||||||
  async run() {
 | 
					  async run() {
 | 
				
			||||||
    this.client.sendChannelTyping(this.message.channel.id);
 | 
					    this.acknowledge();
 | 
				
			||||||
    const controller = new AbortController(); // eslint-disable-line no-undef
 | 
					    const controller = new AbortController(); // eslint-disable-line no-undef
 | 
				
			||||||
    const timeout = setTimeout(() => {
 | 
					    const timeout = setTimeout(() => {
 | 
				
			||||||
      controller.abort();
 | 
					      controller.abort();
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -3,7 +3,7 @@ import Command from "../../classes/command.js";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class DogCommand extends Command {
 | 
					class DogCommand extends Command {
 | 
				
			||||||
  async run() {
 | 
					  async run() {
 | 
				
			||||||
    this.client.sendChannelTyping(this.message.channel.id);
 | 
					    this.acknowledge();
 | 
				
			||||||
    const imageData = await fetch("https://dog.ceo/api/breeds/image/random");
 | 
					    const imageData = await fetch("https://dog.ceo/api/breeds/image/random");
 | 
				
			||||||
    const json = await imageData.json();
 | 
					    const json = await imageData.json();
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -4,7 +4,7 @@ import Command from "../../classes/command.js";
 | 
				
			||||||
class MCCommand extends Command {
 | 
					class MCCommand extends Command {
 | 
				
			||||||
  async run() {
 | 
					  async run() {
 | 
				
			||||||
    if (this.args.length === 0) return "You need to provide some text to generate a Minecraft achievement!";
 | 
					    if (this.args.length === 0) return "You need to provide some text to generate a Minecraft achievement!";
 | 
				
			||||||
    this.client.sendChannelTyping(this.message.channel.id);
 | 
					    this.acknowledge();
 | 
				
			||||||
    const request = await fetch(`https://www.minecraftskinstealer.com/achievement/a.php?i=13&h=Achievement+get%21&t=${encodeURIComponent(this.args.join("+"))}`);
 | 
					    const request = await fetch(`https://www.minecraftskinstealer.com/achievement/a.php?i=13&h=Achievement+get%21&t=${encodeURIComponent(this.args.join("+"))}`);
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      file: Buffer.from(await request.arrayBuffer()),
 | 
					      file: Buffer.from(await request.arrayBuffer()),
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -3,7 +3,7 @@ import Command from "../../classes/command.js";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class WikihowCommand extends Command {
 | 
					class WikihowCommand extends Command {
 | 
				
			||||||
  async run() {
 | 
					  async run() {
 | 
				
			||||||
    this.client.sendChannelTyping(this.message.channel.id);
 | 
					    this.acknowledge();
 | 
				
			||||||
    const request = await fetch("https://www.wikihow.com/api.php?action=query&generator=random&prop=imageinfo&format=json&iiprop=url&grnnamespace=6");
 | 
					    const request = await fetch("https://www.wikihow.com/api.php?action=query&generator=random&prop=imageinfo&format=json&iiprop=url&grnnamespace=6");
 | 
				
			||||||
    const json = await request.json();
 | 
					    const json = await request.json();
 | 
				
			||||||
    const id = Object.keys(json.query.pages)[0];
 | 
					    const id = Object.keys(json.query.pages)[0];
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -3,6 +3,7 @@ import Command from "../../classes/command.js";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class ChannelCommand extends Command {
 | 
					class ChannelCommand extends Command {
 | 
				
			||||||
  async run() {
 | 
					  async run() {
 | 
				
			||||||
 | 
					    if (this.type !== "classic") return "This command only works with the old command style!";
 | 
				
			||||||
    if (!this.message.channel.guild) return "This command only works in servers!";
 | 
					    if (!this.message.channel.guild) return "This command only works in servers!";
 | 
				
			||||||
    const owners = process.env.OWNER.split(",");
 | 
					    const owners = process.env.OWNER.split(",");
 | 
				
			||||||
    if (!this.message.member.permissions.has("administrator") && !owners.includes(this.message.member.id)) return "You need to be an administrator to enable/disable me!";
 | 
					    if (!this.message.member.permissions.has("administrator") && !owners.includes(this.message.member.id)) return "You need to be an administrator to enable/disable me!";
 | 
				
			||||||
| 
						 | 
					@ -40,8 +41,9 @@ class ChannelCommand extends Command {
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  static description = "Enables/disables me in a channel";
 | 
					  static description = "Enables/disables me in a channel (does not work with slash commands)";
 | 
				
			||||||
  static arguments = ["[enable/disable]", "{id}"];
 | 
					  static arguments = ["[enable/disable]", "{id}"];
 | 
				
			||||||
 | 
					  static slashAllowed = false;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export default ChannelCommand;
 | 
					export default ChannelCommand;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -3,7 +3,7 @@ import Command from "../../classes/command.js";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class DonateCommand extends Command {
 | 
					class DonateCommand extends Command {
 | 
				
			||||||
  async run() {
 | 
					  async run() {
 | 
				
			||||||
    this.client.sendChannelTyping(this.message.channel.id);
 | 
					    this.acknowledge();
 | 
				
			||||||
    let prefix = "";
 | 
					    let prefix = "";
 | 
				
			||||||
    const controller = new AbortController(); // eslint-disable-line no-undef
 | 
					    const controller = new AbortController(); // eslint-disable-line no-undef
 | 
				
			||||||
    const timeout = setTimeout(() => {
 | 
					    const timeout = setTimeout(() => {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -9,7 +9,7 @@ class ImageSearchCommand extends Command {
 | 
				
			||||||
  async run() {
 | 
					  async run() {
 | 
				
			||||||
    if (this.message.channel.guild && !this.message.channel.permissionsOf(this.client.user.id).has("embedLinks")) return "I don't have the `Embed Links` permission!";
 | 
					    if (this.message.channel.guild && !this.message.channel.permissionsOf(this.client.user.id).has("embedLinks")) return "I don't have the `Embed Links` permission!";
 | 
				
			||||||
    if (this.args.length === 0) return "You need to provide something to search for!";
 | 
					    if (this.args.length === 0) return "You need to provide something to search for!";
 | 
				
			||||||
    this.client.sendChannelTyping(this.message.channel.id);
 | 
					    this.acknowledge();
 | 
				
			||||||
    const embeds = [];
 | 
					    const embeds = [];
 | 
				
			||||||
    const rawImages = await fetch(`${random(searx)}/search?format=json&safesearch=2&categories=images&q=!goi%20!ddi%20${encodeURIComponent(this.args.join(" "))}`).then(res => res.json());
 | 
					    const rawImages = await fetch(`${random(searx)}/search?format=json&safesearch=2&categories=images&q=!goi%20!ddi%20${encodeURIComponent(this.args.join(" "))}`).then(res => res.json());
 | 
				
			||||||
    if (rawImages.results.length === 0) return "I couldn't find any results!";
 | 
					    if (rawImages.results.length === 0) return "I couldn't find any results!";
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -2,7 +2,7 @@ import Command from "../../classes/command.js";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class ImageStatsCommand extends Command {
 | 
					class ImageStatsCommand extends Command {
 | 
				
			||||||
  async run() {
 | 
					  async run() {
 | 
				
			||||||
    await this.client.sendChannelTyping(this.message.channel.id);
 | 
					    await this.acknowledge();
 | 
				
			||||||
    const servers = await this.ipc.serviceCommand("image", { type: "stats" }, true);
 | 
					    const servers = await this.ipc.serviceCommand("image", { type: "stats" }, true);
 | 
				
			||||||
    const embed = {
 | 
					    const embed = {
 | 
				
			||||||
      embeds: [{
 | 
					      embeds: [{
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -4,7 +4,7 @@ import Command from "../../classes/command.js";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class LengthenCommand extends Command {
 | 
					class LengthenCommand extends Command {
 | 
				
			||||||
  async run() {
 | 
					  async run() {
 | 
				
			||||||
    this.client.sendChannelTyping(this.message.channel.id);
 | 
					    this.acknowledge();
 | 
				
			||||||
    if (this.args.length === 0 || !urlCheck(this.args[0])) return "You need to provide a short URL to lengthen!";
 | 
					    if (this.args.length === 0 || !urlCheck(this.args[0])) return "You need to provide a short URL to lengthen!";
 | 
				
			||||||
    if (urlCheck(this.args[0])) {
 | 
					    if (urlCheck(this.args[0])) {
 | 
				
			||||||
      const url = await fetch(encodeURI(this.args[0]), { redirect: "manual" });
 | 
					      const url = await fetch(encodeURI(this.args[0]), { redirect: "manual" });
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -5,7 +5,7 @@ import Command from "../../classes/command.js";
 | 
				
			||||||
class QrCreateCommand extends Command {
 | 
					class QrCreateCommand extends Command {
 | 
				
			||||||
  async run() {
 | 
					  async run() {
 | 
				
			||||||
    if (this.args.length === 0) return "You need to provide some text to generate a QR code!";
 | 
					    if (this.args.length === 0) return "You need to provide some text to generate a QR code!";
 | 
				
			||||||
    this.client.sendChannelTyping(this.message.channel.id);
 | 
					    this.acknowledge();
 | 
				
			||||||
    const writable = new PassThrough();
 | 
					    const writable = new PassThrough();
 | 
				
			||||||
    qrcode.toFileStream(writable, this.content, { margin: 1 });
 | 
					    qrcode.toFileStream(writable, this.content, { margin: 1 });
 | 
				
			||||||
    const file = await this.streamToBuf(writable);
 | 
					    const file = await this.streamToBuf(writable);
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -9,7 +9,7 @@ class QrReadCommand extends Command {
 | 
				
			||||||
  async run() {
 | 
					  async run() {
 | 
				
			||||||
    const image = await imageDetect(this.client, this.message);
 | 
					    const image = await imageDetect(this.client, this.message);
 | 
				
			||||||
    if (image === undefined) return "You need to provide an image/GIF with a QR code to read!";
 | 
					    if (image === undefined) return "You need to provide an image/GIF with a QR code to read!";
 | 
				
			||||||
    this.client.sendChannelTyping(this.message.channel.id);
 | 
					    this.acknowledge();
 | 
				
			||||||
    const data = await (await fetch(image.path)).buffer();
 | 
					    const data = await (await fetch(image.path)).buffer();
 | 
				
			||||||
    const rawData = await sharp(data).ensureAlpha().raw().toBuffer({ resolveWithObject: true });
 | 
					    const rawData = await sharp(data).ensureAlpha().raw().toBuffer({ resolveWithObject: true });
 | 
				
			||||||
    const qrBuffer = jsqr(rawData.data, rawData.info.width, rawData.info.height);
 | 
					    const qrBuffer = jsqr(rawData.data, rawData.info.width, rawData.info.height);
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -3,7 +3,7 @@ import imageDetect from "../../utils/imagedetect.js";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class RawCommand extends Command {
 | 
					class RawCommand extends Command {
 | 
				
			||||||
  async run() {
 | 
					  async run() {
 | 
				
			||||||
    this.client.sendChannelTyping(this.message.channel.id);
 | 
					    this.acknowledge();
 | 
				
			||||||
    const image = await imageDetect(this.client, this.message);
 | 
					    const image = await imageDetect(this.client, this.message);
 | 
				
			||||||
    if (image === undefined) return "You need to provide an image/GIF to get a raw URL!";
 | 
					    if (image === undefined) return "You need to provide an image/GIF to get a raw URL!";
 | 
				
			||||||
    return image.path;
 | 
					    return image.path;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -6,7 +6,7 @@ class SoundReloadCommand extends Command {
 | 
				
			||||||
    return new Promise((resolve) => {
 | 
					    return new Promise((resolve) => {
 | 
				
			||||||
      const owners = process.env.OWNER.split(",");
 | 
					      const owners = process.env.OWNER.split(",");
 | 
				
			||||||
      if (!owners.includes(this.message.author.id)) return "Only the bot owner can reload Lavalink!";
 | 
					      if (!owners.includes(this.message.author.id)) return "Only the bot owner can reload Lavalink!";
 | 
				
			||||||
      this.client.sendChannelTyping(this.message.channel.id);
 | 
					      this.acknowledge();
 | 
				
			||||||
      this.ipc.broadcast("soundreload");
 | 
					      this.ipc.broadcast("soundreload");
 | 
				
			||||||
      this.ipc.register("soundReloadSuccess", (msg) => {
 | 
					      this.ipc.register("soundReloadSuccess", (msg) => {
 | 
				
			||||||
        this.ipc.unregister("soundReloadSuccess");
 | 
					        this.ipc.unregister("soundReloadSuccess");
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -8,7 +8,7 @@ import Command from "../../classes/command.js";
 | 
				
			||||||
class YouTubeCommand extends Command {
 | 
					class YouTubeCommand extends Command {
 | 
				
			||||||
  async run() {
 | 
					  async run() {
 | 
				
			||||||
    if (this.args.length === 0) return "You need to provide something to search for!";
 | 
					    if (this.args.length === 0) return "You need to provide something to search for!";
 | 
				
			||||||
    this.client.sendChannelTyping(this.message.channel.id);
 | 
					    this.acknowledge();
 | 
				
			||||||
    const messages = [];
 | 
					    const messages = [];
 | 
				
			||||||
    const videos = await fetch(`${random(searx)}/search?format=json&safesearch=1&categories=videos&q=!youtube%20${encodeURIComponent(this.args.join(" "))}`).then(res => res.json());
 | 
					    const videos = await fetch(`${random(searx)}/search?format=json&safesearch=1&categories=videos&q=!youtube%20${encodeURIComponent(this.args.join(" "))}`).then(res => res.json());
 | 
				
			||||||
    if (videos.results.length === 0) return "I couldn't find any results!";
 | 
					    if (videos.results.length === 0) return "I couldn't find any results!";
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										86
									
								
								events/interactionCreate.js
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								events/interactionCreate.js
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,86 @@
 | 
				
			||||||
 | 
					import { promises } from "fs";
 | 
				
			||||||
 | 
					import database from "../utils/database.js";
 | 
				
			||||||
 | 
					import * as logger from "../utils/logger.js";
 | 
				
			||||||
 | 
					import { commands } from "../utils/collections.js";
 | 
				
			||||||
 | 
					import { CommandInteraction } from "eris";
 | 
				
			||||||
 | 
					import { clean } from "../utils/misc.js";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// run when a slash command is executed
 | 
				
			||||||
 | 
					export default async (client, cluster, worker, ipc, interaction) => {
 | 
				
			||||||
 | 
					  if (!(interaction instanceof CommandInteraction)) return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // check if command exists and if it's enabled
 | 
				
			||||||
 | 
					  const command = interaction.data.name;
 | 
				
			||||||
 | 
					  const cmd = commands.get(command);
 | 
				
			||||||
 | 
					  if (!cmd) return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const invoker = interaction.member ?? interaction.user;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // actually run the command
 | 
				
			||||||
 | 
					  logger.log("log", `${invoker.username} (${invoker.id}) ran command ${command}`);
 | 
				
			||||||
 | 
					  try {
 | 
				
			||||||
 | 
					    await database.addCount(command);
 | 
				
			||||||
 | 
					    // eslint-disable-next-line no-unused-vars
 | 
				
			||||||
 | 
					    const commandClass = new cmd(client, cluster, worker, ipc, { type: "application", interaction });
 | 
				
			||||||
 | 
					    const result = await commandClass.run();
 | 
				
			||||||
 | 
					    if (typeof result === "string" || (typeof result === "object" && result.embeds)) {
 | 
				
			||||||
 | 
					      await interaction.createMessage(result);
 | 
				
			||||||
 | 
					    } else if (typeof result === "object" && result.file) {
 | 
				
			||||||
 | 
					      let fileSize = 8388119;
 | 
				
			||||||
 | 
					      if (interaction.channel.guild) {
 | 
				
			||||||
 | 
					        switch (interaction.channel.guild.premiumTier) {
 | 
				
			||||||
 | 
					          case 2:
 | 
				
			||||||
 | 
					            fileSize = 52428308;
 | 
				
			||||||
 | 
					            break;
 | 
				
			||||||
 | 
					          case 3:
 | 
				
			||||||
 | 
					            fileSize = 104856616;
 | 
				
			||||||
 | 
					            break;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      if (result.file.length > fileSize) {
 | 
				
			||||||
 | 
					        if (process.env.TEMPDIR && process.env.TEMPDIR !== "") {
 | 
				
			||||||
 | 
					          const filename = `${Math.random().toString(36).substring(2, 15)}.${result.name.split(".")[1]}`;
 | 
				
			||||||
 | 
					          await promises.writeFile(`${process.env.TEMPDIR}/${filename}`, result.file);
 | 
				
			||||||
 | 
					          const imageURL = `${process.env.TMP_DOMAIN || "https://tmp.projectlounge.pw"}/${filename}`;
 | 
				
			||||||
 | 
					          await interaction.createMessage({
 | 
				
			||||||
 | 
					            embeds: [{
 | 
				
			||||||
 | 
					              color: 16711680,
 | 
				
			||||||
 | 
					              title: "Here's your image!",
 | 
				
			||||||
 | 
					              url: imageURL,
 | 
				
			||||||
 | 
					              image: {
 | 
				
			||||||
 | 
					                url: imageURL
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					              footer: {
 | 
				
			||||||
 | 
					                text: "The result image was more than 8MB in size, so it was uploaded to an external site instead."
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            }]
 | 
				
			||||||
 | 
					          });
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					          await interaction.createMessage("The resulting image was more than 8MB in size, so I can't upload it.");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        await interaction.createMessage({
 | 
				
			||||||
 | 
					          content: result.text ? result.text : undefined
 | 
				
			||||||
 | 
					        }, result);
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  } catch (error) {
 | 
				
			||||||
 | 
					    if (error.toString().includes("Request entity too large")) {
 | 
				
			||||||
 | 
					      await interaction.createMessage("The resulting file was too large to upload. Try again with a smaller image if possible.");
 | 
				
			||||||
 | 
					    } else if (error.toString().includes("Job ended prematurely")) {
 | 
				
			||||||
 | 
					      await interaction.createMessage("Something happened to the image servers before I could receive the image. Try running your command again.");
 | 
				
			||||||
 | 
					    } else if (error.toString().includes("Timed out")) {
 | 
				
			||||||
 | 
					      await interaction.createMessage("The request timed out before I could download that image. Try uploading your image somewhere else or reducing its size.");
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					      logger.error(`Error occurred with slash command ${command} with arguments ${interaction.data.options}: ${error.toString()}`);
 | 
				
			||||||
 | 
					      try {
 | 
				
			||||||
 | 
					        await interaction.createMessage({
 | 
				
			||||||
 | 
					          content: "Uh oh! I ran into an error while running this command. Please report the content of the attached file at the following link or on the esmBot Support server: <https://github.com/esmBot/esmBot/issues>"
 | 
				
			||||||
 | 
					        }, [{
 | 
				
			||||||
 | 
					          file: `Message: ${await clean(error)}\n\nStack Trace: ${await clean(error.stack)}`,
 | 
				
			||||||
 | 
					          name: "error.txt"
 | 
				
			||||||
 | 
					        }]);
 | 
				
			||||||
 | 
					      } catch { /* silently ignore */ }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
| 
						 | 
					@ -101,7 +101,7 @@ export default async (client, cluster, worker, ipc, message) => {
 | 
				
			||||||
    await database.addCount(aliases.get(command) ?? command);
 | 
					    await database.addCount(aliases.get(command) ?? command);
 | 
				
			||||||
    const startTime = new Date();
 | 
					    const startTime = new Date();
 | 
				
			||||||
    // eslint-disable-next-line no-unused-vars
 | 
					    // eslint-disable-next-line no-unused-vars
 | 
				
			||||||
    const commandClass = new cmd(client, cluster, worker, ipc, message, parsed._, message.content.substring(prefix.length).trim().replace(command, "").trim(), (({ _, ...o }) => o)(parsed)); // we also provide the message content as a parameter for cases where we need more accuracy
 | 
					    const commandClass = new cmd(client, cluster, worker, ipc, { type: "classic", message, args: parsed._, content: message.content.substring(prefix.length).trim().replace(command, "").trim(), specialArgs: (({ _, ...o }) => o)(parsed) }); // we also provide the message content as a parameter for cases where we need more accuracy
 | 
				
			||||||
    const result = await commandClass.run();
 | 
					    const result = await commandClass.run();
 | 
				
			||||||
    const endTime = new Date();
 | 
					    const endTime = new Date();
 | 
				
			||||||
    if ((endTime - startTime) >= 180000) reference.allowedMentions.repliedUser = true;
 | 
					    if ((endTime - startTime) >= 180000) reference.allowedMentions.repliedUser = true;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue