mirror of
https://github.com/JonnyBro/JaBa.git
synced 2025-01-17 07:53:47 +05:00
Compare commits
1 commit
3f90ff46cf
...
2dc7172179
Author | SHA1 | Date | |
---|---|---|---|
|
2dc7172179 |
361 changed files with 209 additions and 254 deletions
|
@ -22,11 +22,5 @@
|
||||||
"owner": {
|
"owner": {
|
||||||
"id": "123456789098765432"
|
"id": "123456789098765432"
|
||||||
},
|
},
|
||||||
"apiKeys": {},
|
"apiKeys": {}
|
||||||
"paths": {
|
|
||||||
"commands": "./src/commands",
|
|
||||||
"events": "./src/events",
|
|
||||||
"locales": "./src/services/languages/locales"
|
|
||||||
},
|
|
||||||
"defaultLang": "en-US"
|
|
||||||
}
|
}
|
|
@ -1,6 +1,5 @@
|
||||||
import mongoose from "mongoose";
|
import mongoose from "mongoose";
|
||||||
import IDatabaseAdapter from "./IDatabaseAdapter.js";
|
import IDatabaseAdapter from "./IDatabaseAdapter.js";
|
||||||
import logger from "../../helpers/logger.js";
|
|
||||||
|
|
||||||
export default class MongooseAdapter extends IDatabaseAdapter {
|
export default class MongooseAdapter extends IDatabaseAdapter {
|
||||||
/**
|
/**
|
||||||
|
@ -22,11 +21,11 @@ export default class MongooseAdapter extends IDatabaseAdapter {
|
||||||
|
|
||||||
async connect() {
|
async connect() {
|
||||||
await mongoose.connect(this.uri, this.options);
|
await mongoose.connect(this.uri, this.options);
|
||||||
logger.log("Database connected.");
|
console.log("Database connected.");
|
||||||
}
|
}
|
||||||
|
|
||||||
async disconnect() {
|
async disconnect() {
|
||||||
await mongoose.disconnect();
|
await mongoose.disconnect();
|
||||||
console.warn("Database disconnected.");
|
console.log("Database disconnected.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,72 @@
|
||||||
export const data = {
|
const { SlashCommandBuilder, InteractionContextType, ApplicationIntegrationType } = require("discord.js");
|
||||||
name: "8ball",
|
const BaseCommand = require("../../base/BaseCommand");
|
||||||
description: "8ball",
|
|
||||||
};
|
|
||||||
|
|
||||||
export const run = () => {
|
class Eightball extends BaseCommand {
|
||||||
console.log("8ball");
|
/**
|
||||||
};
|
*
|
||||||
|
* @param {import("../base/Client")} client
|
||||||
|
*/
|
||||||
|
constructor(client) {
|
||||||
|
super({
|
||||||
|
command: new SlashCommandBuilder()
|
||||||
|
.setName("8ball")
|
||||||
|
.setDescription(client.translate("fun/8ball:DESCRIPTION"))
|
||||||
|
.setDescriptionLocalizations({
|
||||||
|
uk: client.translate("fun/8ball:DESCRIPTION", null, "uk-UA"),
|
||||||
|
ru: client.translate("fun/8ball:DESCRIPTION", null, "ru-RU"),
|
||||||
|
})
|
||||||
|
.setIntegrationTypes([ApplicationIntegrationType.GuildInstall, ApplicationIntegrationType.UserInstall])
|
||||||
|
.setContexts([InteractionContextType.BotDM, InteractionContextType.PrivateChannel, InteractionContextType.Guild])
|
||||||
|
.addStringOption(option =>
|
||||||
|
option
|
||||||
|
.setName("question")
|
||||||
|
.setDescription(client.translate("fun/8ball:QUESTION"))
|
||||||
|
.setDescriptionLocalizations({
|
||||||
|
uk: client.translate("fun/8ball:QUESTION", null, "uk-UA"),
|
||||||
|
ru: client.translate("fun/8ball:QUESTION", null, "ru-RU"),
|
||||||
|
})
|
||||||
|
.setRequired(true),
|
||||||
|
)
|
||||||
|
.addBooleanOption(option =>
|
||||||
|
option
|
||||||
|
.setName("ephemeral")
|
||||||
|
.setDescription(client.translate("misc:EPHEMERAL_RESPONSE"))
|
||||||
|
.setDescriptionLocalizations({
|
||||||
|
uk: client.translate("misc:EPHEMERAL_RESPONSE", null, "uk-UA"),
|
||||||
|
ru: client.translate("misc:EPHEMERAL_RESPONSE", null, "ru-RU"),
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
dirname: __dirname,
|
||||||
|
ownerOnly: false,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param {import("../../base/Client")} client
|
||||||
|
* @param {import("discord.js").ChatInputCommandInteraction} interaction
|
||||||
|
*/
|
||||||
|
async execute(client, interaction) {
|
||||||
|
await interaction.deferReply({ ephemeral: interaction.options.getBoolean("ephemeral") || false });
|
||||||
|
|
||||||
|
const question = interaction.options.getString("question");
|
||||||
|
const embed = client.embed({
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
name: interaction.translate("fun/8ball:QUESTION"),
|
||||||
|
value: question,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: interaction.translate("fun/8ball:ANSWER"),
|
||||||
|
value: interaction.translate(`fun/8ball:RESPONSE_${client.functions.randomNum(1, 20)}`),
|
||||||
|
},
|
||||||
|
],
|
||||||
|
});
|
||||||
|
|
||||||
|
await client.wait(5000);
|
||||||
|
|
||||||
|
interaction.editReply({ embeds: [embed] });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = Eightball;
|
||||||
|
|
|
@ -1,72 +0,0 @@
|
||||||
const { SlashCommandBuilder, InteractionContextType, ApplicationIntegrationType } = require("discord.js");
|
|
||||||
const BaseCommand = require("../../base/BaseCommand");
|
|
||||||
|
|
||||||
class Eightball extends BaseCommand {
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param {import("../base/Client")} client
|
|
||||||
*/
|
|
||||||
constructor(client) {
|
|
||||||
super({
|
|
||||||
command: new SlashCommandBuilder()
|
|
||||||
.setName("8ball")
|
|
||||||
.setDescription(client.translate("fun/8ball:DESCRIPTION"))
|
|
||||||
.setDescriptionLocalizations({
|
|
||||||
uk: client.translate("fun/8ball:DESCRIPTION", null, "uk-UA"),
|
|
||||||
ru: client.translate("fun/8ball:DESCRIPTION", null, "ru-RU"),
|
|
||||||
})
|
|
||||||
.setIntegrationTypes([ApplicationIntegrationType.GuildInstall, ApplicationIntegrationType.UserInstall])
|
|
||||||
.setContexts([InteractionContextType.BotDM, InteractionContextType.PrivateChannel, InteractionContextType.Guild])
|
|
||||||
.addStringOption(option =>
|
|
||||||
option
|
|
||||||
.setName("question")
|
|
||||||
.setDescription(client.translate("fun/8ball:QUESTION"))
|
|
||||||
.setDescriptionLocalizations({
|
|
||||||
uk: client.translate("fun/8ball:QUESTION", null, "uk-UA"),
|
|
||||||
ru: client.translate("fun/8ball:QUESTION", null, "ru-RU"),
|
|
||||||
})
|
|
||||||
.setRequired(true),
|
|
||||||
)
|
|
||||||
.addBooleanOption(option =>
|
|
||||||
option
|
|
||||||
.setName("ephemeral")
|
|
||||||
.setDescription(client.translate("misc:EPHEMERAL_RESPONSE"))
|
|
||||||
.setDescriptionLocalizations({
|
|
||||||
uk: client.translate("misc:EPHEMERAL_RESPONSE", null, "uk-UA"),
|
|
||||||
ru: client.translate("misc:EPHEMERAL_RESPONSE", null, "ru-RU"),
|
|
||||||
}),
|
|
||||||
),
|
|
||||||
dirname: __dirname,
|
|
||||||
ownerOnly: false,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param {import("../../base/Client")} client
|
|
||||||
* @param {import("discord.js").ChatInputCommandInteraction} interaction
|
|
||||||
*/
|
|
||||||
async execute(client, interaction) {
|
|
||||||
await interaction.deferReply({ ephemeral: interaction.options.getBoolean("ephemeral") || false });
|
|
||||||
|
|
||||||
const question = interaction.options.getString("question");
|
|
||||||
const embed = client.embed({
|
|
||||||
fields: [
|
|
||||||
{
|
|
||||||
name: interaction.translate("fun/8ball:QUESTION"),
|
|
||||||
value: question,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: interaction.translate("fun/8ball:ANSWER"),
|
|
||||||
value: interaction.translate(`fun/8ball:RESPONSE_${client.functions.randomNum(1, 20)}`),
|
|
||||||
},
|
|
||||||
],
|
|
||||||
});
|
|
||||||
|
|
||||||
await client.wait(5000);
|
|
||||||
|
|
||||||
interaction.editReply({ embeds: [embed] });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = Eightball;
|
|
|
@ -1,14 +1,64 @@
|
||||||
import logger from "../helpers/logger.js";
|
import { ActivityType } from "discord.js";
|
||||||
|
import BaseEvent from "../base/BaseEvent";
|
||||||
|
|
||||||
export const data = {
|
class Ready extends BaseEvent {
|
||||||
name: "ready",
|
constructor() {
|
||||||
once: true,
|
super({
|
||||||
};
|
name: "ready",
|
||||||
|
once: false,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @param {import("../structures/client.js").ExtendedClient} client
|
* @param {import("../base/Client")} client
|
||||||
*/
|
*/
|
||||||
export async function run(client) {
|
async execute(client) {
|
||||||
logger.ready(client.user.tag + " is online!");
|
const commands = [...new Map(client.commands.map(v => [v.constructor.name, v])).values()];
|
||||||
|
let servers = client.guilds.cache.size;
|
||||||
|
let users = 0;
|
||||||
|
|
||||||
|
client.guilds.cache.forEach(g => {
|
||||||
|
users += g.memberCount;
|
||||||
|
});
|
||||||
|
|
||||||
|
const birthdays = require("../helpers/birthdays");
|
||||||
|
birthdays.init(client);
|
||||||
|
|
||||||
|
const checkReminds = require("../helpers/checkReminds");
|
||||||
|
checkReminds.init(client);
|
||||||
|
|
||||||
|
client.logger.ready(`Loaded a total of ${commands.length} command(s).`);
|
||||||
|
client.logger.ready(`${client.user.getUsername()}, ready to serve ${users} members in ${servers} servers.`);
|
||||||
|
console.timeEnd("botReady");
|
||||||
|
|
||||||
|
const version = require("../package.json").version;
|
||||||
|
const status = [
|
||||||
|
`${commands.length} ${client.functions.getNoun(commands.length, client.translate("misc:NOUNS:COMMANDS:1"), client.translate("misc:NOUNS:COMMANDS:2"), client.translate("misc:NOUNS:COMMANDS:5"))} available!`,
|
||||||
|
`I'm in ${servers} ${client.functions.getNoun(servers, client.translate("misc:NOUNS:SERVER:1"), client.translate("misc:NOUNS:SERVER:2"), client.translate("misc:NOUNS:SERVER:5"))}!`,
|
||||||
|
`Cached ${users} ${client.functions.getNoun(users, client.translate("misc:NOUNS:USERS:1"), client.translate("misc:NOUNS:USERS:2"), client.translate("misc:NOUNS:USERS:5"))}.`,
|
||||||
|
"Use /help for commands list!",
|
||||||
|
"Did you know that I have a brother called JaBa IT? Yeah! Ask Jonny about him.",
|
||||||
|
];
|
||||||
|
|
||||||
|
let i = 0;
|
||||||
|
setInterval(async () => {
|
||||||
|
servers = (await client.guilds.fetch()).size;
|
||||||
|
users = 0;
|
||||||
|
|
||||||
|
client.guilds.cache.forEach(g => {
|
||||||
|
users += g.memberCount;
|
||||||
|
});
|
||||||
|
|
||||||
|
client.user.setActivity({
|
||||||
|
type: ActivityType.Custom,
|
||||||
|
name: "custom",
|
||||||
|
state: `${status[i]} | v${version}`,
|
||||||
|
});
|
||||||
|
|
||||||
|
i = (i + 1) % status.length; // Wrap around to the start when reaching the end
|
||||||
|
}, 30 * 1000); // Every 30 seconds
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export default Ready;
|
||||||
|
|
|
@ -1,64 +0,0 @@
|
||||||
import { ActivityType } from "discord.js";
|
|
||||||
import BaseEvent from "../base/BaseEvent";
|
|
||||||
|
|
||||||
class Ready extends BaseEvent {
|
|
||||||
constructor() {
|
|
||||||
super({
|
|
||||||
name: "ready",
|
|
||||||
once: false,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param {import("../base/Client")} client
|
|
||||||
*/
|
|
||||||
async execute(client) {
|
|
||||||
const commands = [...new Map(client.commands.map(v => [v.constructor.name, v])).values()];
|
|
||||||
let servers = client.guilds.cache.size;
|
|
||||||
let users = 0;
|
|
||||||
|
|
||||||
client.guilds.cache.forEach(g => {
|
|
||||||
users += g.memberCount;
|
|
||||||
});
|
|
||||||
|
|
||||||
const birthdays = require("../helpers/birthdays");
|
|
||||||
birthdays.init(client);
|
|
||||||
|
|
||||||
const checkReminds = require("../helpers/checkReminds");
|
|
||||||
checkReminds.init(client);
|
|
||||||
|
|
||||||
client.logger.ready(`Loaded a total of ${commands.length} command(s).`);
|
|
||||||
client.logger.ready(`${client.user.getUsername()}, ready to serve ${users} members in ${servers} servers.`);
|
|
||||||
console.timeEnd("botReady");
|
|
||||||
|
|
||||||
const version = require("../package.json").version;
|
|
||||||
const status = [
|
|
||||||
`${commands.length} ${client.functions.getNoun(commands.length, client.translate("misc:NOUNS:COMMANDS:1"), client.translate("misc:NOUNS:COMMANDS:2"), client.translate("misc:NOUNS:COMMANDS:5"))} available!`,
|
|
||||||
`I'm in ${servers} ${client.functions.getNoun(servers, client.translate("misc:NOUNS:SERVER:1"), client.translate("misc:NOUNS:SERVER:2"), client.translate("misc:NOUNS:SERVER:5"))}!`,
|
|
||||||
`Cached ${users} ${client.functions.getNoun(users, client.translate("misc:NOUNS:USERS:1"), client.translate("misc:NOUNS:USERS:2"), client.translate("misc:NOUNS:USERS:5"))}.`,
|
|
||||||
"Use /help for commands list!",
|
|
||||||
"Did you know that I have a brother called JaBa IT? Yeah! Ask Jonny about him.",
|
|
||||||
];
|
|
||||||
|
|
||||||
let i = 0;
|
|
||||||
setInterval(async () => {
|
|
||||||
servers = (await client.guilds.fetch()).size;
|
|
||||||
users = 0;
|
|
||||||
|
|
||||||
client.guilds.cache.forEach(g => {
|
|
||||||
users += g.memberCount;
|
|
||||||
});
|
|
||||||
|
|
||||||
client.user.setActivity({
|
|
||||||
type: ActivityType.Custom,
|
|
||||||
name: "custom",
|
|
||||||
state: `${status[i]} | v${version}`,
|
|
||||||
});
|
|
||||||
|
|
||||||
i = (i + 1) % status.length; // Wrap around to the start when reaching the end
|
|
||||||
}, 30 * 1000); // Every 30 seconds
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default Ready;
|
|
|
@ -1,4 +1,3 @@
|
||||||
import { resolve } from "node:path";
|
|
||||||
import logger from "../../helpers/logger.js";
|
import logger from "../../helpers/logger.js";
|
||||||
import { client } from "../../index.js";
|
import { client } from "../../index.js";
|
||||||
import { getFilePaths } from "../../utils/index.js";
|
import { getFilePaths } from "../../utils/index.js";
|
||||||
|
@ -17,8 +16,7 @@ export const init = async () => {
|
||||||
};
|
};
|
||||||
|
|
||||||
const buildCommands = async () => {
|
const buildCommands = async () => {
|
||||||
const cmdPath = resolve(client.configService.get("paths.commands"));
|
const commandFilePaths = (await getFilePaths("./newCommands", true)).filter(path => path.endsWith(".js"));
|
||||||
const commandFilePaths = (await getFilePaths(cmdPath, true)).filter(path => path.endsWith(".js"));
|
|
||||||
|
|
||||||
for (const cmdFilePath of commandFilePaths) {
|
for (const cmdFilePath of commandFilePaths) {
|
||||||
const { data, run } = await import(toFileURL(cmdFilePath));
|
const { data, run } = await import(toFileURL(cmdFilePath));
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
import { resolve } from "node:path";
|
|
||||||
import logger from "../../helpers/logger.js";
|
import logger from "../../helpers/logger.js";
|
||||||
import { client } from "../../index.js";
|
import { client } from "../../index.js";
|
||||||
import { getFilePaths } from "../../utils/index.js";
|
import { getFilePaths } from "../../utils/index.js";
|
||||||
|
@ -13,8 +12,7 @@ export const init = async () => {
|
||||||
|
|
||||||
const buildEvents = async () => {
|
const buildEvents = async () => {
|
||||||
try {
|
try {
|
||||||
const eventPath = resolve(client.configService.get("paths.events"));
|
const eventFilePaths = (await getFilePaths("./newEvents", true)).filter(path => path.endsWith(".js"));
|
||||||
const eventFilePaths = (await getFilePaths(eventPath, true)).filter(path => path.endsWith(".js"));
|
|
||||||
|
|
||||||
for (const eventFilePath of eventFilePaths) {
|
for (const eventFilePath of eventFilePaths) {
|
||||||
const { data, run } = await import(toFileURL(eventFilePath));
|
const { data, run } = await import(toFileURL(eventFilePath));
|
||||||
|
|
50
src/index.js
50
src/index.js
|
@ -1,6 +1,11 @@
|
||||||
|
// import "./helpers/extenders.js";
|
||||||
|
|
||||||
|
// import { GatewayIntentBits } from "discord.js";
|
||||||
|
// import JaBaClient from "./base/Client.js";
|
||||||
|
// import languages from "./helpers/languages.js";
|
||||||
|
|
||||||
import { GatewayIntentBits } from "discord.js";
|
import { GatewayIntentBits } from "discord.js";
|
||||||
import { ExtendedClient } from "./structures/client.js";
|
import { ExtendedClient } from "./structures/client.js";
|
||||||
import logger from "./helpers/logger.js";
|
|
||||||
|
|
||||||
export const client = new ExtendedClient({
|
export const client = new ExtendedClient({
|
||||||
intents: [
|
intents: [
|
||||||
|
@ -25,10 +30,41 @@ export const client = new ExtendedClient({
|
||||||
|
|
||||||
client.init();
|
client.init();
|
||||||
|
|
||||||
client
|
// const client = new JaBaClient({
|
||||||
.on("disconnect", () => logger.warn("Bot disconnected."))
|
// intents: [
|
||||||
.on("reconnecting", () => logger.warn("Bot reconnecting..."))
|
// GatewayIntentBits.Guilds,
|
||||||
.on("warn", console.log)
|
// GatewayIntentBits.GuildMembers,
|
||||||
.on("error", console.log);
|
// GatewayIntentBits.GuildModeration,
|
||||||
|
// GatewayIntentBits.GuildEmojisAndStickers,
|
||||||
|
// GatewayIntentBits.GuildIntegrations,
|
||||||
|
// GatewayIntentBits.GuildInvites,
|
||||||
|
// GatewayIntentBits.GuildVoiceStates,
|
||||||
|
// GatewayIntentBits.GuildPresences,
|
||||||
|
// GatewayIntentBits.GuildMessages,
|
||||||
|
// GatewayIntentBits.GuildMessageReactions,
|
||||||
|
// GatewayIntentBits.GuildMessageTyping,
|
||||||
|
// GatewayIntentBits.MessageContent,
|
||||||
|
// GatewayIntentBits.DirectMessageTyping,
|
||||||
|
// GatewayIntentBits.DirectMessages,
|
||||||
|
// GatewayIntentBits.DirectMessageReactions,
|
||||||
|
// ],
|
||||||
|
// allowedMentions: { parse: ["everyone", "roles", "users"] },
|
||||||
|
// });
|
||||||
|
|
||||||
process.on("unhandledRejection", console.log).on("uncaughtException", console.log);
|
// (async () => {
|
||||||
|
// console.time("botReady");
|
||||||
|
|
||||||
|
// client.translations = await languages();
|
||||||
|
|
||||||
|
// await client.loadEvents("../events");
|
||||||
|
// await client.loadCommands("../commands");
|
||||||
|
// await client.init();
|
||||||
|
// })();
|
||||||
|
|
||||||
|
// client
|
||||||
|
// .on("disconnect", () => client.logger.warn("Bot disconnected."))
|
||||||
|
// .on("reconnecting", () => client.logger.warn("Bot reconnecting..."))
|
||||||
|
// .on("warn", console.log)
|
||||||
|
// .on("error", console.log);
|
||||||
|
|
||||||
|
// process.on("unhandledRejection", e => console.log(e)).on("uncaughtException", e => console.log(e));
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue