Add files via upload
This commit is contained in:
parent
6024257772
commit
cb6790de6a
11
config.json
Normal file
11
config.json
Normal file
@ -0,0 +1,11 @@
|
||||
{
|
||||
"TOKEN": "Discord Bot Token",
|
||||
"YOUTUBE_API_KEY": "YOUTUBE_API_KEY",
|
||||
"SOUNDCLOUD_CLIENT_ID": "",
|
||||
"MAX_PLAYLIST_SIZE": 100,
|
||||
"PREFIX": "PREFIX",
|
||||
"PRUNING": false,
|
||||
"LOCALE": "en",
|
||||
"STAY_TIME": 30,
|
||||
"DEFAULT_VOLUME": 100
|
||||
}
|
113
index.js
Normal file
113
index.js
Normal file
@ -0,0 +1,113 @@
|
||||
/**
|
||||
* Module Imports
|
||||
*/
|
||||
const { Client, Collection } = require("discord.js");
|
||||
const { readdirSync } = require("fs");
|
||||
const { join } = require("path");
|
||||
const { TOKEN, PREFIX, LOCALE } = require("./util/Util");
|
||||
const path = require("path");
|
||||
const i18n = require("i18n");
|
||||
|
||||
const client = new Client({
|
||||
disableMentions: "everyone",
|
||||
restTimeOffset: 0
|
||||
});
|
||||
|
||||
client.login(TOKEN);
|
||||
client.commands = new Collection();
|
||||
client.prefix = PREFIX;
|
||||
client.queue = new Map();
|
||||
const cooldowns = new Collection();
|
||||
const escapeRegex = (str) => str.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
|
||||
|
||||
i18n.configure({
|
||||
locales: ["en", "es", "ko", "fr", "tr", "pt_br", "zh_cn", "zh_tw"],
|
||||
directory: path.join(__dirname, "locales"),
|
||||
defaultLocale: "en",
|
||||
objectNotation: true,
|
||||
register: global,
|
||||
|
||||
logWarnFn: function (msg) {
|
||||
console.log("warn", msg);
|
||||
},
|
||||
|
||||
logErrorFn: function (msg) {
|
||||
console.log("error", msg);
|
||||
},
|
||||
|
||||
missingKeyFn: function (locale, value) {
|
||||
return value;
|
||||
},
|
||||
|
||||
mustacheConfig: {
|
||||
tags: ["{{", "}}"],
|
||||
disable: false
|
||||
}
|
||||
});
|
||||
|
||||
/**
|
||||
* Client Events
|
||||
*/
|
||||
client.on("ready", () => {
|
||||
console.log(`${client.user.username} ready!`);
|
||||
client.user.setActivity(`c/play | codsworth.xyz`, { type: "LISTENING" });
|
||||
});
|
||||
client.on("warn", (info) => console.log(info));
|
||||
client.on("error", console.error);
|
||||
|
||||
/**
|
||||
* Import all commands
|
||||
*/
|
||||
const commandFiles = readdirSync(join(__dirname, "commands")).filter((file) => file.endsWith(".js"));
|
||||
for (const file of commandFiles) {
|
||||
const command = require(join(__dirname, "commands", `${file}`));
|
||||
client.commands.set(command.name, command);
|
||||
}
|
||||
|
||||
client.on("message", async (message) => {
|
||||
if (message.author.bot) return;
|
||||
if (!message.guild) return;
|
||||
|
||||
const prefixRegex = new RegExp(`^(<@!?${client.user.id}>|${escapeRegex(PREFIX)})\\s*`);
|
||||
if (!prefixRegex.test(message.content)) return;
|
||||
|
||||
const [, matchedPrefix] = message.content.match(prefixRegex);
|
||||
|
||||
const args = message.content.slice(matchedPrefix.length).trim().split(/ +/);
|
||||
const commandName = args.shift().toLowerCase();
|
||||
|
||||
const command =
|
||||
client.commands.get(commandName) ||
|
||||
client.commands.find((cmd) => cmd.aliases && cmd.aliases.includes(commandName));
|
||||
|
||||
if (!command) return;
|
||||
|
||||
if (!cooldowns.has(command.name)) {
|
||||
cooldowns.set(command.name, new Collection());
|
||||
}
|
||||
|
||||
const now = Date.now();
|
||||
const timestamps = cooldowns.get(command.name);
|
||||
const cooldownAmount = (command.cooldown || 1) * 1000;
|
||||
|
||||
if (timestamps.has(message.author.id)) {
|
||||
const expirationTime = timestamps.get(message.author.id) + cooldownAmount;
|
||||
|
||||
if (now < expirationTime) {
|
||||
const timeLeft = (expirationTime - now) / 1000;
|
||||
return message.reply(
|
||||
i18n.__mf("common.cooldownMessage", { time: timeLeft.toFixed(1), name: command.name })
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
timestamps.set(message.author.id, now);
|
||||
setTimeout(() => timestamps.delete(message.author.id), cooldownAmount);
|
||||
|
||||
try {
|
||||
command.execute(message, args);
|
||||
} catch (error) {
|
||||
console.error(error);
|
||||
message.reply(i18n.__("common.errorCommend")).catch(console.error);
|
||||
}
|
||||
});
|
Reference in New Issue
Block a user