Join our webinar on Wednesday, June 26, at 1pm EDTHow Chia Mitigates Risk in the Crypto Industry.Register
Socket
Socket
Sign inDemoInstall

@notenoughupdates/discord-akairo

Package Overview
Dependencies
5
Maintainers
1
Versions
140
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 9.0.5-dev.1633999353.3c120af to 9.0.5-dev.1634004509.ebde0e8

2

dist/package.json
{
"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

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc