mirror of
https://github.com/sern-handler/handler
synced 2026-06-13 03:12:15 +00:00
75 lines
2.8 KiB
TypeScript
75 lines
2.8 KiB
TypeScript
/*
|
|
* Plugins can be inserted on all commands and are emitted
|
|
*
|
|
* 1. On ready event, where all commands are loaded.
|
|
* 2. On corresponding observable (when command triggers)
|
|
*
|
|
* The goal of plugins is to organize commands and
|
|
* provide extensions to repetitive patterns
|
|
* examples include refreshing modules,
|
|
* categorizing commands, cool-downs, permissions, etc.
|
|
* Plugins are reminiscent of middleware in express.
|
|
*/
|
|
|
|
import type { Awaitable } from 'discord.js';
|
|
import type { Err, Ok, Result } from 'ts-results-es';
|
|
import type { PluginType } from '../handler/structures/enums';
|
|
import type { CommandModule, EventModule } from './module';
|
|
import type { CommandArgs, InitArgs } from '../handler/plugins';
|
|
import type { Deprecated, Processed } from './handler';
|
|
import type { CommandType } from '../handler/structures/enums';
|
|
export type PluginResult = Awaitable<VoidResult>;
|
|
export type VoidResult = Result<void, void>;
|
|
|
|
export interface Controller {
|
|
next: () => Ok<void>;
|
|
stop: () => Err<void>;
|
|
}
|
|
export interface Plugin<Args extends any[] = any[]> {
|
|
type: PluginType;
|
|
execute: (...args: Args) => PluginResult;
|
|
}
|
|
|
|
export interface InitPlugin<Args extends any[] = any[]> {
|
|
type: PluginType.Init;
|
|
execute: (...args: Args) => PluginResult;
|
|
}
|
|
export interface ControlPlugin<Args extends any[] = any[]> {
|
|
type: PluginType.Control;
|
|
execute: (...args: Args) => PluginResult;
|
|
}
|
|
|
|
export type AnyCommandPlugin = ControlPlugin | InitPlugin<[InitArgs<Processed<CommandModule>>]>;
|
|
export type AnyEventPlugin = ControlPlugin | InitPlugin<[InitArgs<Processed<EventModule>>]>;
|
|
|
|
/**
|
|
* @deprecated
|
|
* Use the newer helper functions and import { controller } from '@sern/handler'
|
|
*/
|
|
export interface CommandPlugin<T extends CommandType = CommandType> {
|
|
name?: string;
|
|
description?: string;
|
|
type: PluginType.Command;
|
|
execute: (
|
|
m: InitArgs<Processed<CommandModule>>,
|
|
controller?: Deprecated<'Please import controller instead'>,
|
|
) => PluginResult;
|
|
}
|
|
/**
|
|
* @deprecated
|
|
* Use the newer helper functions
|
|
*/
|
|
export interface EventPlugin<T extends CommandType> {
|
|
name?: string;
|
|
description?: string;
|
|
type: PluginType.Event;
|
|
execute: (args: CommandArgs<T, PluginType.Event>, controller?: Controller) => PluginResult;
|
|
}
|
|
export type DiscordEmitterPlugin = Deprecated<'Please view alternatives: '>;
|
|
export type ExternalEmitterPlugin = Deprecated<'Please view alternatives: '>;
|
|
export type SernEmitterPlugin = Deprecated<'Please view alternatives: '>;
|
|
export type AutocompletePlugin = Deprecated<'Please view alternatives: '>;
|
|
export type SernEventPlugin = Deprecated<'Please view alternatives: '>;
|
|
export type ExternalEventPlugin = Deprecated<'Please view alternatives: '>;
|
|
export type DiscordEventPlugin = Deprecated<'Please view alternatives: '>;
|