@pikokr/command.ts 5.0.6-dev.5612c0e → 5.0.7-dev.a5124c8

Sign up to get free protection for your applications and to get access to all the features.
package/dist/index.d.ts CHANGED
@@ -24,13 +24,11 @@ declare class ComponentArgument {
24
24
  constructor(type: unknown);
25
25
  }
26
26
 
27
- declare class BaseComponent<Options = unknown, OptionsArg = Options> {
28
- options: Options;
27
+ declare class BaseComponent {
29
28
  method: Function;
30
29
  hooks: ComponentHookStore;
31
30
  argTypes: Collection<number, ComponentArgument>;
32
- constructor(options: OptionsArg, method: Function, argTypes: unknown[]);
33
- convertOptions(options: OptionsArg): Options;
31
+ _init(method: Function, argTypes: unknown[]): void;
34
32
  executeHook(target: object, name: string, args: unknown[]): Promise<void>;
35
33
  execute(target: object, args: unknown[], beforeCallArgs?: unknown[]): Promise<any>;
36
34
  }
@@ -38,27 +36,26 @@ declare class BaseComponent<Options = unknown, OptionsArg = Options> {
38
36
  declare type ComponentStore = Collection<string | symbol, BaseComponent>;
39
37
  declare type ComponentArgumentStore = Collection<number, ComponentArgumentDecorator>;
40
38
  declare const getComponentStore: (target: object) => ComponentStore;
41
- declare const getComponent: (target: object, key: string | symbol) => BaseComponent<unknown, unknown> | undefined;
42
- declare const createComponentDecorator: <Options, OptionArgs>(type: {
43
- new (options: OptionArgs, method: Function, argTypes: unknown[]): BaseComponent<Options, OptionArgs>;
44
- }) => (options: OptionArgs) => MethodDecorator;
39
+ declare const getComponent: (target: object, key: string | symbol) => BaseComponent | undefined;
40
+ declare const createComponentDecorator: (component: BaseComponent) => MethodDecorator;
45
41
  declare const getComponentArgumentStore: (target: object, key: string | symbol) => ComponentArgumentStore;
46
42
  declare const createArgumentDecorator: <Options>(type: {
47
43
  new (options: Partial<Options>): ComponentArgumentDecorator<Options>;
48
44
  }) => (options: Options) => ParameterDecorator;
49
45
 
50
- declare type Options = {
51
- component: typeof BaseComponent<unknown>;
46
+ declare type Options$2 = {
47
+ component: unknown;
52
48
  type: Function;
53
49
  parameterless: boolean;
54
50
  };
55
- declare class ConverterComponent extends BaseComponent<Options, Omit<Options, 'parameterless'> & {
51
+ declare type OptionsArg$1 = Omit<Options$2, 'parameterless'> & {
56
52
  parameterless?: boolean;
57
- }> {
53
+ };
54
+ declare class ConverterComponent extends BaseComponent {
55
+ options: Options$2;
56
+ constructor(options: OptionsArg$1);
58
57
  }
59
- declare const argConverter: (options: Omit<Options, "parameterless"> & {
60
- parameterless?: boolean | undefined;
61
- }) => MethodDecorator;
58
+ declare const argConverter: (options: OptionsArg$1) => MethodDecorator;
62
59
 
63
60
  declare const createCheckDecorator: (fn: ComponentHookFn) => MethodDecorator;
64
61
  declare const ownerOnly: MethodDecorator;
@@ -66,29 +63,26 @@ declare const ownerOnly: MethodDecorator;
66
63
  declare class OwnerOnlyError {
67
64
  }
68
65
 
69
- declare class ListenerComponent extends BaseComponent<{
66
+ declare type Options$1 = {
70
67
  emitter: string;
71
68
  event: string;
72
- }, {
69
+ };
70
+ declare type OptionsArg = {
73
71
  emitter?: string;
74
72
  event: string;
75
- }> {
76
- defaultOptions(): {
77
- emitter: string;
78
- };
79
- constructor(options: ListenerComponent['options'], method: Function, argTypes: unknown[]);
73
+ };
74
+ declare class ListenerComponent extends BaseComponent {
75
+ options: Options$1;
76
+ constructor(options: OptionsArg);
80
77
  }
81
- declare const listener: (options: {
82
- emitter?: string | undefined;
83
- event: string;
84
- }) => MethodDecorator;
78
+ declare const listener: (options: OptionsArg) => MethodDecorator;
85
79
 
86
80
  declare class Extension {
87
81
  protected get commandClient(): CommandClient;
88
82
  protected get client(): discord_js.Client<boolean>;
89
83
  protected _logger?: Logger;
90
84
  protected get logger(): Logger;
91
- protected convertArguments(component: typeof BaseComponent<unknown>, argList: unknown[], args: Collection<number, ComponentArgument>, getConverterArgs: (arg: ComponentArgument, index: number, converter: ConverterComponent) => unknown[] | Promise<unknown[]>): Promise<void>;
85
+ protected convertArguments(component: unknown, argList: unknown[], args: Collection<number, ComponentArgument>, getConverterArgs: (arg: ComponentArgument, index: number, converter: ConverterComponent) => unknown[] | Promise<unknown[]>): Promise<void>;
92
86
  }
93
87
 
94
88
  declare class CTSExtension extends Extension {
@@ -114,7 +108,9 @@ declare type TextCommandOptions = {
114
108
  aliases?: string[];
115
109
  description?: string;
116
110
  };
117
- declare class TextCommandComponent extends BaseComponent<TextCommandOptions> {
111
+ declare class TextCommandComponent extends BaseComponent {
112
+ options: TextCommandOptions;
113
+ constructor(options: TextCommandOptions);
118
114
  }
119
115
  declare const command: (options: TextCommandOptions) => MethodDecorator;
120
116
 
@@ -146,8 +142,8 @@ declare class Registry {
146
142
  emitters: Collection<string, EventEmitter>;
147
143
  logger: Logger;
148
144
  constructor(logger: Logger, client: CommandClient);
149
- getComponentsWithTypeGlobal<T extends typeof BaseComponent<Config>, Config>(type: T): InstanceType<T>[];
150
- getComponentsWithType<T extends typeof BaseComponent<Config>, Config>(ext: object, type: T): InstanceType<T>[];
145
+ getComponentsWithTypeGlobal<T>(type: unknown): T[];
146
+ getComponentsWithType<T>(ext: object, type: unknown): T[];
151
147
  registerEventListeners(ext: object): void;
152
148
  unregisterEventListeners(ext: object): void;
153
149
  loadAllModulesInDirectory(dir: string): Promise<object[]>;
@@ -163,15 +159,15 @@ declare class Registry {
163
159
  registerEventEmitter(name: string, emitter: EventEmitter): void;
164
160
  }
165
161
 
166
- declare class ApplicationCommandComponent extends BaseComponent<(UserApplicationCommandData | MessageApplicationCommandData | Omit<ChatInputApplicationCommandData, 'options'>) & {
162
+ declare type Options = (UserApplicationCommandData | MessageApplicationCommandData | Omit<ChatInputApplicationCommandData, 'options'>) & {
167
163
  type: ApplicationCommandType;
168
164
  guilds?: Snowflake[];
169
- }> {
165
+ };
166
+ declare class ApplicationCommandComponent extends BaseComponent {
167
+ options: Options;
168
+ constructor(options: UserApplicationCommandData | MessageApplicationCommandData | Omit<ChatInputApplicationCommandData, 'options'>);
170
169
  }
171
- declare const applicationCommand: (options: (UserApplicationCommandData | MessageApplicationCommandData | Omit<ChatInputApplicationCommandData, "options">) & {
172
- type: ApplicationCommandType;
173
- guilds?: string[] | undefined;
174
- }) => MethodDecorator;
170
+ declare const applicationCommand: (options: Options) => MethodDecorator;
175
171
 
176
172
  declare const option: (options: APIApplicationCommandOption) => ParameterDecorator;
177
173
 
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";var Yt=Object.create;var B=Object.defineProperty;var te=Object.getOwnPropertyDescriptor;var ee=Object.getOwnPropertyNames;var oe=Object.getPrototypeOf,re=Object.prototype.hasOwnProperty;var c=(n,t)=>B(n,"name",{value:t,configurable:!0});var m=(n,t)=>()=>(n&&(t=n(n=0)),t);var Tt=(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 r of ee(t))!re.call(n,r)&&r!==e&&B(n,r,{get:()=>t[r],enumerable:!(o=te(t,r))||o.enumerable});return n};var x=(n,t,e)=>(e=n!=null?Yt(oe(n)):{},Ht(t||!n||!n.__esModule?B(e,"default",{value:n,enumerable:!0}):e,n)),ne=n=>Ht(B({},"__esModule",{value:!0}),n);var z,fe,pt,X,lt,Y,E=m(()=>{"use strict";z=Symbol(),fe=Symbol(),pt=Symbol(),X=Symbol(),lt=Symbol(),Y=Symbol()});var jt,ft,tt,ut=m(()=>{"use strict";jt=require("discord.js");E();ft=c((n,t)=>{let e=Reflect.getMetadata(lt,n,t);return e||(e=new jt.Collection,Reflect.defineMetadata(lt,e,n,t)),e},"getComponentHookStore"),tt=c((n,t)=>(e,o)=>{let r=ft(e,o),s=r.get(n);s||(s=[],r.set(n,s)),s.push(t)},"createComponentHook")});var dt,U,se,w,gt,Z,W=m(()=>{"use strict";dt=require("discord.js");ut();E();U=c(n=>{let t=Reflect.getMetadata(z,n);return t||(t=new dt.Collection,Reflect.defineMetadata(z,t,n)),t},"getComponentStore"),se=c((n,t)=>U(n).get(t),"getComponent"),w=c(n=>t=>(e,o)=>{var r=new n(t,Reflect.get(e,o),Reflect.getMetadata("design:paramtypes",e,o));let s=ft(e,o);r.hooks=s;let i=U(e);gt(e,o).forEach((l,u)=>{var f;(f=r.argTypes.get(u))==null||f.decorators.push(l)}),i.set(o,r)},"createComponentDecorator"),gt=c((n,t)=>{let e=Reflect.getMetadata(z,n,t);return e||(e=new dt.Collection,Reflect.defineMetadata(z,e,n,t)),e},"getComponentArgumentStore"),Z=c(n=>t=>(e,o,r)=>{var s=new n(t);gt(e,o).set(r,s)},"createArgumentDecorator")});var $,ht=m(()=>{"use strict";$=class{constructor(t){this.type=t,this.decorators=[]}};c($,"ComponentArgument")});var It,R,Lt=m(()=>{"use strict";It=x(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 d,ie,yt=m(()=>{"use strict";W();A();d=class extends g{};c(d,"ApplicationCommandComponent");ie=w(d)});var H,Ot,xt=m(()=>{"use strict";D();H=class extends R{};c(H,"ApplicationCommandOption");Ot=Z(H)});var Et,et,Ct,Wt=m(()=>{"use strict";Et=require("discord.js");E();et=c(n=>{let t=Reflect.getMetadata(pt,n);return t||(t=new Et.Collection,Reflect.defineMetadata(pt,t,n)),t},"getModuleHookStore"),Ct=c(n=>(t,e)=>{let o=et(t),r=o.get(n);r||(r=[],o.set(n,r)),r.push(Reflect.get(t,e))},"moduleHook")});var J=m(()=>{"use strict";Wt();ut()});var k,K,Q=m(()=>{"use strict";A();W();k=class extends g{defaultOptions(){return{emitter:"discord"}}constructor(t,e,o){super({event:t.event,emitter:t.emitter??"discord"},e,o)}};c(k,"ListenerComponent");K=w(k)});var ot,$t,At,Dt,Pt,P,wt=m(()=>{"use strict";ot=x(require("chalk")),$t=require("discord.js"),At=x(require("lodash"));bt();J();Q();E();Dt=x(require("walk-sync")),Pt=x(require("path")),P=class{constructor(t,e){this.client=e,this.extensions=[],this.emitters=new $t.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(r=>r.constructor===e).values())}registerEventListeners(t){let e=this.getComponentsWithType(t,k);for(let o of e){let r=this.emitters.get(o.options.emitter);if(r){let s=o.method.bind(t);Reflect.defineMetadata("bound",s,o),r.addListener(o.options.event,s)}}}unregisterEventListeners(t){let e=this.getComponentsWithType(t,k);for(let o of e){let r=this.emitters.get(o.options.emitter),s=Reflect.getMetadata("bound",o);r&&s&&r.removeListener(o.options.event,s)}}async loadAllModulesInDirectory(t){let e=[],o=(0,Dt.default)(t).filter(r=>r.endsWith(".ts")||r.endsWith(".js"));for(let r of o)if(!r.endsWith(".d.ts"))try{let s=Pt.default.join(t,r),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 ${r}`)}return e}async registerModules(t,e){let o=[];if(t instanceof Array)for(let r of t)await this.registerModule(r),Reflect.defineMetadata(Y,e,r),o.push(r);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 r=Reflect.getMetadata(Y,o);!r||(e.add(r),await this.unregisterModule(o),delete require.cache[require.resolve(r)])}for(let o of e)try{let r=require(o);if(typeof r.setup!="function")continue;let s=await r.setup(this.client);await this.registerModules(s,o),t.push({file:o,result:!0})}catch(r){t.push({file:o,result:!1,error:r})}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"),At.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";A();W();j=class extends g{};c(j,"ConverterComponent");b=w(j)});var Nt,Gt,N,St=m(()=>{"use strict";Nt=x(require("chalk")),Gt=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:[Nt.default.green(`[${this.constructor.name}]`)],displayFunctionName:!1})),this._logger}async convertArguments(t,e,o,r){let s=new Gt.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 u=await r(a,i,l.component);e[i]=await l.component.execute(l.ext,u)}}};c(N,"Extension")});var qt,I,vt=m(()=>{"use strict";qt=x(require("chalk"));St();I=class extends N{get logger(){return this._logger||(this._logger=this.commandClient.ctsLogger.getChildLogger({prefix:[qt.default.green(`[${this.constructor.name}]`)],displayFunctionName:!1})),this._logger}};c(I,"CTSExtension")});var F,p,V,C,h,Bt=m(()=>{"use strict";F=x(require("chalk")),p=require("discord.js");yt();xt();J();Q();rt();nt();vt();V=function(n,t,e,o){var r=arguments.length,s=r<3?t:o===null?o=Object.getOwnPropertyDescriptor(t,e):o,i;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")s=Reflect.decorate(n,t,e,o);else for(var a=n.length-1;a>=0;a--)(i=n[a])&&(s=(r<3?i(s):r>3?i(t,e,s):i(t,e))||s);return r>3&&s&&Object.defineProperty(t,e,s),s},C=function(n,t){if(typeof Reflect=="object"&&typeof Reflect.metadata=="function")return Reflect.metadata(n,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,r=this.commandClient.registry.extensions;for(let i of r){let a=this.commandClient.registry.getComponentsWithType(i,d);for(let l of a)l.options.name===t.commandName&&(o=i,e=l)}if(e&&o){let i=[];await this.convertArguments(d,i,e.argTypes,()=>[t]);for(let[a,l]of e.argTypes){let u=null;for(let f of l.decorators)if(f instanceof H){if([p.ApplicationCommandOptionType.Subcommand,p.ApplicationCommandOptionType.SubcommandGroup].includes(f.options.type)&&t.isChatInputCommand()){if(f.options.type===p.ApplicationCommandOptionType.Subcommand){u=t.options.getSubcommand()===f.options.name;break}if(f.options.type===p.ApplicationCommandOptionType.SubcommandGroup){u=t.options.getSubcommandGroup()===f.options.name;break}}u=(s=t.options.get(f.options.name,!1))==null?void 0:s.value;break}u&&(i[a]=u)}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 r of t.registry.getComponentsWithTypeGlobal(d)){let s={...r.options};if(s.type===p.ApplicationCommandType.ChatInput){s.options=[];for(let[,i]of r.argTypes){let a=i.decorators.find(l=>l.constructor===H);a&&s.options.push(a.options)}}if(r.options.guilds){for(let i of r.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[r,s]of o){this.logger.info(`Processing ${F.default.green(s.length)} commands(${s.map(i=>F.default.blue(i.name)).join(", ")})`);try{let i=await this.client.guilds.fetch(r);await i.fetch(),this.logger.info(`Registering commands for guild ${F.default.green(i.name)}(${F.default.blue(i.id)})`),await i.commands.set(s),this.logger.info(`Successfully registered commands for guild ${F.default.green(i.name)}(${F.default.blue(i.id)})`)}catch(i){this.logger.error(`Failed to register commands to guild ${F.default.green(r)}: ${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(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}};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:d,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:d,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:d,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,ce,Rt=m(()=>{"use strict";W();A();y=class extends g{};c(y,"TextCommandComponent");ce=w(y)});var L,ae,kt=m(()=>{"use strict";D();D();L=class extends R{};c(L,"TextCommandRestOption");ae=Z(L)});var G,st,_,S,zt=m(()=>{"use strict";Q();G=require("discord.js");vt();Rt();kt();D();st=function(n,t,e,o){var r=arguments.length,s=r<3?t:o===null?o=Object.getOwnPropertyDescriptor(t,e):o,i;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")s=Reflect.decorate(n,t,e,o);else for(var a=n.length-1;a>=0;a--)(i=n[a])&&(s=(r<3?i(s):r>3?i(t,e,s):i(t,e))||s);return r>3&&s&&Object.defineProperty(t,e,s),s},_=function(n,t){if(typeof Reflect=="object"&&typeof Reflect.metadata=="function")return Reflect.metadata(n,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 r=o.find(s=>e.startsWith(s));return r?r.length:null}return null}async messageCreate(t){let e=await this.processPrefix(t);if(!e)return;let o=t.content.slice(e),r=[],s=new Map;for(let v of this.commandClient.registry.extensions)for(let O of this.commandClient.registry.getComponentsWithType(v,y))r.push(O),s.set(O,v);let i=0,a=r.find(v=>{let O=[v.options.name];v.options.aliases&&O.push(...v.options.aliases);for(let T of O)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 u=[],f=o.slice(i+1).split(/ /g);await this.convertArguments(y,u,a.argTypes,async(v,O,T)=>{if(T.options.parameterless)return[t];if(v.decorators.find(mt=>mt.constructor===L)){let mt=f.join(" ");return f=[],[mt,t]}return[f.shift(),t]}),await a.execute(l,u,[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"}),_("design:type",Function),_("design:paramtypes",[typeof G.Message>"u"?Object:G.Message])],S.prototype,"messageCreate",null);st([b({component:y,type:G.Message,parameterless:!0}),_("design:type",Function),_("design:paramtypes",[typeof G.Message>"u"?Object:G.Message])],S.prototype,"mesage",null);st([b({component:y,type:String}),_("design:type",Function),_("design:paramtypes",[String])],S.prototype,"str",null);st([b({component:y,type:Number}),_("design:type",Function),_("design:paramtypes",[String])],S.prototype,"num",null)});var Jt={};Tt(Jt,{CommandClient:()=>M});var it,ct,Ut,Zt,M,Mt=m(()=>{"use strict";it=x(require("chalk")),ct=require("discord.js"),Ut=x(require("events")),Zt=require("tslog");Bt();zt();E();wt();M=class extends Ut.default{constructor(t,e=new Zt.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,r]of t.members)this.owners.add(o),e.push(r.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 Ft,g,A=m(()=>{"use strict";Ft=require("discord.js");ht();g=class{hooks=new Ft.Collection;argTypes=new Ft.Collection;constructor(t,e,o){this.options=this.convertOptions(t),this.method=e;for(let r=0;r<o.length;r++){let s=o[r];this.argTypes.set(r,new $(s))}}convertOptions(t){return t}async executeHook(t,e,o){let r=this.hooks.get(e);if(!r)return;let{CommandClient:s}=await Promise.resolve().then(()=>(Mt(),Jt));for(let i of r)await i.call(null,s.getFromModule(t),...o)}async execute(t,e,o=e){await this.executeHook(t,"beforeCall",o);let r;try{r=await this.method.call(t,...e)}catch(s){throw await this.executeHook(t,"invokeError",[s]),s}return await this.executeHook(t,"afterCall",[r]),r}};c(g,"BaseComponent")});var So,bt=m(()=>{"use strict";So=require("reflect-metadata");W();ht();Lt();A()});var q,_t=m(()=>{"use strict";q=class{};c(q,"OwnerOnlyError")});var at,Kt,me,Qt=m(()=>{"use strict";at=require("discord.js");J();_t();Kt=c(n=>tt("beforeCall",n),"createCheckDecorator"),me=Kt(async(n,t)=>{let e=!1;if(t instanceof at.BaseInteraction?e=n.owners.has(t.user.id):t instanceof at.Message&&(e=n.owners.has(t.author.id)),!e)throw new q})});var Vt=m(()=>{"use strict";Qt();_t()});var Xt=m(()=>{"use strict";St()});var D=m(()=>{"use strict";bt();J();nt();Vt();Q();rt();Xt()});var pe={};Tt(pe,{ApplicationCommandComponent:()=>d,BaseComponent:()=>g,CommandClient:()=>M,ComponentArgument:()=>$,ComponentArgumentDecorator:()=>R,ConverterComponent:()=>j,Extension:()=>N,ListenerComponent:()=>k,OwnerOnlyError:()=>q,Registry:()=>P,TextCommandComponent:()=>y,TextCommandRestOption:()=>L,applicationCommand:()=>ie,argConverter:()=>b,command:()=>ce,createArgumentDecorator:()=>Z,createCheckDecorator:()=>Kt,createComponentDecorator:()=>w,createComponentHook:()=>tt,getComponent:()=>se,getComponentArgumentStore:()=>gt,getComponentStore:()=>U,getModuleHookStore:()=>et,listener:()=>K,moduleHook:()=>Ct,option:()=>Ot,ownerOnly:()=>me,rest:()=>ae});module.exports=ne(pe);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 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});
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","/*\r\n* File: decoratorCreator.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 { 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 = <Options, OptionArgs>(type: typeof BaseComponent<Options, OptionArgs>) => {\n return (options: OptionArgs): MethodDecorator => {\n return (target, key) => {\n var component: BaseComponent<Options, OptionArgs> = new type(options, 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}\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\nexport class ApplicationCommandComponent extends BaseComponent<\n (UserApplicationCommandData | MessageApplicationCommandData | Omit<ChatInputApplicationCommandData, 'options'>) & { type: ApplicationCommandType; guilds?: Snowflake[] }\n> {}\n\nexport const applicationCommand = createComponentDecorator(ApplicationCommandComponent)\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","/*\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 { BaseComponent } from '../components/BaseComponent'\nimport { createComponentDecorator } from '../components/decoratorCreator'\n\nexport class ListenerComponent extends BaseComponent<{ emitter: string; event: string }, { emitter?: string; event: string }> {\n defaultOptions() {\n return { emitter: 'discord' }\n }\n\n constructor(options: ListenerComponent['options'], method: Function, argTypes: unknown[]) {\n super(\n {\n event: options.event,\n emitter: options.emitter ?? 'discord',\n },\n method,\n argTypes,\n )\n }\n}\n\nexport const listener = createComponentDecorator(ListenerComponent)\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 extends typeof BaseComponent<Config>, Config>(type: T): InstanceType<T>[] {\n const result: InstanceType<T>[] = []\n\n for (const ext of this.extensions) {\n result.push(...this.getComponentsWithType(ext, type))\n }\n\n return result\n }\n\n getComponentsWithType<T extends typeof BaseComponent<Config>, Config>(ext: object, type: T): InstanceType<T>[] {\n const componentStore = getComponentStore(ext)\n\n return Array.from(componentStore.filter((x) => (x.constructor as unknown) === type).values() as Iterable<InstanceType<T>>)\n }\n\n registerEventListeners(ext: object) {\n const listeners = this.getComponentsWithType(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(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","/*\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 { BaseComponent } from '../components/BaseComponent'\nimport { createComponentDecorator } from '../components/decoratorCreator'\n\ntype Options = { component: typeof BaseComponent<unknown>; type: Function; parameterless: boolean }\n\nexport class ConverterComponent extends BaseComponent<Options, Omit<Options, 'parameterless'> & { parameterless?: boolean }> {}\n\nexport const argConverter = createComponentDecorator(ConverterComponent)\n","/*\r\n* File: Extension.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 { 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: typeof BaseComponent<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(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(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)) {\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<TextCommandOptions> {}\n\nexport const command = createComponentDecorator(TextCommandComponent)\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(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","/*\r\n* File: BaseComponent.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 _ from 'lodash'\nimport type { ComponentHookStore } from '../hooks'\nimport { ComponentArgument } from './ComponentArgument'\n\nexport class BaseComponent<Options = unknown, OptionsArg = Options> {\n options: Options\n\n method: Function\n\n hooks: ComponentHookStore = new Collection()\n\n argTypes: Collection<number, ComponentArgument> = new Collection()\n\n constructor(options: OptionsArg, method: Function, argTypes: unknown[]) {\n this.options = this.convertOptions(options)\n\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 convertOptions(options: OptionsArg): Options {\n return options as unknown as Options\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/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":[]}
package/package.json CHANGED
@@ -1,22 +1,22 @@
1
1
  {
2
2
  "name": "@pikokr/command.ts",
3
3
  "description": "Discord.js command framework for typescript.",
4
- "version": "5.0.6-dev.5612c0e",
4
+ "version": "5.0.7-dev.a5124c8",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
7
7
  "license": "MIT",
8
8
  "devDependencies": {
9
9
  "@discordjs/ts-docgen": "0.4.1",
10
- "@swc/core": "1.2.220",
10
+ "@swc/core": "1.2.222",
11
11
  "@types/chalk": "2.2.0",
12
12
  "@types/lodash": "4.14.182",
13
13
  "all-contributors-cli": "6.20.0",
14
- "discord.js": "14.0.3",
14
+ "discord.js": "14.1.2",
15
15
  "dotenv": "16.0.1",
16
16
  "prettier": "2.7.1",
17
17
  "rimraf": "3.0.2",
18
18
  "ts-node": "10.9.1",
19
- "tsup": "6.2.0",
19
+ "tsup": "6.2.1",
20
20
  "typedoc": "0.23.9",
21
21
  "typescript": "4.7.4"
22
22
  },
@@ -10,8 +10,19 @@ import type { ApplicationCommandType, ChatInputApplicationCommandData, MessageAp
10
10
  import { createComponentDecorator } from '../core/components/decoratorCreator'
11
11
  import { BaseComponent } from '../core/components/BaseComponent'
12
12
 
13
- export class ApplicationCommandComponent extends BaseComponent<
14
- (UserApplicationCommandData | MessageApplicationCommandData | Omit<ChatInputApplicationCommandData, 'options'>) & { type: ApplicationCommandType; guilds?: Snowflake[] }
15
- > {}
13
+ type Options = (UserApplicationCommandData | MessageApplicationCommandData | Omit<ChatInputApplicationCommandData, 'options'>) & {
14
+ type: ApplicationCommandType
15
+ guilds?: Snowflake[]
16
+ }
16
17
 
17
- export const applicationCommand = createComponentDecorator(ApplicationCommandComponent)
18
+ export class ApplicationCommandComponent extends BaseComponent {
19
+ options: Options
20
+
21
+ constructor(options: UserApplicationCommandData | MessageApplicationCommandData | Omit<ChatInputApplicationCommandData, 'options'>) {
22
+ super()
23
+
24
+ this.options = options as Options
25
+ }
26
+ }
27
+
28
+ export const applicationCommand = (options: Options) => createComponentDecorator(new ApplicationCommandComponent(options))
@@ -46,7 +46,7 @@ export class ApplicationCommandExtension extends CTSExtension {
46
46
  const extensions = this.commandClient.registry.extensions
47
47
 
48
48
  for (const extension of extensions) {
49
- const components = this.commandClient.registry.getComponentsWithType(extension, ApplicationCommandComponent)
49
+ const components = this.commandClient.registry.getComponentsWithType<ApplicationCommandComponent>(extension, ApplicationCommandComponent)
50
50
 
51
51
  for (const command of components) {
52
52
  if (command.options.name === i.commandName) {
@@ -107,7 +107,7 @@ export class ApplicationCommandExtension extends CTSExtension {
107
107
 
108
108
  const guildCommands = new Collection<Snowflake, ApplicationCommandData[]>()
109
109
 
110
- for (const command of client.registry.getComponentsWithTypeGlobal(ApplicationCommandComponent)) {
110
+ for (const command of client.registry.getComponentsWithTypeGlobal<ApplicationCommandComponent>(ApplicationCommandComponent)) {
111
111
  const cmd: ApplicationCommandData = { ...command.options }
112
112
 
113
113
  if (cmd.type === ApplicationCommandType.ChatInput) {
@@ -1,28 +1,24 @@
1
- /*
2
- * File: BaseComponent.ts
3
- *
4
- * Copyright (c) 2022-2022 pikokr
5
- *
6
- * Licensed under MIT License. Please see more defails in LICENSE file.
7
- */
8
-
1
+ /*
2
+ * File: BaseComponent.ts
3
+ *
4
+ * Copyright (c) 2022-2022 pikokr
5
+ *
6
+ * Licensed under MIT License. Please see more defails in LICENSE file.
7
+ */
8
+
9
9
  import { Collection } from 'discord.js'
10
10
  import _ from 'lodash'
11
11
  import type { ComponentHookStore } from '../hooks'
12
12
  import { ComponentArgument } from './ComponentArgument'
13
13
 
14
- export class BaseComponent<Options = unknown, OptionsArg = Options> {
15
- options: Options
16
-
17
- method: Function
14
+ export class BaseComponent {
15
+ method!: Function
18
16
 
19
17
  hooks: ComponentHookStore = new Collection()
20
18
 
21
19
  argTypes: Collection<number, ComponentArgument> = new Collection()
22
20
 
23
- constructor(options: OptionsArg, method: Function, argTypes: unknown[]) {
24
- this.options = this.convertOptions(options)
25
-
21
+ _init(method: Function, argTypes: unknown[]) {
26
22
  this.method = method
27
23
  for (let i = 0; i < argTypes.length; i++) {
28
24
  const element = argTypes[i]
@@ -30,10 +26,6 @@ export class BaseComponent<Options = unknown, OptionsArg = Options> {
30
26
  }
31
27
  }
32
28
 
33
- convertOptions(options: OptionsArg): Options {
34
- return options as unknown as Options
35
- }
36
-
37
29
  async executeHook(target: object, name: string, args: unknown[]) {
38
30
  const hook = this.hooks.get(name)
39
31
 
@@ -1,11 +1,11 @@
1
- /*
2
- * File: decoratorCreator.ts
3
- *
4
- * Copyright (c) 2022-2022 pikokr
5
- *
6
- * Licensed under MIT License. Please see more defails in LICENSE file.
7
- */
8
-
1
+ /*
2
+ * File: decoratorCreator.ts
3
+ *
4
+ * Copyright (c) 2022-2022 pikokr
5
+ *
6
+ * Licensed under MIT License. Please see more defails in LICENSE file.
7
+ */
8
+
9
9
  import { Collection } from 'discord.js'
10
10
  import { ComponentHookStore } from '../hooks'
11
11
  import { getComponentHookStore } from '../hooks/componentHook'
@@ -34,25 +34,23 @@ export const getComponent = (target: object, key: string | symbol) => {
34
34
  return store.get(key)
35
35
  }
36
36
 
37
- export const createComponentDecorator = <Options, OptionArgs>(type: typeof BaseComponent<Options, OptionArgs>) => {
38
- return (options: OptionArgs): MethodDecorator => {
39
- return (target, key) => {
40
- var component: BaseComponent<Options, OptionArgs> = new type(options, Reflect.get(target, key), Reflect.getMetadata('design:paramtypes', target, key))
37
+ export const createComponentDecorator = (component: BaseComponent): MethodDecorator => {
38
+ return (target, key) => {
39
+ component._init(Reflect.get(target, key), Reflect.getMetadata('design:paramtypes', target, key))
41
40
 
42
- const componentHookStore: ComponentHookStore = getComponentHookStore(target, key)
41
+ const componentHookStore: ComponentHookStore = getComponentHookStore(target, key)
43
42
 
44
- component.hooks = componentHookStore
43
+ component.hooks = componentHookStore
45
44
 
46
- const store = getComponentStore(target)
45
+ const store = getComponentStore(target)
47
46
 
48
- const decorators = getComponentArgumentStore(target, key)
47
+ const decorators = getComponentArgumentStore(target, key)
49
48
 
50
- decorators.forEach((x, i) => {
51
- component.argTypes.get(i)?.decorators.push(x)
52
- })
49
+ decorators.forEach((x, i) => {
50
+ component.argTypes.get(i)?.decorators.push(x)
51
+ })
53
52
 
54
- store.set(key, component)
55
- }
53
+ store.set(key, component)
56
54
  }
57
55
  }
58
56
 
@@ -1,16 +1,25 @@
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
- */
8
-
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
+ */
8
+
9
9
  import { BaseComponent } from '../components/BaseComponent'
10
10
  import { createComponentDecorator } from '../components/decoratorCreator'
11
11
 
12
- type Options = { component: typeof BaseComponent<unknown>; type: Function; parameterless: boolean }
12
+ type Options = { component: unknown; type: Function; parameterless: boolean }
13
+
14
+ type OptionsArg = Omit<Options, 'parameterless'> & { parameterless?: boolean }
15
+
16
+ export class ConverterComponent extends BaseComponent {
17
+ options: Options
13
18
 
14
- export class ConverterComponent extends BaseComponent<Options, Omit<Options, 'parameterless'> & { parameterless?: boolean }> {}
19
+ constructor(options: OptionsArg) {
20
+ super()
21
+ this.options = options as Options
22
+ }
23
+ }
15
24
 
16
- export const argConverter = createComponentDecorator(ConverterComponent)
25
+ export const argConverter = (options: OptionsArg) => createComponentDecorator(new ConverterComponent(options))
@@ -1,11 +1,11 @@
1
- /*
2
- * File: Extension.ts
3
- *
4
- * Copyright (c) 2022-2022 pikokr
5
- *
6
- * Licensed under MIT License. Please see more defails in LICENSE file.
7
- */
8
-
1
+ /*
2
+ * File: Extension.ts
3
+ *
4
+ * Copyright (c) 2022-2022 pikokr
5
+ *
6
+ * Licensed under MIT License. Please see more defails in LICENSE file.
7
+ */
8
+
9
9
  import chalk from 'chalk'
10
10
  import { Collection } from 'discord.js'
11
11
  import { Logger } from 'tslog'
@@ -31,7 +31,7 @@ export class Extension {
31
31
  }
32
32
 
33
33
  protected async convertArguments(
34
- component: typeof BaseComponent<unknown>,
34
+ component: unknown,
35
35
  argList: unknown[],
36
36
  args: Collection<number, ComponentArgument>,
37
37
  getConverterArgs: (arg: ComponentArgument, index: number, converter: ConverterComponent) => unknown[] | Promise<unknown[]>,
@@ -39,7 +39,7 @@ export class Extension {
39
39
  const items = new Collection<unknown, { ext: object; component: ConverterComponent }>()
40
40
 
41
41
  for (const extension of this.commandClient.registry.extensions) {
42
- for (const converter of this.commandClient.registry.getComponentsWithType(extension, ConverterComponent)) {
42
+ for (const converter of this.commandClient.registry.getComponentsWithType<ConverterComponent>(extension, ConverterComponent)) {
43
43
  if (converter.options.component != component) continue
44
44
 
45
45
  items.set(converter.options.type, { component: converter, ext: extension })
@@ -1,29 +1,27 @@
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
- */
8
-
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
+ */
8
+
9
+ import _ from 'lodash'
9
10
  import { BaseComponent } from '../components/BaseComponent'
10
11
  import { createComponentDecorator } from '../components/decoratorCreator'
11
12
 
12
- export class ListenerComponent extends BaseComponent<{ emitter: string; event: string }, { emitter?: string; event: string }> {
13
- defaultOptions() {
14
- return { emitter: 'discord' }
15
- }
13
+ type Options = { emitter: string; event: string }
14
+
15
+ type OptionsArg = { emitter?: string; event: string }
16
+
17
+ export class ListenerComponent extends BaseComponent {
18
+ options: Options
19
+
20
+ constructor(options: OptionsArg) {
21
+ super()
16
22
 
17
- constructor(options: ListenerComponent['options'], method: Function, argTypes: unknown[]) {
18
- super(
19
- {
20
- event: options.event,
21
- emitter: options.emitter ?? 'discord',
22
- },
23
- method,
24
- argTypes,
25
- )
23
+ this.options = _.merge({ emitter: 'discord' }, options)
26
24
  }
27
25
  }
28
26
 
29
- export const listener = createComponentDecorator(ListenerComponent)
27
+ export const listener = (options: OptionsArg) => createComponentDecorator(new ListenerComponent(options))
@@ -33,24 +33,24 @@ export class Registry {
33
33
  })
34
34
  }
35
35
 
36
- getComponentsWithTypeGlobal<T extends typeof BaseComponent<Config>, Config>(type: T): InstanceType<T>[] {
37
- const result: InstanceType<T>[] = []
36
+ getComponentsWithTypeGlobal<T>(type: unknown): T[] {
37
+ const result: T[] = []
38
38
 
39
39
  for (const ext of this.extensions) {
40
- result.push(...this.getComponentsWithType(ext, type))
40
+ result.push(...this.getComponentsWithType<T>(ext, type))
41
41
  }
42
42
 
43
43
  return result
44
44
  }
45
45
 
46
- getComponentsWithType<T extends typeof BaseComponent<Config>, Config>(ext: object, type: T): InstanceType<T>[] {
46
+ getComponentsWithType<T>(ext: object, type: unknown): T[] {
47
47
  const componentStore = getComponentStore(ext)
48
48
 
49
- return Array.from(componentStore.filter((x) => (x.constructor as unknown) === type).values() as Iterable<InstanceType<T>>)
49
+ return Array.from(componentStore.filter((x) => (x.constructor as unknown) === type).values() as Iterable<T>)
50
50
  }
51
51
 
52
52
  registerEventListeners(ext: object) {
53
- const listeners = this.getComponentsWithType(ext, ListenerComponent)
53
+ const listeners = this.getComponentsWithType<ListenerComponent>(ext, ListenerComponent)
54
54
 
55
55
  for (const listener of listeners) {
56
56
  const emitter = this.emitters.get(listener.options.emitter)
@@ -66,7 +66,7 @@ export class Registry {
66
66
  }
67
67
 
68
68
  unregisterEventListeners(ext: object) {
69
- const listeners = this.getComponentsWithType(ext, ListenerComponent)
69
+ const listeners = this.getComponentsWithType<ListenerComponent>(ext, ListenerComponent)
70
70
 
71
71
  for (const listener of listeners) {
72
72
  const emitter = this.emitters.get(listener.options.emitter)
@@ -15,6 +15,10 @@ type TextCommandOptions = {
15
15
  description?: string
16
16
  }
17
17
 
18
- export class TextCommandComponent extends BaseComponent<TextCommandOptions> {}
18
+ export class TextCommandComponent extends BaseComponent {
19
+ constructor(public options: TextCommandOptions) {
20
+ super()
21
+ }
22
+ }
19
23
 
20
- export const command = createComponentDecorator(TextCommandComponent)
24
+ export const command = (options: TextCommandOptions) => createComponentDecorator(new TextCommandComponent(options))
@@ -58,7 +58,7 @@ export class TextCommandExtension extends CTSExtension {
58
58
  const extensions = new Map<TextCommandComponent, object>()
59
59
 
60
60
  for (const ext of this.commandClient.registry.extensions) {
61
- for (const cmd of this.commandClient.registry.getComponentsWithType(ext, TextCommandComponent)) {
61
+ for (const cmd of this.commandClient.registry.getComponentsWithType<TextCommandComponent>(ext, TextCommandComponent)) {
62
62
  commands.push(cmd)
63
63
  extensions.set(cmd, ext)
64
64
  }