EventHandler
Base class for a Discord client event handler.
Pass the event name(s) as the generic, the same one(s) as @RegisterEvent@RegisterEvent. A single-event handler reads this.eventthis.event (the payload tuple) directly. A handler registered for several events branches with this.matchthis.match, keyed by event name, since the union of payload tuples is not directly readable.
abstract class EventHandler<Names extends ValidNonInteractionKeys>
extends BaseHandler<ClientEvents[Names]>
implements Handlerabstract class EventHandler<Names extends ValidNonInteractionKeys>
extends BaseHandler<ClientEvents[Names]>
implements HandlerMember visibility
Filter class members by access level.
EventHandler(
event: ClientEvents[Names],
core: Core,
eventName?: Names
)EventHandler(
event: ClientEvents[Names],
core: Core,
eventName?: Names
)Names
One or more ClientEventsClientEvents keys, e.g. Events.MessageCreateEvents.MessageCreate or Events.MessageCreate | Events.MessageUpdateEvents.MessageCreate | Events.MessageUpdate.
Names extends ValidNonInteractionKeysNames extends ValidNonInteractionKeyscore
Inherited from:BaseHandler
protected readonly event: SingleEventPayload<Names>protected readonly event: SingleEventPayload<Names>logger
Inherited from:BaseHandler
execute()
Holds the main logic of your handler. The dispatcher calls it after the handler's gates pass, so a gate that refuses stops execute()execute() from running.
Inherited from:BaseHandler
Run the arm for whichever event fired. Use this only when the handler is registered for several events. A single-event handler reads this.eventthis.event directly. On a multi-event handler this.eventthis.event is nevernever, so match is the only way to read the payload.
Provide one arm per registered event, keyed by its name, and each arm receives that event's own payload tuple. The arms must cover every event in the generic, a missing event or an unknown key is a compile error.
protected async match<Ret>(
arms: EventMatchArms<Names, Ret>
): Promise<Ret>protected async match<Ret>(
arms: EventMatchArms<Names, Ret>
): Promise<Ret>armsOne handler per registered event, keyed by event name.