import { Common } from '../../miao.js' import { EventType } from './types.js' const State = {} const SymbolTimeout = Symbol('Timeout') const SymbolResolve = Symbol('Resolve') export class plugin { /** * @deprecated 已废弃 */ name = 'your-plugin' /** * @deprecated 已废弃 */ dsc = '无' /** * @deprecated 已废弃 */ task = null rule: { reg?: RegExp | string fnc: string event?: string log?: boolean permission?: string }[] = [] event = 'message' priority = 9999 namespace = null handler = null e: EventType /** * @param name 插件名称 * @param dsc 插件描述 * @param handler handler配置 * @param handler.key handler支持的事件key * @param handler.fn handler的处理func * @param namespace namespace,设置handler时建议设置 * @param event 执行事件,默认message * @param priority 优先级,数字越小优先级越高 * @param rule * @param rule.reg 命令正则 * @param rule.fnc 命令执行方法 * @param rule.event 执行事件,默认message * @param rule.log false时不显示执行日志 * @param rule.permission 权限 master,owner,admin,all * @param task * @param task.name 定时任务名称 * @param task.cron 定时任务cron表达式 * @param task.fnc 定时任务方法名 * @param task.log false时不显示执行日志 */ constructor({ name, dsc, handler, namespace, event, priority = 5000, task, rule }: { /** * @deprecated 已废弃 */ name?: typeof this.name /** * @deprecated 已废弃 */ dsc?: typeof this.dsc namespace?: typeof this.namespace priority?: typeof this.priority handler?: typeof this.handler event?: typeof this.event /** * @deprecated 已废弃 */ task?: typeof this.task rule?: typeof this.rule }) { name && (this.name = name) dsc && (this.dsc = dsc) event && (this.event = event) priority && (this.priority = priority) /** 定时任务,可以是数组 */ task && (this.task = { /** 任务名 */ name: task?.name ?? '', /** 任务方法名 */ fnc: task?.fnc ?? '', /** 任务cron表达式 */ cron: task?.cron ?? '' }) /** 命令规则 */ rule && (this.rule = rule) if (handler) { this.handler = handler this.namespace = namespace || '' } } /** * @param msg 发送的消息 * @param quote 是否引用回复 * @param data.recallMsg 群聊是否撤回消息,0-120秒,0不撤回 * @param data.at 是否at用户 * @deprecated 已废弃 */ reply(msg = '', quote = false, data = {}) { if (!this.e?.reply || !msg) return false return this.e.reply(msg, quote, data) } /** * @deprecated 已废弃 */ group_id: number /** * @deprecated 已废弃 */ groupId: number /** * @deprecated 已废弃 */ user_id: number /** * @deprecated 已废弃 */ userId: number /** * * @param isGroup * @returns */ conKey(isGroup = false) { if (isGroup) { return `${this.name}.${this.group_id || this.groupId || this.e.group_id}` } else { return `${this.name}.${this.user_id || this.userId || this.e.user_id}` } } /** * @param type 执行方法 * @param isGroup 是否群聊 * @param time 操作时间 * @param timeout 操作超时回复 */ setContext( type: string, isGroup = false, time = 120, timeout = '操作超时已取消' ) { const key = this.conKey(isGroup) if (!State[key]) State[key] = {} State[key][type] = this.e if (time) State[key][type][SymbolTimeout] = setTimeout(() => { if (State[key][type]) { const resolve = State[key][type][SymbolResolve] delete State[key][type] resolve ? resolve(false) : this.reply(timeout, true) } }, time * 1000) return State[key][type] } /** * * @param type * @param isGroup * @returns */ getContext(type: string, isGroup?: boolean) { if (type) return State[this.conKey(isGroup)]?.[type] return State[this.conKey(isGroup)] } /** * * @param type * @param isGroup */ finish(type: string, isGroup?: boolean) { const key = this.conKey(isGroup) if (State[key]?.[type]) { clearTimeout(State[key][type][SymbolTimeout]) delete State[key][type] } } /** * * @param args * @returns */ awaitContext(...args) { return new Promise( resolve => (this.setContext('resolveContext', ...args)[SymbolResolve] = resolve) ) } /** * * @param context */ resolveContext(context) { this.finish('resolveContext') context[SymbolResolve](this.e) } /** * @deprecated 已废弃 * @param plugin * @param tpl * @param data * @param cfg * @returns */ async renderImg(plugin, tpl, data, cfg) { return Common.render(plugin, tpl, data, { ...cfg, e: this.e }) } }