From 195c923becf0b691bf82786aa5773561c77cf716 Mon Sep 17 00:00:00 2001 From: Rapptz Date: Sat, 19 Mar 2022 01:37:00 -0400 Subject: [PATCH] Fallback to Object if the type is not resolved in namespace --- discord/app_commands/namespace.py | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/discord/app_commands/namespace.py b/discord/app_commands/namespace.py index 02cd22f49..85b41914a 100644 --- a/discord/app_commands/namespace.py +++ b/discord/app_commands/namespace.py @@ -113,6 +113,14 @@ class Namespace: +-------------------------------------------+-------------------------------------------------------------------------------+ | :attr:`.AppCommandOptionType.attachment` | :class:`~discord.Attachment` | +-------------------------------------------+-------------------------------------------------------------------------------+ + + .. note:: + + In autocomplete interactions, the namespace might not be validated or filled in. Discord does not + send the resolved data as well, so this means that certain fields end up just as IDs rather than + the resolved data. In these cases, a :class:`discord.Object` is returned instead. + + This is a Discord limitation. """ def __init__( @@ -147,7 +155,7 @@ class Namespace: # servers will still have them so this needs to be handled. key = ResolveKey(id=snowflake, type=opt_type) - value = completed.get(key) + value = completed.get(key) or Object(id=int(snowflake)) self.__dict__[name] = value @classmethod