implement guild stickers
This commit is contained in:
		
							
								
								
									
										174
									
								
								discord/guild.py
									
									
									
									
									
								
							
							
						
						
									
										174
									
								
								discord/guild.py
									
									
									
									
									
								
							| @@ -25,6 +25,7 @@ DEALINGS IN THE SOFTWARE. | ||||
| from __future__ import annotations | ||||
|  | ||||
| import copy | ||||
| import unicodedata | ||||
| from typing import ( | ||||
|     Any, | ||||
|     ClassVar, | ||||
| @@ -72,6 +73,9 @@ from .flags import SystemChannelFlags | ||||
| from .integrations import Integration, _integration_factory | ||||
| from .stage_instance import StageInstance | ||||
| from .threads import Thread | ||||
| from .sticker import GuildSticker | ||||
| from .file import File | ||||
|  | ||||
|  | ||||
| __all__ = ( | ||||
|     'Guild', | ||||
| @@ -107,6 +111,7 @@ class BanEntry(NamedTuple): | ||||
|  | ||||
| class _GuildLimit(NamedTuple): | ||||
|     emoji: int | ||||
|     stickers: int | ||||
|     bitrate: float | ||||
|     filesize: int | ||||
|  | ||||
| @@ -140,6 +145,10 @@ class Guild(Hashable): | ||||
|         The guild name. | ||||
|     emojis: Tuple[:class:`Emoji`, ...] | ||||
|         All emojis that the guild owns. | ||||
|     stickers: Tuple[:class:`GuildSticker`, ...] | ||||
|         All stickers that the guild owns. | ||||
|  | ||||
|         .. versionadded:: 2.0 | ||||
|     region: :class:`VoiceRegion` | ||||
|         The region the guild belongs on. There is a chance that the region | ||||
|         will be a :class:`str` if the value is not recognised by the enumerator. | ||||
| @@ -234,6 +243,7 @@ class Guild(Hashable): | ||||
|         'owner_id', | ||||
|         'mfa_level', | ||||
|         'emojis', | ||||
|         'stickers', | ||||
|         'features', | ||||
|         'verification_level', | ||||
|         'explicit_content_filter', | ||||
| @@ -266,11 +276,11 @@ class Guild(Hashable): | ||||
|     ) | ||||
|  | ||||
|     _PREMIUM_GUILD_LIMITS: ClassVar[Dict[Optional[int], _GuildLimit]] = { | ||||
|         None: _GuildLimit(emoji=50, bitrate=96e3, filesize=8388608), | ||||
|         0: _GuildLimit(emoji=50, bitrate=96e3, filesize=8388608), | ||||
|         1: _GuildLimit(emoji=100, bitrate=128e3, filesize=8388608), | ||||
|         2: _GuildLimit(emoji=150, bitrate=256e3, filesize=52428800), | ||||
|         3: _GuildLimit(emoji=250, bitrate=384e3, filesize=104857600), | ||||
|         None: _GuildLimit(emoji=50, stickers=0, bitrate=96e3, filesize=8388608), | ||||
|         0: _GuildLimit(emoji=50, stickers=0, bitrate=96e3, filesize=8388608), | ||||
|         1: _GuildLimit(emoji=100, stickers=15, bitrate=128e3, filesize=8388608), | ||||
|         2: _GuildLimit(emoji=150, stickers=30, bitrate=256e3, filesize=52428800), | ||||
|         3: _GuildLimit(emoji=250, stickers=60, bitrate=384e3, filesize=104857600), | ||||
|     } | ||||
|  | ||||
|     def __init__(self, *, data: GuildPayload, state: ConnectionState): | ||||
| @@ -412,6 +422,7 @@ class Guild(Hashable): | ||||
|  | ||||
|         self.mfa_level: MFALevel = guild.get('mfa_level') | ||||
|         self.emojis: Tuple[Emoji, ...] = tuple(map(lambda d: state.store_emoji(self, d), guild.get('emojis', []))) | ||||
|         self.stickers: Tuple[GuildSticker, ...] = tuple(map(lambda d: state.store_sticker(self, d), guild.get('stickers', []))) | ||||
|         self.features: List[GuildFeature] = guild.get('features', []) | ||||
|         self._splash: Optional[str] = guild.get('splash') | ||||
|         self._system_channel_id: Optional[int] = utils._get_as_snowflake(guild, 'system_channel_id') | ||||
| @@ -698,6 +709,15 @@ class Guild(Hashable): | ||||
|         more_emoji = 200 if 'MORE_EMOJI' in self.features else 50 | ||||
|         return max(more_emoji, self._PREMIUM_GUILD_LIMITS[self.premium_tier].emoji) | ||||
|  | ||||
|     @property | ||||
|     def sticker_limit(self) -> int: | ||||
|         """:class:`int`: The maximum number of sticker slots this guild has. | ||||
|  | ||||
|         .. versionadded:: 2.0 | ||||
|         """ | ||||
|         more_stickers = 60 if 'MORE_STICKERS' in self.features else 15 | ||||
|         return max(more_stickers, self._PREMIUM_GUILD_LIMITS[self.premium_tier].stickers) | ||||
|  | ||||
|     @property | ||||
|     def bitrate_limit(self) -> float: | ||||
|         """:class:`float`: The maximum bitrate for voice channels this guild can have.""" | ||||
| @@ -2027,6 +2047,150 @@ class Guild(Hashable): | ||||
|  | ||||
|         return [convert(d) for d in data] | ||||
|  | ||||
|     async def fetch_stickers(self) -> List[GuildSticker]: | ||||
|         r"""|coro| | ||||
|  | ||||
|         Retrieves a list of all :class:`Sticker`\s for the guild. | ||||
|  | ||||
|         .. versionadded:: 2.0 | ||||
|  | ||||
|         .. note:: | ||||
|  | ||||
|             This method is an API call. For general usage, consider :attr:`stickers` instead. | ||||
|  | ||||
|         Raises | ||||
|         --------- | ||||
|         HTTPException | ||||
|             An error occurred fetching the stickers. | ||||
|  | ||||
|         Returns | ||||
|         -------- | ||||
|         List[:class:`GuildSticker`] | ||||
|             The retrieved stickers. | ||||
|         """ | ||||
|         data = await self._state.http.get_all_guild_stickers(self.id) | ||||
|         return [GuildSticker(state=self._state, data=d) for d in data] | ||||
|  | ||||
|     async def fetch_sticker(self, sticker_id: int, /) -> GuildSticker: | ||||
|         """|coro| | ||||
|  | ||||
|         Retrieves a custom :class:`Sticker` from the guild. | ||||
|  | ||||
|         .. versionadded:: 2.0 | ||||
|  | ||||
|         .. note:: | ||||
|  | ||||
|             This method is an API call. | ||||
|             For general usage, consider iterating over :attr:`stickers` instead. | ||||
|  | ||||
|         Parameters | ||||
|         ------------- | ||||
|         sticker_id: :class:`int` | ||||
|             The sticker's ID. | ||||
|  | ||||
|         Raises | ||||
|         --------- | ||||
|         NotFound | ||||
|             The sticker requested could not be found. | ||||
|         HTTPException | ||||
|             An error occurred fetching the sticker. | ||||
|  | ||||
|         Returns | ||||
|         -------- | ||||
|         :class:`GuildSticker` | ||||
|             The retrieved sticker. | ||||
|         """ | ||||
|         data = await self._state.http.get_guild_sticker(self.id, sticker_id) | ||||
|         return GuildSticker(state=self._state, data=data) | ||||
|  | ||||
|     async def create_sticker( | ||||
|         self, | ||||
|         *, | ||||
|         name: str, | ||||
|         description: Optional[str] = None, | ||||
|         emoji: str, | ||||
|         file: File, | ||||
|         reason: Optional[str] = None, | ||||
|     ) -> GuildSticker: | ||||
|         """|coro| | ||||
|  | ||||
|         Creates a :class:`Sticker` for the guild. | ||||
|  | ||||
|         You must have :attr:`~Permissions.manage_emojis_and_stickers` permission to | ||||
|         do this. | ||||
|  | ||||
|         .. versionadded:: 2.0 | ||||
|  | ||||
|         Parameters | ||||
|         ----------- | ||||
|         name: :class:`str` | ||||
|             The sticker name. Must be at least 2 characters. | ||||
|         description: Optional[:class:`str`] | ||||
|             The sticker's description. Can be ``None``. | ||||
|         emoji: :class:`str` | ||||
|             The name of a unicode emoji that represents the sticker's expression. | ||||
|         file: :class:`File` | ||||
|             The file of the sticker to upload. | ||||
|         reason: :class:`str` | ||||
|             The reason for creating this sticker. Shows up on the audit log. | ||||
|  | ||||
|         Raises | ||||
|         ------- | ||||
|         Forbidden | ||||
|             You are not allowed to create stickers. | ||||
|         HTTPException | ||||
|             An error occurred creating a sticker. | ||||
|  | ||||
|         Returns | ||||
|         -------- | ||||
|         :class:`GuildSticker` | ||||
|             The created sticker. | ||||
|         """ | ||||
|         payload = { | ||||
|             'name': name, | ||||
|         } | ||||
|  | ||||
|         if description: | ||||
|             payload['description'] = description | ||||
|  | ||||
|         try: | ||||
|             emoji = unicodedata.name(emoji) | ||||
|         except TypeError: | ||||
|             pass | ||||
|         else: | ||||
|             emoji = emoji.replace(' ', '_') | ||||
|  | ||||
|         payload['tags'] = emoji | ||||
|  | ||||
|         data = await self._state.http.create_guild_sticker(self.id, payload, file, reason) | ||||
|         return self._state.store_sticker(self, data) | ||||
|  | ||||
|     async def delete_sticker(self, sticker: Snowflake, *, reason: Optional[str] = None) -> None: | ||||
|         """|coro| | ||||
|  | ||||
|         Deletes the custom :class:`Sticker` from the guild. | ||||
|  | ||||
|         You must have :attr:`~Permissions.manage_emojis_and_stickers` permission to | ||||
|         do this. | ||||
|  | ||||
|         .. versionadded:: 2.0 | ||||
|  | ||||
|         Parameters | ||||
|         ----------- | ||||
|         sticker: :class:`abc.Snowflake` | ||||
|             The sticker you are deleting. | ||||
|         reason: Optional[:class:`str`] | ||||
|             The reason for deleting this sticker. Shows up on the audit log. | ||||
|  | ||||
|         Raises | ||||
|         ------- | ||||
|         Forbidden | ||||
|             You are not allowed to delete stickers. | ||||
|         HTTPException | ||||
|             An error occurred deleting the sticker. | ||||
|         """ | ||||
|         await self._state.http.delete_guild_sticker(self.id, sticker.id, reason) | ||||
|  | ||||
|     async def fetch_emojis(self) -> List[Emoji]: | ||||
|         r"""|coro| | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user