@pikokr/command.ts 5.0.7-dev.c3c22eb → 5.0.7-dev.ee21c50

Sign up to get free protection for your applications and to get access to all the features.
package/dist/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import * as discord_js from 'discord.js';
2
- import { Collection, Snowflake, Interaction, ChatInputCommandInteraction, MessageContextMenuCommandInteraction, UserContextMenuCommandInteraction, Message, Client, UserApplicationCommandData, MessageApplicationCommandData, ChatInputApplicationCommandData, ApplicationCommandType, APIApplicationCommandOption } from 'discord.js';
2
+ import { Collection, Snowflake, Interaction, ChatInputCommandInteraction, MessageContextMenuCommandInteraction, UserContextMenuCommandInteraction, Message, Client, APIApplicationCommandSubcommandOption, ChatInputApplicationCommandData, UserApplicationCommandData, MessageApplicationCommandData, ApplicationCommandType, APIApplicationCommandOption } from 'discord.js';
3
3
  import EventEmitter from 'events';
4
4
  import * as tslog from 'tslog';
5
5
  import { Logger } from 'tslog';
@@ -96,11 +96,11 @@ declare class ApplicationCommandExtension extends CTSExtension {
96
96
  config: ApplicationCommandExtensionConfig;
97
97
  constructor(config: ApplicationCommandExtensionConfig);
98
98
  interactionCreate(i: Interaction): Promise<void>;
99
- load(): Promise<void>;
100
99
  sync(): Promise<void>;
101
100
  chatInteraction(i: ChatInputCommandInteraction): Promise<ChatInputCommandInteraction<discord_js.CacheType>>;
102
101
  messageInteraction(i: MessageContextMenuCommandInteraction): Promise<MessageContextMenuCommandInteraction<discord_js.CacheType>>;
103
102
  userInteraction(i: UserContextMenuCommandInteraction): Promise<UserContextMenuCommandInteraction<discord_js.CacheType>>;
103
+ commandInteraction(i: UserContextMenuCommandInteraction): Promise<UserContextMenuCommandInteraction<discord_js.CacheType>>;
104
104
  }
105
105
 
