@notenoughupdates/discord-akairo
Advanced tools
Comparing version 9.0.5-dev.1633999353.3c120af to 9.0.5-dev.1634004509.ebde0e8
{ | ||
"name": "@notenoughupdates/discord-akairo", | ||
"version": "9.0.5-dev.1633999353.3c120af", | ||
"version": "9.0.5-dev.1634004509.ebde0e8", | ||
"description": "A highly customizable bot framework for Discord.js.", | ||
@@ -5,0 +5,0 @@ "main": "./dist/src/index.js", |
@@ -246,2 +246,2 @@ "use strict"; | ||
exports.default = Command; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Command.js","sourceRoot":"","sources":["../../../../src/struct/commands/Command.ts"],"names":[],"mappings":"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","sourcesContent":["/*  eslint-disable func-names, @typescript-eslint/no-unused-vars */\nimport { ApplicationCommandOptionData, Message, PermissionResolvable, Snowflake } from \"discord.js\";\nimport AkairoError from \"../../util/AkairoError\";\nimport AkairoMessage from \"../../util/AkairoMessage\";\nimport Category from \"../../util/Category\";\nimport AkairoClient from \"../AkairoClient\";\nimport AkairoModule, { AkairoModuleOptions } from \"../AkairoModule\";\nimport Argument, { ArgumentOptions, DefaultArgumentOptions } from \"./arguments/Argument\";\nimport ArgumentRunner, { ArgumentRunnerState } from \"./arguments/ArgumentRunner\";\nimport CommandHandler, { IgnoreCheckPredicate, PrefixSupplier } from \"./CommandHandler\";\nimport ContentParser, { ContentParserResult } from \"./ContentParser\";\nimport Flag from \"./Flag\";\n\n/**\n * Represents a command.\n * @param id - Command ID.\n * @param options - Options for the command.\n */\nexport default abstract class Command extends AkairoModule {\n\t/**\n\t * Executes the command.\n\t * @param message - Message that triggered the command.\n\t * @param args - Evaluated arguments.\n\t */\n\tconstructor(id: string, options?: CommandOptions) {\n\t\tsuper(id, { category: options?.category });\n\n\t\tconst {\n\t\t\tonlyNsfw = false,\n\t\t\taliases = [],\n\t\t\targs = this._args || this.args || [],\n\t\t\tquoted = true,\n\t\t\tseparator,\n\t\t\tchannel = null!,\n\t\t\townerOnly = false,\n\t\t\tsuperUserOnly = false,\n\t\t\teditable = true,\n\t\t\ttyping = false,\n\t\t\tcooldown = null!,\n\t\t\tratelimit = 1,\n\t\t\targumentDefaults = {},\n\t\t\tdescription = \"\",\n\t\t\tprefix = this.prefix,\n\t\t\tclientPermissions = this.clientPermissions,\n\t\t\tuserPermissions = this.userPermissions,\n\t\t\tregex = this.regex,\n\t\t\tcondition = this.condition || (() => false),\n\t\t\tbefore = this.before || (() => undefined),\n\t\t\tlock,\n\t\t\tignoreCooldown,\n\t\t\tignorePermissions,\n\t\t\tflags = [],\n\t\t\toptionFlags = [],\n\t\t\tslash = false,\n\t\t\tslashOptions,\n\t\t\tslashEphemeral = false,\n\t\t\tslashGuilds = [],\n\t\t\tslashOnly = false\n\t\t}: CommandOptions = options ?? {};\n\t\tthis.aliases = aliases ?? [];\n\t\tconst { flagWords, optionFlagWords } = Array.isArray(args)\n\t\t\t? ContentParser.getFlags(args)\n\t\t\t: { flagWords: flags, optionFlagWords: optionFlags };\n\t\tthis.contentParser = new ContentParser({\n\t\t\tflagWords,\n\t\t\toptionFlagWords,\n\t\t\tquoted,\n\t\t\tseparator\n\t\t});\n\t\tthis.argumentRunner = new ArgumentRunner(this);\n\t\tthis.argumentGenerator = (\n\t\t\tArray.isArray(args)\n\t\t\t\t? ArgumentRunner.fromArguments(args.map(arg => [arg.id!, new Argument(this, arg)]))\n\t\t\t\t: args.bind(this)\n\t\t) as ArgumentGenerator;\n\t\tthis.onlyNsfw = Boolean(onlyNsfw);\n\t\tthis.channel = channel!;\n\t\tthis.ownerOnly = Boolean(ownerOnly);\n\t\tthis.superUserOnly = Boolean(superUserOnly);\n\t\tthis.editable = Boolean(editable);\n\t\tthis.typing = Boolean(typing);\n\t\tthis.cooldown = cooldown!;\n\t\tthis.ratelimit = ratelimit;\n\t\tthis.argumentDefaults = argumentDefaults;\n\t\tthis.description = Array.isArray(description) ? description.join(\"\\n\") : description;\n\t\tthis.prefix = typeof prefix === \"function\" ? prefix.bind(this) : prefix;\n\t\tthis.clientPermissions = typeof clientPermissions === \"function\" ? clientPermissions.bind(this) : clientPermissions;\n\t\tthis.userPermissions = typeof userPermissions === \"function\" ? userPermissions.bind(this) : userPermissions;\n\t\tthis.regex = typeof regex === \"function\" ? regex.bind(this) : regex;\n\t\tthis.condition = condition.bind(this);\n\t\tthis.before = before.bind(this);\n\t\tthis.lock = lock;\n\t\tif (typeof lock === \"string\") {\n\t\t\tthis.lock = {\n\t\t\t\tguild: (message: Message | AkairoMessage): string => message.guild! && message.guild.id!,\n\t\t\t\tchannel: (message: Message | AkairoMessage): string => message.channel!.id,\n\t\t\t\tuser: (message: Message | AkairoMessage): string => message.author.id\n\t\t\t}[lock];\n\t\t}\n\t\tif (this.lock) this.locker = new Set();\n\t\tthis.ignoreCooldown = typeof ignoreCooldown === \"function\" ? ignoreCooldown.bind(this) : ignoreCooldown;\n\t\tthis.ignorePermissions = typeof ignorePermissions === \"function\" ? ignorePermissions.bind(this) : ignorePermissions;\n\t\tthis.slashOptions = slashOptions;\n\t\tthis.slashEphemeral = slashEphemeral;\n\t\tthis.slash = slash;\n\t\tthis.slashGuilds = slashGuilds;\n\t\tthis.slashOnly = slashOnly;\n\t}\n\n\t/**\n\t * Command names.\n\t */\n\tpublic aliases: string[];\n\n\t/**\n\t * Default prompt options.\n\t */\n\tpublic argumentDefaults: DefaultArgumentOptions;\n\n\t/**\n\t * Category the command belongs to.\n\t */\n\tpublic declare category: Category<string, Command>;\n\n\t/**\n\t * Usable only in this channel type.\n\t */\n\tpublic channel?: string;\n\n\t/**\n\t * The Akairo client.\n\t */\n\tpublic declare client: AkairoClient;\n\n\t/**\n\t * Permissions required to run command by the client.\n\t */\n\tpublic clientPermissions?: PermissionResolvable | PermissionResolvable[] | MissingPermissionSupplier;\n\n\t/**\n\t * Cooldown in milliseconds.\n\t */\n\tpublic cooldown?: number;\n\n\t/**\n\t * Description of the command.\n\t */\n\tpublic description: any;\n\n\t/**\n\t * Whether or not this command can be ran by an edit.\n\t */\n\tpublic editable: boolean;\n\n\t/**\n\t * The filepath.\n\t */\n\tpublic declare filepath: string;\n\n\t/**\n\t * The handler.\n\t */\n\tpublic declare handler: CommandHandler;\n\n\t/**\n\t * The ID of the command.\n\t */\n\tpublic declare id: string;\n\n\t/**\n\t * ID of user(s) to ignore cooldown or a function to ignore.\n\t */\n\tpublic ignoreCooldown?: Snowflake | Snowflake[] | IgnoreCheckPredicate;\n\n\t/**\n\t * ID of user(s) to ignore `userPermissions` checks or a function to ignore.\n\t */\n\tpublic ignorePermissions?: Snowflake | Snowflake[] | IgnoreCheckPredicate;\n\n\t/**\n\t * The key supplier for the locker.\n\t */\n\tpublic lock?: KeySupplier | \"channel\" | \"guild\" | \"user\";\n\n\t/**\n\t * Stores the current locks.\n\t */\n\tpublic locker?: Set<string>;\n\n\t/**\n\t * Whether or not the command can only be run in  NSFW channels.\n\t */\n\tpublic onlyNsfw: boolean;\n\n\t/**\n\t * Usable only by the client owner.\n\t */\n\tpublic ownerOnly: boolean;\n\n\t/**\n\t * Command prefix overwrite.\n\t */\n\tpublic prefix?: string | string[] | PrefixSupplier;\n\n\t/**\n\t * Whether or not to consider quotes.\n\t */\n\tpublic quoted!: boolean;\n\n\t/**\n\t * Uses allowed before cooldown.\n\t */\n\tpublic ratelimit: number;\n\n\t/**\n\t * The regex trigger for this command.\n\t */\n\tpublic regex?: RegExp | RegexSupplier;\n\n\t/**\n\t * Mark command as slash command and set information.\n\t */\n\tpublic slash?: boolean;\n\n\t/**\n\t * Whether slash command responses for this command should be ephemeral or not.\n\t */\n\tpublic slashEphemeral?: boolean;\n\n\t/**\n\t * Assign slash commands to Specific guilds. This option will make the commands not register globally, but only in the chosen servers.\n\t */\n\tpublic slashGuilds?: Snowflake[];\n\n\t/**\n\t * Options for using the slash command.\n\t */\n\tpublic slashOptions?: ApplicationCommandOptionData[];\n\n\t/**\n\t * Whether or not to allow client superUsers(s) only.\n\t */\n\tpublic superUserOnly: boolean;\n\n\t/**\n\t * Whether or not to type during command execution.\n\t */\n\tpublic typing: boolean;\n\n\t/**\n\t * Permissions required to run command by the user.\n\t */\n\tpublic userPermissions?: PermissionResolvable | PermissionResolvable[] | MissingPermissionSupplier;\n\n\t/**\n\t * Argument options or generator.\n\t */\n\tpublic _args?: ArgumentOptions[] | ArgumentGenerator;\n\n\t/**\n\t * The content parser.\n\t */\n\tpublic contentParser: ContentParser;\n\n\t/**\n\t * The argument runner.\n\t */\n\tpublic argumentRunner: ArgumentRunner;\n\n\t/**\n\t * Only allows this command to be executed as a slash command.\n\t */\n\tpublic slashOnly: boolean;\n\n\t/**\n\t * Generator for arguments.\n\t * When yielding argument options, that argument is ran and the result of the processing is given.\n\t * The last value when the generator is done is the resulting `args` for the command's `exec`.\n\t * @param message - Message that triggered the command.\n\t * @param parsed - Parsed content.\n\t * @param state - Argument processing state.\n\t */\n\tpublic *args(\n\t\tmessage: Message,\n\t\tparsed: ContentParserResult,\n\t\tstate: ArgumentRunnerState\n\t): IterableIterator<ArgumentOptions | Flag> {}\n\n\t/**\n\t * Generator for arguments.\n\t */\n\tpublic argumentGenerator: ArgumentGenerator;\n\n\t/**\n\t * Runs before argument parsing and execution.\n\t * @param message - Message being handled.\n\t */\n\tpublic before(message: Message): any {}\n\n\t/**\n\t * Checks if the command should be ran by using an arbitrary condition.\n\t * @param message - Message being handled.\n\t */\n\tpublic condition(message: Message): boolean | Promise<boolean> {\n\t\treturn false;\n\t}\n\n\tpublic exec(message: Message, args: any): any;\n\tpublic exec(message: AkairoMessage, args: any): any;\n\tpublic exec(message: Message | AkairoMessage, args: any): any;\n\tpublic exec(message: Message | AkairoMessage, args: any): any {\n\t\tthrow new AkairoError(\"NOT_IMPLEMENTED\", this.constructor.name, \"exec\");\n\t}\n\n\t/**\n\t * Execute the slash command\n\t * @param message - Message for slash command\n\t * @param args - Slash command options\n\t */\n\tpublic execSlash(message: AkairoMessage, ...args: any[]): any {\n\t\tif (this.slash) {\n\t\t\tthrow new AkairoError(\"NOT_IMPLEMENTED\", this.constructor.name, \"execSlash\");\n\t\t}\n\t}\n\n\t/**\n\t * Parses content using the command's arguments.\n\t * @param message - Message to use.\n\t * @param content - String to parse.\n\t */\n\tpublic parse(message: Message, content: string): Promise<Flag | any> {\n\t\tconst parsed = this.contentParser.parse(content);\n\t\treturn this.argumentRunner.run(message, parsed, this.argumentGenerator);\n\t}\n\n\t/**\n\t * Reloads the command.\n\t */\n\tpublic override reload(): Promise<Command> {\n\t\treturn super.reload() as Promise<Command>;\n\t}\n\n\t/**\n\t * Removes the command.\n\t */\n\tpublic override remove(): Command {\n\t\treturn super.remove() as Command;\n\t}\n}\n\n/**\n * Options to use for command execution behavior.\n */\nexport interface CommandOptions extends AkairoModuleOptions {\n\t/**\n\t * Command names.\n\t */\n\taliases?: string[];\n\n\t/**\n\t * Argument options or generator.\n\t */\n\targs?: ArgumentOptions[] | ArgumentGenerator;\n\n\t/**\n\t * The default argument options.\n\t */\n\targumentDefaults?: DefaultArgumentOptions;\n\n\t/**\n\t * Function to run before argument parsing and execution.\n\t */\n\tbefore?: BeforeAction;\n\n\t/**\n\t * Restricts channel to either 'guild' or 'dm'.\n\t */\n\tchannel?: \"guild\" | \"dm\";\n\n\t/**\n\t * Permissions required by the client to run this command.\n\t */\n\tclientPermissions?: PermissionResolvable | PermissionResolvable[] | MissingPermissionSupplier;\n\n\t/**\n\t * Whether or not to run on messages that are not directly commands.\n\t */\n\tcondition?: ExecutionPredicate;\n\n\t/**\n\t * The command cooldown in milliseconds.\n\t */\n\tcooldown?: number;\n\n\t/**\n\t * Description of the command.\n\t */\n\tdescription?: string | any | any[];\n\n\t/**\n\t * Whether or not message edits will run this command.\n\t */\n\teditable?: boolean;\n\n\t/**\n\t * Flags to use when using an ArgumentGenerator\n\t */\n\tflags?: string[];\n\n\t/**\n\t * ID of user(s) to ignore cooldown or a function to ignore.\n\t */\n\tignoreCooldown?: Snowflake | Snowflake[] | IgnoreCheckPredicate;\n\n\t/**\n\t * ID of user(s) to ignore `userPermissions` checks or a function to ignore.\n\t */\n\tignorePermissions?: Snowflake | Snowflake[] | IgnoreCheckPredicate;\n\n\t/**\n\t * The key type or key generator for the locker. If lock is a string, it's expected one of 'guild', 'channel', or 'user'\n\t */\n\tlock?: KeySupplier | \"guild\" | \"channel\" | \"user\";\n\n\t/**\n\t * Whether or not to only allow the command to be run in NSFW channels.\n\t */\n\tonlyNsfw?: boolean;\n\n\t/**\n\t * Option flags to use when using an ArgumentGenerator.\n\t */\n\toptionFlags?: string[];\n\n\t/**\n\t * Whether or not to allow client owner(s) only.\n\t */\n\townerOnly?: boolean;\n\n\t/**\n\t * The prefix(es) to overwrite the global one for this command.\n\t */\n\tprefix?: string | string[] | PrefixSupplier;\n\n\t/**\n\t * Whether or not to consider quotes.\n\t */\n\tquoted?: boolean;\n\n\t/**\n\t * Amount of command uses allowed until cooldown.\n\t */\n\tratelimit?: number;\n\n\t/**\n\t * A regex to match in messages that are not directly commands. The args object will have `match` and `matches` properties.\n\t */\n\tregex?: RegExp | RegexSupplier;\n\n\t/**\n\t * Custom separator for argument input.\n\t */\n\tseparator?: string;\n\n\t/**\n\t * Mark command as slash command and set information.\n\t */\n\tslash?: boolean;\n\n\t/**\n\t * Whether slash command responses for this command should be ephemeral or not.\n\t */\n\tslashEphemeral?: boolean;\n\n\t/**\n\t * Assign slash commands to Specific guilds. This option will make the commands do not register globally, but only to the chosen servers.\n\t */\n\tslashGuilds?: string[];\n\n\t/**\n\t * Options for using the slash command.\n\t */\n\tslashOptions?: ApplicationCommandOptionData[];\n\n\t/**\n\t * Whether or not to allow client superUsers(s) only.\n\t */\n\tsuperUserOnly?: boolean;\n\n\t/**\n\t * Whether or not to type in channel during execution.\n\t */\n\ttyping?: boolean;\n\n\t/**\n\t * Permissions required by the user to run this command.\n\t */\n\tuserPermissions?: PermissionResolvable | PermissionResolvable[] | MissingPermissionSupplier;\n\n\t/**\n\t * Only allow this command to be used as a slash command. Also makes `slash` `true`\n\t */\n\tslashOnly?: boolean;\n}\n\n/**\n * A function to run before argument parsing and execution.\n * @param message - Message that triggered the command.\n */\nexport type BeforeAction = (message: Message) => any;\n\n/**\n * A function used to supply the key for the locker.\n * @param message - Message that triggered the command.\n * @param args - Evaluated arguments.\n */\nexport type KeySupplier = (message: Message | AkairoMessage, args: any) => string;\n\n/**\n * A function used to check if the command should run arbitrarily.\n * @param message - Message to check.\n */\nexport type ExecutionPredicate = (message: Message) => boolean | Promise<boolean>;\n\n/**\n * A function used to check if a message has permissions for the command.\n * A non-null return value signifies the reason for missing permissions.\n * @param message - Message that triggered the command.\n */\nexport type MissingPermissionSupplier = (message: Message | AkairoMessage) => Promise<any> | any;\n\n/**\n * A function used to return a regular expression.\n * @param message - Message to get regex for.\n */\nexport type RegexSupplier = (message: Message) => RegExp;\n\n/**\n * Generator for arguments.\n * When yielding argument options, that argument is ran and the result of the processing is given.\n * The last value when the generator is done is the resulting `args` for the command's `exec`.\n * @param message - Message that triggered the command.\n * @param parsed - Parsed content.\n * @param state - Argument processing state.\n */\nexport type ArgumentGenerator = (\n\tmessage: Message,\n\tparsed: ContentParserResult,\n\tstate: ArgumentRunnerState\n) => IterableIterator<ArgumentOptions | Flag>;\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Command.js","sourceRoot":"","sources":["../../../../src/struct/commands/Command.ts"],"names":[],"mappings":"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","sourcesContent":["/*  eslint-disable func-names, @typescript-eslint/no-unused-vars */\nimport { ApplicationCommandOptionData, Message, PermissionResolvable, Snowflake } from \"discord.js\";\nimport AkairoError from \"../../util/AkairoError\";\nimport AkairoMessage from \"../../util/AkairoMessage\";\nimport Category from \"../../util/Category\";\nimport AkairoClient from \"../AkairoClient\";\nimport AkairoModule, { AkairoModuleOptions } from \"../AkairoModule\";\nimport Argument, { ArgumentOptions, DefaultArgumentOptions } from \"./arguments/Argument\";\nimport ArgumentRunner, { ArgumentRunnerState } from \"./arguments/ArgumentRunner\";\nimport CommandHandler, { IgnoreCheckPredicate, PrefixSupplier, SlashResolveTypes } from \"./CommandHandler\";\nimport ContentParser, { ContentParserResult } from \"./ContentParser\";\nimport Flag from \"./Flag\";\n\n/**\n * Represents a command.\n * @param id - Command ID.\n * @param options - Options for the command.\n */\nexport default abstract class Command extends AkairoModule {\n\t/**\n\t * Executes the command.\n\t * @param message - Message that triggered the command.\n\t * @param args - Evaluated arguments.\n\t */\n\tconstructor(id: string, options?: CommandOptions) {\n\t\tsuper(id, { category: options?.category });\n\n\t\tconst {\n\t\t\tonlyNsfw = false,\n\t\t\taliases = [],\n\t\t\targs = this._args || this.args || [],\n\t\t\tquoted = true,\n\t\t\tseparator,\n\t\t\tchannel = null!,\n\t\t\townerOnly = false,\n\t\t\tsuperUserOnly = false,\n\t\t\teditable = true,\n\t\t\ttyping = false,\n\t\t\tcooldown = null!,\n\t\t\tratelimit = 1,\n\t\t\targumentDefaults = {},\n\t\t\tdescription = \"\",\n\t\t\tprefix = this.prefix,\n\t\t\tclientPermissions = this.clientPermissions,\n\t\t\tuserPermissions = this.userPermissions,\n\t\t\tregex = this.regex,\n\t\t\tcondition = this.condition || (() => false),\n\t\t\tbefore = this.before || (() => undefined),\n\t\t\tlock,\n\t\t\tignoreCooldown,\n\t\t\tignorePermissions,\n\t\t\tflags = [],\n\t\t\toptionFlags = [],\n\t\t\tslash = false,\n\t\t\tslashOptions,\n\t\t\tslashEphemeral = false,\n\t\t\tslashGuilds = [],\n\t\t\tslashOnly = false\n\t\t}: CommandOptions = options ?? {};\n\t\tthis.aliases = aliases ?? [];\n\t\tconst { flagWords, optionFlagWords } = Array.isArray(args)\n\t\t\t? ContentParser.getFlags(args)\n\t\t\t: { flagWords: flags, optionFlagWords: optionFlags };\n\t\tthis.contentParser = new ContentParser({\n\t\t\tflagWords,\n\t\t\toptionFlagWords,\n\t\t\tquoted,\n\t\t\tseparator\n\t\t});\n\t\tthis.argumentRunner = new ArgumentRunner(this);\n\t\tthis.argumentGenerator = (\n\t\t\tArray.isArray(args)\n\t\t\t\t? ArgumentRunner.fromArguments(args.map(arg => [arg.id!, new Argument(this, arg)]))\n\t\t\t\t: args.bind(this)\n\t\t) as ArgumentGenerator;\n\t\tthis.onlyNsfw = Boolean(onlyNsfw);\n\t\tthis.channel = channel!;\n\t\tthis.ownerOnly = Boolean(ownerOnly);\n\t\tthis.superUserOnly = Boolean(superUserOnly);\n\t\tthis.editable = Boolean(editable);\n\t\tthis.typing = Boolean(typing);\n\t\tthis.cooldown = cooldown!;\n\t\tthis.ratelimit = ratelimit;\n\t\tthis.argumentDefaults = argumentDefaults;\n\t\tthis.description = Array.isArray(description) ? description.join(\"\\n\") : description;\n\t\tthis.prefix = typeof prefix === \"function\" ? prefix.bind(this) : prefix;\n\t\tthis.clientPermissions = typeof clientPermissions === \"function\" ? clientPermissions.bind(this) : clientPermissions;\n\t\tthis.userPermissions = typeof userPermissions === \"function\" ? userPermissions.bind(this) : userPermissions;\n\t\tthis.regex = typeof regex === \"function\" ? regex.bind(this) : regex;\n\t\tthis.condition = condition.bind(this);\n\t\tthis.before = before.bind(this);\n\t\tthis.lock = lock;\n\t\tif (typeof lock === \"string\") {\n\t\t\tthis.lock = {\n\t\t\t\tguild: (message: Message | AkairoMessage): string => message.guild! && message.guild.id!,\n\t\t\t\tchannel: (message: Message | AkairoMessage): string => message.channel!.id,\n\t\t\t\tuser: (message: Message | AkairoMessage): string => message.author.id\n\t\t\t}[lock];\n\t\t}\n\t\tif (this.lock) this.locker = new Set();\n\t\tthis.ignoreCooldown = typeof ignoreCooldown === \"function\" ? ignoreCooldown.bind(this) : ignoreCooldown;\n\t\tthis.ignorePermissions = typeof ignorePermissions === \"function\" ? ignorePermissions.bind(this) : ignorePermissions;\n\t\tthis.slashOptions = slashOptions;\n\t\tthis.slashEphemeral = slashEphemeral;\n\t\tthis.slash = slash;\n\t\tthis.slashGuilds = slashGuilds;\n\t\tthis.slashOnly = slashOnly;\n\t}\n\n\t/**\n\t * Command names.\n\t */\n\tpublic aliases: string[];\n\n\t/**\n\t * Default prompt options.\n\t */\n\tpublic argumentDefaults: DefaultArgumentOptions;\n\n\t/**\n\t * Category the command belongs to.\n\t */\n\tpublic declare category: Category<string, Command>;\n\n\t/**\n\t * Usable only in this channel type.\n\t */\n\tpublic channel?: string;\n\n\t/**\n\t * The Akairo client.\n\t */\n\tpublic declare client: AkairoClient;\n\n\t/**\n\t * Permissions required to run command by the client.\n\t */\n\tpublic clientPermissions?: PermissionResolvable | PermissionResolvable[] | MissingPermissionSupplier;\n\n\t/**\n\t * Cooldown in milliseconds.\n\t */\n\tpublic cooldown?: number;\n\n\t/**\n\t * Description of the command.\n\t */\n\tpublic description: any;\n\n\t/**\n\t * Whether or not this command can be ran by an edit.\n\t */\n\tpublic editable: boolean;\n\n\t/**\n\t * The filepath.\n\t */\n\tpublic declare filepath: string;\n\n\t/**\n\t * The handler.\n\t */\n\tpublic declare handler: CommandHandler;\n\n\t/**\n\t * The ID of the command.\n\t */\n\tpublic declare id: string;\n\n\t/**\n\t * ID of user(s) to ignore cooldown or a function to ignore.\n\t */\n\tpublic ignoreCooldown?: Snowflake | Snowflake[] | IgnoreCheckPredicate;\n\n\t/**\n\t * ID of user(s) to ignore `userPermissions` checks or a function to ignore.\n\t */\n\tpublic ignorePermissions?: Snowflake | Snowflake[] | IgnoreCheckPredicate;\n\n\t/**\n\t * The key supplier for the locker.\n\t */\n\tpublic lock?: KeySupplier | \"channel\" | \"guild\" | \"user\";\n\n\t/**\n\t * Stores the current locks.\n\t */\n\tpublic locker?: Set<string>;\n\n\t/**\n\t * Whether or not the command can only be run in  NSFW channels.\n\t */\n\tpublic onlyNsfw: boolean;\n\n\t/**\n\t * Usable only by the client owner.\n\t */\n\tpublic ownerOnly: boolean;\n\n\t/**\n\t * Command prefix overwrite.\n\t */\n\tpublic prefix?: string | string[] | PrefixSupplier;\n\n\t/**\n\t * Whether or not to consider quotes.\n\t */\n\tpublic quoted!: boolean;\n\n\t/**\n\t * Uses allowed before cooldown.\n\t */\n\tpublic ratelimit: number;\n\n\t/**\n\t * The regex trigger for this command.\n\t */\n\tpublic regex?: RegExp | RegexSupplier;\n\n\t/**\n\t * Mark command as slash command and set information.\n\t */\n\tpublic slash?: boolean;\n\n\t/**\n\t * Whether slash command responses for this command should be ephemeral or not.\n\t */\n\tpublic slashEphemeral?: boolean;\n\n\t/**\n\t * Assign slash commands to Specific guilds. This option will make the commands not register globally, but only in the chosen servers.\n\t */\n\tpublic slashGuilds?: Snowflake[];\n\n\t/**\n\t * Options for using the slash command.\n\t */\n\tpublic slashOptions?: SlashOption[];\n\n\t/**\n\t * Whether or not to allow client superUsers(s) only.\n\t */\n\tpublic superUserOnly: boolean;\n\n\t/**\n\t * Whether or not to type during command execution.\n\t */\n\tpublic typing: boolean;\n\n\t/**\n\t * Permissions required to run command by the user.\n\t */\n\tpublic userPermissions?: PermissionResolvable | PermissionResolvable[] | MissingPermissionSupplier;\n\n\t/**\n\t * Argument options or generator.\n\t */\n\tpublic _args?: ArgumentOptions[] | ArgumentGenerator;\n\n\t/**\n\t * The content parser.\n\t */\n\tpublic contentParser: ContentParser;\n\n\t/**\n\t * The argument runner.\n\t */\n\tpublic argumentRunner: ArgumentRunner;\n\n\t/**\n\t * Only allows this command to be executed as a slash command.\n\t */\n\tpublic slashOnly: boolean;\n\n\t/**\n\t * Generator for arguments.\n\t * When yielding argument options, that argument is ran and the result of the processing is given.\n\t * The last value when the generator is done is the resulting `args` for the command's `exec`.\n\t * @param message - Message that triggered the command.\n\t * @param parsed - Parsed content.\n\t * @param state - Argument processing state.\n\t */\n\tpublic *args(\n\t\tmessage: Message,\n\t\tparsed: ContentParserResult,\n\t\tstate: ArgumentRunnerState\n\t): IterableIterator<ArgumentOptions | Flag> {}\n\n\t/**\n\t * Generator for arguments.\n\t */\n\tpublic argumentGenerator: ArgumentGenerator;\n\n\t/**\n\t * Runs before argument parsing and execution.\n\t * @param message - Message being handled.\n\t */\n\tpublic before(message: Message): any {}\n\n\t/**\n\t * Checks if the command should be ran by using an arbitrary condition.\n\t * @param message - Message being handled.\n\t */\n\tpublic condition(message: Message): boolean | Promise<boolean> {\n\t\treturn false;\n\t}\n\n\tpublic exec(message: Message, args: any): any;\n\tpublic exec(message: Message | AkairoMessage, args: any): any;\n\tpublic exec(message: Message | AkairoMessage, args: any): any {\n\t\tthrow new AkairoError(\"NOT_IMPLEMENTED\", this.constructor.name, \"exec\");\n\t}\n\n\t/**\n\t * Execute the slash command\n\t * @param message - Message for slash command\n\t * @param args - Slash command options\n\t */\n\tpublic execSlash(message: AkairoMessage, ...args: any[]): any {\n\t\tif (this.slash) {\n\t\t\tthrow new AkairoError(\"NOT_IMPLEMENTED\", this.constructor.name, \"execSlash\");\n\t\t}\n\t}\n\n\t/**\n\t * Parses content using the command's arguments.\n\t * @param message - Message to use.\n\t * @param content - String to parse.\n\t */\n\tpublic parse(message: Message, content: string): Promise<Flag | any> {\n\t\tconst parsed = this.contentParser.parse(content);\n\t\treturn this.argumentRunner.run(message, parsed, this.argumentGenerator);\n\t}\n\n\t/**\n\t * Reloads the command.\n\t */\n\tpublic override reload(): Promise<Command> {\n\t\treturn super.reload() as Promise<Command>;\n\t}\n\n\t/**\n\t * Removes the command.\n\t */\n\tpublic override remove(): Command {\n\t\treturn super.remove() as Command;\n\t}\n}\n\n/**\n * Options to use for command execution behavior.\n */\nexport interface CommandOptions extends AkairoModuleOptions {\n\t/**\n\t * Command names.\n\t */\n\taliases?: string[];\n\n\t/**\n\t * Argument options or generator.\n\t */\n\targs?: ArgumentOptions[] | ArgumentGenerator;\n\n\t/**\n\t * The default argument options.\n\t */\n\targumentDefaults?: DefaultArgumentOptions;\n\n\t/**\n\t * Function to run before argument parsing and execution.\n\t */\n\tbefore?: BeforeAction;\n\n\t/**\n\t * Restricts channel to either 'guild' or 'dm'.\n\t */\n\tchannel?: \"guild\" | \"dm\";\n\n\t/**\n\t * Permissions required by the client to run this command.\n\t */\n\tclientPermissions?: PermissionResolvable | PermissionResolvable[] | MissingPermissionSupplier;\n\n\t/**\n\t * Whether or not to run on messages that are not directly commands.\n\t */\n\tcondition?: ExecutionPredicate;\n\n\t/**\n\t * The command cooldown in milliseconds.\n\t */\n\tcooldown?: number;\n\n\t/**\n\t * Description of the command.\n\t */\n\tdescription?: string | any | any[];\n\n\t/**\n\t * Whether or not message edits will run this command.\n\t */\n\teditable?: boolean;\n\n\t/**\n\t * Flags to use when using an ArgumentGenerator\n\t */\n\tflags?: string[];\n\n\t/**\n\t * ID of user(s) to ignore cooldown or a function to ignore.\n\t */\n\tignoreCooldown?: Snowflake | Snowflake[] | IgnoreCheckPredicate;\n\n\t/**\n\t * ID of user(s) to ignore `userPermissions` checks or a function to ignore.\n\t */\n\tignorePermissions?: Snowflake | Snowflake[] | IgnoreCheckPredicate;\n\n\t/**\n\t * The key type or key generator for the locker. If lock is a string, it's expected one of 'guild', 'channel', or 'user'\n\t */\n\tlock?: KeySupplier | \"guild\" | \"channel\" | \"user\";\n\n\t/**\n\t * Whether or not to only allow the command to be run in NSFW channels.\n\t */\n\tonlyNsfw?: boolean;\n\n\t/**\n\t * Option flags to use when using an ArgumentGenerator.\n\t */\n\toptionFlags?: string[];\n\n\t/**\n\t * Whether or not to allow client owner(s) only.\n\t */\n\townerOnly?: boolean;\n\n\t/**\n\t * The prefix(es) to overwrite the global one for this command.\n\t */\n\tprefix?: string | string[] | PrefixSupplier;\n\n\t/**\n\t * Whether or not to consider quotes.\n\t */\n\tquoted?: boolean;\n\n\t/**\n\t * Amount of command uses allowed until cooldown.\n\t */\n\tratelimit?: number;\n\n\t/**\n\t * A regex to match in messages that are not directly commands. The args object will have `match` and `matches` properties.\n\t */\n\tregex?: RegExp | RegexSupplier;\n\n\t/**\n\t * Custom separator for argument input.\n\t */\n\tseparator?: string;\n\n\t/**\n\t * Mark command as slash command and set information.\n\t */\n\tslash?: boolean;\n\n\t/**\n\t * Whether slash command responses for this command should be ephemeral or not.\n\t */\n\tslashEphemeral?: boolean;\n\n\t/**\n\t * Assign slash commands to Specific guilds. This option will make the commands not register globally, but only to the chosen servers.\n\t */\n\tslashGuilds?: string[];\n\n\t/**\n\t * Options for using the slash command.\n\t */\n\tslashOptions?: SlashOption[];\n\n\t/**\n\t * Whether or not to allow client superUsers(s) only.\n\t */\n\tsuperUserOnly?: boolean;\n\n\t/**\n\t * Whether or not to type in channel during execution.\n\t */\n\ttyping?: boolean;\n\n\t/**\n\t * Permissions required by the user to run this command.\n\t */\n\tuserPermissions?: PermissionResolvable | PermissionResolvable[] | MissingPermissionSupplier;\n\n\t/**\n\t * Only allow this command to be used as a slash command. Also makes `slash` `true`\n\t */\n\tslashOnly?: boolean;\n}\n\n/**\n * A function to run before argument parsing and execution.\n * @param message - Message that triggered the command.\n */\nexport type BeforeAction = (message: Message) => any;\n\n/**\n * A function used to supply the key for the locker.\n * @param message - Message that triggered the command.\n * @param args - Evaluated arguments.\n */\nexport type KeySupplier = (message: Message | AkairoMessage, args: any) => string;\n\n/**\n * A function used to check if the command should run arbitrarily.\n * @param message - Message to check.\n */\nexport type ExecutionPredicate = (message: Message) => boolean | Promise<boolean>;\n\n/**\n * A function used to check if a message has permissions for the command.\n * A non-null return value signifies the reason for missing permissions.\n * @param message - Message that triggered the command.\n */\nexport type MissingPermissionSupplier = (message: Message | AkairoMessage) => Promise<any> | any;\n\n/**\n * A function used to return a regular expression.\n * @param message - Message to get regex for.\n */\nexport type RegexSupplier = (message: Message) => RegExp;\n\n/**\n * Generator for arguments.\n * When yielding argument options, that argument is ran and the result of the processing is given.\n * The last value when the generator is done is the resulting `args` for the command's `exec`.\n * @param message - Message that triggered the command.\n * @param parsed - Parsed content.\n * @param state - Argument processing state.\n */\nexport type ArgumentGenerator = (\n\tmessage: Message,\n\tparsed: ContentParserResult,\n\tstate: ArgumentRunnerState\n) => IterableIterator<ArgumentOptions | Flag>;\n\nexport type SlashOption = ApplicationCommandOptionData & {\n\t/**\n\t * Allows you to get a discord resolved object\n\t *\n\t * ex. get the resolved member object when the type is `USER`\n\t */\n\tresolve?: SlashResolveTypes;\n};\n"]} |
@@ -50,2 +50,2 @@ "use strict"; | ||
exports.default = Inhibitor; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSW5oaWJpdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3N0cnVjdC9pbmhpYml0b3JzL0luaGliaXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUNBLHlFQUFpRDtBQUlqRCxtRUFBb0U7QUFJcEU7Ozs7R0FJRztBQUNILE1BQThCLFNBQVUsU0FBUSxzQkFBWTtJQUMzRCxZQUFtQixFQUFVLEVBQUUsRUFBRSxRQUFRLEVBQUUsTUFBTSxHQUFHLEVBQUUsRUFBRSxJQUFJLEdBQUcsTUFBTSxFQUFFLFFBQVEsR0FBRyxDQUFDLEtBQXVCLEVBQUU7UUFDM0csS0FBSyxDQUFDLEVBQUUsRUFBRSxFQUFFLFFBQVEsRUFBRSxDQUFDLENBQUM7UUFFeEIsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFFckIsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFFakIsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUM7SUFDMUIsQ0FBQztJQUVEOztPQUVHO0lBQ0ksUUFBUSxDQUFTO0lBMkJ4Qjs7T0FFRztJQUNJLE1BQU0sQ0FBUztJQUV0Qjs7T0FFRztJQUNJLElBQUksQ0FBUztJQWFiLElBQUksQ0FBQyxPQUFnQyxFQUFFLE9BQWlCO1FBQzlELE1BQU0sSUFBSSxxQkFBVyxDQUFDLGlCQUFpQixFQUFFLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ3pFLENBQUM7SUFDRCxzREFBc0Q7SUFFdEQ7O09BRUc7SUFDYSxNQUFNO1FBQ3JCLE9BQU8sS0FBSyxDQUFDLE1BQU0sRUFBd0IsQ0FBQztJQUM3QyxDQUFDO0lBRUQ7O09BRUc7SUFDYSxNQUFNO1FBQ3JCLE9BQU8sS0FBSyxDQUFDLE1BQU0sRUFBZSxDQUFDO0lBQ3BDLENBQUM7Q0FDRDtBQWhGRCw0QkFnRkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNZXNzYWdlIH0gZnJvbSBcImRpc2NvcmQuanNcIjtcbmltcG9ydCBBa2Fpcm9FcnJvciBmcm9tIFwiLi4vLi4vdXRpbC9Ba2Fpcm9FcnJvclwiO1xuaW1wb3J0IEFrYWlyb01lc3NhZ2UgZnJvbSBcIi4uLy4uL3V0aWwvQWthaXJvTWVzc2FnZVwiO1xuaW1wb3J0IENhdGVnb3J5IGZyb20gXCIuLi8uLi91dGlsL0NhdGVnb3J5XCI7XG5pbXBvcnQgQWthaXJvQ2xpZW50IGZyb20gXCIuLi9Ba2Fpcm9DbGllbnRcIjtcbmltcG9ydCBBa2Fpcm9Nb2R1bGUsIHsgQWthaXJvTW9kdWxlT3B0aW9ucyB9IGZyb20gXCIuLi9Ba2Fpcm9Nb2R1bGVcIjtcbmltcG9ydCBDb21tYW5kIGZyb20gXCIuLi9jb21tYW5kcy9Db21tYW5kXCI7XG5pbXBvcnQgSW5oaWJpdG9ySGFuZGxlciBmcm9tIFwiLi9JbmhpYml0b3JIYW5kbGVyXCI7XG5cbi8qKlxuICogUmVwcmVzZW50cyBhbiBpbmhpYml0b3IuXG4gKiBAcGFyYW0gaWQgLSBJbmhpYml0b3IgSUQuXG4gKiBAcGFyYW0gb3B0aW9ucyAtIE9wdGlvbnMgZm9yIHRoZSBpbmhpYml0b3IuXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGFic3RyYWN0IGNsYXNzIEluaGliaXRvciBleHRlbmRzIEFrYWlyb01vZHVsZSB7XG5cdHB1YmxpYyBjb25zdHJ1Y3RvcihpZDogc3RyaW5nLCB7IGNhdGVnb3J5LCByZWFzb24gPSBcIlwiLCB0eXBlID0gXCJwb3N0XCIsIHByaW9yaXR5ID0gMCB9OiBJbmhpYml0b3JPcHRpb25zID0ge30pIHtcblx0XHRzdXBlcihpZCwgeyBjYXRlZ29yeSB9KTtcblxuXHRcdHRoaXMucmVhc29uID0gcmVhc29uO1xuXG5cdFx0dGhpcy50eXBlID0gdHlwZTtcblxuXHRcdHRoaXMucHJpb3JpdHkgPSBwcmlvcml0eTtcblx0fVxuXG5cdC8qKlxuXHQgKiBUaGUgcHJpb3JpdHkgb2YgdGhlIGluaGliaXRvci5cblx0ICovXG5cdHB1YmxpYyBwcmlvcml0eTogbnVtYmVyO1xuXG5cdC8qKlxuXHQgKiBUaGUgY2F0ZWdvcnkgdGhlIGluaGliaXRvciBiZWxvbmdzIHRvLlxuXHQgKi9cblx0cHVibGljIGRlY2xhcmUgY2F0ZWdvcnk6IENhdGVnb3J5PHN0cmluZywgSW5oaWJpdG9yPjtcblxuXHQvKipcblx0ICogVGhlIEFrYWlybyBjbGllbnQuXG5cdCAqL1xuXHRwdWJsaWMgZGVjbGFyZSBjbGllbnQ6IEFrYWlyb0NsaWVudDtcblxuXHQvKipcblx0ICogVGhlIGZpbGVwYXRoLlxuXHQgKi9cblx0cHVibGljIGRlY2xhcmUgZmlsZXBhdGg6IHN0cmluZztcblxuXHQvKipcblx0ICogVGhlIGluaGliaXRvciBoYW5kbGVyLlxuXHQgKi9cblx0cHVibGljIGRlY2xhcmUgaGFuZGxlcjogSW5oaWJpdG9ySGFuZGxlcjtcblxuXHQvKipcblx0ICogVGhlIElEIG9mIHRoaXMgaW5oaWJpdG9yLlxuXHQgKi9cblx0cHVibGljIGRlY2xhcmUgaWQ6IHN0cmluZztcblxuXHQvKipcblx0ICogUmVhc29uIGVtaXR0ZWQgd2hlbiBjb21tYW5kIGlzIGluaGliaXRlZC5cblx0ICovXG5cdHB1YmxpYyByZWFzb246IHN0cmluZztcblxuXHQvKipcblx0ICogVGhlIHR5cGUgb2YgdGhlIGluaGliaXRvciBmb3Igd2hlbiBpdCBzaG91bGQgcnVuLlxuXHQgKi9cblx0cHVibGljIHR5cGU6IHN0cmluZztcblxuXHQvKipcblx0ICogQ2hlY2tzIGlmIG1lc3NhZ2Ugc2hvdWxkIGJlIGJsb2NrZWQuXG5cdCAqIEEgcmV0dXJuIHZhbHVlIG9mIHRydWUgd2lsbCBibG9jayB0aGUgbWVzc2FnZS5cblx0ICogSWYgcmV0dXJuaW5nIGEgUHJvbWlzZSwgYSByZXNvbHZlZCB2YWx1ZSBvZiB0cnVlIHdpbGwgYmxvY2sgdGhlIG1lc3NhZ2UuXG5cdCAqIEBwYXJhbSBtZXNzYWdlIC0gTWVzc2FnZSBiZWluZyBoYW5kbGVkLlxuXHQgKiBAcGFyYW0gY29tbWFuZCAtIENvbW1hbmQgdG8gY2hlY2suXG5cdCAqL1xuXHQvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnMgKi9cblx0cHVibGljIGV4ZWMobWVzc2FnZTogTWVzc2FnZSwgY29tbWFuZD86IENvbW1hbmQpOiBib29sZWFuIHwgUHJvbWlzZTxib29sZWFuPjtcblx0cHVibGljIGV4ZWMobWVzc2FnZTogQWthaXJvTWVzc2FnZSwgY29tbWFuZD86IENvbW1hbmQpOiBib29sZWFuIHwgUHJvbWlzZTxib29sZWFuPjtcblx0cHVibGljIGV4ZWMobWVzc2FnZTogTWVzc2FnZSB8IEFrYWlyb01lc3NhZ2UsIGNvbW1hbmQ/OiBDb21tYW5kKTogYm9vbGVhbiB8IFByb21pc2U8Ym9vbGVhbj47XG5cdHB1YmxpYyBleGVjKG1lc3NhZ2U6IE1lc3NhZ2UgfCBBa2Fpcm9NZXNzYWdlLCBjb21tYW5kPzogQ29tbWFuZCk6IGJvb2xlYW4gfCBQcm9taXNlPGJvb2xlYW4+IHtcblx0XHR0aHJvdyBuZXcgQWthaXJvRXJyb3IoXCJOT1RfSU1QTEVNRU5URURcIiwgdGhpcy5jb25zdHJ1Y3Rvci5uYW1lLCBcImV4ZWNcIik7XG5cdH1cblx0LyogZXNsaW50LWVuYWJsZSAgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVudXNlZC12YXJzICovXG5cblx0LyoqXG5cdCAqIFJlbG9hZHMgdGhlIGluaGliaXRvci5cblx0ICovXG5cdHB1YmxpYyBvdmVycmlkZSByZWxvYWQoKTogUHJvbWlzZTxJbmhpYml0b3I+IHtcblx0XHRyZXR1cm4gc3VwZXIucmVsb2FkKCkgYXMgUHJvbWlzZTxJbmhpYml0b3I+O1xuXHR9XG5cblx0LyoqXG5cdCAqIFJlbW92ZXMgdGhlIGluaGliaXRvci5cblx0ICovXG5cdHB1YmxpYyBvdmVycmlkZSByZW1vdmUoKTogSW5oaWJpdG9yIHtcblx0XHRyZXR1cm4gc3VwZXIucmVtb3ZlKCkgYXMgSW5oaWJpdG9yO1xuXHR9XG59XG5cbi8qKlxuICogT3B0aW9ucyB0byB1c2UgZm9yIGluaGliaXRvciBleGVjdXRpb24gYmVoYXZpb3IuXG4gKiBBbHNvIGluY2x1ZGVzIHByb3BlcnRpZXMgZnJvbSBBa2Fpcm9Nb2R1bGVPcHRpb25zLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEluaGliaXRvck9wdGlvbnMgZXh0ZW5kcyBBa2Fpcm9Nb2R1bGVPcHRpb25zIHtcblx0LyoqXG5cdCAqIFJlYXNvbiBlbWl0dGVkIHdoZW4gY29tbWFuZCBvciBtZXNzYWdlIGlzIGJsb2NrZWQuXG5cdCAqL1xuXHRyZWFzb24/OiBzdHJpbmc7XG5cblx0LyoqXG5cdCAqIENhbiBiZSAnYWxsJyB0byBydW4gb24gYWxsIG1lc3NhZ2VzLCAncHJlJyB0byBydW4gb24gbWVzc2FnZXMgbm90IGJsb2NrZWQgYnkgdGhlIGJ1aWx0LWluIGluaGliaXRvcnMsIG9yICdwb3N0JyB0byBydW4gb24gbWVzc2FnZXMgdGhhdCBhcmUgY29tbWFuZHMuXG5cdCAqIERlZmF1bHRzIHRvIGBwb3N0YFxuXHQgKi9cblx0dHlwZT86IFwiYWxsXCIgfCBcInByZVwiIHwgXCJwb3N0XCI7XG5cblx0LyoqXG5cdCAqIFByaW9yaXR5IGZvciB0aGUgaW5oaWJpdG9yIGZvciB3aGVuIG1vcmUgdGhhbiBvbmUgaW5oaWJpdG9ycyBibG9jayBhIG1lc3NhZ2UuXG5cdCAqIFRoZSBpbmhpYml0b3Igd2l0aCB0aGUgaGlnaGVzdCBwcmlvcml0eSBpcyB0aGUgb25lIHRoYXQgaXMgdXNlZCBmb3IgdGhlIGJsb2NrIHJlYXNvbi5cblx0ICogRGVmYXVsdHMgdG8gYDBgXG5cdCAqL1xuXHRwcmlvcml0eT86IG51bWJlcjtcbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSW5oaWJpdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3N0cnVjdC9pbmhpYml0b3JzL0luaGliaXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUNBLHlFQUFpRDtBQUlqRCxtRUFBb0U7QUFJcEU7Ozs7R0FJRztBQUNILE1BQThCLFNBQVUsU0FBUSxzQkFBWTtJQUMzRCxZQUFtQixFQUFVLEVBQUUsRUFBRSxRQUFRLEVBQUUsTUFBTSxHQUFHLEVBQUUsRUFBRSxJQUFJLEdBQUcsTUFBTSxFQUFFLFFBQVEsR0FBRyxDQUFDLEtBQXVCLEVBQUU7UUFDM0csS0FBSyxDQUFDLEVBQUUsRUFBRSxFQUFFLFFBQVEsRUFBRSxDQUFDLENBQUM7UUFFeEIsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFFckIsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFFakIsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUM7SUFDMUIsQ0FBQztJQUVEOztPQUVHO0lBQ0ksUUFBUSxDQUFTO0lBMkJ4Qjs7T0FFRztJQUNJLE1BQU0sQ0FBUztJQUV0Qjs7T0FFRztJQUNJLElBQUksQ0FBUztJQVliLElBQUksQ0FBQyxPQUFnQyxFQUFFLE9BQWlCO1FBQzlELE1BQU0sSUFBSSxxQkFBVyxDQUFDLGlCQUFpQixFQUFFLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ3pFLENBQUM7SUFDRCxzREFBc0Q7SUFFdEQ7O09BRUc7SUFDYSxNQUFNO1FBQ3JCLE9BQU8sS0FBSyxDQUFDLE1BQU0sRUFBd0IsQ0FBQztJQUM3QyxDQUFDO0lBRUQ7O09BRUc7SUFDYSxNQUFNO1FBQ3JCLE9BQU8sS0FBSyxDQUFDLE1BQU0sRUFBZSxDQUFDO0lBQ3BDLENBQUM7Q0FDRDtBQS9FRCw0QkErRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNZXNzYWdlIH0gZnJvbSBcImRpc2NvcmQuanNcIjtcbmltcG9ydCBBa2Fpcm9FcnJvciBmcm9tIFwiLi4vLi4vdXRpbC9Ba2Fpcm9FcnJvclwiO1xuaW1wb3J0IEFrYWlyb01lc3NhZ2UgZnJvbSBcIi4uLy4uL3V0aWwvQWthaXJvTWVzc2FnZVwiO1xuaW1wb3J0IENhdGVnb3J5IGZyb20gXCIuLi8uLi91dGlsL0NhdGVnb3J5XCI7XG5pbXBvcnQgQWthaXJvQ2xpZW50IGZyb20gXCIuLi9Ba2Fpcm9DbGllbnRcIjtcbmltcG9ydCBBa2Fpcm9Nb2R1bGUsIHsgQWthaXJvTW9kdWxlT3B0aW9ucyB9IGZyb20gXCIuLi9Ba2Fpcm9Nb2R1bGVcIjtcbmltcG9ydCBDb21tYW5kIGZyb20gXCIuLi9jb21tYW5kcy9Db21tYW5kXCI7XG5pbXBvcnQgSW5oaWJpdG9ySGFuZGxlciBmcm9tIFwiLi9JbmhpYml0b3JIYW5kbGVyXCI7XG5cbi8qKlxuICogUmVwcmVzZW50cyBhbiBpbmhpYml0b3IuXG4gKiBAcGFyYW0gaWQgLSBJbmhpYml0b3IgSUQuXG4gKiBAcGFyYW0gb3B0aW9ucyAtIE9wdGlvbnMgZm9yIHRoZSBpbmhpYml0b3IuXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGFic3RyYWN0IGNsYXNzIEluaGliaXRvciBleHRlbmRzIEFrYWlyb01vZHVsZSB7XG5cdHB1YmxpYyBjb25zdHJ1Y3RvcihpZDogc3RyaW5nLCB7IGNhdGVnb3J5LCByZWFzb24gPSBcIlwiLCB0eXBlID0gXCJwb3N0XCIsIHByaW9yaXR5ID0gMCB9OiBJbmhpYml0b3JPcHRpb25zID0ge30pIHtcblx0XHRzdXBlcihpZCwgeyBjYXRlZ29yeSB9KTtcblxuXHRcdHRoaXMucmVhc29uID0gcmVhc29uO1xuXG5cdFx0dGhpcy50eXBlID0gdHlwZTtcblxuXHRcdHRoaXMucHJpb3JpdHkgPSBwcmlvcml0eTtcblx0fVxuXG5cdC8qKlxuXHQgKiBUaGUgcHJpb3JpdHkgb2YgdGhlIGluaGliaXRvci5cblx0ICovXG5cdHB1YmxpYyBwcmlvcml0eTogbnVtYmVyO1xuXG5cdC8qKlxuXHQgKiBUaGUgY2F0ZWdvcnkgdGhlIGluaGliaXRvciBiZWxvbmdzIHRvLlxuXHQgKi9cblx0cHVibGljIGRlY2xhcmUgY2F0ZWdvcnk6IENhdGVnb3J5PHN0cmluZywgSW5oaWJpdG9yPjtcblxuXHQvKipcblx0ICogVGhlIEFrYWlybyBjbGllbnQuXG5cdCAqL1xuXHRwdWJsaWMgZGVjbGFyZSBjbGllbnQ6IEFrYWlyb0NsaWVudDtcblxuXHQvKipcblx0ICogVGhlIGZpbGVwYXRoLlxuXHQgKi9cblx0cHVibGljIGRlY2xhcmUgZmlsZXBhdGg6IHN0cmluZztcblxuXHQvKipcblx0ICogVGhlIGluaGliaXRvciBoYW5kbGVyLlxuXHQgKi9cblx0cHVibGljIGRlY2xhcmUgaGFuZGxlcjogSW5oaWJpdG9ySGFuZGxlcjtcblxuXHQvKipcblx0ICogVGhlIElEIG9mIHRoaXMgaW5oaWJpdG9yLlxuXHQgKi9cblx0cHVibGljIGRlY2xhcmUgaWQ6IHN0cmluZztcblxuXHQvKipcblx0ICogUmVhc29uIGVtaXR0ZWQgd2hlbiBjb21tYW5kIGlzIGluaGliaXRlZC5cblx0ICovXG5cdHB1YmxpYyByZWFzb246IHN0cmluZztcblxuXHQvKipcblx0ICogVGhlIHR5cGUgb2YgdGhlIGluaGliaXRvciBmb3Igd2hlbiBpdCBzaG91bGQgcnVuLlxuXHQgKi9cblx0cHVibGljIHR5cGU6IHN0cmluZztcblxuXHQvKipcblx0ICogQ2hlY2tzIGlmIG1lc3NhZ2Ugc2hvdWxkIGJlIGJsb2NrZWQuXG5cdCAqIEEgcmV0dXJuIHZhbHVlIG9mIHRydWUgd2lsbCBibG9jayB0aGUgbWVzc2FnZS5cblx0ICogSWYgcmV0dXJuaW5nIGEgUHJvbWlzZSwgYSByZXNvbHZlZCB2YWx1ZSBvZiB0cnVlIHdpbGwgYmxvY2sgdGhlIG1lc3NhZ2UuXG5cdCAqIEBwYXJhbSBtZXNzYWdlIC0gTWVzc2FnZSBiZWluZyBoYW5kbGVkLlxuXHQgKiBAcGFyYW0gY29tbWFuZCAtIENvbW1hbmQgdG8gY2hlY2suXG5cdCAqL1xuXHQvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnMgKi9cblx0cHVibGljIGV4ZWMobWVzc2FnZTogTWVzc2FnZSwgY29tbWFuZD86IENvbW1hbmQpOiBib29sZWFuIHwgUHJvbWlzZTxib29sZWFuPjtcblx0cHVibGljIGV4ZWMobWVzc2FnZTogTWVzc2FnZSB8IEFrYWlyb01lc3NhZ2UsIGNvbW1hbmQ/OiBDb21tYW5kKTogYm9vbGVhbiB8IFByb21pc2U8Ym9vbGVhbj47XG5cdHB1YmxpYyBleGVjKG1lc3NhZ2U6IE1lc3NhZ2UgfCBBa2Fpcm9NZXNzYWdlLCBjb21tYW5kPzogQ29tbWFuZCk6IGJvb2xlYW4gfCBQcm9taXNlPGJvb2xlYW4+IHtcblx0XHR0aHJvdyBuZXcgQWthaXJvRXJyb3IoXCJOT1RfSU1QTEVNRU5URURcIiwgdGhpcy5jb25zdHJ1Y3Rvci5uYW1lLCBcImV4ZWNcIik7XG5cdH1cblx0LyogZXNsaW50LWVuYWJsZSAgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVudXNlZC12YXJzICovXG5cblx0LyoqXG5cdCAqIFJlbG9hZHMgdGhlIGluaGliaXRvci5cblx0ICovXG5cdHB1YmxpYyBvdmVycmlkZSByZWxvYWQoKTogUHJvbWlzZTxJbmhpYml0b3I+IHtcblx0XHRyZXR1cm4gc3VwZXIucmVsb2FkKCkgYXMgUHJvbWlzZTxJbmhpYml0b3I+O1xuXHR9XG5cblx0LyoqXG5cdCAqIFJlbW92ZXMgdGhlIGluaGliaXRvci5cblx0ICovXG5cdHB1YmxpYyBvdmVycmlkZSByZW1vdmUoKTogSW5oaWJpdG9yIHtcblx0XHRyZXR1cm4gc3VwZXIucmVtb3ZlKCkgYXMgSW5oaWJpdG9yO1xuXHR9XG59XG5cbi8qKlxuICogT3B0aW9ucyB0byB1c2UgZm9yIGluaGliaXRvciBleGVjdXRpb24gYmVoYXZpb3IuXG4gKiBBbHNvIGluY2x1ZGVzIHByb3BlcnRpZXMgZnJvbSBBa2Fpcm9Nb2R1bGVPcHRpb25zLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEluaGliaXRvck9wdGlvbnMgZXh0ZW5kcyBBa2Fpcm9Nb2R1bGVPcHRpb25zIHtcblx0LyoqXG5cdCAqIFJlYXNvbiBlbWl0dGVkIHdoZW4gY29tbWFuZCBvciBtZXNzYWdlIGlzIGJsb2NrZWQuXG5cdCAqL1xuXHRyZWFzb24/OiBzdHJpbmc7XG5cblx0LyoqXG5cdCAqIENhbiBiZSAnYWxsJyB0byBydW4gb24gYWxsIG1lc3NhZ2VzLCAncHJlJyB0byBydW4gb24gbWVzc2FnZXMgbm90IGJsb2NrZWQgYnkgdGhlIGJ1aWx0LWluIGluaGliaXRvcnMsIG9yICdwb3N0JyB0byBydW4gb24gbWVzc2FnZXMgdGhhdCBhcmUgY29tbWFuZHMuXG5cdCAqIERlZmF1bHRzIHRvIGBwb3N0YFxuXHQgKi9cblx0dHlwZT86IFwiYWxsXCIgfCBcInByZVwiIHwgXCJwb3N0XCI7XG5cblx0LyoqXG5cdCAqIFByaW9yaXR5IGZvciB0aGUgaW5oaWJpdG9yIGZvciB3aGVuIG1vcmUgdGhhbiBvbmUgaW5oaWJpdG9ycyBibG9jayBhIG1lc3NhZ2UuXG5cdCAqIFRoZSBpbmhpYml0b3Igd2l0aCB0aGUgaGlnaGVzdCBwcmlvcml0eSBpcyB0aGUgb25lIHRoYXQgaXMgdXNlZCBmb3IgdGhlIGJsb2NrIHJlYXNvbi5cblx0ICogRGVmYXVsdHMgdG8gYDBgXG5cdCAqL1xuXHRwcmlvcml0eT86IG51bWJlcjtcbn1cbiJdfQ== |
{ | ||
"name": "@notenoughupdates/discord-akairo", | ||
"version": "9.0.5-dev.1633999353.3c120af", | ||
"version": "9.0.5-dev.1634004509.ebde0e8", | ||
"description": "A highly customizable bot framework for Discord.js.", | ||
@@ -5,0 +5,0 @@ "main": "./dist/src/index.js", |
@@ -10,3 +10,3 @@ /* eslint-disable func-names, @typescript-eslint/no-unused-vars */ | ||
import ArgumentRunner, { ArgumentRunnerState } from "./arguments/ArgumentRunner"; | ||
import CommandHandler, { IgnoreCheckPredicate, PrefixSupplier } from "./CommandHandler"; | ||
import CommandHandler, { IgnoreCheckPredicate, PrefixSupplier, SlashResolveTypes } from "./CommandHandler"; | ||
import ContentParser, { ContentParserResult } from "./ContentParser"; | ||
@@ -239,3 +239,3 @@ import Flag from "./Flag"; | ||
*/ | ||
public slashOptions?: ApplicationCommandOptionData[]; | ||
public slashOptions?: SlashOption[]; | ||
@@ -311,3 +311,2 @@ /** | ||
public exec(message: Message, args: any): any; | ||
public exec(message: AkairoMessage, args: any): any; | ||
public exec(message: Message | AkairoMessage, args: any): any; | ||
@@ -479,3 +478,3 @@ public exec(message: Message | AkairoMessage, args: any): any { | ||
/** | ||
* Assign slash commands to Specific guilds. This option will make the commands do not register globally, but only to the chosen servers. | ||
* Assign slash commands to Specific guilds. This option will make the commands not register globally, but only to the chosen servers. | ||
*/ | ||
@@ -487,3 +486,3 @@ slashGuilds?: string[]; | ||
*/ | ||
slashOptions?: ApplicationCommandOptionData[]; | ||
slashOptions?: SlashOption[]; | ||
@@ -556,1 +555,10 @@ /** | ||
) => IterableIterator<ArgumentOptions | Flag>; | ||
export type SlashOption = ApplicationCommandOptionData & { | ||
/** | ||
* Allows you to get a discord resolved object | ||
* | ||
* ex. get the resolved member object when the type is `USER` | ||
*/ | ||
resolve?: SlashResolveTypes; | ||
}; |
@@ -8,2 +8,3 @@ import { | ||
CommandInteractionOption, | ||
CommandInteractionOptionResolver, | ||
GuildApplicationCommandPermissionData, | ||
@@ -376,3 +377,8 @@ GuildResolvable, | ||
description: parseDescriptionCommand(data.description) || "No description provided.", | ||
options: data.slashOptions, | ||
options: data.slashOptions?.map(o => { | ||
// this may not be necessary but im not sure | ||
const temp = Object.assign({}, o); | ||
delete temp.resolve; | ||
return temp as ApplicationCommandOptionData; | ||
}), | ||
guilds: data.slashGuilds ?? [], | ||
@@ -680,5 +686,5 @@ defaultPermission: !(data.ownerOnly || /* data.superUserOnly || */ false), | ||
public async handleSlash(interaction: CommandInteraction): Promise<boolean | null> { | ||
const command = this.findCommand(interaction.commandName); | ||
const commandModule = this.findCommand(interaction.commandName); | ||
if (!command) { | ||
if (!commandModule) { | ||
this.emit(CommandHandlerEvents.SLASH_NOT_FOUND, interaction); | ||
@@ -724,3 +730,3 @@ return false; | ||
if (await this.runPostTypeInhibitors(message, command)) { | ||
if (await this.runPostTypeInhibitors(message, commandModule)) { | ||
return false; | ||
@@ -734,6 +740,6 @@ } | ||
if (["SUB_COMMAND", "SUB_COMMAND_GROUP"].includes(option.type)) continue; | ||
convertedOptions[option.name] = interaction.options[_.camelCase(`GET_${option.type}`) as GetFunctions]( | ||
option.name, | ||
false | ||
); | ||
const originalOption = commandModule.slashOptions?.find(o => o.name === option.name); | ||
convertedOptions[option.name] = interaction.options[ | ||
_.camelCase(`GET_${originalOption?.resolve ?? option.type}`) as GetFunctions | ||
](option.name, false); | ||
} | ||
@@ -743,36 +749,36 @@ | ||
try { | ||
if (command.lock) key = (command.lock as KeySupplier)(message, convertedOptions); | ||
if (commandModule.lock) key = (commandModule.lock as KeySupplier)(message, convertedOptions); | ||
if (Util.isPromise(key)) key = await key; | ||
if (key) { | ||
if (command.locker?.has(key)) { | ||
if (commandModule.locker?.has(key)) { | ||
key = null; | ||
this.emit(CommandHandlerEvents.COMMAND_LOCKED, message, command); | ||
this.emit(CommandHandlerEvents.COMMAND_LOCKED, message, commandModule); | ||
return true; | ||
} | ||
command.locker?.add(key); | ||
commandModule.locker?.add(key); | ||
} | ||
} catch (err) { | ||
this.emitError(err, message, command); | ||
this.emitError(err, message, commandModule); | ||
} finally { | ||
if (key) command.locker?.delete(key); | ||
if (key) commandModule.locker?.delete(key); | ||
} | ||
if (this.autoDefer || command.slashEphemeral) { | ||
await interaction.deferReply({ ephemeral: command.slashEphemeral }); | ||
if (this.autoDefer || commandModule.slashEphemeral) { | ||
await interaction.deferReply({ ephemeral: commandModule.slashEphemeral }); | ||
} | ||
try { | ||
this.emit(CommandHandlerEvents.SLASH_STARTED, message, command, convertedOptions); | ||
this.emit(CommandHandlerEvents.SLASH_STARTED, message, commandModule, convertedOptions); | ||
const ret = | ||
Object.getOwnPropertyNames(Object.getPrototypeOf(command)).includes("execSlash") || this.execSlash | ||
? await command.execSlash(message, convertedOptions) | ||
: await command.exec(message, convertedOptions); | ||
this.emit(CommandHandlerEvents.SLASH_FINISHED, message, command, convertedOptions, ret); | ||
Object.getOwnPropertyNames(Object.getPrototypeOf(commandModule)).includes("execSlash") || this.execSlash | ||
? await commandModule.execSlash(message, convertedOptions) | ||
: await commandModule.exec(message, convertedOptions); | ||
this.emit(CommandHandlerEvents.SLASH_FINISHED, message, commandModule, convertedOptions, ret); | ||
return true; | ||
} catch (err) { | ||
this.emit(CommandHandlerEvents.SLASH_ERROR, err, message, command); | ||
this.emit(CommandHandlerEvents.SLASH_ERROR, err, message, commandModule); | ||
return false; | ||
} | ||
} catch (err) { | ||
this.emitError(err, message, command); | ||
this.emitError(err, message, commandModule); | ||
return null; | ||
@@ -1660,2 +1666,17 @@ } | ||
/** | ||
* Calls the corresponding get function on the {@link CommandInteractionOptionResolver} | ||
*/ | ||
export type SlashResolveTypes = | ||
| "boolean" | ||
| "channel" | ||
| "string" | ||
| "integer" | ||
| "number" | ||
| "user" | ||
| "member" | ||
| "role" | ||
| "mentionable" | ||
| "message"; | ||
type GetFunctions = | ||
@@ -1686,1 +1707,4 @@ | "getBoolean" | ||
}; | ||
// eslint-disable-next-line no-unused-expressions, no-constant-condition | ||
if (false) CommandInteractionOptionResolver; |
@@ -75,3 +75,2 @@ import { Message } from "discord.js"; | ||
public exec(message: Message, command?: Command): boolean | Promise<boolean>; | ||
public exec(message: AkairoMessage, command?: Command): boolean | Promise<boolean>; | ||
public exec(message: Message | AkairoMessage, command?: Command): boolean | Promise<boolean>; | ||
@@ -78,0 +77,0 @@ public exec(message: Message | AkairoMessage, command?: Command): boolean | Promise<boolean> { |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
1061014
12862