implement WelcomeScreen
This commit is contained in:
		| @@ -44,6 +44,7 @@ from .widget import * | ||||
| from .object import * | ||||
| from .reaction import * | ||||
| from . import utils, opus, abc, ui | ||||
| from .welcome_screen import WelcomeScreen, WelcomeChannel | ||||
| from .enums import * | ||||
| from .embeds import * | ||||
| from .mentions import * | ||||
|   | ||||
| @@ -76,6 +76,7 @@ from .stage_instance import StageInstance | ||||
| from .threads import Thread, ThreadMember | ||||
| from .sticker import GuildSticker | ||||
| from .file import File | ||||
| from .welcome_screen import WelcomeScreen, WelcomeChannel | ||||
|  | ||||
|  | ||||
| __all__ = ( | ||||
| @@ -2574,6 +2575,66 @@ class Guild(Hashable): | ||||
|  | ||||
|         return roles | ||||
|  | ||||
|     async def welcome_screen(self): | ||||
|         """|coro| | ||||
|  | ||||
|         Returns the guild's welcome screen. | ||||
|  | ||||
|         The guild must have ``COMMUNITY`` in :attr:`~Guild.features`. | ||||
|  | ||||
|         You must have the :attr:`~Permissions.manage_guild` permission to use | ||||
|         this as well. | ||||
|  | ||||
|         .. versionadded:: 1.7 | ||||
|  | ||||
|         Raises | ||||
|         ------- | ||||
|         Forbidden | ||||
|             You do not have the proper permissions to get this. | ||||
|         HTTPException | ||||
|             Retrieving the welcome screen failed. | ||||
|  | ||||
|         Returns | ||||
|         -------- | ||||
|         :class:`WelcomeScreen` | ||||
|             The welcome screen. | ||||
|         """ | ||||
|         data = await self._state.http.get_welcome_screen(self.id) | ||||
|         return WelcomeScreen(data=data, guild=self) | ||||
|  | ||||
|     async def edit_welcome_screen(self, **kwargs): | ||||
|         """|coro| | ||||
|  | ||||
|         A shorthand method of :attr:`WelcomeScreen.edit` without needing | ||||
|         to fetch the welcome screen beforehand. | ||||
|  | ||||
|         The guild must have ``COMMUNITY`` in :attr:`~Guild.features`. | ||||
|  | ||||
|         You must have the :attr:`~Permissions.manage_guild` permission to use | ||||
|         this as well. | ||||
|  | ||||
|         .. versionadded:: 1.7 | ||||
|  | ||||
|         Returns | ||||
|         -------- | ||||
|         :class:`WelcomeScreen` | ||||
|             The edited welcome screen. | ||||
|         """ | ||||
|         try: | ||||
|             welcome_channels = kwargs['welcome_channels'] | ||||
|         except KeyError: | ||||
|             pass | ||||
|         else: | ||||
|             welcome_channels_serialised = [] | ||||
|             for wc in welcome_channels: | ||||
|                 if not isinstance(wc, WelcomeChannel): | ||||
|                     raise InvalidArgument('welcome_channels parameter must be a list of WelcomeChannel') | ||||
|                 welcome_channels_serialised.append(wc.to_dict()) | ||||
|  | ||||
|         if kwargs: | ||||
|             data = await self._state.http.edit_welcome_screen(self.id, kwargs) | ||||
|             return WelcomeScreen(data=data, guild=self) | ||||
|  | ||||
|     async def kick(self, user: Snowflake, *, reason: Optional[str] = None) -> None: | ||||
|         """|coro| | ||||
|  | ||||
|   | ||||
| @@ -1116,6 +1116,20 @@ class HTTPClient: | ||||
|             payload['icon'] = icon | ||||
|         return self.request(Route('POST', '/guilds/templates/{code}', code=code), json=payload) | ||||
|  | ||||
|     def get_welcome_screen(self, guild_id): | ||||
|         return self.request(Route('GET', '/guilds/{guild_id}/welcome-screen', guild_id=guild_id)) | ||||
|  | ||||
|     def edit_welcome_screen(self, guild_id, payload): | ||||
|         valid_keys = ( | ||||
|             'description', | ||||
|             'welcome_channels', | ||||
|             'enabled', | ||||
|         ) | ||||
|         payload = { | ||||
|             k: v for k, v in payload.items() if k in valid_keys | ||||
|         } | ||||
|         return self.request(Route('PATCH', '/guilds/{guild_id}/welcome-screen', guild_id=guild_id), json=payload) | ||||
|  | ||||
|     def get_bans(self, guild_id: Snowflake) -> Response[List[guild.Ban]]: | ||||
|         return self.request(Route('GET', '/guilds/{guild_id}/bans', guild_id=guild_id)) | ||||
|  | ||||
|   | ||||
							
								
								
									
										181
									
								
								discord/welcome_screen.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										181
									
								
								discord/welcome_screen.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,181 @@ | ||||
| # -*- coding: utf-8 -*- | ||||
|  | ||||
| """ | ||||
| The MIT License (MIT) | ||||
|  | ||||
| Copyright (c) 2015-present Rapptz | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a | ||||
| copy of this software and associated documentation files (the "Software"), | ||||
| to deal in the Software without restriction, including without limitation | ||||
| the rights to use, copy, modify, merge, publish, distribute, sublicense, | ||||
| and/or sell copies of the Software, and to permit persons to whom the | ||||
| Software is furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in | ||||
| all copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS | ||||
| OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | ||||
| FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | ||||
| DEALINGS IN THE SOFTWARE. | ||||
| """ | ||||
|  | ||||
| from .utils import _get_as_snowflake, get | ||||
| from .errors import InvalidArgument | ||||
| from .partial_emoji import _EmojiTag | ||||
|  | ||||
|  | ||||
| class WelcomeChannel: | ||||
|     """Represents a :class:`WelcomeScreen` welcome channel. | ||||
|  | ||||
|     .. versionadded:: 1.7 | ||||
|  | ||||
|     Attributes | ||||
|     ----------- | ||||
|     channel: :class:`abc.Snowflake` | ||||
|         The guild channel that is being referenced. | ||||
|     description: :class:`str` | ||||
|         The description shown of the channel. | ||||
|     emoji: Optional[:class:`PartialEmoji`, :class:`Emoji`, :class:`str`] | ||||
|         The emoji used beside the channel description. | ||||
|     """ | ||||
|     def __init__(self, *, channel, description, emoji=None): | ||||
|         self.channel = channel | ||||
|         self.description = description | ||||
|         self.emoji = emoji | ||||
|      | ||||
|     def __repr__(self): | ||||
|         return '<WelcomeChannel channel={0.channel!r} description={0.description!r} emoji={0.emoji}>'.format(self) | ||||
|  | ||||
|     @classmethod | ||||
|     def _from_dict(cls, *, data, guild): | ||||
|         channel_id = _get_as_snowflake(data, 'channel_id') | ||||
|         channel = guild.get_channel(channel_id) | ||||
|         description = data['description'] | ||||
|         _emoji_id  = _get_as_snowflake(data, 'emoji_id') | ||||
|         _emoji_name = data['emoji_name'] | ||||
|  | ||||
|         if _emoji_id: | ||||
|             # custom | ||||
|             emoji = get(guild.emojis, id=_emoji_id) | ||||
|         else: | ||||
|             # unicode or None | ||||
|             emoji = _emoji_name | ||||
|  | ||||
|         return cls(channel=channel, description=description, emoji=emoji) | ||||
|  | ||||
|     def to_dict(self): | ||||
|         ret = { | ||||
|             'channel_id': self.channel.id, | ||||
|             'description': self.description, | ||||
|             'emoji_id': None, | ||||
|             'emoji_name': None, | ||||
|         } | ||||
|  | ||||
|         if isinstance(self.emoji, _EmojiTag): | ||||
|             ret['emoji_id'] = self.emoji.id | ||||
|             ret['emoji_name'] = self.emoji.name | ||||
|         else: | ||||
|             # unicode or None | ||||
|             ret['emoji_name'] = self.emoji | ||||
|  | ||||
|         return ret | ||||
|  | ||||
| class WelcomeScreen: | ||||
|     """Represents a :class:`Guild` welcome screen. | ||||
|  | ||||
|     .. versionadded:: 1.7 | ||||
|  | ||||
|     Attributes | ||||
|     ----------- | ||||
|     description: :class:`str` | ||||
|         The description shown on the welcome screen. | ||||
|     welcome_channels: List[:class:`WelcomeChannel`] | ||||
|         The channels shown on the welcome screen. | ||||
|     """ | ||||
|     def __init__(self, *, data, guild): | ||||
|         self._state = guild._state | ||||
|         self._guild = guild | ||||
|         self._store(data) | ||||
|      | ||||
|     def _store(self, data): | ||||
|         self.description = data['description'] | ||||
|         welcome_channels = data.get('welcome_channels', []) | ||||
|         self.welcome_channels = [WelcomeChannel._from_dict(data=wc, guild=self._guild) for wc in welcome_channels] | ||||
|  | ||||
|     def __repr__(self): | ||||
|         return '<WelcomeScreen description={0.description!r} welcome_channels={0.welcome_channels!r} enabled={0.enabled}>'.format(self) | ||||
|  | ||||
|     @property | ||||
|     def enabled(self): | ||||
|         """:class:`bool`: Whether the welcome screen is displayed. | ||||
|          | ||||
|         This is equivalent to checking if ``WELCOME_SCREEN_ENABLED`` | ||||
|         is present in :attr:`Guild.features`. | ||||
|         """ | ||||
|         return 'WELCOME_SCREEN_ENABLED' in self._guild.features | ||||
|  | ||||
|     async def edit(self, **kwargs): | ||||
|         """|coro| | ||||
|          | ||||
|         Edit the welcome screen. | ||||
|          | ||||
|         You must have the :attr:`~Permissions.manage_guild` permission in the | ||||
|         guild to do this. | ||||
|  | ||||
|         Usage: :: | ||||
|  | ||||
|             channel_1 = guild.get_channel(12345678) | ||||
|             channel_2 = guild.get_channel(87654321) | ||||
|  | ||||
|             custom_emoji = utils.get(guild.emojis, name='loudspeaker') | ||||
|  | ||||
|             await welcome_screen.edit( | ||||
|                 description='This is a very cool community server!', | ||||
|                 welcome_channels=[ | ||||
|                     WelcomeChannel(channel=channel_one, description='Read the rules!', emoji='👨🏫'), | ||||
|                     WelcomeChannel(channel=channel_two, description='Watch out for announcements!', emoji=custom_emoji),  | ||||
|                 ] | ||||
|             ) | ||||
|          | ||||
|         .. note:: | ||||
|  | ||||
|             Welcome channels can only accept custom emojis if :attr:`~Guild.premium_tier` is level 2 or above. | ||||
|          | ||||
|         Parameters | ||||
|         ------------ | ||||
|         description: Optional[:class:`str`] | ||||
|             The template's description. | ||||
|         welcome_channels: Optional[List[:class:`WelcomeChannel`]] | ||||
|             The welcome channels, in their respective order. | ||||
|         enabled: Optional[:class:`bool`] | ||||
|             Whether the welcome screen should be displayed. | ||||
|  | ||||
|         Raises | ||||
|         ------- | ||||
|         HTTPException | ||||
|             Editing the welcome screen failed failed. | ||||
|         Forbidden | ||||
|             You don't have permissions to edit the welcome screen. | ||||
|         NotFound | ||||
|             This welcome screen does not exist. | ||||
|         """ | ||||
|         try: | ||||
|             welcome_channels = kwargs['welcome_channels'] | ||||
|         except KeyError: | ||||
|             pass | ||||
|         else: | ||||
|             welcome_channels_serialised = [] | ||||
|             for wc in welcome_channels: | ||||
|                 if not isinstance(wc, WelcomeChannel): | ||||
|                     raise InvalidArgument('welcome_channels parameter must be a list of WelcomeChannel') | ||||
|                 welcome_channels_serialised.append(wc.to_dict()) | ||||
|             kwargs['welcome_channels'] = welcome_channels_serialised | ||||
|  | ||||
|         if kwargs: | ||||
|             data = await self._state.http.edit_welcome_screen(self._guild.id, kwargs) | ||||
|             self._store(data) | ||||
							
								
								
									
										16
									
								
								docs/api.rst
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								docs/api.rst
									
									
									
									
									
								
							| @@ -3781,6 +3781,22 @@ Template | ||||
| .. autoclass:: Template() | ||||
|     :members: | ||||
|  | ||||
| WelcomeScreen | ||||
| ~~~~~~~~~~~~~~~ | ||||
|  | ||||
| .. attributetable:: WelcomeScreen | ||||
|  | ||||
| .. autoclass:: WelcomeScreen() | ||||
|     :members: | ||||
|  | ||||
| WelcomeChannel | ||||
| ~~~~~~~~~~~~~~~ | ||||
|  | ||||
| .. attributetable:: WelcomeChannel | ||||
|  | ||||
| .. autoclass:: WelcomeChannel() | ||||
|     :members: | ||||
|  | ||||
| WidgetChannel | ||||
| ~~~~~~~~~~~~~~~ | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user