|
|
@ -45,6 +45,7 @@ from typing import ( |
|
|
|
) |
|
|
|
|
|
|
|
from . import utils |
|
|
|
from .asset import Asset |
|
|
|
from .reaction import Reaction |
|
|
|
from .emoji import Emoji |
|
|
|
from .partial_emoji import PartialEmoji |
|
|
@ -106,6 +107,7 @@ __all__ = ( |
|
|
|
'MessageInteraction', |
|
|
|
'MessageReference', |
|
|
|
'DeletedReferencedMessage', |
|
|
|
'MessageApplication', |
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
@ -610,6 +612,51 @@ def flatten_handlers(cls: Type[Message]) -> Type[Message]: |
|
|
|
return cls |
|
|
|
|
|
|
|
|
|
|
|
class MessageApplication: |
|
|
|
"""Represents a message's application data from a :class:`~discord.Message`. |
|
|
|
|
|
|
|
.. versionadded:: 2.0 |
|
|
|
|
|
|
|
Attributes |
|
|
|
----------- |
|
|
|
id: :class:`int` |
|
|
|
The application ID. |
|
|
|
description: :class:`str` |
|
|
|
The application description. |
|
|
|
name: :class:`str` |
|
|
|
The application's name. |
|
|
|
""" |
|
|
|
|
|
|
|
__slots__ = ('_state', '_icon', '_cover_image', 'id', 'description', 'name') |
|
|
|
|
|
|
|
def __init__(self, *, state: ConnectionState, data: MessageApplicationPayload) -> None: |
|
|
|
self._state: ConnectionState = state |
|
|
|
self.id: int = int(data['id']) |
|
|
|
self.description: str = data['description'] |
|
|
|
self.name: str = data['name'] |
|
|
|
self._icon: Optional[str] = data['icon'] |
|
|
|
self._cover_image: Optional[str] = data.get('cover_image') |
|
|
|
|
|
|
|
def __repr__(self) -> str: |
|
|
|
return f'<MessageApplication id={self.id} name={self.name!r}>' |
|
|
|
|
|
|
|
@property |
|
|
|
def icon(self) -> Optional[Asset]: |
|
|
|
"""Optional[:class:`Asset`]: The application's icon, if any.""" |
|
|
|
if self._icon: |
|
|
|
return Asset._from_app_icon(state=self._state, object_id=self.id, icon_hash=self._icon, asset_type='icon') |
|
|
|
return None |
|
|
|
|
|
|
|
@property |
|
|
|
def cover(self) -> Optional[Asset]: |
|
|
|
"""Optional[:class:`Asset`]: The application's cover image, if any.""" |
|
|
|
if self._cover_image: |
|
|
|
return Asset._from_app_icon( |
|
|
|
state=self._state, object_id=self.id, icon_hash=self._cover_image, asset_type='cover_image' |
|
|
|
) |
|
|
|
return None |
|
|
|
|
|
|
|
|
|
|
|
class PartialMessage(Hashable): |
|
|
|
"""Represents a partial message to aid with working messages when only |
|
|
|
a message and channel ID are present. |
|
|
@ -1327,16 +1374,12 @@ class Message(PartialMessage, Hashable): |
|
|
|
|
|
|
|
- ``type``: An integer denoting the type of message activity being requested. |
|
|
|
- ``party_id``: The party ID associated with the party. |
|
|
|
application: Optional[:class:`dict`] |
|
|
|
application: Optional[:class:`~discord.MessageApplication`] |
|
|
|
The rich presence enabled application associated with this message. |
|
|
|
|
|
|
|
It is a dictionary with the following keys: |
|
|
|
.. versionchanged:: 2.0 |
|
|
|
Type is now :class:`MessageApplication` instead of :class:`dict`. |
|
|
|
|
|
|
|
- ``id``: A string representing the application's ID. |
|
|
|
- ``name``: A string representing the application's name. |
|
|
|
- ``description``: A string representing the application's description. |
|
|
|
- ``icon``: A string representing the icon ID of the application. |
|
|
|
- ``cover_image``: A string representing the embed's image asset ID. |
|
|
|
stickers: List[:class:`StickerItem`] |
|
|
|
A list of sticker items given to the message. |
|
|
|
|
|
|
@ -1409,7 +1452,6 @@ class Message(PartialMessage, Hashable): |
|
|
|
self.reactions: List[Reaction] = [Reaction(message=self, data=d) for d in data.get('reactions', [])] |
|
|
|
self.attachments: List[Attachment] = [Attachment(data=a, state=self._state) for a in data['attachments']] |
|
|
|
self.embeds: List[Embed] = [Embed.from_dict(a) for a in data['embeds']] |
|
|
|
self.application: Optional[MessageApplicationPayload] = data.get('application') |
|
|
|
self.activity: Optional[MessageActivityPayload] = data.get('activity') |
|
|
|
self._edited_timestamp: Optional[datetime.datetime] = utils.parse_time(data['edited_timestamp']) |
|
|
|
self.type: MessageType = try_enum(MessageType, data['type']) |
|
|
@ -1461,6 +1503,14 @@ class Message(PartialMessage, Hashable): |
|
|
|
# the channel will be the correct type here |
|
|
|
ref.resolved = self.__class__(channel=chan, data=resolved, state=state) # type: ignore |
|
|
|
|
|
|
|
self.application: Optional[MessageApplication] = None |
|
|
|
try: |
|
|
|
application = data['application'] |
|
|
|
except KeyError: |
|
|
|
pass |
|
|
|
else: |
|
|
|
self.application = MessageApplication(state=self._state, data=application) |
|
|
|
|
|
|
|
for handler in ('author', 'member', 'mentions', 'mention_roles', 'components'): |
|
|
|
try: |
|
|
|
getattr(self, f'_handle_{handler}')(data[handler]) |
|
|
@ -1559,7 +1609,8 @@ class Message(PartialMessage, Hashable): |
|
|
|
self.flags = MessageFlags._from_value(value) |
|
|
|
|
|
|
|
def _handle_application(self, value: MessageApplicationPayload) -> None: |
|
|
|
self.application = value |
|
|
|
application = MessageApplication(state=self._state, data=value) |
|
|
|
self.application = application |
|
|
|
|
|
|
|
def _handle_activity(self, value: MessageActivityPayload) -> None: |
|
|
|
self.activity = value |
|
|
|