fix: sendSlash search failure (>25 bot)
This commit is contained in:
		| @@ -52,6 +52,7 @@ const Messages = { | ||||
|   EMBED_PROVIDER_NAME: 'MessageEmbed provider name must be a string.', | ||||
|   INVALID_COMMAND_NAME: allCMD => `Could not parse subGroupCommand and subCommand due to too long: ${allCMD.join(' ')}`, | ||||
|   INVALID_RANGE_QUERY_MEMBER: 'Invalid range query member. (0<x<=100)', | ||||
|   MUST_SPECIFY_BOT: 'You must specify a bot to use this command.', | ||||
|  | ||||
|   BUTTON_LABEL: 'MessageButton label must be a string', | ||||
|   BUTTON_URL: 'MessageButton URL must be a string', | ||||
|   | ||||
| @@ -229,12 +229,12 @@ class User extends Base { | ||||
|     } | ||||
|  | ||||
|     if ('premium_type' in data) { | ||||
|       const nitro = NitroType[data.premium_type]; | ||||
|       const nitro = NitroType[data.premium_type ?? 0]; | ||||
|       /** | ||||
|        * Nitro type of the user. | ||||
|        * @type {NitroType} | ||||
|        */ | ||||
|       this.nitroType = nitro ?? `UNKNOWN_${data.premium_type}`; | ||||
|       this.nitroType = nitro ?? `UNKNOWN_TYPE_${data.premium_type}`; | ||||
|     } | ||||
|  | ||||
|     if ('guild_member_profile' in data && 'guild_member' in data) { | ||||
|   | ||||
| @@ -402,7 +402,7 @@ class TextBasedChannel { | ||||
|  | ||||
|   /** | ||||
|    * Send Slash to this channel | ||||
|    * @param {Snowflake} botId Bot Id (Supports application ID - not bot) | ||||
|    * @param {UserResolvable} bot Bot user | ||||
|    * @param {string} commandString Command name (and sub / group formats) | ||||
|    * @param {...?string|string[]} args Command arguments | ||||
|    * @returns {Promise<InteractionResponseBody>} | ||||
| @@ -418,7 +418,7 @@ class TextBasedChannel { | ||||
|    * // CommandName is Group Command / Sub Command | ||||
|    * channel.sendSlash('123456789012345678', 'embed title', 'description', 'author', '#00ff00') | ||||
|    */ | ||||
|   async sendSlash(botId, commandString, ...args) { | ||||
|   async sendSlash(bot, commandString, ...args) { | ||||
|     args = args.flat(2); | ||||
|     const cmd = commandString.trim().split(' '); | ||||
|     // Validate CommandName | ||||
| @@ -430,7 +430,8 @@ class TextBasedChannel { | ||||
|       } | ||||
|       validateName(sub[i]); | ||||
|     } | ||||
|     if (!botId) throw new Error('Bot ID is required'); | ||||
|     if (!bot) throw new Error('MUST_SPECIFY_BOT'); | ||||
|     const botId = this.client.users.resolveId(bot); | ||||
|     // ? maybe ... | ||||
|     const user = await this.client.users.fetch(botId).catch(() => {}); | ||||
|     if (!user || !user.bot || !user.application) { | ||||
| @@ -439,41 +440,29 @@ class TextBasedChannel { | ||||
|     if (user._partial) await user.getProfile(); | ||||
|     if (!commandName || typeof commandName !== 'string') throw new Error('Command name is required'); | ||||
|     // Using API to search (without opcode ~ehehe) | ||||
|     let commandTarget; | ||||
|     // https://discord.com/api/v9/channels/id/application-commands/search?type=1&query=aiko&limit=7&include_applications=false&application_id=id | ||||
|     // https://discord.com/api/v9/channels/id/application-commands/search?type=1&application_id=161660517914509312 | ||||
|     const query = { | ||||
|       type: 1, // Slash commands | ||||
|       include_applications: false, | ||||
|       application_id: user.application?.id ?? user.id, | ||||
|     }; | ||||
|     if (this.client.channels.cache.get(this.id)?.type == 'DM') { | ||||
|       query.application_id = user.application.id; | ||||
|     } else { | ||||
|       query.limit = 25; | ||||
|       query.query = commandName; | ||||
|     } | ||||
|     const data = await this.client.api.channels[this.id]['application-commands'].search.get({ | ||||
|       query, | ||||
|     }); | ||||
|     for (const command of data.application_commands) { | ||||
|       if (user.id == command.application_id || user.application.id == command.application_id) { | ||||
|         const c = user.application?.commands?._add(command, true); | ||||
|         if (command.name == commandName) commandTarget = c; | ||||
|       } else { | ||||
|         const tempUser = this.client.users.cache.get(command.application_id); | ||||
|         if (tempUser && tempUser.bot && tempUser.application) { | ||||
|           tempUser.application?.commands?._add(command, true); | ||||
|         } | ||||
|         user.application?.commands?._add(command, true); | ||||
|       } | ||||
|     } | ||||
|     // Remove | ||||
|     commandTarget = | ||||
|       commandTarget || user.application?.commands?.cache.find(c => c.name === commandName && c.type === 'CHAT_INPUT'); | ||||
|     const commandTarget = user.application?.commands?.cache.find( | ||||
|       c => c.name === commandName && c.type === 'CHAT_INPUT', | ||||
|     ); | ||||
|     if (!commandTarget) { | ||||
|       throw new Error( | ||||
|         'INTERACTION_SEND_FAILURE', | ||||
|         `SlashCommand ${commandName} is not found (With search)\nDebug:\n+ botId: ${botId}\n+ args: ${args.join( | ||||
|           ' | ', | ||||
|         )}`, | ||||
|         `SlashCommand ${commandName} is not found (With search)\nDebug:\n+ botId: ${botId} (ApplicationId: ${ | ||||
|           user.application?.id | ||||
|         })\n+ args: ${args.join(' | ') || null}`, | ||||
|       ); | ||||
|     } | ||||
|     return commandTarget.sendSlashCommand( | ||||
|   | ||||
							
								
								
									
										2
									
								
								typings/index.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								typings/index.d.ts
									
									
									
									
										vendored
									
									
								
							| @@ -4061,7 +4061,7 @@ export interface TextBasedChannelFields extends PartialTextBasedChannelFields { | ||||
|   setNSFW(nsfw?: boolean, reason?: string): Promise<this>; | ||||
|   fetchWebhooks(): Promise<Collection<Snowflake, Webhook>>; | ||||
|   sendTyping(): Promise<void>; | ||||
|   sendSlash(botId: Snowflake, commandName: string, ...args: any): Promise<InteractionResponseBody>; | ||||
|   sendSlash(bot: UserResolvable, commandName: string, ...args: any): Promise<InteractionResponseBody>; | ||||
| } | ||||
|  | ||||
| export function PartialWebhookMixin<T>(Base?: Constructable<T>): Constructable<T & PartialWebhookFields>; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user