diff --git a/handlers/Actions.ts b/handlers/Actions.ts index 0721737..c8be5f6 100644 --- a/handlers/Actions.ts +++ b/handlers/Actions.ts @@ -1 +1,39 @@ -export * from "./MessageRelated.ts"; +import type { DiscordMessage, DiscordReady } from "../vendor/external.ts"; +import type { Snowflake } from "../util/Snowflake.ts"; +import type { Session } from "../session/Session.ts"; +import Message from "../structures/Message.ts"; + +export type RawHandler = (...args: [Session, number, ...T]) => void; +export type Handler = (...args: T) => unknown; + +export type Ready = [DiscordReady]; +export const READY: RawHandler = (session, shardId, payload) => { + session.emit("ready", payload, shardId); +}; + +export type MessageCreate = [DiscordMessage]; +export const MESSAGE_CREATE: RawHandler = (session, _shardId, message) => { + session.emit("messageCreate", new Message(session, message)); +}; + +export type MessageUpdate = [DiscordMessage]; +export const MESSAGE_UPDATE: RawHandler = (session, _shardId, new_message) => { + session.emit("messageUpdate", new Message(session, new_message)); +}; + +export type MessageDelete = [Snowflake]; +export const MESSAGE_DELETE: RawHandler = (session, _shardId, deleted_message_id) => { + session.emit("messageDelete", deleted_message_id); +} + +export const raw: RawHandler<[unknown]> = (session, shardId, data) => { + session.emit("raw", data, shardId); +}; + +export interface Events { + "ready": Handler<[DiscordReady, number]>; + "messageCreate": Handler<[Message]>; + "messageUpdate": Handler<[Message]>; + "messageDelete": Handler<[Snowflake]>; + "raw": Handler<[unknown]>; +} diff --git a/handlers/MessageRelated.ts b/handlers/MessageRelated.ts deleted file mode 100644 index afd1a3d..0000000 --- a/handlers/MessageRelated.ts +++ /dev/null @@ -1,18 +0,0 @@ -import type { DiscordMessage, DiscordReady } from "../vendor/external.ts"; -import type { Session } from "../session/Session.ts"; -import { Message } from "../structures/Message.ts"; - -type Handler = (...args: [Session, number, T]) => void; - -// TODO: move this lol -export const READY: Handler = (session, shardId, payload) => { - session.emit("ready", shardId, payload); -}; - -export const MESSAGE_CREATE: Handler = (session, _shardId, message) => { - session.emit("messageCreate", new Message(session, message)); -}; - -export const raw: Handler = (session, shardId, data) => { - session.emit("raw", data, shardId); -}; diff --git a/mod.ts b/mod.ts index fc4e693..b462a6d 100644 --- a/mod.ts +++ b/mod.ts @@ -23,7 +23,6 @@ export * from "./structures/WelcomeChannel.ts"; export * from "./structures/WelcomeScreen.ts"; export * from "./session/Session.ts"; -export * from "./session/Events.ts"; export * from "./util/shared/flags.ts"; export * from "./util/shared/images.ts"; diff --git a/session/Events.ts b/session/Events.ts deleted file mode 100644 index d024a6c..0000000 --- a/session/Events.ts +++ /dev/null @@ -1,10 +0,0 @@ -import type { DiscordGatewayPayload, DiscordReady, Shard } from "../vendor/external.ts"; -import type { Message } from "../structures/Message.ts"; - -export type DiscordRawEventHandler = (shard: Shard, data: DiscordGatewayPayload) => unknown; - -export interface Events { - ready(shardId: number, payload: DiscordReady): unknown; - messageCreate(message: Message): unknown; - raw(data: DiscordGatewayPayload, shardId: number): unknown; -} diff --git a/session/Session.ts b/session/Session.ts index cce960e..f66519b 100644 --- a/session/Session.ts +++ b/session/Session.ts @@ -1,5 +1,6 @@ import type { DiscordGetGatewayBot, GatewayBot, GatewayIntents } from "../vendor/external.ts"; -import type { DiscordRawEventHandler, Events } from "./Events.ts"; +import type { Shard, DiscordGatewayPayload } from "../vendor/external.ts"; +import type { Events } from "../handlers/Actions.ts"; import { Snowflake } from "../util/Snowflake.ts"; import { EventEmitter } from "../util/EventEmmiter.ts"; @@ -8,6 +9,8 @@ import { createGatewayManager, createRestManager } from "../vendor/external.ts"; import * as Routes from "../util/Routes.ts"; import * as Actions from "../handlers/Actions.ts"; +export type DiscordRawEventHandler = (shard: Shard, data: DiscordGatewayPayload) => unknown; + export interface RestOptions { secretKey?: string; applicationId?: Snowflake; @@ -71,24 +74,18 @@ export class Session extends EventEmitter { // TODO: set botId in Session.botId or something } - override on(event: "ready", func: Events["ready"]): this; - override on(event: "messageCreate", func: Events["messageCreate"]): this; - override on(event: "raw", func: Events["raw"]): this; - override on(event: keyof Events, func: Events[keyof Events]): this { + override on(event: K, func: Events[K]): this; + override on(event: K, func: (...args: unknown[]) => unknown): this { return super.on(event, func); } - override off(event: "ready", func: Events["ready"]): this; - override off(event: "messageCreate", func: Events["messageCreate"]): this; - override off(event: "raw", func: Events["raw"]): this; - override off(event: keyof Events, func: Events[keyof Events]): this { - return super.off(event, func); + override off(event: K, func: Events[K]): this; + override off(event: K, func: (...args: unknown[]) => unknown): this { + return super.off(event, func); } - - override once(event: "ready", func: Events["ready"]): this; - override once(event: "messageCreate", func: Events["messageCreate"]): this; - override once(event: "raw", func: Events["raw"]): this; - override once(event: keyof Events, func: Events[keyof Events]): this { + + override once(event: K, func: Events[K]): this; + override once(event: K, func: (...args: unknown[]) => unknown): this { return super.once(event, func); } diff --git a/structures/Message.ts b/structures/Message.ts index bf9b2af..d2a8da6 100644 --- a/structures/Message.ts +++ b/structures/Message.ts @@ -31,19 +31,7 @@ export interface CreateMessageReference { export interface CreateMessage { content: string; allowedMentions?: AllowedMentions; - messageReference?: CreateMessageReference; -} - -export interface CreateMessage { - allowedMentions?: AllowedMentions; - files: FileContent[]; - messageReference?: CreateMessageReference; -} - -export interface CreateMessage { - content: string; - allowedMentions?: AllowedMentions; - files: FileContent[]; + files?: FileContent[]; messageReference?: CreateMessageReference; } diff --git a/tests/mod.ts b/tests/mod.ts index 75ed69d..9b933fd 100644 --- a/tests/mod.ts +++ b/tests/mod.ts @@ -7,7 +7,7 @@ if (!Deno.args[0]) { const intents = GatewayIntents.MessageContent | GatewayIntents.Guilds | GatewayIntents.GuildMessages; const session = new Session({ token: Deno.args[0], intents }); -session.on("ready", (_shardId, payload) => { +session.on("ready", (payload) => { console.log("Logged in as:", payload.user.username); });