fix: fixing handlers

This commit is contained in:
Slincnik 2025-01-08 13:13:18 +03:00
parent 32a4ca1c01
commit de46344ccf
No known key found for this signature in database
4 changed files with 93 additions and 72 deletions

View file

@ -1,40 +1,42 @@
import { resolve } from "node:path"; import { resolve } from "node:path";
import logger from "../../helpers/logger.js"; import logger from "../../helpers/logger.js";
import useClient from "../../utils/use-client.js";
import { getFilePaths } from "../../utils/index.js"; import { getFilePaths } from "../../utils/index.js";
import { toFileURL } from "../../utils/resolve-file.js"; import { toFileURL } from "../../utils/resolve-file.js";
import registerCommands from "./functions/registerCommands.js"; import registerCommands from "./functions/registerCommands.js";
export const commands = []; export class CommandHandler {
constructor(client) {
export const init = async () => { this.client = client;
const client = useClient(); this.commands = [];
await buildCommands();
await registerCommands({
client,
commands,
});
};
const buildCommands = async () => {
const client = useClient();
const cmdPath = resolve(client.configService.get("paths.commands"));
const commandFilePaths = (await getFilePaths(cmdPath, true)).filter(path => path.endsWith(".js"));
for (const cmdFilePath of commandFilePaths) {
const { data, run } = await import(toFileURL(cmdFilePath));
if (!data || !data.name) {
logger.warn(`Command ${cmdFilePath} does not have a data object or name`);
continue;
}
if (typeof run !== "function") {
logger.warn(`Command ${cmdFilePath} does not have a run function or it is not a function`);
continue;
}
commands.push({ data, run });
} }
};
async init() {
await this.#buildCommands();
await registerCommands({
client: this.client,
commands: this.commands,
});
}
async #buildCommands() {
const cmdPath = resolve(this.client.configService.get("paths.commands"));
const commandFilePaths = (await getFilePaths(cmdPath, true)).filter(path => path.endsWith(".js"));
for (const cmdFilePath of commandFilePaths) {
const { data, run } = await import(toFileURL(cmdFilePath));
if (!data || !data.name) {
logger.warn(`Command ${cmdFilePath} does not have a data object or name`);
continue;
}
if (typeof run !== "function") {
logger.warn(`Command ${cmdFilePath} does not have a run function or it is not a function`);
continue;
}
this.commands.push({ data, run });
}
}
}

View file

@ -1,49 +1,52 @@
import { resolve } from "node:path"; import { resolve } from "node:path";
import logger from "../../helpers/logger.js"; import logger from "../../helpers/logger.js";
import useClient from "../../utils/use-client.js";
import { getFilePaths } from "../../utils/index.js"; import { getFilePaths } from "../../utils/index.js";
import { toFileURL } from "../../utils/resolve-file.js"; import { toFileURL } from "../../utils/resolve-file.js";
import { useMainPlayer } from "discord-player"; import { useMainPlayer } from "discord-player";
export const events = []; export class EventHandler {
constructor(client) {
this.events = [];
this.client = client;
}
export const init = async () => { async init() {
await buildEvents(); await this.#buildEvents();
registerEvents(); this.$registerEvents();
}; }
const buildEvents = async () => { async #buildEvents() {
const client = useClient(); try {
try { const eventPath = resolve(this.client.configService.get("paths.events"));
const eventPath = resolve(client.configService.get("paths.events")); const eventFilePaths = (await getFilePaths(eventPath, 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));
if (!data || !data.name) { if (!data || !data.name) {
logger.warn(`Event ${eventFilePath} does not have a data object or name`); logger.warn(`Event ${eventFilePath} does not have a data object or name`);
continue; continue;
}
if (typeof run !== "function") {
logger.warn(`Event ${eventFilePath} does not have a run function or it is not a function`);
continue;
}
this.events.push({ data, run });
} }
} catch (error) {
if (typeof run !== "function") { logger.error("Error build events: ", error);
logger.warn(`Event ${eventFilePath} does not have a run function or it is not a function`);
continue;
}
events.push({ data, run });
} }
} catch (error) { logger.log("Events loaded");
logger.error("Error build events: ", error);
} }
};
const registerEvents = async () => { $registerEvents() {
const client = useClient(); const player = useMainPlayer();
const player = useMainPlayer(); for (const { data, run } of this.events) {
for (const { data, run } of events) { if (data.player) player.events.on(data.name, run);
if (data.player) player.events.on(data.name, run); if (data.once) this.client.once(data.name, run);
if (data.once) client.once(data.name, run); else this.client.on(data.name, run);
else client.on(data.name, run); }
} }
}; }

18
src/handlers/index.js Normal file
View file

@ -0,0 +1,18 @@
import { CommandHandler } from "./command-handler/index.js";
import { EventHandler } from "./event-handler/index.js";
export class Handlers {
constructor(client) {
this.client = client;
this.#init();
}
async #init() {
const eventHandler = new EventHandler(this.client);
await eventHandler.init();
const commandHandler = new CommandHandler(this.client);
await commandHandler.init();
}
}

View file

@ -1,9 +1,8 @@
import { Client } from "discord.js"; import { Client } from "discord.js";
import { Player } from "discord-player"; import { Player } from "discord-player";
import MongooseAdapter from "../adapters/database/MongooseAdapter.js"; import MongooseAdapter from "../adapters/database/MongooseAdapter.js";
import { init as initCommands } from "../handlers/command-handler/index.js";
import { init as initEvents } from "../handlers/event-handler/index.js";
import logger from "../helpers/logger.js"; import logger from "../helpers/logger.js";
import { Handlers } from "../handlers/index.js";
import ConfigService from "../services/config/index.js"; import ConfigService from "../services/config/index.js";
import InternationalizationService from "../services/languages/index.js"; import InternationalizationService from "../services/languages/index.js";
import { SUPER_CONTEXT } from "../constants/index.js"; import { SUPER_CONTEXT } from "../constants/index.js";
@ -23,6 +22,7 @@ export class ExtendedClient extends Client {
this.i18n = new InternationalizationService(this); this.i18n = new InternationalizationService(this);
this.cacheReminds = new Map(); this.cacheReminds = new Map();
new Player(this); new Player(this);
new Handlers(this);
SUPER_CONTEXT.enterWith(this); SUPER_CONTEXT.enterWith(this);
} }
@ -31,9 +31,7 @@ export class ExtendedClient extends Client {
try { try {
await this.adapter.connect(); await this.adapter.connect();
return this.login(this.configService.get("token")) await this.login(this.configService.get("token"));
.then(async () => await Promise.all([initCommands(), initEvents()]))
.catch(console.error);
} catch (error) { } catch (error) {
logger.error(error); logger.error(error);
} }