Browse Source

Add and change Guild attributes and Guild.edit params

pull/9367/head
Andrin S 2 years ago
committed by GitHub
parent
commit
bee2db805d
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 66
      discord/guild.py
  2. 1
      discord/http.py
  3. 1
      discord/types/guild.py

66
discord/guild.py

@ -267,6 +267,10 @@ class Guild(Hashable):
Indicates if the guild has widget enabled. Indicates if the guild has widget enabled.
.. versionadded:: 2.0 .. versionadded:: 2.0
max_stage_video_users: Optional[:class:`int`]
The maximum amount of users in a stage video channel.
.. versionadded:: 2.3
""" """
__slots__ = ( __slots__ = (
@ -315,6 +319,8 @@ class Guild(Hashable):
'approximate_member_count', 'approximate_member_count',
'approximate_presence_count', 'approximate_presence_count',
'premium_progress_bar_enabled', 'premium_progress_bar_enabled',
'_safety_alerts_channel_id',
'max_stage_video_users',
) )
_PREMIUM_GUILD_LIMITS: ClassVar[Dict[Optional[int], _GuildLimit]] = { _PREMIUM_GUILD_LIMITS: ClassVar[Dict[Optional[int], _GuildLimit]] = {
@ -478,6 +484,7 @@ class Guild(Hashable):
self.max_presences: Optional[int] = guild.get('max_presences') self.max_presences: Optional[int] = guild.get('max_presences')
self.max_members: Optional[int] = guild.get('max_members') self.max_members: Optional[int] = guild.get('max_members')
self.max_video_channel_users: Optional[int] = guild.get('max_video_channel_users') self.max_video_channel_users: Optional[int] = guild.get('max_video_channel_users')
self.max_stage_video_users: Optional[int] = guild.get('max_stage_video_channel_users')
self.premium_tier: int = guild.get('premium_tier', 0) self.premium_tier: int = guild.get('premium_tier', 0)
self.premium_subscription_count: int = guild.get('premium_subscription_count') or 0 self.premium_subscription_count: int = guild.get('premium_subscription_count') or 0
self.vanity_url_code: Optional[str] = guild.get('vanity_url_code') self.vanity_url_code: Optional[str] = guild.get('vanity_url_code')
@ -488,6 +495,7 @@ class Guild(Hashable):
self._discovery_splash: Optional[str] = guild.get('discovery_splash') self._discovery_splash: Optional[str] = guild.get('discovery_splash')
self._rules_channel_id: Optional[int] = utils._get_as_snowflake(guild, 'rules_channel_id') self._rules_channel_id: Optional[int] = utils._get_as_snowflake(guild, 'rules_channel_id')
self._public_updates_channel_id: Optional[int] = utils._get_as_snowflake(guild, 'public_updates_channel_id') self._public_updates_channel_id: Optional[int] = utils._get_as_snowflake(guild, 'public_updates_channel_id')
self._safety_alerts_channel_id: Optional[int] = utils._get_as_snowflake(guild, 'safety_alerts_channel_id')
self.nsfw_level: NSFWLevel = try_enum(NSFWLevel, guild.get('nsfw_level', 0)) self.nsfw_level: NSFWLevel = try_enum(NSFWLevel, guild.get('nsfw_level', 0))
self.mfa_level: MFALevel = try_enum(MFALevel, guild.get('mfa_level', 0)) self.mfa_level: MFALevel = try_enum(MFALevel, guild.get('mfa_level', 0))
self.approximate_presence_count: Optional[int] = guild.get('approximate_presence_count') self.approximate_presence_count: Optional[int] = guild.get('approximate_presence_count')
@ -801,6 +809,17 @@ class Guild(Hashable):
channel_id = self._public_updates_channel_id channel_id = self._public_updates_channel_id
return channel_id and self._channels.get(channel_id) # type: ignore return channel_id and self._channels.get(channel_id) # type: ignore
@property
def safety_alerts_channel(self) -> Optional[TextChannel]:
"""Optional[:class:`TextChannel`]: Return's the guild's channel used for safety alerts, if set.
For example, this is used for the raid protection setting. The guild must have the ``COMMUNITY`` feature.
.. versionadded:: 2.3
"""
channel_id = self._safety_alerts_channel_id
return channel_id and self._channels.get(channel_id) # type: ignore
@property @property
def widget_channel(self) -> Optional[Union[TextChannel, ForumChannel, VoiceChannel, StageChannel]]: def widget_channel(self) -> Optional[Union[TextChannel, ForumChannel, VoiceChannel, StageChannel]]:
"""Optional[Union[:class:`TextChannel`, :class:`ForumChannel`, :class:`VoiceChannel`, :class:`StageChannel`]]: Returns """Optional[Union[:class:`TextChannel`, :class:`ForumChannel`, :class:`VoiceChannel`, :class:`StageChannel`]]: Returns
@ -1820,6 +1839,8 @@ class Guild(Hashable):
widget_enabled: bool = MISSING, widget_enabled: bool = MISSING,
widget_channel: Optional[Snowflake] = MISSING, widget_channel: Optional[Snowflake] = MISSING,
mfa_level: MFALevel = MISSING, mfa_level: MFALevel = MISSING,
raid_alerts_disabled: bool = MISSING,
safety_alerts_channel: TextChannel = MISSING,
) -> Guild: ) -> Guild:
r"""|coro| r"""|coro|
@ -1934,6 +1955,18 @@ class Guild(Hashable):
reason: Optional[:class:`str`] reason: Optional[:class:`str`]
The reason for editing this guild. Shows up on the audit log. The reason for editing this guild. Shows up on the audit log.
raid_alerts_disabled: :class:`bool`
Whether the alerts for raid protection should be disabled for the guild.
.. versionadded:: 2.3
safety_alerts_channel: Optional[:class:`TextChannel`]
The new channel that is used for safety alerts. This is only available to
guilds that contain ``COMMUNITY`` in :attr:`Guild.features`. Could be ``None`` for no
safety alerts channel.
.. versionadded:: 2.3
Raises Raises
------- -------
Forbidden Forbidden
@ -1945,9 +1978,9 @@ class Guild(Hashable):
PNG or JPG. This is also raised if you are not the owner of the PNG or JPG. This is also raised if you are not the owner of the
guild and request an ownership transfer. guild and request an ownership transfer.
TypeError TypeError
The type passed to the ``default_notifications``, ``verification_level``, The type passed to the ``default_notifications``, ``rules_channel``, ``public_updates_channel``,
``explicit_content_filter``, ``system_channel_flags``, or ``mfa_level`` parameter was ``safety_alerts_channel`` ``verification_level``, ``explicit_content_filter``,
of the incorrect type. ``system_channel_flags``, or ``mfa_level`` parameter was of the incorrect type.
Returns Returns
-------- --------
@ -2019,14 +2052,33 @@ class Guild(Hashable):
if rules_channel is None: if rules_channel is None:
fields['rules_channel_id'] = rules_channel fields['rules_channel_id'] = rules_channel
else: else:
if not isinstance(rules_channel, TextChannel):
raise TypeError(f'rules_channel must be of type TextChannel not {rules_channel.__class__.__name__}')
fields['rules_channel_id'] = rules_channel.id fields['rules_channel_id'] = rules_channel.id
if public_updates_channel is not MISSING: if public_updates_channel is not MISSING:
if public_updates_channel is None: if public_updates_channel is None:
fields['public_updates_channel_id'] = public_updates_channel fields['public_updates_channel_id'] = public_updates_channel
else: else:
if not isinstance(public_updates_channel, TextChannel):
raise TypeError(
f'public_updates_channel must be of type TextChannel not {public_updates_channel.__class__.__name__}'
)
fields['public_updates_channel_id'] = public_updates_channel.id fields['public_updates_channel_id'] = public_updates_channel.id
if safety_alerts_channel is not MISSING:
if safety_alerts_channel is None:
fields['safety_alerts_channel_id'] = safety_alerts_channel
else:
if not isinstance(safety_alerts_channel, TextChannel):
raise TypeError(
f'safety_alerts_channel must be of type TextChannel not {safety_alerts_channel.__class__.__name__}'
)
fields['safety_alerts_channel_id'] = safety_alerts_channel.id
if owner is not MISSING: if owner is not MISSING:
if self.owner_id != self._state.self_id: if self.owner_id != self._state.self_id:
raise ValueError('To transfer ownership you must be the owner of the guild.') raise ValueError('To transfer ownership you must be the owner of the guild.')
@ -2051,7 +2103,7 @@ class Guild(Hashable):
fields['system_channel_flags'] = system_channel_flags.value fields['system_channel_flags'] = system_channel_flags.value
if any(feat is not MISSING for feat in (community, discoverable, invites_disabled)): if any(feat is not MISSING for feat in (community, discoverable, invites_disabled, raid_alerts_disabled)):
features = set(self.features) features = set(self.features)
if community is not MISSING: if community is not MISSING:
@ -2077,6 +2129,12 @@ class Guild(Hashable):
else: else:
features.discard('INVITES_DISABLED') features.discard('INVITES_DISABLED')
if raid_alerts_disabled is not MISSING:
if raid_alerts_disabled:
features.add('RAID_ALERTS_DISABLED')
else:
features.discard('RAID_ALERTS_DISABLED')
fields['features'] = list(features) fields['features'] = list(features)
if premium_progress_bar_enabled is not MISSING: if premium_progress_bar_enabled is not MISSING:

1
discord/http.py

@ -1426,6 +1426,7 @@ class HTTPClient:
'public_updates_channel_id', 'public_updates_channel_id',
'preferred_locale', 'preferred_locale',
'premium_progress_bar_enabled', 'premium_progress_bar_enabled',
'safety_alerts_channel_id',
) )
payload = {k: v for k, v in fields.items() if k in valid_keys} payload = {k: v for k, v in fields.items() if k in valid_keys}

1
discord/types/guild.py

@ -84,6 +84,7 @@ GuildFeature = Literal[
'VERIFIED', 'VERIFIED',
'VIP_REGIONS', 'VIP_REGIONS',
'WELCOME_SCREEN_ENABLED', 'WELCOME_SCREEN_ENABLED',
'RAID_ALERTS_DISABLED',
] ]

Loading…
Cancel
Save