106
106
  declare type TextCommandOptions = {
@@ -159,16 +159,32 @@ declare class Registry {
159
159
  registerEventEmitter(name: string, emitter: EventEmitter): void;
160
160
  }
161
161
 
162
+ declare class SubCommandGroup {
163
+ options: Omit<APIApplicationCommandSubcommandOption, 'type'>;
164
+ guilds?: string[] | undefined;
165
+ constructor(options: Omit<APIApplicationCommandSubcommandOption, 'type'>, guilds?: string[] | undefined);
166
+ command(options: Omit<ChatInputApplicationCommandData, 'options' | 'type'>): MethodDecorator;
167
+ createChild(options: Omit<APIApplicationCommandSubcommandOption, 'type'>): SubCommandGroupChild;
168
+ }
169
+ declare class SubCommandGroupChild {
170
+ options: Omit<APIApplicationCommandSubcommandOption, 'type'>;
171
+ parent: SubCommandGroup;
172
+ constructor(options: Omit<APIApplicationCommandSubcommandOption, 'type'>, parent: SubCommandGroup);
173
+ command(options: Omit<ChatInputApplicationCommandData, 'options' | 'type'>): MethodDecorator;
174
+ }
175
+
162
176
  declare type Options = (UserApplicationCommandData | MessageApplicationCommandData | Omit<ChatInputApplicationCommandData, 'options'>) & {
163
177
  type: ApplicationCommandType;
164
178
  guilds?: Snowflake[];
165
179
  };
166
180
  declare class ApplicationCommandComponent extends BaseComponent {
167
181
  options: Options;
182
+ subcommandGroup?: SubCommandGroup;
183
+ subcommandGroupChild?: SubCommandGroupChild;
168
184
  constructor(options: UserApplicationCommandData | MessageApplicationCommandData | Omit<ChatInputApplicationCommandData, 'options'>);
169
185
  }
170
186
  declare const applicationCommand: (options: Options) => MethodDecorator;
171
187
 
172
188
  declare const option: (options: APIApplicationCommandOption) => ParameterDecorator;
173
189
 
174
- export { ApplicationCommandComponent, BaseComponent, CommandClient, ComponentArgument, ComponentArgumentDecorator, ComponentHookStore, ConverterComponent, Extension, ListenerComponent, OwnerOnlyError, Registry, TextCommandComponent, TextCommandConfig, TextCommandRestOption, applicationCommand, argConverter, command, createArgumentDecorator, createCheckDecorator, createComponentDecorator, createComponentHook, getComponent, getComponentArgumentStore, getComponentStore, getModuleHookStore, listener, moduleHook, option, ownerOnly, rest };
190
+ export { ApplicationCommandComponent, Options as ApplicationCommandComponentOptions, BaseComponent, CommandClient, ComponentArgument, ComponentArgumentDecorator, ComponentHookStore, ConverterComponent, Extension, ListenerComponent, OwnerOnlyError, Registry, SubCommandGroup, SubCommandGroupChild, TextCommandComponent, TextCommandConfig, TextCommandRestOption, applicationCommand, argConverter, command, createArgumentDecorator, createCheckDecorator, createComponentDecorator, createComponentHook, getComponent, getComponentArgumentStore, getComponentStore, getModuleHookStore, listener, moduleHook, option, ownerOnly, rest };
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";var te=Object.create;var B=Object.defineProperty;var ee=Object.getOwnPropertyDescriptor;var oe=Object.getOwnPropertyNames;var re=Object.getPrototypeOf,ne=Object.prototype.hasOwnProperty;var c=(r,t)=>B(r,"name",{value:t,configurable:!0});var m=(r,t)=>()=>(r&&(t=r(r=0)),t);var Tt=(r,t)=>{for(var e in t)B(r,e,{get:t[e],enumerable:!0})},Ht=(r,t,e,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of oe(t))!ne.call(r,n)&&n!==e&&B(r,n,{get:()=>t[n],enumerable:!(o=ee(t,n))||o.enumerable});return r};var g=(r,t,e)=>(e=r!=null?te(re(r)):{},Ht(t||!r||!r.__esModule?B(e,"default",{value:r,enumerable:!0}):e,r)),se=r=>Ht(B({},"__esModule",{value:!0}),r);var z,ue,pt,X,lt,Y,W=m(()=>{"use strict";z=Symbol(),ue=Symbol(),pt=Symbol(),X=Symbol(),lt=Symbol(),Y=Symbol()});var jt,ft,tt,ut=m(()=>{"use strict";jt=require("discord.js");W();ft=c((r,t)=>{let e=Reflect.getMetadata(lt,r,t);return e||(e=new jt.Collection,Reflect.defineMetadata(lt,e,r,t)),e},"getComponentHookStore"),tt=c((r,t)=>(e,o)=>{let n=ft(e,o),s=n.get(r);s||(s=[],n.set(r,s)),s.push(t)},"createComponentHook")});var dt,U,ie,w,gt,Z,$=m(()=>{"use strict";dt=require("discord.js");ut();W();U=c(r=>{let t=Reflect.getMetadata(z,r);return t||(t=new dt.Collection,Reflect.defineMetadata(z,t,r)),t},"getComponentStore"),ie=c((r,t)=>U(r).get(t),"getComponent"),w=c(r=>(t,e)=>{r._init(Reflect.get(t,e),Reflect.getMetadata("design:paramtypes",t,e));let o=ft(t,e);r.hooks=o;let n=U(t);gt(t,e).forEach((i,a)=>{var l;(l=r.argTypes.get(a))==null||l.decorators.push(i)}),n.set(e,r)},"createComponentDecorator"),gt=c((r,t)=>{let e=Reflect.getMetadata(z,r,t);return e||(e=new dt.Collection,Reflect.defineMetadata(z,e,r,t)),e},"getComponentArgumentStore"),Z=c(r=>t=>(e,o,n)=>{var s=new r(t);gt(e,o).set(n,s)},"createArgumentDecorator")});var A,ht=m(()=>{"use strict";A=class{constructor(t){this.type=t,this.decorators=[]}};c(A,"ComponentArgument")});var It,R,Lt=m(()=>{"use strict";It=g(require("lodash")),R=class{constructor(t){typeof t=="object"?this.options=It.default.merge(this.defaultOptions(),t):this.options=t}defaultOptions(){return{}}};c(R,"ComponentArgumentDecorator")});var f,ce,yt=m(()=>{"use strict";$();O();f=class extends u{constructor(t){super(),this.options=t}};c(f,"ApplicationCommandComponent");ce=c(r=>w(new f(r)),"applicationCommand")});var H,Et,xt=m(()=>{"use strict";D();H=class extends R{};c(H,"ApplicationCommandOption");Et=Z(H)});var Wt,et,Ct,$t=m(()=>{"use strict";Wt=require("discord.js");W();et=c(r=>{let t=Reflect.getMetadata(pt,r);return t||(t=new Wt.Collection,Reflect.defineMetadata(pt,t,r)),t},"getModuleHookStore"),Ct=c(r=>(t,e)=>{let o=et(t),n=o.get(r);n||(n=[],o.set(r,n)),n.push(Reflect.get(t,e))},"moduleHook")});var J=m(()=>{"use strict";$t();ut()});var At,k,K,Q=m(()=>{"use strict";At=g(require("lodash"));O();$();k=class extends u{constructor(t){super(),this.options=At.default.merge({emitter:"discord"},t)}};c(k,"ListenerComponent");K=c(r=>w(new k(r)),"listener")});var ot,Ot,Dt,Pt,Nt,P,wt=m(()=>{"use strict";ot=g(require("chalk")),Ot=require("discord.js"),Dt=g(require("lodash"));bt();J();Q();W();Pt=g(require("walk-sync")),Nt=g(require("path")),P=class{constructor(t,e){this.client=e,this.extensions=[],this.emitters=new Ot.Collection,this.logger=t.getChildLogger({prefix:[ot.default.green("[Registry]")]})}getComponentsWithTypeGlobal(t){let e=[];for(let o of this.extensions)e.push(...this.getComponentsWithType(o,t));return e}getComponentsWithType(t,e){let o=U(t);return Array.from(o.filter(n=>n.constructor===e).values())}registerEventListeners(t){let e=this.getComponentsWithType(t,k);for(let o of e){let n=this.emitters.get(o.options.emitter);if(n){let s=o.method.bind(t);Reflect.defineMetadata("bound",s,o),n.addListener(o.options.event,s)}}}unregisterEventListeners(t){let e=this.getComponentsWithType(t,k);for(let o of e){let n=this.emitters.get(o.options.emitter),s=Reflect.getMetadata("bound",o);n&&s&&n.removeListener(o.options.event,s)}}async loadAllModulesInDirectory(t){let e=[],o=(0,Pt.default)(t).filter(n=>n.endsWith(".ts")||n.endsWith(".js"));for(let n of o)if(!n.endsWith(".d.ts"))try{let s=Nt.default.join(t,n),i=require(s);if(typeof i.setup!="function")continue;let a=await i.setup();e.push(...await this.registerModules(a,s))}catch{this.logger.error(`Failed to load ${n}`)}return e}async registerModules(t,e){let o=[];if(t instanceof Array)for(let n of t)await this.registerModule(n),Reflect.defineMetadata(Y,e,n),o.push(n);else await this.registerModule(t),Reflect.defineMetadata(Y,e,t),o.push(t);return o}async reloadModules(){let t=[],e=new Set;for(let o of this.extensions){let n=Reflect.getMetadata(Y,o);!n||(e.add(n),await this.unregisterModule(o),delete require.cache[require.resolve(n)])}for(let o of e)try{let n=require(o);if(typeof n.setup!="function")continue;let s=await n.setup(this.client);await this.registerModules(s,o),t.push({file:o,result:!0})}catch(n){t.push({file:o,result:!1,error:n})}return t}async registerModule(t){Reflect.defineMetadata(X,this.client,t),this.registerEventListeners(t),await this.runModuleHook(t,"load"),this.extensions.push(t),this.logger.info(`Module registered: ${ot.default.green(t.constructor.name)}`)}async unregisterModule(t){this.unregisterEventListeners(t),await this.runModuleHook(t,"unload"),Dt.default.remove(this.extensions,e=>e===t),this.logger.info(`Module unregistered: ${ot.default.green(t.constructor.name)}`)}runModuleHook(t,e,...o){let s=et(t).get(e);if(s)for(let i of s)i.call(t,...o)}registerEventEmitter(t,e){this.emitters.set(t,e)}};c(P,"Registry")});var rt=m(()=>{"use strict";wt();Mt()});var j,b,nt=m(()=>{"use strict";O();$();j=class extends u{constructor(t){super(),this.options=t}};c(j,"ConverterComponent");b=c(r=>w(new j(r)),"argConverter")});var Gt,qt,N,St=m(()=>{"use strict";Gt=g(require("chalk")),qt=require("discord.js");nt();rt();N=class{get commandClient(){return M.getFromModule(this)}get client(){return this.commandClient.discord}get logger(){return this._logger||(this._logger=this.commandClient.logger.getChildLogger({prefix:[Gt.default.green(`[${this.constructor.name}]`)],displayFunctionName:!1})),this._logger}async convertArguments(t,e,o,n){let s=new qt.Collection;for(let i of this.commandClient.registry.extensions)for(let a of this.commandClient.registry.getComponentsWithType(i,j))a.options.component==t&&s.set(a.options.type,{component:a,ext:i});for(let[i,a]of o){let l=s.get(a.type);if(!l){e[i]=void 0;continue}let x=await n(a,i,l.component);e[i]=await l.component.execute(l.ext,x)}}};c(N,"Extension")});var Bt,I,vt=m(()=>{"use strict";Bt=g(require("chalk"));St();I=class extends N{get logger(){return this._logger||(this._logger=this.commandClient.ctsLogger.getChildLogger({prefix:[Bt.default.green(`[${this.constructor.name}]`)],displayFunctionName:!1})),this._logger}};c(I,"CTSExtension")});var _,p,V,C,h,zt=m(()=>{"use strict";_=g(require("chalk")),p=require("discord.js");yt();xt();J();Q();rt();nt();vt();V=function(r,t,e,o){var n=arguments.length,s=n<3?t:o===null?o=Object.getOwnPropertyDescriptor(t,e):o,i;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")s=Reflect.decorate(r,t,e,o);else for(var a=r.length-1;a>=0;a--)(i=r[a])&&(s=(n<3?i(s):n>3?i(t,e,s):i(t,e))||s);return n>3&&s&&Object.defineProperty(t,e,s),s},C=function(r,t){if(typeof Reflect=="object"&&typeof Reflect.metadata=="function")return Reflect.metadata(r,t)},h=class extends I{constructor(t){super(),this.config=t}async interactionCreate(t){var s;if(t.type!==p.InteractionType.ApplicationCommand)return;let e=null,o=null,n=this.commandClient.registry.extensions;for(let i of n){let a=this.commandClient.registry.getComponentsWithType(i,f);for(let l of a)l.options.name===t.commandName&&(o=i,e=l)}if(e&&o){let i=[];await this.convertArguments(f,i,e.argTypes,()=>[t]);for(let[a,l]of e.argTypes){let x=null;for(let d of l.decorators)if(d instanceof H){if([p.ApplicationCommandOptionType.Subcommand,p.ApplicationCommandOptionType.SubcommandGroup].includes(d.options.type)&&t.isChatInputCommand()){if(d.options.type===p.ApplicationCommandOptionType.Subcommand){x=t.options.getSubcommand()===d.options.name;break}if(d.options.type===p.ApplicationCommandOptionType.SubcommandGroup){x=t.options.getSubcommandGroup()===d.options.name;break}}x=(s=t.options.get(d.options.name,!1))==null?void 0:s.value;break}x&&(i[a]=x)}try{await e.execute(o,i,[t])}catch(a){this.commandClient.emit("applicationCommandInvokeError",a,t)}}}async load(){}async sync(){let t=M.getFromModule(this);this.logger.info("Trying to sync commands...");let e=[],o=new p.Collection;for(let n of t.registry.getComponentsWithTypeGlobal(f)){let s={...n.options};if(s.type===p.ApplicationCommandType.ChatInput){s.options=[];for(let[,i]of n.argTypes){let a=i.decorators.find(l=>l.constructor===H);a&&s.options.push(a.options)}}if(n.options.guilds){for(let i of n.options.guilds){let a=o.get(i);a||(a=[],o.set(i,a)),a.push(s)}continue}if(this.config.guilds){for(let i of this.config.guilds){let a=o.get(i);a||(a=[],o.set(i,a)),a.push(s)}continue}e.push(s)}if(o.size)for(let[n,s]of o){this.logger.info(`Processing ${_.default.green(s.length)} commands(${s.map(i=>_.default.blue(i.name)).join(", ")})`);try{let i=await this.client.guilds.fetch(n);await i.fetch(),this.logger.info(`Registering commands for guild ${_.default.green(i.name)}(${_.default.blue(i.id)})`),await i.commands.set(s),this.logger.info(`Successfully registered commands for guild ${_.default.green(i.name)}(${_.default.blue(i.id)})`)}catch(i){this.logger.error(`Failed to register commands to guild ${_.default.green(n)}: ${i.message}`)}}if(e.length)try{this.logger.info("Registering commands globally..."),await this.client.application.commands.set(e),this.logger.info("Successfully registered commands.")}catch(n){this.logger.error(`Failed to register commands to global: ${n.message}`)}}async chatInteraction(t){return t}async messageInteraction(t){return t}async userInteraction(t){return t}};c(h,"ApplicationCommandExtension");V([K({event:"interactionCreate"}),C("design:type",Function),C("design:paramtypes",[typeof p.Interaction>"u"?Object:p.Interaction])],h.prototype,"interactionCreate",null);V([Ct("load"),C("design:type",Function),C("design:paramtypes",[])],h.prototype,"load",null);V([b({component:f,parameterless:!0,type:p.ChatInputCommandInteraction}),C("design:type",Function),C("design:paramtypes",[typeof p.ChatInputCommandInteraction>"u"?Object:p.ChatInputCommandInteraction])],h.prototype,"chatInteraction",null);V([b({component:f,parameterless:!0,type:p.MessageContextMenuCommandInteraction}),C("design:type",Function),C("design:paramtypes",[typeof p.MessageContextMenuCommandInteraction>"u"?Object:p.MessageContextMenuCommandInteraction])],h.prototype,"messageInteraction",null);V([b({component:f,parameterless:!0,type:p.UserContextMenuCommandInteraction}),C("design:type",Function),C("design:paramtypes",[typeof p.UserContextMenuCommandInteraction>"u"?Object:p.UserContextMenuCommandInteraction])],h.prototype,"userInteraction",null)});var y,ae,Rt=m(()=>{"use strict";$();O();y=class extends u{constructor(t){super(),this.options=t}};c(y,"TextCommandComponent");ae=c(r=>w(new y(r)),"command")});var L,me,kt=m(()=>{"use strict";D();D();L=class extends R{};c(L,"TextCommandRestOption");me=Z(L)});var G,st,F,S,Ut=m(()=>{"use strict";Q();G=require("discord.js");vt();Rt();kt();D();st=function(r,t,e,o){var n=arguments.length,s=n<3?t:o===null?o=Object.getOwnPropertyDescriptor(t,e):o,i;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")s=Reflect.decorate(r,t,e,o);else for(var a=r.length-1;a>=0;a--)(i=r[a])&&(s=(n<3?i(s):n>3?i(t,e,s):i(t,e))||s);return n>3&&s&&Object.defineProperty(t,e,s),s},F=function(r,t){if(typeof Reflect=="object"&&typeof Reflect.metadata=="function")return Reflect.metadata(r,t)},S=class extends I{constructor(t){super(),this.config=t}async processPrefix(t){let e=t.content,o=this.config.prefix;if(typeof o=="function"&&(o=await o(t)),typeof o=="string")return e.startsWith(o)?o.length:null;if(o instanceof Array){let n=o.find(s=>e.startsWith(s));return n?n.length:null}return null}async messageCreate(t){let e=await this.processPrefix(t);if(!e)return;let o=t.content.slice(e),n=[],s=new Map;for(let v of this.commandClient.registry.extensions)for(let E of this.commandClient.registry.getComponentsWithType(v,y))n.push(E),s.set(E,v);let i=0,a=n.find(v=>{let E=[v.options.name];v.options.aliases&&E.push(...v.options.aliases);for(let T of E)if(o.startsWith(T))return o.length===T.length?(i=T.length,!0):(i=T.length,o.startsWith(T+" "));return!1});if(!a)return;let l=s.get(a);if(!l)return;let x=[],d=o.slice(i+1).split(/ /g);await this.convertArguments(y,x,a.argTypes,async(v,E,T)=>{if(T.options.parameterless)return[t];if(v.decorators.find(mt=>mt.constructor===L)){let mt=d.join(" ");return d=[],[mt,t]}return[d.shift(),t]}),await a.execute(l,x,[t])}async mesage(t){return t}async str(t){return t}async num(t){return Number(t)}};c(S,"TextCommandExtension");st([K({event:"messageCreate",emitter:"discord"}),F("design:type",Function),F("design:paramtypes",[typeof G.Message>"u"?Object:G.Message])],S.prototype,"messageCreate",null);st([b({component:y,type:G.Message,parameterless:!0}),F("design:type",Function),F("design:paramtypes",[typeof G.Message>"u"?Object:G.Message])],S.prototype,"mesage",null);st([b({component:y,type:String}),F("design:type",Function),F("design:paramtypes",[String])],S.prototype,"str",null);st([b({component:y,type:Number}),F("design:type",Function),F("design:paramtypes",[String])],S.prototype,"num",null)});var Kt={};Tt(Kt,{CommandClient:()=>M});var it,ct,Zt,Jt,M,Mt=m(()=>{"use strict";it=g(require("chalk")),ct=require("discord.js"),Zt=g(require("events")),Jt=require("tslog");zt();Ut();W();wt();M=class extends Zt.default{constructor(t,e=new Jt.Logger({dateTimeTimezone:Intl.DateTimeFormat().resolvedOptions().timeZone})){super(),this.discord=t,this.logger=e,this.owners=new Set,this.ctsLogger=e.getChildLogger({prefix:[it.default.blue("[command.ts]")],displayFilePath:"hidden",displayFunctionName:!1}),this.registry=new P(this.ctsLogger,this),this.registry.registerEventEmitter("cts",this),this.registry.registerEventEmitter("discord",this.discord)}async fetchOwners(){if(!this.discord.application)throw new Error("The client is not logged in.");this.ctsLogger.info("Fetching owners..."),await this.discord.application.fetch();let t=this.discord.application.owner;if(!t)throw new Error("Cannot find application owner");let e=[];if(t instanceof ct.User)this.owners.add(t.id),e.push(t.tag);else if(t instanceof ct.Team)for(let[o,n]of t.members)this.owners.add(o),e.push(n.user.tag);this.ctsLogger.info(`Fetched ${it.default.green(e.length)} owners(${e.map(o=>it.default.blue(o)).join(", ")})`)}async enableApplicationCommandsExtension(t){await this.registry.registerModule(new h(t)),this.ctsLogger.info("Application command extension enabled.")}async enableTextCommandsExtension(t){await this.registry.registerModule(new S(t)),this.ctsLogger.info("Text command extension enabled.")}getApplicationCommandsExtension(){return this.registry.extensions.find(t=>t.constructor===h)}static getFromModule(t){return Reflect.getMetadata(X,t)}};c(M,"CommandClient")});var _t,u,O=m(()=>{"use strict";_t=require("discord.js");ht();u=class{hooks=new _t.Collection;argTypes=new _t.Collection;_init(t,e){this.method=t;for(let o=0;o<e.length;o++){let n=e[o];this.argTypes.set(o,new A(n))}}async executeHook(t,e,o){let n=this.hooks.get(e);if(!n)return;let{CommandClient:s}=await Promise.resolve().then(()=>(Mt(),Kt));for(let i of n)await i.call(null,s.getFromModule(t),...o)}async execute(t,e,o=e){await this.executeHook(t,"beforeCall",o);let n;try{n=await this.method.call(t,...e)}catch(s){throw await this.executeHook(t,"invokeError",[s]),s}return await this.executeHook(t,"afterCall",[n]),n}};c(u,"BaseComponent")});var vo,bt=m(()=>{"use strict";vo=require("reflect-metadata");$();ht();Lt();O()});var q,Ft=m(()=>{"use strict";q=class{};c(q,"OwnerOnlyError")});var at,Qt,pe,Vt=m(()=>{"use strict";at=require("discord.js");J();Ft();Qt=c(r=>tt("beforeCall",r),"createCheckDecorator"),pe=Qt(async(r,t)=>{let e=!1;if(t instanceof at.BaseInteraction?e=r.owners.has(t.user.id):t instanceof at.Message&&(e=r.owners.has(t.author.id)),!e)throw new q})});var Xt=m(()=>{"use strict";Vt();Ft()});var Yt=m(()=>{"use strict";St()});var D=m(()=>{"use strict";bt();J();nt();Xt();Q();rt();Yt()});var le={};Tt(le,{ApplicationCommandComponent:()=>f,BaseComponent:()=>u,CommandClient:()=>M,ComponentArgument:()=>A,ComponentArgumentDecorator:()=>R,ConverterComponent:()=>j,Extension:()=>N,ListenerComponent:()=>k,OwnerOnlyError:()=>q,Registry:()=>P,TextCommandComponent:()=>y,TextCommandRestOption:()=>L,applicationCommand:()=>ce,argConverter:()=>b,command:()=>ae,createArgumentDecorator:()=>Z,createCheckDecorator:()=>Qt,createComponentDecorator:()=>w,createComponentHook:()=>tt,getComponent:()=>ie,getComponentArgumentStore:()=>gt,getComponentStore:()=>U,getModuleHookStore:()=>et,listener:()=>K,moduleHook:()=>Ct,option:()=>Et,ownerOnly:()=>pe,rest:()=>me});module.exports=se(le);D();yt();xt();Rt();kt();0&&(module.exports={ApplicationCommandComponent,BaseComponent,CommandClient,ComponentArgument,ComponentArgumentDecorator,ConverterComponent,Extension,ListenerComponent,OwnerOnlyError,Registry,TextCommandComponent,TextCommandRestOption,applicationCommand,argConverter,command,createArgumentDecorator,createCheckDecorator,createComponentDecorator,createComponentHook,getComponent,getComponentArgumentStore,getComponentStore,getModuleHookStore,listener,moduleHook,option,ownerOnly,rest});
1
+ "use strict";var oe=Object.create;var B=Object.defineProperty;var ne=Object.getOwnPropertyDescriptor;var re=Object.getOwnPropertyNames;var se=Object.getPrototypeOf,ie=Object.prototype.hasOwnProperty;var c=(n,t)=>B(n,"name",{value:t,configurable:!0});var l=(n,t)=>()=>(n&&(t=n(n=0)),t);var jt=(n,t)=>{for(var e in t)B(n,e,{get:t[e],enumerable:!0})},Ht=(n,t,e,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of re(t))!ie.call(n,s)&&s!==e&&B(n,s,{get:()=>t[s],enumerable:!(o=ne(t,s))||o.enumerable});return n};var x=(n,t,e)=>(e=n!=null?oe(se(n)):{},Ht(t||!n||!n.__esModule?B(e,"default",{value:n,enumerable:!0}):e,n)),ce=n=>Ht(B({},"__esModule",{value:!0}),n);var z,he,ft,X,ut,Y,E=l(()=>{"use strict";z=Symbol(),he=Symbol(),ft=Symbol(),X=Symbol(),ut=Symbol(),Y=Symbol()});var Lt,dt,tt,gt=l(()=>{"use strict";Lt=require("discord.js");E();dt=c((n,t)=>{let e=Reflect.getMetadata(ut,n,t);return e||(e=new Lt.Collection,Reflect.defineMetadata(ut,e,n,t)),e},"getComponentHookStore"),tt=c((n,t)=>(e,o)=>{let s=dt(e,o),r=s.get(n);r||(r=[],s.set(n,r)),r.push(t)},"createComponentHook")});var ht,U,ae,h,yt,Z,O=l(()=>{"use strict";ht=require("discord.js");gt();E();U=c(n=>{let t=Reflect.getMetadata(z,n);return t||(t=new ht.Collection,Reflect.defineMetadata(z,t,n)),t},"getComponentStore"),ae=c((n,t)=>U(n).get(t),"getComponent"),h=c(n=>(t,e)=>{n._init(Reflect.get(t,e),Reflect.getMetadata("design:paramtypes",t,e));let o=dt(t,e);n.hooks=o;let s=U(t);yt(t,e).forEach((a,i)=>{var m;(m=n.argTypes.get(i))==null||m.decorators.push(a)}),s.set(e,n)},"createComponentDecorator"),yt=c((n,t)=>{let e=Reflect.getMetadata(z,n,t);return e||(e=new ht.Collection,Reflect.defineMetadata(z,e,n,t)),e},"getComponentArgumentStore"),Z=c(n=>t=>(e,o,s)=>{var r=new n(t);yt(e,o).set(s,r)},"createArgumentDecorator")});var W,xt=l(()=>{"use strict";W=class{constructor(t){this.type=t,this.decorators=[]}};c(W,"ComponentArgument")});var $t,R,At=l(()=>{"use strict";$t=x(require("lodash")),R=class{constructor(t){typeof t=="object"?this.options=$t.default.merge(this.defaultOptions(),t):this.options=t}defaultOptions(){return{}}};c(R,"ComponentArgumentDecorator")});var d,me,et=l(()=>{"use strict";O();G();d=class extends y{constructor(t){super(),this.options=t}};c(d,"ApplicationCommandComponent");me=c(n=>h(new d(n)),"applicationCommand")});var F,Et,Ct=l(()=>{"use strict";T();F=class extends R{};c(F,"ApplicationCommandOption");Et=Z(F)});var Ot,_,J,K=l(()=>{"use strict";Ot=x(require("lodash"));G();O();_=class extends y{constructor(t){super(),this.options=Ot.default.merge({emitter:"discord"},t)}};c(_,"ListenerComponent");J=c(n=>h(new _(n)),"listener")});var j,w,ot=l(()=>{"use strict";G();O();j=class extends y{constructor(t){super(),this.options=t}};c(j,"ConverterComponent");w=c(n=>h(new j(n)),"argConverter")});var Wt,nt,pe,Gt=l(()=>{"use strict";Wt=require("discord.js");E();nt=c(n=>{let t=Reflect.getMetadata(ft,n);return t||(t=new Wt.Collection,Reflect.defineMetadata(ft,t,n)),t},"getModuleHookStore"),pe=c(n=>(t,e)=>{let o=nt(t),s=o.get(n);s||(s=[],o.set(n,s)),s.push(Reflect.get(t,e))},"moduleHook")});var rt=l(()=>{"use strict";Gt();gt()});var st,Dt,Pt,Nt,qt,D,bt=l(()=>{"use strict";st=x(require("chalk")),Dt=require("discord.js"),Pt=x(require("lodash"));wt();rt();K();E();Nt=x(require("walk-sync")),qt=x(require("path")),D=class{constructor(t,e){this.client=e,this.extensions=[],this.emitters=new Dt.Collection,this.logger=t.getChildLogger({prefix:[st.default.green("[Registry]")]})}getComponentsWithTypeGlobal(t){let e=[];for(let o of this.extensions)e.push(...this.getComponentsWithType(o,t));return e}getComponentsWithType(t,e){let o=U(t);return Array.from(o.filter(s=>s.constructor===e).values())}registerEventListeners(t){let e=this.getComponentsWithType(t,_);for(let o of e){let s=this.emitters.get(o.options.emitter);if(s){let r=o.method.bind(t);Reflect.defineMetadata("bound",r,o),s.addListener(o.options.event,r)}}}unregisterEventListeners(t){let e=this.getComponentsWithType(t,_);for(let o of e){let s=this.emitters.get(o.options.emitter),r=Reflect.getMetadata("bound",o);s&&r&&s.removeListener(o.options.event,r)}}async loadAllModulesInDirectory(t){let e=[],o=(0,Nt.default)(t).filter(s=>s.endsWith(".ts")||s.endsWith(".js"));for(let s of o)if(!s.endsWith(".d.ts"))try{let r=qt.default.join(t,s),a=require(r);if(typeof a.setup!="function")continue;let i=await a.setup();e.push(...await this.registerModules(i,r))}catch{this.logger.error(`Failed to load ${s}`)}return e}async registerModules(t,e){let o=[];if(t instanceof Array)for(let s of t)await this.registerModule(s),Reflect.defineMetadata(Y,e,s),o.push(s);else await this.registerModule(t),Reflect.defineMetadata(Y,e,t),o.push(t);return o}async reloadModules(){let t=[],e=new Set;for(let o of this.extensions){let s=Reflect.getMetadata(Y,o);!s||(e.add(s),await this.unregisterModule(o),delete require.cache[require.resolve(s)])}for(let o of e)try{let s=require(o);if(typeof s.setup!="function")continue;let r=await s.setup(this.client);await this.registerModules(r,o),t.push({file:o,result:!0})}catch(s){t.push({file:o,result:!1,error:s})}return t}async registerModule(t){Reflect.defineMetadata(X,this.client,t),this.registerEventListeners(t),await this.runModuleHook(t,"load"),this.extensions.push(t),this.logger.info(`Module registered: ${st.default.green(t.constructor.name)}`)}async unregisterModule(t){this.unregisterEventListeners(t),await this.runModuleHook(t,"unload"),Pt.default.remove(this.extensions,e=>e===t),this.logger.info(`Module unregistered: ${st.default.green(t.constructor.name)}`)}runModuleHook(t,e,...o){let r=nt(t).get(e);if(r)for(let a of r)a.call(t,...o)}registerEventEmitter(t,e){this.emitters.set(t,e)}};c(D,"Registry")});var Mt=l(()=>{"use strict";bt();St()});var Bt,zt,P,vt=l(()=>{"use strict";Bt=x(require("chalk")),zt=require("discord.js");ot();Mt();P=class{get commandClient(){return H.getFromModule(this)}get client(){return this.commandClient.discord}get logger(){return this._logger||(this._logger=this.commandClient.logger.getChildLogger({prefix:[Bt.default.green(`[${this.constructor.name}]`)],displayFunctionName:!1})),this._logger}async convertArguments(t,e,o,s){let r=new zt.Collection;for(let a of this.commandClient.registry.extensions)for(let i of this.commandClient.registry.getComponentsWithType(a,j))i.options.component==t&&r.set(i.options.type,{component:i,ext:a});for(let[a,i]of o){let m=r.get(i.type);if(!m){e[a]=void 0;continue}let f=await s(i,a,m.component);e[a]=await m.component.execute(m.ext,f)}}};c(P,"Extension")});var Ut,L,Rt=l(()=>{"use strict";Ut=x(require("chalk"));vt();L=class extends P{get logger(){return this._logger||(this._logger=this.commandClient.ctsLogger.getChildLogger({prefix:[Ut.default.green(`[${this.constructor.name}]`)],displayFunctionName:!1})),this._logger}};c(L,"CTSExtension")});var M,p,Q,S,C,Zt=l(()=>{"use strict";M=x(require("chalk")),p=require("discord.js");et();Ct();K();ot();Rt();Q=function(n,t,e,o){var s=arguments.length,r=s<3?t:o===null?o=Object.getOwnPropertyDescriptor(t,e):o,a;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")r=Reflect.decorate(n,t,e,o);else for(var i=n.length-1;i>=0;i--)(a=n[i])&&(r=(s<3?a(r):s>3?a(t,e,r):a(t,e))||r);return s>3&&r&&Object.defineProperty(t,e,r),r},S=function(n,t){if(typeof Reflect=="object"&&typeof Reflect.metadata=="function")return Reflect.metadata(n,t)},C=class extends L{constructor(t){super(),this.config=t}async interactionCreate(t){var r;if(t.type!==p.InteractionType.ApplicationCommand)return;let e=null,o=null,s=this.commandClient.registry.extensions;for(let a of s){let i=this.commandClient.registry.getComponentsWithType(a,d);for(let m of i)m.options.name===t.commandName&&(o=a,e=m)}if(e&&o){let a=[];await this.convertArguments(d,a,e.argTypes,()=>[t]);for(let[i,m]of e.argTypes){let f=null;for(let u of m.decorators)if(u instanceof F){if([p.ApplicationCommandOptionType.Subcommand,p.ApplicationCommandOptionType.SubcommandGroup].includes(u.options.type)&&t.isChatInputCommand()){if(u.options.type===p.ApplicationCommandOptionType.Subcommand){f=t.options.getSubcommand()===u.options.name;break}if(u.options.type===p.ApplicationCommandOptionType.SubcommandGroup){f=t.options.getSubcommandGroup()===u.options.name;break}}f=(r=t.options.get(u.options.name,!1))==null?void 0:r.value;break}f&&(a[i]=f)}try{await e.execute(o,a,[t])}catch(i){this.commandClient.emit("applicationCommandInvokeError",i,t)}}}async sync(){let t=this.commandClient;this.logger.info("Trying to sync commands...");let e=[],o=new p.Collection,s=new p.Collection;for(let r of t.registry.getComponentsWithTypeGlobal(d)){if(r.subcommandGroup){let i=s.get(r.subcommandGroup.options.name);if(!i){if(i={...r.subcommandGroup.options,type:p.ApplicationCommandType.ChatInput},r.subcommandGroup.guilds)for(let m of r.subcommandGroup.guilds){let f=o.get(m);f||(f=[],o.set(m,f))}else e.push(i);s.set(r.subcommandGroup.options.name,i)}i.options||(i.options=[]),i.options.push({...r.options,type:p.ApplicationCommandOptionType.Subcommand});continue}else if(r.subcommandGroupChild){let i=r.subcommandGroupChild.parent,m=s.get(i.options.name);if(!m){if(m={...i.options,type:p.ApplicationCommandType.ChatInput},i.guilds)for(let u of i.guilds){let g=o.get(u);g||(g=[],o.set(u,g))}else e.push(m);s.set(i.options.name,m)}m.options||(m.options=[]);let f=m.options.find(u=>u.name===r.subcommandGroupChild.options.name);f||(f={type:p.ApplicationCommandOptionType.SubcommandGroup,...r.subcommandGroupChild.options},m.options.push(f)),f.options||(f.options=[]),f.options.push({...r.options,type:p.ApplicationCommandOptionType.Subcommand});continue}let a={...r.options};if(a.type===p.ApplicationCommandType.ChatInput){a.options=[];for(let[,i]of r.argTypes){let m=i.decorators.find(f=>f.constructor===F);m&&a.options.push(m.options)}}if(r.options.guilds){for(let i of r.options.guilds){let m=o.get(i);m||(m=[],o.set(i,m))}continue}e.push(a)}if(this.config.guilds){for(let r of this.config.guilds){let a=o.get(r);a||(a=[],o.set(r,a)),a.push(...e)}e=[]}if(o.size)for(let[r,a]of o)try{let i=await this.client.guilds.fetch(r);await i.fetch(),this.logger.info(`Processing ${M.default.green(a.length)} commands(${a.map(m=>M.default.blue(m.name)).join(", ")}) for guild ${M.default.green(i.name)}(${M.default.blue(i.id)})`),await i.commands.set(a),this.logger.info(`Successfully registered commands for guild ${M.default.green(i.name)}(${M.default.blue(i.id)})`)}catch(i){this.logger.error(`Failed to register commands to guild ${M.default.green(r)}: ${i.message}`)}if(e.length)try{this.logger.info(`Processing ${M.default.green(e.length)} commands(${e.map(r=>M.default.blue(r.name)).join(", ")}) for application scope...`),await this.client.application.commands.set(e),this.logger.info("Successfully registered commands.")}catch(r){this.logger.error(`Failed to register commands to global: ${r.message}`)}}async chatInteraction(t){return t}async messageInteraction(t){return t}async userInteraction(t){return t}async commandInteraction(t){return t}};c(C,"ApplicationCommandExtension");Q([J({event:"interactionCreate"}),S("design:type",Function),S("design:paramtypes",[typeof p.Interaction>"u"?Object:p.Interaction])],C.prototype,"interactionCreate",null);Q([w({component:d,parameterless:!0,type:p.ChatInputCommandInteraction}),S("design:type",Function),S("design:paramtypes",[typeof p.ChatInputCommandInteraction>"u"?Object:p.ChatInputCommandInteraction])],C.prototype,"chatInteraction",null);Q([w({component:d,parameterless:!0,type:p.MessageContextMenuCommandInteraction}),S("design:type",Function),S("design:paramtypes",[typeof p.MessageContextMenuCommandInteraction>"u"?Object:p.MessageContextMenuCommandInteraction])],C.prototype,"messageInteraction",null);Q([w({component:d,parameterless:!0,type:p.UserContextMenuCommandInteraction}),S("design:type",Function),S("design:paramtypes",[typeof p.UserContextMenuCommandInteraction>"u"?Object:p.UserContextMenuCommandInteraction])],C.prototype,"userInteraction",null);Q([w({component:d,parameterless:!0,type:p.CommandInteraction}),S("design:type",Function),S("design:paramtypes",[typeof p.UserContextMenuCommandInteraction>"u"?Object:p.UserContextMenuCommandInteraction])],C.prototype,"commandInteraction",null)});var b,le,_t=l(()=>{"use strict";O();G();b=class extends y{constructor(t){super(),this.options=t}};c(b,"TextCommandComponent");le=c(n=>h(new b(n)),"command")});var $,fe,kt=l(()=>{"use strict";T();T();$=class extends R{};c($,"TextCommandRestOption");fe=Z($)});var N,it,k,v,Jt=l(()=>{"use strict";K();N=require("discord.js");Rt();_t();kt();T();it=function(n,t,e,o){var s=arguments.length,r=s<3?t:o===null?o=Object.getOwnPropertyDescriptor(t,e):o,a;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")r=Reflect.decorate(n,t,e,o);else for(var i=n.length-1;i>=0;i--)(a=n[i])&&(r=(s<3?a(r):s>3?a(t,e,r):a(t,e))||r);return s>3&&r&&Object.defineProperty(t,e,r),r},k=function(n,t){if(typeof Reflect=="object"&&typeof Reflect.metadata=="function")return Reflect.metadata(n,t)},v=class extends L{constructor(t){super(),this.config=t}async processPrefix(t){let e=t.content,o=this.config.prefix;if(typeof o=="function"&&(o=await o(t)),typeof o=="string")return e.startsWith(o)?o.length:null;if(o instanceof Array){let s=o.find(r=>e.startsWith(r));return s?s.length:null}return null}async messageCreate(t){let e=await this.processPrefix(t);if(!e)return;let o=t.content.slice(e),s=[],r=new Map;for(let g of this.commandClient.registry.extensions)for(let A of this.commandClient.registry.getComponentsWithType(g,b))s.push(A),r.set(A,g);let a=0,i=s.find(g=>{let A=[g.options.name];g.options.aliases&&A.push(...g.options.aliases);for(let I of A)if(o.startsWith(I))return o.length===I.length?(a=I.length,!0):(a=I.length,o.startsWith(I+" "));return!1});if(!i)return;let m=r.get(i);if(!m)return;let f=[],u=o.slice(a+1).split(/ /g);await this.convertArguments(b,f,i.argTypes,async(g,A,I)=>{if(I.options.parameterless)return[t];if(g.decorators.find(lt=>lt.constructor===$)){let lt=u.join(" ");return u=[],[lt,t]}return[u.shift(),t]}),await i.execute(m,f,[t])}async mesage(t){return t}async str(t){return t}async num(t){return Number(t)}};c(v,"TextCommandExtension");it([J({event:"messageCreate",emitter:"discord"}),k("design:type",Function),k("design:paramtypes",[typeof N.Message>"u"?Object:N.Message])],v.prototype,"messageCreate",null);it([w({component:b,type:N.Message,parameterless:!0}),k("design:type",Function),k("design:paramtypes",[typeof N.Message>"u"?Object:N.Message])],v.prototype,"mesage",null);it([w({component:b,type:String}),k("design:type",Function),k("design:paramtypes",[String])],v.prototype,"str",null);it([w({component:b,type:Number}),k("design:type",Function),k("design:paramtypes",[String])],v.prototype,"num",null)});var Vt={};jt(Vt,{CommandClient:()=>H});var ct,at,Kt,Qt,H,St=l(()=>{"use strict";ct=x(require("chalk")),at=require("discord.js"),Kt=x(require("events")),Qt=require("tslog");Zt();Jt();E();bt();H=class extends Kt.default{constructor(t,e=new Qt.Logger({dateTimeTimezone:Intl.DateTimeFormat().resolvedOptions().timeZone})){super(),this.discord=t,this.logger=e,this.owners=new Set,this.ctsLogger=e.getChildLogger({prefix:[ct.default.blue("[command.ts]")],displayFilePath:"hidden",displayFunctionName:!1}),this.registry=new D(this.ctsLogger,this),this.registry.registerEventEmitter("cts",this),this.registry.registerEventEmitter("discord",this.discord)}async fetchOwners(){if(!this.discord.application)throw new Error("The client is not logged in.");this.ctsLogger.info("Fetching owners..."),await this.discord.application.fetch();let t=this.discord.application.owner;if(!t)throw new Error("Cannot find application owner");let e=[];if(t instanceof at.User)this.owners.add(t.id),e.push(t.tag);else if(t instanceof at.Team)for(let[o,s]of t.members)this.owners.add(o),e.push(s.user.tag);this.ctsLogger.info(`Fetched ${ct.default.green(e.length)} owners(${e.map(o=>ct.default.blue(o)).join(", ")})`)}async enableApplicationCommandsExtension(t){await this.registry.registerModule(new C(t)),this.ctsLogger.info("Application command extension enabled.")}async enableTextCommandsExtension(t){await this.registry.registerModule(new v(t)),this.ctsLogger.info("Text command extension enabled.")}getApplicationCommandsExtension(){return this.registry.extensions.find(t=>t.constructor===C)}static getFromModule(t){return Reflect.getMetadata(X,t)}};c(H,"CommandClient")});var It,y,G=l(()=>{"use strict";It=require("discord.js");xt();y=class{hooks=new It.Collection;argTypes=new It.Collection;_init(t,e){this.method=t;for(let o=0;o<e.length;o++){let s=e[o];this.argTypes.set(o,new W(s))}}async executeHook(t,e,o){let s=this.hooks.get(e);if(!s)return;let{CommandClient:r}=await Promise.resolve().then(()=>(St(),Vt));for(let a of s)await a.call(null,r.getFromModule(t),...o)}async execute(t,e,o=e){await this.executeHook(t,"beforeCall",o);let s;try{s=await this.method.call(t,...e)}catch(r){throw await this.executeHook(t,"invokeError",[r]),r}return await this.executeHook(t,"afterCall",[s]),s}};c(y,"BaseComponent")});var Ro,wt=l(()=>{"use strict";Ro=require("reflect-metadata");O();xt();At();G()});var q,Ft=l(()=>{"use strict";q=class{};c(q,"OwnerOnlyError")});var mt,Xt,ue,Yt=l(()=>{"use strict";mt=require("discord.js");rt();Ft();Xt=c(n=>tt("beforeCall",n),"createCheckDecorator"),ue=Xt(async(n,t)=>{let e=!1;if(t instanceof mt.BaseInteraction?e=n.owners.has(t.user.id):t instanceof mt.Message&&(e=n.owners.has(t.author.id)),!e)throw new q})});var te=l(()=>{"use strict";Yt();Ft()});var ee=l(()=>{"use strict";vt()});var T=l(()=>{"use strict";wt();rt();ot();te();K();Mt();ee()});var de={};jt(de,{ApplicationCommandComponent:()=>d,BaseComponent:()=>y,CommandClient:()=>H,ComponentArgument:()=>W,ComponentArgumentDecorator:()=>R,ConverterComponent:()=>j,Extension:()=>P,ListenerComponent:()=>_,OwnerOnlyError:()=>q,Registry:()=>D,SubCommandGroup:()=>pt,SubCommandGroupChild:()=>V,TextCommandComponent:()=>b,TextCommandRestOption:()=>$,applicationCommand:()=>me,argConverter:()=>w,command:()=>le,createArgumentDecorator:()=>Z,createCheckDecorator:()=>Xt,createComponentDecorator:()=>h,createComponentHook:()=>tt,getComponent:()=>ae,getComponentArgumentStore:()=>yt,getComponentStore:()=>U,getModuleHookStore:()=>nt,listener:()=>J,moduleHook:()=>pe,option:()=>Et,ownerOnly:()=>ue,rest:()=>fe});module.exports=ce(de);T();et();Ct();var Tt=require("discord.js");T();et();var pt=class{constructor(t,e){this.options=t,this.guilds=e}command(t){let e=new d({type:Tt.ApplicationCommandType.ChatInput,...t});return e.subcommandGroup=this,h(e)}createChild(t){return new V(t,this)}};c(pt,"SubCommandGroup");var V=class{constructor(t,e){this.options=t,this.parent=e}command(t){let e=new d({type:Tt.ApplicationCommandType.ChatInput,...t});return e.subcommandGroupChild=this,h(e)}};c(V,"SubCommandGroupChild");_t();kt();0&&(module.exports={ApplicationCommandComponent,BaseComponent,CommandClient,ComponentArgument,ComponentArgumentDecorator,ConverterComponent,Extension,ListenerComponent,OwnerOnlyError,Registry,SubCommandGroup,SubCommandGroupChild,TextCommandComponent,TextCommandRestOption,applicationCommand,argConverter,command,createArgumentDecorator,createCheckDecorator,createComponentDecorator,createComponentHook,getComponent,getComponentArgumentStore,getComponentStore,getModuleHookStore,listener,moduleHook,option,ownerOnly,rest});
2
2
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/core/symbols.ts","../src/core/hooks/componentHook.ts","../src/core/components/decoratorCreator.ts","../src/core/components/ComponentArgument.ts","../src/core/components/ComponentArgumentDecorator.ts","../src/applicationCommand/ApplicationCommand.ts","../src/applicationCommand/ApplicationCommandOption.ts","../src/core/hooks/moduleHook.ts","../src/core/hooks/index.ts","../src/core/listener/index.ts","../src/core/structures/Registry.ts","../src/core/structures/index.ts","../src/core/converter/index.ts","../src/core/extensions/Extension.ts","../src/core/extensions/CTSExtension.ts","../src/applicationCommand/ApplicationCommandExtension.ts","../src/textCommand/TextCommand.ts","../src/textCommand/parameters.ts","../src/textCommand/TextCommandExtension.ts","../src/core/structures/CommandClient.ts","../src/core/components/BaseComponent.ts","../src/core/components/index.ts","../src/core/utils/errors.ts","../src/core/utils/checks.ts","../src/core/utils/index.ts","../src/core/extensions/index.ts","../src/core/index.ts","../src/index.ts"],"sourcesContent":["/*\r\n * File: symbols.ts\r\n *\r\n * Copyright (c) 2022-2022 pikokr\r\n *\r\n * Licensed under MIT License. Please see more defails in LICENSE file.\r\n */\r\n\r\nexport const ComponentStoreSymbol = Symbol()\r\nexport const ComponentArgStoreSymbol = Symbol()\r\nexport const ModuleHookStoreSymbol = Symbol()\r\nexport const CommandClientSymbol = Symbol()\r\nexport const ComponentHookSymbol = Symbol()\r\nexport const FilePathSymbol = Symbol()\r\n","/*\r\n* File: componentHook.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport { Collection } from 'discord.js'\nimport { ComponentHookSymbol } from '../symbols'\n\nexport type ComponentHookFn = (...args: any[]) => void | Promise<void>\n\nexport type ComponentHookStore = Collection<string, ComponentHookFn[]>\n\nexport const getComponentHookStore = (target: object, property: string | symbol): ComponentHookStore => {\n let data = Reflect.getMetadata(ComponentHookSymbol, target, property) as ComponentHookStore\n\n if (!data) {\n data = new Collection()\n Reflect.defineMetadata(ComponentHookSymbol, data, target, property)\n }\n\n return data\n}\n\nexport const createComponentHook = (name: string, fn: ComponentHookFn): MethodDecorator => {\n return (target, key) => {\n const store = getComponentHookStore(target, key)\n\n let hooks = store.get(name)\n\n if (!hooks) {\n hooks = []\n store.set(name, hooks)\n }\n\n hooks.push(fn)\n }\n}\n","/*\n * File: decoratorCreator.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport { Collection } from 'discord.js'\nimport { ComponentHookStore } from '../hooks'\nimport { getComponentHookStore } from '../hooks/componentHook'\nimport { ComponentStoreSymbol } from '../symbols'\nimport { BaseComponent } from './BaseComponent'\nimport { ComponentArgumentDecorator } from './ComponentArgumentDecorator'\n\ntype ComponentStore = Collection<string | symbol, BaseComponent>\ntype ComponentArgumentStore = Collection<number, ComponentArgumentDecorator>\n\nexport const getComponentStore = (target: object): ComponentStore => {\n let result: ComponentStore | null = Reflect.getMetadata(ComponentStoreSymbol, target)\n\n if (!result) {\n result = new Collection()\n\n Reflect.defineMetadata(ComponentStoreSymbol, result, target)\n }\n\n return result\n}\n\nexport const getComponent = (target: object, key: string | symbol) => {\n const store = getComponentStore(target)\n\n return store.get(key)\n}\n\nexport const createComponentDecorator = (component: BaseComponent): MethodDecorator => {\n return (target, key) => {\n component._init(Reflect.get(target, key), Reflect.getMetadata('design:paramtypes', target, key))\n\n const componentHookStore: ComponentHookStore = getComponentHookStore(target, key)\n\n component.hooks = componentHookStore\n\n const store = getComponentStore(target)\n\n const decorators = getComponentArgumentStore(target, key)\n\n decorators.forEach((x, i) => {\n component.argTypes.get(i)?.decorators.push(x)\n })\n\n store.set(key, component)\n }\n}\n\nexport const getComponentArgumentStore = (target: object, key: string | symbol): ComponentArgumentStore => {\n let result: ComponentArgumentStore | null = Reflect.getMetadata(ComponentStoreSymbol, target, key)\n\n if (!result) {\n result = new Collection()\n\n Reflect.defineMetadata(ComponentStoreSymbol, result, target, key)\n }\n\n return result\n}\n\nexport const createArgumentDecorator = <Options>(type: typeof ComponentArgumentDecorator<Options>) => {\n return (options: Options): ParameterDecorator => {\n return (target, key, idx) => {\n var arg: ComponentArgumentDecorator<Options> = new type(options)\n\n const store = getComponentArgumentStore(target, key)\n\n store.set(idx, arg)\n }\n }\n}\n","/*\r\n* File: ComponentArgument.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport { ComponentArgumentDecorator } from './ComponentArgumentDecorator'\n\nexport class ComponentArgument {\n decorators: ComponentArgumentDecorator[] = []\n\n constructor(public type: unknown) {}\n}\n","/*\r\n* File: ComponentArgumentDecorator.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport _ from 'lodash'\n\nexport class ComponentArgumentDecorator<Options = unknown> {\n options: Options\n\n constructor(options: Partial<Options>) {\n if (typeof options === 'object') {\n this.options = _.merge(this.defaultOptions(), options)\n } else {\n this.options = options\n }\n }\n\n defaultOptions(): Options {\n return {} as unknown as Options\n }\n}\n","/*\n * File: ApplicationCommand.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport type { ApplicationCommandType, ChatInputApplicationCommandData, MessageApplicationCommandData, Snowflake, UserApplicationCommandData } from 'discord.js'\nimport { createComponentDecorator } from '../core/components/decoratorCreator'\nimport { BaseComponent } from '../core/components/BaseComponent'\n\ntype Options = (UserApplicationCommandData | MessageApplicationCommandData | Omit<ChatInputApplicationCommandData, 'options'>) & {\n type: ApplicationCommandType\n guilds?: Snowflake[]\n}\n\nexport class ApplicationCommandComponent extends BaseComponent {\n options: Options\n\n constructor(options: UserApplicationCommandData | MessageApplicationCommandData | Omit<ChatInputApplicationCommandData, 'options'>) {\n super()\n\n this.options = options as Options\n }\n}\n\nexport const applicationCommand = (options: Options) => createComponentDecorator(new ApplicationCommandComponent(options))\n","/*\r\n* File: ApplicationCommandOption.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport { APIApplicationCommandOption } from 'discord.js'\nimport { createArgumentDecorator, ComponentArgumentDecorator } from '../core'\n\ntype Options = APIApplicationCommandOption\n\nexport class ApplicationCommandOption extends ComponentArgumentDecorator<Options> {}\n\nexport const option = createArgumentDecorator(ApplicationCommandOption)\n","/*\r\n* File: moduleHook.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport { Collection } from 'discord.js'\nimport { ModuleHookStoreSymbol } from '../symbols'\n\ntype ModuleHookStore = Collection<string, Function[]>\n\nexport const getModuleHookStore = (target: object) => {\n let result: ModuleHookStore | null = Reflect.getMetadata(ModuleHookStoreSymbol, target)\n\n if (!result) {\n result = new Collection()\n\n Reflect.defineMetadata(ModuleHookStoreSymbol, result, target)\n }\n\n return result\n}\n\nexport const moduleHook = (name: string): MethodDecorator => {\n return (target, key) => {\n const store = getModuleHookStore(target)\n\n let v = store.get(name)\n\n if (!v) {\n v = []\n store.set(name, v)\n }\n\n v.push(Reflect.get(target, key))\n }\n}\n","/*\r\n* File: index.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nexport * from './moduleHook'\r\nexport { createComponentHook } from './componentHook'\r\nexport type { ComponentHookStore } from './componentHook'\r\n","/*\n * File: index.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport _ from 'lodash'\nimport { BaseComponent } from '../components/BaseComponent'\nimport { createComponentDecorator } from '../components/decoratorCreator'\n\ntype Options = { emitter: string; event: string }\n\ntype OptionsArg = { emitter?: string; event: string }\n\nexport class ListenerComponent extends BaseComponent {\n options: Options\n\n constructor(options: OptionsArg) {\n super()\n\n this.options = _.merge({ emitter: 'discord' }, options)\n }\n}\n\nexport const listener = (options: OptionsArg) => createComponentDecorator(new ListenerComponent(options))\n","/*\n * File: Registry.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport chalk from 'chalk'\nimport { Collection } from 'discord.js'\nimport EventEmitter from 'events'\nimport _, { result } from 'lodash'\nimport { Logger } from 'tslog'\nimport { getComponentStore } from '../components'\nimport type { BaseComponent } from '../components'\nimport { getModuleHookStore } from '../hooks'\nimport { ListenerComponent } from '../listener'\nimport { CommandClientSymbol, FilePathSymbol } from '../symbols'\nimport { CommandClient } from './CommandClient'\nimport walkSync from 'walk-sync'\nimport path from 'path'\n\nexport class Registry {\n extensions: object[] = []\n\n emitters: Collection<string, EventEmitter> = new Collection()\n\n logger: Logger\n\n constructor(logger: Logger, public client: CommandClient) {\n this.logger = logger.getChildLogger({\n prefix: [chalk.green('[Registry]')],\n })\n }\n\n getComponentsWithTypeGlobal<T>(type: unknown): T[] {\n const result: T[] = []\n\n for (const ext of this.extensions) {\n result.push(...this.getComponentsWithType<T>(ext, type))\n }\n\n return result\n }\n\n getComponentsWithType<T>(ext: object, type: unknown): T[] {\n const componentStore = getComponentStore(ext)\n\n return Array.from(componentStore.filter((x) => (x.constructor as unknown) === type).values() as Iterable<T>)\n }\n\n registerEventListeners(ext: object) {\n const listeners = this.getComponentsWithType<ListenerComponent>(ext, ListenerComponent)\n\n for (const listener of listeners) {\n const emitter = this.emitters.get(listener.options.emitter)\n\n if (emitter) {\n const bound = listener.method.bind(ext)\n\n Reflect.defineMetadata('bound', bound, listener)\n\n emitter.addListener(listener.options.event, bound)\n }\n }\n }\n\n unregisterEventListeners(ext: object) {\n const listeners = this.getComponentsWithType<ListenerComponent>(ext, ListenerComponent)\n\n for (const listener of listeners) {\n const emitter = this.emitters.get(listener.options.emitter)\n const bound = Reflect.getMetadata('bound', listener)\n\n if (emitter && bound) {\n emitter.removeListener(listener.options.event, bound)\n }\n }\n }\n\n async loadAllModulesInDirectory(dir: string): Promise<object[]> {\n const results: object[] = []\n\n const files = walkSync(dir).filter((x) => x.endsWith('.ts') || x.endsWith('.js'))\n\n for (const file of files) {\n if (file.endsWith('.d.ts')) continue\n try {\n const p = path.join(dir, file)\n const mod = require(p)\n\n if (typeof mod.setup !== 'function') continue\n\n const modules = await mod.setup()\n\n results.push(...(await this.registerModules(modules, p)))\n } catch (e) {\n this.logger.error(`Failed to load ${file}`)\n }\n }\n\n return results\n }\n\n private async registerModules(modules: object | object[], p: string) {\n const results: object[] = []\n if (modules instanceof Array) {\n for (const module of modules) {\n await this.registerModule(module)\n Reflect.defineMetadata(FilePathSymbol, p, module)\n results.push(module)\n }\n } else {\n await this.registerModule(modules)\n Reflect.defineMetadata(FilePathSymbol, p, modules)\n results.push(modules)\n }\n\n return results\n }\n\n async reloadModules() {\n const result: { file: string; result: boolean; error?: Error }[] = []\n const paths = new Set<string>()\n for (const module of this.extensions) {\n const file = Reflect.getMetadata(FilePathSymbol, module)\n if (!file) continue\n\n paths.add(file)\n\n await this.unregisterModule(module)\n delete require.cache[require.resolve(file)]\n }\n\n for (const path of paths) {\n try {\n const mod = require(path)\n\n if (typeof mod.setup !== 'function') continue\n\n const modules = await mod.setup(this.client)\n\n await this.registerModules(modules, path)\n\n result.push({\n file: path,\n result: true,\n })\n } catch (e) {\n result.push({\n file: path,\n result: false,\n error: e as Error,\n })\n }\n }\n\n return result\n }\n\n async registerModule(ext: object) {\n Reflect.defineMetadata(CommandClientSymbol, this.client, ext)\n\n this.registerEventListeners(ext)\n await this.runModuleHook(ext, 'load')\n this.extensions.push(ext)\n this.logger.info(`Module registered: ${chalk.green(ext.constructor.name)}`)\n }\n\n async unregisterModule(ext: object) {\n this.unregisterEventListeners(ext)\n await this.runModuleHook(ext, 'unload')\n _.remove(this.extensions, (x) => x === ext)\n this.logger.info(`Module unregistered: ${chalk.green(ext.constructor.name)}`)\n }\n\n runModuleHook(ext: object, hookName: string, ...args: unknown[]) {\n const hooks = getModuleHookStore(ext)\n\n const functions = hooks.get(hookName)\n\n if (functions) {\n for (const fn of functions) {\n fn.call(ext, ...args)\n }\n }\n }\n\n registerEventEmitter(name: string, emitter: EventEmitter) {\n this.emitters.set(name, emitter)\n }\n}\n","/*\r\n* File: index.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nexport * from './Registry'\nexport * from './CommandClient'\n","/*\n * File: index.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport { BaseComponent } from '../components/BaseComponent'\nimport { createComponentDecorator } from '../components/decoratorCreator'\n\ntype Options = { component: unknown; type: Function; parameterless: boolean }\n\ntype OptionsArg = Omit<Options, 'parameterless'> & { parameterless?: boolean }\n\nexport class ConverterComponent extends BaseComponent {\n options: Options\n\n constructor(options: OptionsArg) {\n super()\n this.options = options as Options\n }\n}\n\nexport const argConverter = (options: OptionsArg) => createComponentDecorator(new ConverterComponent(options))\n","/*\n * File: Extension.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport chalk from 'chalk'\nimport { Collection } from 'discord.js'\nimport { Logger } from 'tslog'\nimport { BaseComponent } from '../components'\nimport { ComponentArgument } from '../components/ComponentArgument'\nimport { ConverterComponent } from '../converter'\nimport { CommandClient } from '../structures'\n\nexport class Extension {\n protected get commandClient() {\n return CommandClient.getFromModule(this)\n }\n\n protected get client() {\n return this.commandClient.discord\n }\n\n protected _logger?: Logger\n\n protected get logger() {\n if (!this._logger) this._logger = this.commandClient.logger.getChildLogger({ prefix: [chalk.green(`[${this.constructor.name}]`)], displayFunctionName: false })\n return this._logger\n }\n\n protected async convertArguments(\n component: unknown,\n argList: unknown[],\n args: Collection<number, ComponentArgument>,\n getConverterArgs: (arg: ComponentArgument, index: number, converter: ConverterComponent) => unknown[] | Promise<unknown[]>,\n ) {\n const items = new Collection<unknown, { ext: object; component: ConverterComponent }>()\n\n for (const extension of this.commandClient.registry.extensions) {\n for (const converter of this.commandClient.registry.getComponentsWithType<ConverterComponent>(extension, ConverterComponent)) {\n if (converter.options.component != component) continue\n\n items.set(converter.options.type, { component: converter, ext: extension })\n }\n }\n\n for (const [index, arg] of args) {\n const converter = items.get(arg.type)\n\n if (!converter) {\n argList[index] = undefined\n continue\n }\n\n const converterArgs = await getConverterArgs(arg, index, converter.component)\n\n argList[index] = await converter.component.execute(converter.ext, converterArgs)\n }\n }\n}\n","/*\r\n* File: CTSExtension.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport chalk from 'chalk'\nimport { Extension } from './Extension'\n\nexport class CTSExtension extends Extension {\n protected get logger() {\n if (!this._logger) this._logger = this.commandClient.ctsLogger.getChildLogger({ prefix: [chalk.green(`[${this.constructor.name}]`)], displayFunctionName: false })\n return this._logger\n }\n}\n","/*\n * File: ApplicationCommandExtension.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport chalk from 'chalk'\nimport {\n ApplicationCommandData,\n ApplicationCommandOptionType,\n ApplicationCommandType,\n ChatInputCommandInteraction,\n Collection,\n Interaction,\n InteractionType,\n MessageContextMenuCommandInteraction,\n Snowflake,\n UserContextMenuCommandInteraction,\n} from 'discord.js'\nimport { ApplicationCommandComponent } from './ApplicationCommand'\nimport { ApplicationCommandOption } from './ApplicationCommandOption'\nimport { moduleHook } from '../core/hooks'\nimport { listener } from '../core/listener'\nimport { CommandClient } from '../core/structures'\nimport { argConverter } from '../core/converter'\nimport { CTSExtension } from '../core/extensions/CTSExtension'\n\nexport type ApplicationCommandExtensionConfig = {\n guilds?: Snowflake[]\n}\n\nexport class ApplicationCommandExtension extends CTSExtension {\n constructor(public config: ApplicationCommandExtensionConfig) {\n super()\n }\n\n @listener({ event: 'interactionCreate' })\n async interactionCreate(i: Interaction) {\n if (i.type !== InteractionType.ApplicationCommand) return\n\n let cmd: ApplicationCommandComponent | null = null\n let ext: object | null = null\n\n const extensions = this.commandClient.registry.extensions\n\n for (const extension of extensions) {\n const components = this.commandClient.registry.getComponentsWithType<ApplicationCommandComponent>(extension, ApplicationCommandComponent)\n\n for (const command of components) {\n if (command.options.name === i.commandName) {\n ext = extension\n cmd = command\n }\n }\n }\n\n if (cmd && ext) {\n const argList: unknown[] = []\n\n await this.convertArguments(ApplicationCommandComponent, argList, cmd.argTypes, () => [i])\n\n for (const [idx, arg] of cmd.argTypes) {\n let value: unknown = null\n\n for (const decorator of arg.decorators) {\n if (decorator instanceof ApplicationCommandOption) {\n if ([ApplicationCommandOptionType.Subcommand, ApplicationCommandOptionType.SubcommandGroup].includes(decorator.options.type) && i.isChatInputCommand()) {\n if (decorator.options.type === ApplicationCommandOptionType.Subcommand) {\n value = i.options.getSubcommand() === decorator.options.name\n break\n }\n if (decorator.options.type === ApplicationCommandOptionType.SubcommandGroup) {\n value = i.options.getSubcommandGroup() === decorator.options.name\n break\n }\n }\n\n value = i.options.get(decorator.options.name, false)?.value\n break\n }\n }\n\n if (value) {\n argList[idx] = value\n }\n }\n\n try {\n await cmd.execute(ext, argList, [i])\n } catch (e) {\n this.commandClient.emit('applicationCommandInvokeError', e, i)\n }\n }\n }\n\n @moduleHook('load')\n async load() {}\n\n async sync() {\n const client = CommandClient.getFromModule(this)\n\n this.logger.info('Trying to sync commands...')\n\n const commands: ApplicationCommandData[] = []\n\n const guildCommands = new Collection<Snowflake, ApplicationCommandData[]>()\n\n for (const command of client.registry.getComponentsWithTypeGlobal<ApplicationCommandComponent>(ApplicationCommandComponent)) {\n const cmd: ApplicationCommandData = { ...command.options }\n\n if (cmd.type === ApplicationCommandType.ChatInput) {\n cmd.options = []\n\n for (const [, arg] of command.argTypes) {\n const option = arg.decorators.find((x) => x.constructor === ApplicationCommandOption) as ApplicationCommandOption\n\n if (option) {\n cmd.options.push(option.options)\n }\n }\n }\n\n if (command.options.guilds) {\n for (const guild of command.options.guilds) {\n let commands = guildCommands.get(guild)\n if (!commands) {\n commands = []\n guildCommands.set(guild, commands)\n }\n commands.push(cmd)\n }\n continue\n }\n\n if (this.config.guilds) {\n for (const guild of this.config.guilds) {\n let commands = guildCommands.get(guild)\n if (!commands) {\n commands = []\n guildCommands.set(guild, commands)\n }\n commands.push(cmd)\n }\n continue\n }\n commands.push(cmd)\n }\n\n if (guildCommands.size) {\n for (const [guild, commands] of guildCommands) {\n this.logger.info(`Processing ${chalk.green(commands.length)} commands(${commands.map((x) => chalk.blue(x.name)).join(', ')})`)\n try {\n const g = await this.client.guilds.fetch(guild)\n await g.fetch()\n this.logger.info(`Registering commands for guild ${chalk.green(g.name)}(${chalk.blue(g.id)})`)\n\n await g.commands.set(commands)\n\n this.logger.info(`Successfully registered commands for guild ${chalk.green(g.name)}(${chalk.blue(g.id)})`)\n } catch (e) {\n this.logger.error(`Failed to register commands to guild ${chalk.green(guild)}: ${(e as Error).message}`)\n }\n }\n }\n if (commands.length) {\n try {\n this.logger.info(`Registering commands globally...`)\n\n await this.client.application!.commands.set(commands)\n\n this.logger.info('Successfully registered commands.')\n } catch (e) {\n this.logger.error(`Failed to register commands to global: ${(e as Error).message}`)\n }\n }\n }\n\n @argConverter({\n component: ApplicationCommandComponent,\n parameterless: true,\n type: ChatInputCommandInteraction,\n })\n async chatInteraction(i: ChatInputCommandInteraction) {\n return i\n }\n\n @argConverter({\n component: ApplicationCommandComponent,\n parameterless: true,\n type: MessageContextMenuCommandInteraction,\n })\n async messageInteraction(i: MessageContextMenuCommandInteraction) {\n return i\n }\n\n @argConverter({\n component: ApplicationCommandComponent,\n parameterless: true,\n type: UserContextMenuCommandInteraction,\n })\n async userInteraction(i: UserContextMenuCommandInteraction) {\n return i\n }\n}\n","/*\n * File: TextCommand.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport { createComponentDecorator } from '../core/components/decoratorCreator'\nimport { BaseComponent } from '../core/components/BaseComponent'\n\ntype TextCommandOptions = {\n name: string\n aliases?: string[]\n description?: string\n}\n\nexport class TextCommandComponent extends BaseComponent {\n constructor(public options: TextCommandOptions) {\n super()\n }\n}\n\nexport const command = (options: TextCommandOptions) => createComponentDecorator(new TextCommandComponent(options))\n","/*\r\n * File: parameters.ts\r\n *\r\n * Copyright (c) 2022-2022 pikokr\r\n *\r\n * Licensed under MIT License. Please see more defails in LICENSE file.\r\n */\r\n\r\nimport { ComponentArgumentDecorator } from '../core'\r\nimport { createArgumentDecorator } from '../core'\r\n\r\nexport class TextCommandRestOption extends ComponentArgumentDecorator<void> {}\r\n\r\nexport const rest = createArgumentDecorator(TextCommandRestOption)\r\n","/*\n * File: TextCommandExtension.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport { listener } from '../core/listener'\nimport { Message } from 'discord.js'\nimport { CTSExtension } from '../core/extensions/CTSExtension'\nimport { TextCommandComponent } from './TextCommand'\nimport { TextCommandRestOption } from './parameters'\nimport { argConverter } from '../core'\n\nexport type TextCommandConfig = {\n prefix: string | string[] | ((msg: Message) => Promise<string | string[]> | string | string[])\n}\n\nexport class TextCommandExtension extends CTSExtension {\n constructor(private config: TextCommandConfig) {\n super()\n }\n\n private async processPrefix(msg: Message): Promise<number | null> {\n const content = msg.content\n let prefix = this.config.prefix\n\n if (typeof prefix === 'function') {\n prefix = await prefix(msg)\n }\n\n if (typeof prefix === 'string') {\n if (content.startsWith(prefix)) return prefix.length\n return null\n }\n\n if (prefix instanceof Array) {\n const p = prefix.find((x) => content.startsWith(x))\n\n if (p) return p.length\n return null\n }\n\n return null\n }\n\n @listener({ event: 'messageCreate', emitter: 'discord' })\n private async messageCreate(msg: Message) {\n const startIndex = await this.processPrefix(msg)\n\n if (!startIndex) return\n\n const content = msg.content.slice(startIndex)\n\n const commands: TextCommandComponent[] = []\n\n const extensions = new Map<TextCommandComponent, object>()\n\n for (const ext of this.commandClient.registry.extensions) {\n for (const cmd of this.commandClient.registry.getComponentsWithType<TextCommandComponent>(ext, TextCommandComponent)) {\n commands.push(cmd)\n extensions.set(cmd, ext)\n }\n }\n\n let commandNameLength = 0\n\n const command = commands.find((x) => {\n const names = [x.options.name]\n\n if (x.options.aliases) {\n names.push(...x.options.aliases)\n }\n\n for (const name of names) {\n if (content.startsWith(name)) {\n if (content.length === name.length) {\n commandNameLength = name.length\n return true\n }\n commandNameLength = name.length\n return content.startsWith(name + ' ')\n }\n }\n\n return false\n })\n\n if (!command) return\n\n const ext = extensions.get(command)\n\n if (!ext) return\n\n const args: unknown[] = []\n\n let argStrings = content.slice(commandNameLength + 1).split(/ /g)\n\n await this.convertArguments(TextCommandComponent, args, command.argTypes, async (arg, i, converter) => {\n if (converter.options.parameterless) return [msg]\n\n if (arg.decorators.find((x) => x.constructor === TextCommandRestOption)) {\n const text = argStrings.join(' ')\n argStrings = []\n return [text, msg]\n }\n return [argStrings.shift(), msg]\n })\n\n await command.execute(ext, args, [msg])\n }\n\n @argConverter({ component: TextCommandComponent, type: Message, parameterless: true })\n async mesage(msg: Message) {\n return msg\n }\n\n @argConverter({ component: TextCommandComponent, type: String })\n async str(value: string) {\n return value\n }\n\n @argConverter({ component: TextCommandComponent, type: Number })\n async num(value: string) {\n return Number(value)\n }\n}\n","/*\r\n* File: CommandClient.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport chalk from 'chalk'\nimport { Client, Snowflake, Team, User } from 'discord.js'\nimport EventEmitter from 'events'\nimport { Logger } from 'tslog'\nimport { ApplicationCommandExtension, ApplicationCommandExtensionConfig } from '../../applicationCommand/ApplicationCommandExtension'\nimport { TextCommandConfig } from '../../textCommand'\nimport { TextCommandExtension } from '../../textCommand/TextCommandExtension'\nimport { CommandClientSymbol } from '../symbols'\nimport { Registry } from './Registry'\nexport class CommandClient extends EventEmitter {\n ctsLogger: Logger\n registry: Registry\n\n owners: Set<Snowflake> = new Set()\n\n constructor(public discord: Client, public logger: Logger = new Logger({ dateTimeTimezone: Intl.DateTimeFormat().resolvedOptions().timeZone })) {\n super()\n\n this.ctsLogger = logger.getChildLogger({ prefix: [chalk.blue('[command.ts]')], displayFilePath: 'hidden', displayFunctionName: false })\n\n this.registry = new Registry(this.ctsLogger, this)\n\n this.registry.registerEventEmitter('cts', this)\n this.registry.registerEventEmitter('discord', this.discord)\n }\n\n async fetchOwners() {\n if (!this.discord.application) throw new Error('The client is not logged in.')\n\n this.ctsLogger.info('Fetching owners...')\n\n await this.discord.application.fetch()\n\n const owner = this.discord.application.owner\n\n if (!owner) throw new Error('Cannot find application owner')\n\n const owners: string[] = []\n\n if (owner instanceof User) {\n this.owners.add(owner.id)\n owners.push(owner.tag)\n } else if (owner instanceof Team) {\n for (const [id, member] of owner.members) {\n this.owners.add(id)\n owners.push(member.user.tag)\n }\n }\n\n this.ctsLogger.info(`Fetched ${chalk.green(owners.length)} owners(${owners.map((x) => chalk.blue(x)).join(', ')})`)\n }\n\n async enableApplicationCommandsExtension(config: ApplicationCommandExtensionConfig) {\n await this.registry.registerModule(new ApplicationCommandExtension(config))\n this.ctsLogger.info('Application command extension enabled.')\n }\n\n async enableTextCommandsExtension(config: TextCommandConfig) {\n await this.registry.registerModule(new TextCommandExtension(config))\n this.ctsLogger.info('Text command extension enabled.')\n }\n\n getApplicationCommandsExtension() {\n return this.registry.extensions.find((x) => x.constructor === ApplicationCommandExtension) as ApplicationCommandExtension | undefined\n }\n\n static getFromModule(ext: object): CommandClient {\n return Reflect.getMetadata(CommandClientSymbol, ext)\n }\n}\n","/*\n * File: BaseComponent.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport { Collection } from 'discord.js'\nimport _ from 'lodash'\nimport type { ComponentHookStore } from '../hooks'\nimport { ComponentArgument } from './ComponentArgument'\n\nexport class BaseComponent {\n method!: Function\n\n hooks: ComponentHookStore = new Collection()\n\n argTypes: Collection<number, ComponentArgument> = new Collection()\n\n _init(method: Function, argTypes: unknown[]) {\n this.method = method\n for (let i = 0; i < argTypes.length; i++) {\n const element = argTypes[i]\n this.argTypes.set(i, new ComponentArgument(element))\n }\n }\n\n async executeHook(target: object, name: string, args: unknown[]) {\n const hook = this.hooks.get(name)\n\n if (!hook) return\n\n const { CommandClient } = await import('../structures/CommandClient')\n\n for (const fn of hook) {\n await fn.call(null, CommandClient.getFromModule(target), ...args)\n }\n }\n\n async execute(target: object, args: unknown[], beforeCallArgs: unknown[] = args) {\n await this.executeHook(target, 'beforeCall', beforeCallArgs)\n let result\n try {\n result = await this.method.call(target, ...args)\n } catch (e) {\n await this.executeHook(target, 'invokeError', [e])\n throw e\n }\n await this.executeHook(target, 'afterCall', [result])\n\n return result\n }\n}\n","/*\r\n* File: index.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport 'reflect-metadata'\r\nexport * from './decoratorCreator'\r\nexport * from './ComponentArgument'\r\nexport * from './ComponentArgumentDecorator'\r\nexport * from './BaseComponent'\r\n","/*\r\n* File: errors.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nexport class OwnerOnlyError {}\n","/*\r\n* File: checks.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport { BaseInteraction, Interaction, Message } from 'discord.js'\nimport { createComponentHook } from '../hooks'\nimport { ComponentHookFn } from '../hooks/componentHook'\nimport { CommandClient } from '../structures'\nimport { OwnerOnlyError } from './errors'\n\nexport const createCheckDecorator = (fn: ComponentHookFn) => createComponentHook('beforeCall', fn)\n\nexport const ownerOnly = createCheckDecorator(async (client: CommandClient, i: Interaction | Message) => {\n let isOwner = false\n\n if (i instanceof BaseInteraction) {\n isOwner = client.owners.has(i.user.id)\n } else if (i instanceof Message) {\n isOwner = client.owners.has(i.author.id)\n }\n\n if (!isOwner) throw new OwnerOnlyError()\n})\n","/*\r\n* File: index.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nexport * from './checks'\nexport * from './errors'\n","/*\r\n* File: index.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nexport * from './Extension'\n","/*\r\n* File: index.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nexport * from './components'\nexport * from './hooks'\nexport * from './converter'\nexport * from './utils'\nexport * from './listener'\nexport * from './structures'\nexport * from './extensions'\n","/*\r\n* File: index.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nexport * from './core'\r\nexport * from './applicationCommand'\r\nexport * from './textCommand'\r\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../src/core/symbols.ts","../src/core/hooks/componentHook.ts","../src/core/components/decoratorCreator.ts","../src/core/components/ComponentArgument.ts","../src/core/components/ComponentArgumentDecorator.ts","../src/applicationCommand/ApplicationCommand.ts","../src/applicationCommand/ApplicationCommandOption.ts","../src/core/listener/index.ts","../src/core/converter/index.ts","../src/core/hooks/moduleHook.ts","../src/core/hooks/index.ts","../src/core/structures/Registry.ts","../src/core/structures/index.ts","../src/core/extensions/Extension.ts","../src/core/extensions/CTSExtension.ts","../src/applicationCommand/ApplicationCommandExtension.ts","../src/textCommand/TextCommand.ts","../src/textCommand/parameters.ts","../src/textCommand/TextCommandExtension.ts","../src/core/structures/CommandClient.ts","../src/core/components/BaseComponent.ts","../src/core/components/index.ts","../src/core/utils/errors.ts","../src/core/utils/checks.ts","../src/core/utils/index.ts","../src/core/extensions/index.ts","../src/core/index.ts","../src/index.ts","../src/applicationCommand/group.ts"],"sourcesContent":["/*\r\n * File: symbols.ts\r\n *\r\n * Copyright (c) 2022-2022 pikokr\r\n *\r\n * Licensed under MIT License. Please see more defails in LICENSE file.\r\n */\r\n\r\nexport const ComponentStoreSymbol = Symbol()\r\nexport const ComponentArgStoreSymbol = Symbol()\r\nexport const ModuleHookStoreSymbol = Symbol()\r\nexport const CommandClientSymbol = Symbol()\r\nexport const ComponentHookSymbol = Symbol()\r\nexport const FilePathSymbol = Symbol()\r\n","/*\r\n* File: componentHook.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport { Collection } from 'discord.js'\nimport { ComponentHookSymbol } from '../symbols'\n\nexport type ComponentHookFn = (...args: any[]) => void | Promise<void>\n\nexport type ComponentHookStore = Collection<string, ComponentHookFn[]>\n\nexport const getComponentHookStore = (target: object, property: string | symbol): ComponentHookStore => {\n let data = Reflect.getMetadata(ComponentHookSymbol, target, property) as ComponentHookStore\n\n if (!data) {\n data = new Collection()\n Reflect.defineMetadata(ComponentHookSymbol, data, target, property)\n }\n\n return data\n}\n\nexport const createComponentHook = (name: string, fn: ComponentHookFn): MethodDecorator => {\n return (target, key) => {\n const store = getComponentHookStore(target, key)\n\n let hooks = store.get(name)\n\n if (!hooks) {\n hooks = []\n store.set(name, hooks)\n }\n\n hooks.push(fn)\n }\n}\n","/*\n * File: decoratorCreator.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport { Collection } from 'discord.js'\nimport { ComponentHookStore } from '../hooks'\nimport { getComponentHookStore } from '../hooks/componentHook'\nimport { ComponentStoreSymbol } from '../symbols'\nimport { BaseComponent } from './BaseComponent'\nimport { ComponentArgumentDecorator } from './ComponentArgumentDecorator'\n\ntype ComponentStore = Collection<string | symbol, BaseComponent>\ntype ComponentArgumentStore = Collection<number, ComponentArgumentDecorator>\n\nexport const getComponentStore = (target: object): ComponentStore => {\n let result: ComponentStore | null = Reflect.getMetadata(ComponentStoreSymbol, target)\n\n if (!result) {\n result = new Collection()\n\n Reflect.defineMetadata(ComponentStoreSymbol, result, target)\n }\n\n return result\n}\n\nexport const getComponent = (target: object, key: string | symbol) => {\n const store = getComponentStore(target)\n\n return store.get(key)\n}\n\nexport const createComponentDecorator = (component: BaseComponent): MethodDecorator => {\n return (target, key) => {\n component._init(Reflect.get(target, key), Reflect.getMetadata('design:paramtypes', target, key))\n\n const componentHookStore: ComponentHookStore = getComponentHookStore(target, key)\n\n component.hooks = componentHookStore\n\n const store = getComponentStore(target)\n\n const decorators = getComponentArgumentStore(target, key)\n\n decorators.forEach((x, i) => {\n component.argTypes.get(i)?.decorators.push(x)\n })\n\n store.set(key, component)\n }\n}\n\nexport const getComponentArgumentStore = (target: object, key: string | symbol): ComponentArgumentStore => {\n let result: ComponentArgumentStore | null = Reflect.getMetadata(ComponentStoreSymbol, target, key)\n\n if (!result) {\n result = new Collection()\n\n Reflect.defineMetadata(ComponentStoreSymbol, result, target, key)\n }\n\n return result\n}\n\nexport const createArgumentDecorator = <Options>(type: typeof ComponentArgumentDecorator<Options>) => {\n return (options: Options): ParameterDecorator => {\n return (target, key, idx) => {\n var arg: ComponentArgumentDecorator<Options> = new type(options)\n\n const store = getComponentArgumentStore(target, key)\n\n store.set(idx, arg)\n }\n }\n}\n","/*\r\n* File: ComponentArgument.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport { ComponentArgumentDecorator } from './ComponentArgumentDecorator'\n\nexport class ComponentArgument {\n decorators: ComponentArgumentDecorator[] = []\n\n constructor(public type: unknown) {}\n}\n","/*\r\n* File: ComponentArgumentDecorator.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport _ from 'lodash'\n\nexport class ComponentArgumentDecorator<Options = unknown> {\n options: Options\n\n constructor(options: Partial<Options>) {\n if (typeof options === 'object') {\n this.options = _.merge(this.defaultOptions(), options)\n } else {\n this.options = options\n }\n }\n\n defaultOptions(): Options {\n return {} as unknown as Options\n }\n}\n","/*\n * File: ApplicationCommand.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport type { ApplicationCommandType, ChatInputApplicationCommandData, MessageApplicationCommandData, Snowflake, UserApplicationCommandData } from 'discord.js'\nimport { createComponentDecorator } from '../core/components/decoratorCreator'\nimport { BaseComponent } from '../core/components/BaseComponent'\nimport { SubCommandGroup, SubCommandGroupChild } from './group'\n\ntype Options = (UserApplicationCommandData | MessageApplicationCommandData | Omit<ChatInputApplicationCommandData, 'options'>) & {\n type: ApplicationCommandType\n guilds?: Snowflake[]\n}\n\nexport class ApplicationCommandComponent extends BaseComponent {\n options: Options\n\n subcommandGroup?: SubCommandGroup\n subcommandGroupChild?: SubCommandGroupChild\n\n constructor(options: UserApplicationCommandData | MessageApplicationCommandData | Omit<ChatInputApplicationCommandData, 'options'>) {\n super()\n\n this.options = options as Options\n }\n}\n\nexport const applicationCommand = (options: Options) => createComponentDecorator(new ApplicationCommandComponent(options))\n\nexport type { Options as ApplicationCommandComponentOptions }\n","/*\r\n* File: ApplicationCommandOption.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport { APIApplicationCommandOption } from 'discord.js'\nimport { createArgumentDecorator, ComponentArgumentDecorator } from '../core'\n\ntype Options = APIApplicationCommandOption\n\nexport class ApplicationCommandOption extends ComponentArgumentDecorator<Options> {}\n\nexport const option = createArgumentDecorator(ApplicationCommandOption)\n","/*\n * File: index.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport _ from 'lodash'\nimport { BaseComponent } from '../components/BaseComponent'\nimport { createComponentDecorator } from '../components/decoratorCreator'\n\ntype Options = { emitter: string; event: string }\n\ntype OptionsArg = { emitter?: string; event: string }\n\nexport class ListenerComponent extends BaseComponent {\n options: Options\n\n constructor(options: OptionsArg) {\n super()\n\n this.options = _.merge({ emitter: 'discord' }, options)\n }\n}\n\nexport const listener = (options: OptionsArg) => createComponentDecorator(new ListenerComponent(options))\n","/*\n * File: index.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport { BaseComponent } from '../components/BaseComponent'\nimport { createComponentDecorator } from '../components/decoratorCreator'\n\ntype Options = { component: unknown; type: Function; parameterless: boolean }\n\ntype OptionsArg = Omit<Options, 'parameterless'> & { parameterless?: boolean }\n\nexport class ConverterComponent extends BaseComponent {\n options: Options\n\n constructor(options: OptionsArg) {\n super()\n this.options = options as Options\n }\n}\n\nexport const argConverter = (options: OptionsArg) => createComponentDecorator(new ConverterComponent(options))\n","/*\r\n* File: moduleHook.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport { Collection } from 'discord.js'\nimport { ModuleHookStoreSymbol } from '../symbols'\n\ntype ModuleHookStore = Collection<string, Function[]>\n\nexport const getModuleHookStore = (target: object) => {\n let result: ModuleHookStore | null = Reflect.getMetadata(ModuleHookStoreSymbol, target)\n\n if (!result) {\n result = new Collection()\n\n Reflect.defineMetadata(ModuleHookStoreSymbol, result, target)\n }\n\n return result\n}\n\nexport const moduleHook = (name: string): MethodDecorator => {\n return (target, key) => {\n const store = getModuleHookStore(target)\n\n let v = store.get(name)\n\n if (!v) {\n v = []\n store.set(name, v)\n }\n\n v.push(Reflect.get(target, key))\n }\n}\n","/*\r\n* File: index.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nexport * from './moduleHook'\r\nexport { createComponentHook } from './componentHook'\r\nexport type { ComponentHookStore } from './componentHook'\r\n","/*\n * File: Registry.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport chalk from 'chalk'\nimport { Collection } from 'discord.js'\nimport EventEmitter from 'events'\nimport _, { result } from 'lodash'\nimport { Logger } from 'tslog'\nimport { getComponentStore } from '../components'\nimport type { BaseComponent } from '../components'\nimport { getModuleHookStore } from '../hooks'\nimport { ListenerComponent } from '../listener'\nimport { CommandClientSymbol, FilePathSymbol } from '../symbols'\nimport { CommandClient } from './CommandClient'\nimport walkSync from 'walk-sync'\nimport path from 'path'\n\nexport class Registry {\n extensions: object[] = []\n\n emitters: Collection<string, EventEmitter> = new Collection()\n\n logger: Logger\n\n constructor(logger: Logger, public client: CommandClient) {\n this.logger = logger.getChildLogger({\n prefix: [chalk.green('[Registry]')],\n })\n }\n\n getComponentsWithTypeGlobal<T>(type: unknown): T[] {\n const result: T[] = []\n\n for (const ext of this.extensions) {\n result.push(...this.getComponentsWithType<T>(ext, type))\n }\n\n return result\n }\n\n getComponentsWithType<T>(ext: object, type: unknown): T[] {\n const componentStore = getComponentStore(ext)\n\n return Array.from(componentStore.filter((x) => (x.constructor as unknown) === type).values() as Iterable<T>)\n }\n\n registerEventListeners(ext: object) {\n const listeners = this.getComponentsWithType<ListenerComponent>(ext, ListenerComponent)\n\n for (const listener of listeners) {\n const emitter = this.emitters.get(listener.options.emitter)\n\n if (emitter) {\n const bound = listener.method.bind(ext)\n\n Reflect.defineMetadata('bound', bound, listener)\n\n emitter.addListener(listener.options.event, bound)\n }\n }\n }\n\n unregisterEventListeners(ext: object) {\n const listeners = this.getComponentsWithType<ListenerComponent>(ext, ListenerComponent)\n\n for (const listener of listeners) {\n const emitter = this.emitters.get(listener.options.emitter)\n const bound = Reflect.getMetadata('bound', listener)\n\n if (emitter && bound) {\n emitter.removeListener(listener.options.event, bound)\n }\n }\n }\n\n async loadAllModulesInDirectory(dir: string): Promise<object[]> {\n const results: object[] = []\n\n const files = walkSync(dir).filter((x) => x.endsWith('.ts') || x.endsWith('.js'))\n\n for (const file of files) {\n if (file.endsWith('.d.ts')) continue\n try {\n const p = path.join(dir, file)\n const mod = require(p)\n\n if (typeof mod.setup !== 'function') continue\n\n const modules = await mod.setup()\n\n results.push(...(await this.registerModules(modules, p)))\n } catch (e) {\n this.logger.error(`Failed to load ${file}`)\n }\n }\n\n return results\n }\n\n private async registerModules(modules: object | object[], p: string) {\n const results: object[] = []\n if (modules instanceof Array) {\n for (const module of modules) {\n await this.registerModule(module)\n Reflect.defineMetadata(FilePathSymbol, p, module)\n results.push(module)\n }\n } else {\n await this.registerModule(modules)\n Reflect.defineMetadata(FilePathSymbol, p, modules)\n results.push(modules)\n }\n\n return results\n }\n\n async reloadModules() {\n const result: { file: string; result: boolean; error?: Error }[] = []\n const paths = new Set<string>()\n for (const module of this.extensions) {\n const file = Reflect.getMetadata(FilePathSymbol, module)\n if (!file) continue\n\n paths.add(file)\n\n await this.unregisterModule(module)\n delete require.cache[require.resolve(file)]\n }\n\n for (const path of paths) {\n try {\n const mod = require(path)\n\n if (typeof mod.setup !== 'function') continue\n\n const modules = await mod.setup(this.client)\n\n await this.registerModules(modules, path)\n\n result.push({\n file: path,\n result: true,\n })\n } catch (e) {\n result.push({\n file: path,\n result: false,\n error: e as Error,\n })\n }\n }\n\n return result\n }\n\n async registerModule(ext: object) {\n Reflect.defineMetadata(CommandClientSymbol, this.client, ext)\n\n this.registerEventListeners(ext)\n await this.runModuleHook(ext, 'load')\n this.extensions.push(ext)\n this.logger.info(`Module registered: ${chalk.green(ext.constructor.name)}`)\n }\n\n async unregisterModule(ext: object) {\n this.unregisterEventListeners(ext)\n await this.runModuleHook(ext, 'unload')\n _.remove(this.extensions, (x) => x === ext)\n this.logger.info(`Module unregistered: ${chalk.green(ext.constructor.name)}`)\n }\n\n runModuleHook(ext: object, hookName: string, ...args: unknown[]) {\n const hooks = getModuleHookStore(ext)\n\n const functions = hooks.get(hookName)\n\n if (functions) {\n for (const fn of functions) {\n fn.call(ext, ...args)\n }\n }\n }\n\n registerEventEmitter(name: string, emitter: EventEmitter) {\n this.emitters.set(name, emitter)\n }\n}\n","/*\r\n* File: index.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nexport * from './Registry'\nexport * from './CommandClient'\n","/*\n * File: Extension.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport chalk from 'chalk'\nimport { Collection } from 'discord.js'\nimport { Logger } from 'tslog'\nimport { BaseComponent } from '../components'\nimport { ComponentArgument } from '../components/ComponentArgument'\nimport { ConverterComponent } from '../converter'\nimport { CommandClient } from '../structures'\n\nexport class Extension {\n protected get commandClient() {\n return CommandClient.getFromModule(this)\n }\n\n protected get client() {\n return this.commandClient.discord\n }\n\n protected _logger?: Logger\n\n protected get logger() {\n if (!this._logger) this._logger = this.commandClient.logger.getChildLogger({ prefix: [chalk.green(`[${this.constructor.name}]`)], displayFunctionName: false })\n return this._logger\n }\n\n protected async convertArguments(\n component: unknown,\n argList: unknown[],\n args: Collection<number, ComponentArgument>,\n getConverterArgs: (arg: ComponentArgument, index: number, converter: ConverterComponent) => unknown[] | Promise<unknown[]>,\n ) {\n const items = new Collection<unknown, { ext: object; component: ConverterComponent }>()\n\n for (const extension of this.commandClient.registry.extensions) {\n for (const converter of this.commandClient.registry.getComponentsWithType<ConverterComponent>(extension, ConverterComponent)) {\n if (converter.options.component != component) continue\n\n items.set(converter.options.type, { component: converter, ext: extension })\n }\n }\n\n for (const [index, arg] of args) {\n const converter = items.get(arg.type)\n\n if (!converter) {\n argList[index] = undefined\n continue\n }\n\n const converterArgs = await getConverterArgs(arg, index, converter.component)\n\n argList[index] = await converter.component.execute(converter.ext, converterArgs)\n }\n }\n}\n","/*\r\n* File: CTSExtension.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport chalk from 'chalk'\nimport { Extension } from './Extension'\n\nexport class CTSExtension extends Extension {\n protected get logger() {\n if (!this._logger) this._logger = this.commandClient.ctsLogger.getChildLogger({ prefix: [chalk.green(`[${this.constructor.name}]`)], displayFunctionName: false })\n return this._logger\n }\n}\n","/*\n * File: ApplicationCommandExtension.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport chalk from 'chalk'\nimport {\n APIApplicationCommandSubcommandGroupOption,\n APIApplicationCommandSubcommandOption,\n ApplicationCommandData,\n ApplicationCommandOptionData,\n ApplicationCommandOptionType,\n ApplicationCommandSubCommandData,\n ApplicationCommandType,\n ChatInputApplicationCommandData,\n ChatInputCommandInteraction,\n Collection,\n CommandInteraction,\n Interaction,\n InteractionType,\n MessageContextMenuCommandInteraction,\n Snowflake,\n UserContextMenuCommandInteraction,\n} from 'discord.js'\nimport { ApplicationCommandComponent } from './ApplicationCommand'\nimport { ApplicationCommandOption } from './ApplicationCommandOption'\nimport { moduleHook } from '../core/hooks'\nimport { listener } from '../core/listener'\nimport { CommandClient } from '../core/structures'\nimport { argConverter } from '../core/converter'\nimport { CTSExtension } from '../core/extensions/CTSExtension'\nimport { inspect } from 'util'\n\nexport type ApplicationCommandExtensionConfig = {\n guilds?: Snowflake[]\n}\n\nexport class ApplicationCommandExtension extends CTSExtension {\n constructor(public config: ApplicationCommandExtensionConfig) {\n super()\n }\n\n @listener({ event: 'interactionCreate' })\n async interactionCreate(i: Interaction) {\n if (i.type !== InteractionType.ApplicationCommand) return\n\n let cmd: ApplicationCommandComponent | null = null\n let ext: object | null = null\n\n const extensions = this.commandClient.registry.extensions\n\n for (const extension of extensions) {\n const components = this.commandClient.registry.getComponentsWithType<ApplicationCommandComponent>(extension, ApplicationCommandComponent)\n\n for (const command of components) {\n if (command.options.name === i.commandName) {\n ext = extension\n cmd = command\n }\n }\n }\n\n if (cmd && ext) {\n const argList: unknown[] = []\n\n await this.convertArguments(ApplicationCommandComponent, argList, cmd.argTypes, () => [i])\n\n for (const [idx, arg] of cmd.argTypes) {\n let value: unknown = null\n\n for (const decorator of arg.decorators) {\n if (decorator instanceof ApplicationCommandOption) {\n if ([ApplicationCommandOptionType.Subcommand, ApplicationCommandOptionType.SubcommandGroup].includes(decorator.options.type) && i.isChatInputCommand()) {\n if (decorator.options.type === ApplicationCommandOptionType.Subcommand) {\n value = i.options.getSubcommand() === decorator.options.name\n break\n }\n if (decorator.options.type === ApplicationCommandOptionType.SubcommandGroup) {\n value = i.options.getSubcommandGroup() === decorator.options.name\n break\n }\n }\n\n value = i.options.get(decorator.options.name, false)?.value\n break\n }\n }\n\n if (value) {\n argList[idx] = value\n }\n }\n\n try {\n await cmd.execute(ext, argList, [i])\n } catch (e) {\n this.commandClient.emit('applicationCommandInvokeError', e, i)\n }\n }\n }\n\n async sync() {\n const client = this.commandClient\n\n this.logger.info('Trying to sync commands...')\n\n let commands: ApplicationCommandData[] = []\n\n const guildCommands = new Collection<Snowflake, ApplicationCommandData[]>()\n\n const subcommandGroups = new Collection<string, ChatInputApplicationCommandData>()\n\n for (const command of client.registry.getComponentsWithTypeGlobal<ApplicationCommandComponent>(ApplicationCommandComponent)) {\n if (command.subcommandGroup) {\n let group = subcommandGroups.get(command.subcommandGroup.options.name)\n\n if (!group) {\n group = {\n ...command.subcommandGroup.options,\n type: ApplicationCommandType.ChatInput,\n }\n\n if (command.subcommandGroup.guilds) {\n for (const guild of command.subcommandGroup.guilds) {\n let commands = guildCommands.get(guild)\n if (!commands) {\n commands = []\n guildCommands.set(guild, commands)\n }\n }\n } else {\n commands.push(group)\n }\n\n subcommandGroups.set(command.subcommandGroup.options.name, group)\n }\n\n if (!group.options) group.options = []\n\n group.options.push({ ...command.options, type: ApplicationCommandOptionType.Subcommand } as ApplicationCommandSubCommandData)\n\n continue\n } else if (command.subcommandGroupChild) {\n const parent = command.subcommandGroupChild.parent\n let group = subcommandGroups.get(parent.options.name)\n\n if (!group) {\n group = {\n ...parent.options,\n type: ApplicationCommandType.ChatInput,\n }\n\n if (parent.guilds) {\n for (const guild of parent.guilds) {\n let commands = guildCommands.get(guild)\n if (!commands) {\n commands = []\n guildCommands.set(guild, commands)\n }\n }\n } else {\n commands.push(group)\n }\n\n subcommandGroups.set(parent.options.name, group)\n }\n\n if (!group.options) group.options = []\n\n let child = group.options.find((x) => x.name === command.subcommandGroupChild!.options.name) as APIApplicationCommandSubcommandGroupOption\n\n if (!child) {\n child = { type: ApplicationCommandOptionType.SubcommandGroup, ...(command.subcommandGroupChild.options as Omit<APIApplicationCommandSubcommandGroupOption, 'type'>) }\n group.options.push(child)\n }\n\n if (!child.options) child.options = []\n\n child.options.push({ ...command.options, type: ApplicationCommandOptionType.Subcommand } as APIApplicationCommandSubcommandOption)\n\n continue\n }\n\n const cmd: ApplicationCommandData = { ...command.options }\n\n if (cmd.type === ApplicationCommandType.ChatInput) {\n cmd.options = []\n\n for (const [, arg] of command.argTypes) {\n const option = arg.decorators.find((x) => x.constructor === ApplicationCommandOption) as ApplicationCommandOption\n\n if (option) {\n cmd.options.push(option.options)\n }\n }\n }\n\n if (command.options.guilds) {\n for (const guild of command.options.guilds) {\n let commands = guildCommands.get(guild)\n if (!commands) {\n commands = []\n guildCommands.set(guild, commands)\n }\n }\n continue\n }\n\n commands.push(cmd)\n }\n\n if (this.config.guilds) {\n for (const guild of this.config.guilds) {\n let g = guildCommands.get(guild)\n if (!g) {\n g = []\n guildCommands.set(guild, g)\n }\n g.push(...commands)\n }\n\n commands = []\n }\n\n if (guildCommands.size) {\n for (const [guild, commands] of guildCommands) {\n try {\n const g = await this.client.guilds.fetch(guild)\n await g.fetch()\n this.logger.info(\n `Processing ${chalk.green(commands.length)} commands(${commands.map((x) => chalk.blue(x.name)).join(', ')}) for guild ${chalk.green(g.name)}(${chalk.blue(g.id)})`,\n )\n\n await g.commands.set(commands)\n\n this.logger.info(`Successfully registered commands for guild ${chalk.green(g.name)}(${chalk.blue(g.id)})`)\n } catch (e) {\n this.logger.error(`Failed to register commands to guild ${chalk.green(guild)}: ${(e as Error).message}`)\n }\n }\n }\n if (commands.length) {\n try {\n this.logger.info(`Processing ${chalk.green(commands.length)} commands(${commands.map((x) => chalk.blue(x.name)).join(', ')}) for application scope...`)\n\n await this.client.application!.commands.set(commands)\n\n this.logger.info('Successfully registered commands.')\n } catch (e) {\n this.logger.error(`Failed to register commands to global: ${(e as Error).message}`)\n }\n }\n }\n\n @argConverter({\n component: ApplicationCommandComponent,\n parameterless: true,\n type: ChatInputCommandInteraction,\n })\n async chatInteraction(i: ChatInputCommandInteraction) {\n return i\n }\n\n @argConverter({\n component: ApplicationCommandComponent,\n parameterless: true,\n type: MessageContextMenuCommandInteraction,\n })\n async messageInteraction(i: MessageContextMenuCommandInteraction) {\n return i\n }\n\n @argConverter({\n component: ApplicationCommandComponent,\n parameterless: true,\n type: UserContextMenuCommandInteraction,\n })\n async userInteraction(i: UserContextMenuCommandInteraction) {\n return i\n }\n\n @argConverter({\n component: ApplicationCommandComponent,\n parameterless: true,\n type: CommandInteraction,\n })\n async commandInteraction(i: UserContextMenuCommandInteraction) {\n return i\n }\n}\n","/*\n * File: TextCommand.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport { createComponentDecorator } from '../core/components/decoratorCreator'\nimport { BaseComponent } from '../core/components/BaseComponent'\n\ntype TextCommandOptions = {\n name: string\n aliases?: string[]\n description?: string\n}\n\nexport class TextCommandComponent extends BaseComponent {\n constructor(public options: TextCommandOptions) {\n super()\n }\n}\n\nexport const command = (options: TextCommandOptions) => createComponentDecorator(new TextCommandComponent(options))\n","/*\r\n * File: parameters.ts\r\n *\r\n * Copyright (c) 2022-2022 pikokr\r\n *\r\n * Licensed under MIT License. Please see more defails in LICENSE file.\r\n */\r\n\r\nimport { ComponentArgumentDecorator } from '../core'\r\nimport { createArgumentDecorator } from '../core'\r\n\r\nexport class TextCommandRestOption extends ComponentArgumentDecorator<void> {}\r\n\r\nexport const rest = createArgumentDecorator(TextCommandRestOption)\r\n","/*\n * File: TextCommandExtension.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport { listener } from '../core/listener'\nimport { Message } from 'discord.js'\nimport { CTSExtension } from '../core/extensions/CTSExtension'\nimport { TextCommandComponent } from './TextCommand'\nimport { TextCommandRestOption } from './parameters'\nimport { argConverter } from '../core'\n\nexport type TextCommandConfig = {\n prefix: string | string[] | ((msg: Message) => Promise<string | string[]> | string | string[])\n}\n\nexport class TextCommandExtension extends CTSExtension {\n constructor(private config: TextCommandConfig) {\n super()\n }\n\n private async processPrefix(msg: Message): Promise<number | null> {\n const content = msg.content\n let prefix = this.config.prefix\n\n if (typeof prefix === 'function') {\n prefix = await prefix(msg)\n }\n\n if (typeof prefix === 'string') {\n if (content.startsWith(prefix)) return prefix.length\n return null\n }\n\n if (prefix instanceof Array) {\n const p = prefix.find((x) => content.startsWith(x))\n\n if (p) return p.length\n return null\n }\n\n return null\n }\n\n @listener({ event: 'messageCreate', emitter: 'discord' })\n private async messageCreate(msg: Message) {\n const startIndex = await this.processPrefix(msg)\n\n if (!startIndex) return\n\n const content = msg.content.slice(startIndex)\n\n const commands: TextCommandComponent[] = []\n\n const extensions = new Map<TextCommandComponent, object>()\n\n for (const ext of this.commandClient.registry.extensions) {\n for (const cmd of this.commandClient.registry.getComponentsWithType<TextCommandComponent>(ext, TextCommandComponent)) {\n commands.push(cmd)\n extensions.set(cmd, ext)\n }\n }\n\n let commandNameLength = 0\n\n const command = commands.find((x) => {\n const names = [x.options.name]\n\n if (x.options.aliases) {\n names.push(...x.options.aliases)\n }\n\n for (const name of names) {\n if (content.startsWith(name)) {\n if (content.length === name.length) {\n commandNameLength = name.length\n return true\n }\n commandNameLength = name.length\n return content.startsWith(name + ' ')\n }\n }\n\n return false\n })\n\n if (!command) return\n\n const ext = extensions.get(command)\n\n if (!ext) return\n\n const args: unknown[] = []\n\n let argStrings = content.slice(commandNameLength + 1).split(/ /g)\n\n await this.convertArguments(TextCommandComponent, args, command.argTypes, async (arg, i, converter) => {\n if (converter.options.parameterless) return [msg]\n\n if (arg.decorators.find((x) => x.constructor === TextCommandRestOption)) {\n const text = argStrings.join(' ')\n argStrings = []\n return [text, msg]\n }\n return [argStrings.shift(), msg]\n })\n\n await command.execute(ext, args, [msg])\n }\n\n @argConverter({ component: TextCommandComponent, type: Message, parameterless: true })\n async mesage(msg: Message) {\n return msg\n }\n\n @argConverter({ component: TextCommandComponent, type: String })\n async str(value: string) {\n return value\n }\n\n @argConverter({ component: TextCommandComponent, type: Number })\n async num(value: string) {\n return Number(value)\n }\n}\n","/*\r\n* File: CommandClient.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport chalk from 'chalk'\nimport { Client, Snowflake, Team, User } from 'discord.js'\nimport EventEmitter from 'events'\nimport { Logger } from 'tslog'\nimport { ApplicationCommandExtension, ApplicationCommandExtensionConfig } from '../../applicationCommand/ApplicationCommandExtension'\nimport { TextCommandConfig } from '../../textCommand'\nimport { TextCommandExtension } from '../../textCommand/TextCommandExtension'\nimport { CommandClientSymbol } from '../symbols'\nimport { Registry } from './Registry'\nexport class CommandClient extends EventEmitter {\n ctsLogger: Logger\n registry: Registry\n\n owners: Set<Snowflake> = new Set()\n\n constructor(public discord: Client, public logger: Logger = new Logger({ dateTimeTimezone: Intl.DateTimeFormat().resolvedOptions().timeZone })) {\n super()\n\n this.ctsLogger = logger.getChildLogger({ prefix: [chalk.blue('[command.ts]')], displayFilePath: 'hidden', displayFunctionName: false })\n\n this.registry = new Registry(this.ctsLogger, this)\n\n this.registry.registerEventEmitter('cts', this)\n this.registry.registerEventEmitter('discord', this.discord)\n }\n\n async fetchOwners() {\n if (!this.discord.application) throw new Error('The client is not logged in.')\n\n this.ctsLogger.info('Fetching owners...')\n\n await this.discord.application.fetch()\n\n const owner = this.discord.application.owner\n\n if (!owner) throw new Error('Cannot find application owner')\n\n const owners: string[] = []\n\n if (owner instanceof User) {\n this.owners.add(owner.id)\n owners.push(owner.tag)\n } else if (owner instanceof Team) {\n for (const [id, member] of owner.members) {\n this.owners.add(id)\n owners.push(member.user.tag)\n }\n }\n\n this.ctsLogger.info(`Fetched ${chalk.green(owners.length)} owners(${owners.map((x) => chalk.blue(x)).join(', ')})`)\n }\n\n async enableApplicationCommandsExtension(config: ApplicationCommandExtensionConfig) {\n await this.registry.registerModule(new ApplicationCommandExtension(config))\n this.ctsLogger.info('Application command extension enabled.')\n }\n\n async enableTextCommandsExtension(config: TextCommandConfig) {\n await this.registry.registerModule(new TextCommandExtension(config))\n this.ctsLogger.info('Text command extension enabled.')\n }\n\n getApplicationCommandsExtension() {\n return this.registry.extensions.find((x) => x.constructor === ApplicationCommandExtension) as ApplicationCommandExtension | undefined\n }\n\n static getFromModule(ext: object): CommandClient {\n return Reflect.getMetadata(CommandClientSymbol, ext)\n }\n}\n","/*\n * File: BaseComponent.ts\n *\n * Copyright (c) 2022-2022 pikokr\n *\n * Licensed under MIT License. Please see more defails in LICENSE file.\n */\n\nimport { Collection } from 'discord.js'\nimport _ from 'lodash'\nimport type { ComponentHookStore } from '../hooks'\nimport { ComponentArgument } from './ComponentArgument'\n\nexport class BaseComponent {\n method!: Function\n\n hooks: ComponentHookStore = new Collection()\n\n argTypes: Collection<number, ComponentArgument> = new Collection()\n\n _init(method: Function, argTypes: unknown[]) {\n this.method = method\n for (let i = 0; i < argTypes.length; i++) {\n const element = argTypes[i]\n this.argTypes.set(i, new ComponentArgument(element))\n }\n }\n\n async executeHook(target: object, name: string, args: unknown[]) {\n const hook = this.hooks.get(name)\n\n if (!hook) return\n\n const { CommandClient } = await import('../structures/CommandClient')\n\n for (const fn of hook) {\n await fn.call(null, CommandClient.getFromModule(target), ...args)\n }\n }\n\n async execute(target: object, args: unknown[], beforeCallArgs: unknown[] = args) {\n await this.executeHook(target, 'beforeCall', beforeCallArgs)\n let result\n try {\n result = await this.method.call(target, ...args)\n } catch (e) {\n await this.executeHook(target, 'invokeError', [e])\n throw e\n }\n await this.executeHook(target, 'afterCall', [result])\n\n return result\n }\n}\n","/*\r\n* File: index.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport 'reflect-metadata'\r\nexport * from './decoratorCreator'\r\nexport * from './ComponentArgument'\r\nexport * from './ComponentArgumentDecorator'\r\nexport * from './BaseComponent'\r\n","/*\r\n* File: errors.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nexport class OwnerOnlyError {}\n","/*\r\n* File: checks.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nimport { BaseInteraction, Interaction, Message } from 'discord.js'\nimport { createComponentHook } from '../hooks'\nimport { ComponentHookFn } from '../hooks/componentHook'\nimport { CommandClient } from '../structures'\nimport { OwnerOnlyError } from './errors'\n\nexport const createCheckDecorator = (fn: ComponentHookFn) => createComponentHook('beforeCall', fn)\n\nexport const ownerOnly = createCheckDecorator(async (client: CommandClient, i: Interaction | Message) => {\n let isOwner = false\n\n if (i instanceof BaseInteraction) {\n isOwner = client.owners.has(i.user.id)\n } else if (i instanceof Message) {\n isOwner = client.owners.has(i.author.id)\n }\n\n if (!isOwner) throw new OwnerOnlyError()\n})\n","/*\r\n* File: index.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nexport * from './checks'\nexport * from './errors'\n","/*\r\n* File: index.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nexport * from './Extension'\n","/*\r\n* File: index.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nexport * from './components'\nexport * from './hooks'\nexport * from './converter'\nexport * from './utils'\nexport * from './listener'\nexport * from './structures'\nexport * from './extensions'\n","/*\r\n* File: index.ts\r\n* \r\n* Copyright (c) 2022-2022 pikokr\r\n* \r\n* Licensed under MIT License. Please see more defails in LICENSE file.\r\n*/\r\n\r\nexport * from './core'\r\nexport * from './applicationCommand'\r\nexport * from './textCommand'\r\n","import { APIApplicationCommandSubcommandOption, ApplicationCommandType, ChatInputApplicationCommandData } from 'discord.js'\nimport { createComponentDecorator } from '../core'\nimport { ApplicationCommandComponent } from './ApplicationCommand'\n\nexport class SubCommandGroup {\n constructor(public options: Omit<APIApplicationCommandSubcommandOption, 'type'>, public guilds?: string[]) {}\n\n command(options: Omit<ChatInputApplicationCommandData, 'options' | 'type'>): MethodDecorator {\n const cmd = new ApplicationCommandComponent({\n type: ApplicationCommandType.ChatInput,\n ...options,\n })\n cmd.subcommandGroup = this\n return createComponentDecorator(cmd)\n }\n\n createChild(options: Omit<APIApplicationCommandSubcommandOption, 'type'>) {\n return new SubCommandGroupChild(options, this)\n }\n}\n\nexport class SubCommandGroupChild {\n constructor(public options: Omit<APIApplicationCommandSubcommandOption, 'type'>, public parent: SubCommandGroup) {}\n\n command(options: Omit<ChatInputApplicationCommandData, 'options' | 'type'>): MethodDecorator {\n const cmd = new ApplicationCommandComponent({\n type: ApplicationCommandType.ChatInput,\n ...options,\n })\n cmd.subcommandGroupChild = this\n return createComponentDecorator(cmd)\n }\n}\n"],"mappings":"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","names":[]}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@pikokr/command.ts",
3
3
  "description": "Discord.js command framework for typescript.",
4
- "version": "5.0.7-dev.c3c22eb",
4
+ "version": "5.0.7-dev.ee21c50",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
7
7
  "license": "MIT",
@@ -9,6 +9,7 @@
9
9
  import type { ApplicationCommandType, ChatInputApplicationCommandData, MessageApplicationCommandData, Snowflake, UserApplicationCommandData } from 'discord.js'
10
10
  import { createComponentDecorator } from '../core/components/decoratorCreator'
11
11
  import { BaseComponent } from '../core/components/BaseComponent'
12
+ import { SubCommandGroup, SubCommandGroupChild } from './group'
12
13
 
13
14
  type Options = (UserApplicationCommandData | MessageApplicationCommandData | Omit<ChatInputApplicationCommandData, 'options'>) & {
14
15
  type: ApplicationCommandType
@@ -18,6 +19,9 @@ type Options = (UserApplicationCommandData | MessageApplicationCommandData | Omi
18
19
  export class ApplicationCommandComponent extends BaseComponent {
19
20
  options: Options
20
21
 
22
+ subcommandGroup?: SubCommandGroup
23
+ subcommandGroupChild?: SubCommandGroupChild
24
+
21
25
  constructor(options: UserApplicationCommandData | MessageApplicationCommandData | Omit<ChatInputApplicationCommandData, 'options'>) {
22
26
  super()
23
27
 
@@ -26,3 +30,5 @@ export class ApplicationCommandComponent extends BaseComponent {
26
30
  }
27
31
 
28
32
  export const applicationCommand = (options: Options) => createComponentDecorator(new ApplicationCommandComponent(options))
33
+
34
+ export type { Options as ApplicationCommandComponentOptions }
@@ -8,11 +8,17 @@
8
8
 
9
9
  import chalk from 'chalk'
10
10
  import {
11
+ APIApplicationCommandSubcommandGroupOption,
12
+ APIApplicationCommandSubcommandOption,
11
13
  ApplicationCommandData,
14
+ ApplicationCommandOptionData,
12
15
  ApplicationCommandOptionType,
16
+ ApplicationCommandSubCommandData,
13
17
  ApplicationCommandType,
18
+ ChatInputApplicationCommandData,
14
19
  ChatInputCommandInteraction,
15
20
  Collection,
21
+ CommandInteraction,
16
22
  Interaction,
17
23
  InteractionType,
18
24
  MessageContextMenuCommandInteraction,
@@ -26,6 +32,7 @@ import { listener } from '../core/listener'
26
32
  import { CommandClient } from '../core/structures'
27
33
  import { argConverter } from '../core/converter'
28
34
  import { CTSExtension } from '../core/extensions/CTSExtension'
35
+ import { inspect } from 'util'
29
36
 
30
37
  export type ApplicationCommandExtensionConfig = {
31
38
  guilds?: Snowflake[]
@@ -95,19 +102,88 @@ export class ApplicationCommandExtension extends CTSExtension {
95
102
  }
96
103
  }
97
104
 
98
- @moduleHook('load')
99
- async load() {}
100
-
101
105
  async sync() {
102
- const client = CommandClient.getFromModule(this)
106
+ const client = this.commandClient
103
107
 
104
108
  this.logger.info('Trying to sync commands...')
105
109
 
106
- const commands: ApplicationCommandData[] = []
110
+ let commands: ApplicationCommandData[] = []
107
111
 
108
112
  const guildCommands = new Collection<Snowflake, ApplicationCommandData[]>()
109
113
 
114
+ const subcommandGroups = new Collection<string, ChatInputApplicationCommandData>()
115
+
110
116
  for (const command of client.registry.getComponentsWithTypeGlobal<ApplicationCommandComponent>(ApplicationCommandComponent)) {
117
+ if (command.subcommandGroup) {
118
+ let group = subcommandGroups.get(command.subcommandGroup.options.name)
119
+
120
+ if (!group) {
121
+ group = {
122
+ ...command.subcommandGroup.options,
123
+ type: ApplicationCommandType.ChatInput,
124
+ }
125
+
126
+ if (command.subcommandGroup.guilds) {
127
+ for (const guild of command.subcommandGroup.guilds) {
128
+ let commands = guildCommands.get(guild)
129
+ if (!commands) {
130
+ commands = []
131
+ guildCommands.set(guild, commands)
132
+ }
133
+ }
134
+ } else {
135
+ commands.push(group)
136
+ }
137
+
138
+ subcommandGroups.set(command.subcommandGroup.options.name, group)
139
+ }
140
+
141
+ if (!group.options) group.options = []
142
+
143
+ group.options.push({ ...command.options, type: ApplicationCommandOptionType.Subcommand } as ApplicationCommandSubCommandData)
144
+
145
+ continue
146
+ } else if (command.subcommandGroupChild) {
147
+ const parent = command.subcommandGroupChild.parent
148
+ let group = subcommandGroups.get(parent.options.name)
149
+
150
+ if (!group) {
151
+ group = {
152
+ ...parent.options,
153
+ type: ApplicationCommandType.ChatInput,
154
+ }
155
+
156
+ if (parent.guilds) {
157
+ for (const guild of parent.guilds) {
158
+ let commands = guildCommands.get(guild)
159
+ if (!commands) {
160
+ commands = []
161
+ guildCommands.set(guild, commands)
162
+ }
163
+ }
164
+ } else {
165
+ commands.push(group)
166
+ }
167
+
168
+ subcommandGroups.set(parent.options.name, group)
169
+ }
170
+
171
+ if (!group.options) group.options = []
172
+
173
+ let child = group.options.find((x) => x.name === command.subcommandGroupChild!.options.name) as APIApplicationCommandSubcommandGroupOption
174
+
175
+ if (!child) {
176
+ child = { type: ApplicationCommandOptionType.SubcommandGroup, ...(command.subcommandGroupChild.options as Omit<APIApplicationCommandSubcommandGroupOption, 'type'>) }
177
+ group.options.push(child)
178
+ }
179
+
180
+ if (!child.options) child.options = []
181
+
182
+ child.options.push({ ...command.options, type: ApplicationCommandOptionType.Subcommand } as APIApplicationCommandSubcommandOption)
183
+
184
+ continue
185
+ }
186
+
111
187
  const cmd: ApplicationCommandData = { ...command.options }
112
188
 
113
189
  if (cmd.type === ApplicationCommandType.ChatInput) {
@@ -129,32 +205,34 @@ export class ApplicationCommandExtension extends CTSExtension {
129
205
  commands = []
130
206
  guildCommands.set(guild, commands)
131
207
  }
132
- commands.push(cmd)
133
208
  }
134
209
  continue
135
210
  }
136
211
 
137
- if (this.config.guilds) {
138
- for (const guild of this.config.guilds) {
139
- let commands = guildCommands.get(guild)
140
- if (!commands) {
141
- commands = []
142
- guildCommands.set(guild, commands)
143
- }
144
- commands.push(cmd)
212
+ commands.push(cmd)
213
+ }
214
+
215
+ if (this.config.guilds) {
216
+ for (const guild of this.config.guilds) {
217
+ let g = guildCommands.get(guild)
218
+ if (!g) {
219
+ g = []
220
+ guildCommands.set(guild, g)
145
221
  }
146
- continue
222
+ g.push(...commands)
147
223
  }
148
- commands.push(cmd)
224
+
225
+ commands = []
149
226
  }
150
227
 
151
228
  if (guildCommands.size) {
152
229
  for (const [guild, commands] of guildCommands) {
153
- this.logger.info(`Processing ${chalk.green(commands.length)} commands(${commands.map((x) => chalk.blue(x.name)).join(', ')})`)
154
230
  try {
155
231
  const g = await this.client.guilds.fetch(guild)
156
232
  await g.fetch()
157
- this.logger.info(`Registering commands for guild ${chalk.green(g.name)}(${chalk.blue(g.id)})`)
233
+ this.logger.info(
234
+ `Processing ${chalk.green(commands.length)} commands(${commands.map((x) => chalk.blue(x.name)).join(', ')}) for guild ${chalk.green(g.name)}(${chalk.blue(g.id)})`,
235
+ )
158
236
 
159
237
  await g.commands.set(commands)
160
238
 
@@ -166,7 +244,7 @@ export class ApplicationCommandExtension extends CTSExtension {
166
244
  }
167
245
  if (commands.length) {
168
246
  try {
169
- this.logger.info(`Registering commands globally...`)
247
+ this.logger.info(`Processing ${chalk.green(commands.length)} commands(${commands.map((x) => chalk.blue(x.name)).join(', ')}) for application scope...`)
170
248
 
171
249
  await this.client.application!.commands.set(commands)
172
250
 
@@ -203,4 +281,13 @@ export class ApplicationCommandExtension extends CTSExtension {
203
281
  async userInteraction(i: UserContextMenuCommandInteraction) {
204
282
  return i
205
283
  }
284
+
285
+ @argConverter({
286
+ component: ApplicationCommandComponent,
287
+ parameterless: true,
288
+ type: CommandInteraction,
289
+ })
290
+ async commandInteraction(i: UserContextMenuCommandInteraction) {
291
+ return i
292
+ }
206
293
  }
@@ -0,0 +1,33 @@
1
+ import { APIApplicationCommandSubcommandOption, ApplicationCommandType, ChatInputApplicationCommandData } from 'discord.js'
2
+ import { createComponentDecorator } from '../core'
3
+ import { ApplicationCommandComponent } from './ApplicationCommand'
4
+
5
+ export class SubCommandGroup {
6
+ constructor(public options: Omit<APIApplicationCommandSubcommandOption, 'type'>, public guilds?: string[]) {}
7
+
8
+ command(options: Omit<ChatInputApplicationCommandData, 'options' | 'type'>): MethodDecorator {
9
+ const cmd = new ApplicationCommandComponent({
10
+ type: ApplicationCommandType.ChatInput,
11
+ ...options,
12
+ })
13
+ cmd.subcommandGroup = this
14
+ return createComponentDecorator(cmd)
15
+ }
16
+
17
+ createChild(options: Omit<APIApplicationCommandSubcommandOption, 'type'>) {
18
+ return new SubCommandGroupChild(options, this)
19
+ }
20
+ }
21
+
22
+ export class SubCommandGroupChild {
23
+ constructor(public options: Omit<APIApplicationCommandSubcommandOption, 'type'>, public parent: SubCommandGroup) {}
24
+
25
+ command(options: Omit<ChatInputApplicationCommandData, 'options' | 'type'>): MethodDecorator {
26
+ const cmd = new ApplicationCommandComponent({
27
+ type: ApplicationCommandType.ChatInput,
28
+ ...options,
29
+ })
30
+ cmd.subcommandGroupChild = this
31
+ return createComponentDecorator(cmd)
32
+ }
33
+ }
@@ -1,10 +1,11 @@
1
1
  /*
2
- * File: index.ts
3
- *
4
- * Copyright (c) 2022-2022 pikokr
5
- *
6
- * Licensed under MIT License. Please see more defails in LICENSE file.
7
- */
2
+ * File: index.ts
3
+ *
4
+ * Copyright (c) 2022-2022 pikokr
5
+ *
6
+ * Licensed under MIT License. Please see more defails in LICENSE file.
7
+ */
8
8
 
9
- export * from './ApplicationCommand'
10
- export { option } from './ApplicationCommandOption'
9
+ export * from './ApplicationCommand'
10
+ export { option } from './ApplicationCommandOption'
11
+ export * from './group'
package/test/index.ts CHANGED
@@ -7,11 +7,18 @@
7
7
  */
8
8
 
9
9
  import { ApplicationCommandOptionType, ApplicationCommandType, ChatInputCommandInteraction, Client, Message } from 'discord.js'
10
- import { applicationCommand, CommandClient, moduleHook, option, ownerOnly, listener, Extension, command, rest } from '../src'
10
+ import { applicationCommand, CommandClient, moduleHook, option, ownerOnly, listener, Extension, command, rest, SubCommandGroup } from '../src'
11
11
  import 'dotenv/config'
12
12
  import { Logger } from 'tslog'
13
13
  import chalk from 'chalk'
14
14
 
15
+ const group = new SubCommandGroup({
16
+ name: 'hi',
17
+ description: 'sans',
18
+ })
19
+
20
+ const sub = group.createChild({ name: 'sub', description: 'wow this is subcommand group' })
21
+
15
22
  class Test extends Extension {
16
23
  @applicationCommand({
17
24
  type: ApplicationCommandType.ChatInput,
@@ -46,6 +53,16 @@ class Test extends Extension {
46
53
  this.logger.info('Load')
47
54
  }
48
55
 
56
+ @group.command({ name: 'hi', description: 'Wow this is sans' })
57
+ hi(i: ChatInputCommandInteraction) {
58
+ i.reply('Hi this is subcommand')
59
+ }
60
+
61
+ @sub.command({ name: 'hi', description: 'Wow this is sans' })
62
+ subHi(i: ChatInputCommandInteraction) {
63
+ i.reply('Hi this is subcommand in subcommand group')
64
+ }
65
+
49
66
  @moduleHook('unload')
50
67
  unload() {
51
68
  this.logger.info('Unload')
@@ -87,6 +104,8 @@ const run = async () => {
87
104
 
88
105
  await client.login(process.env.TOKEN)
89
106
 
107
+ await client.application?.commands.set([])
108
+
90
109
  await cc.getApplicationCommandsExtension()!.sync()
91
110
  }
92
111