aboutsummaryrefslogtreecommitdiff
path: root/discord
diff options
context:
space:
mode:
Diffstat (limited to 'discord')
-rw-r--r--discord/errors.py19
-rw-r--r--discord/interactions.py24
2 files changed, 39 insertions, 4 deletions
diff --git a/discord/errors.py b/discord/errors.py
index 2e694318..a6d2ce45 100644
--- a/discord/errors.py
+++ b/discord/errors.py
@@ -36,6 +36,7 @@ __all__ = (
'LoginFailure',
'ConnectionClosed',
'PrivilegedIntentsRequired',
+ 'InteractionResponded',
)
class DiscordException(Exception):
@@ -213,3 +214,21 @@ class PrivilegedIntentsRequired(ClientException):
'and explicitly enable the privileged intents within your application\'s page. If this is not ' \
'possible, then consider disabling the privileged intents instead.'
super().__init__(msg % shard_id)
+
+class InteractionResponded(ClientException):
+ """Exception that's raised when sending another interaction response using
+ :class:`InteractionResponse` when one has already been done before.
+
+ An interaction can only respond once.
+
+ .. versionadded:: 2.0
+
+ Attributes
+ -----------
+ interaction: :class:`Interaction`
+ The interaction that's already been responded to.
+ """
+
+ def __init__(self, interaction):
+ self.interaction = interaction
+ super().__init__('This interaction has already been responded to before')
diff --git a/discord/interactions.py b/discord/interactions.py
index 46128f3d..1a6c6a5b 100644
--- a/discord/interactions.py
+++ b/discord/interactions.py
@@ -30,6 +30,7 @@ from typing import Any, Dict, List, Optional, TYPE_CHECKING, Tuple, Union
from . import utils
from .enums import try_enum, InteractionType, InteractionResponseType
+from .errors import InteractionResponded
from .user import User
from .member import Member
@@ -189,6 +190,13 @@ class InteractionResponse:
self._parent: Interaction = parent
self._responded: bool = False
+ def is_done(self) -> bool:
+ """:class:`bool`: Indicates whether an interaction response has been done before.
+
+ An interaction can only be responded to once.
+ """
+ return self._responded
+
async def defer(self, *, ephemeral: bool = False) -> None:
"""|coro|
@@ -207,9 +215,11 @@ class InteractionResponse:
-------
HTTPException
Deferring the interaction failed.
+ InteractionResponsed
+ This interaction has already been responded to before.
"""
if self._responded:
- return
+ raise InteractionResponded(self._parent)
defer_type: int = 0
data: Optional[Dict[str, Any]] = None
@@ -239,9 +249,11 @@ class InteractionResponse:
-------
HTTPException
Ponging the interaction failed.
+ InteractionResponsed
+ This interaction has already been responded to before.
"""
if self._responded:
- return
+ raise InteractionResponded(self._parent)
parent = self._parent
if parent.type is InteractionType.ping:
@@ -292,9 +304,11 @@ class InteractionResponse:
You specified both ``embed`` and ``embeds``.
ValueError
The length of ``embeds`` was invalid.
+ InteractionResponsed
+ This interaction has already been responded to before.
"""
if self._responded:
- return
+ raise InteractionResponded(self._parent)
payload: Dict[str, Any] = {
'tts': tts,
@@ -374,9 +388,11 @@ class InteractionResponse:
Editing the message failed.
TypeError
You specified both ``embed`` and ``embeds``.
+ InteractionResponsed
+ This interaction has already been responded to before.
"""
if self._responded:
- return
+ raise InteractionResponded(self._parent)
parent = self._parent
msg = parent.message