API v10 checklist:
- \[ALL VERSIONS\] application.summary now returns an empty string. This field will be removed in v11 \[x\]
- Achievement localization format has changed. name and description are now strings, and localized strings are now
stored in name_localizations and description_localizations \[x\]
- /channels/<channel_id>/threads/active has been removed \[x\]
- Existing attachments must be specified when PATCHing messages with new attachments. Any attachments not specified
will be removed and replaced with the specified list \[x\]
- Audit log reason as a body/query parameter is no longer supported, and you should instead use the X-Audit-Log-Reason
header. \[x\]
- Message routes accept embeds rather than embed \[x\]
- Requests to v10 and higher will no longer be supported on discordapp.com \[x\]
Improvements
- API v10 hype.
- Add `message_content` intent.
- Add `create_identifier_custom_id_from_name`.
- `ComponentTextInput` now auto-generates `custom_id` from `label` parameter instead.
- `ComponentSelectOption`'s `label` parameter is optional and defaults to `value`. (Gilgamesh8939)
- Add `Achievement.description_localizations`.
- Add `Achievement.name_localizations`.
- Add `description_localizations` parameter to `Client.achievement_create`.
- Add `name_localizations` parameter to `Client.achievement_create`.
- `Client.achievement_get` now accepts `Achievement` instances as well.
- Add `description_localizations` parameter to `Client.achievement_edit`.
- Add `name_localizations` parameter to `Client.achievement_edit`.
- Add `EmbeddedActivityConfiguration.premium_tier_treatment_default`.
- Add `EmbeddedActivityConfiguration.premium_tier_treatment_map`.
- Add `VoiceRegion.deprecated`.
- Add `force_update` parameter to `Client.emoji_get`.
- Add `Emoji._set_attributes`.
- Add `Client.emoji_guild_get_all` (renamed from `guild_sync_emojis`).
- `Client.emoji_edit` now accepts snowflake pair as well.
- `Client.emoji_guild_get_all` wont create a partial guild.
- `Client.emoji_guild_get_all` now returns a list emojis.
- `Client.sticker_guild_get_all` wont create a partial guild.
- `Client.sticker_guild_get_all` now returns a list emojis.
- Add missing `InteractionResponseContext.__repr__`.
- Add `Message.has_any_content_field`.
- Update content fields of message if required.
- Synchronise message edit dispatch event parsers based on message content availability.
ext.slash
- Returned and yielded values from form commands will depending the form was invoked by a message component or
application command.
- Followup yields from a message component command are sent followup messages instead of editing the source message.
Bug Fixes
- `Guild.get_emoji_like` returned the default value always. (from 1.1.137)
- `Guild.get_sticker_like` returned the default value always. (from 1.1.137)
- `Guild.get_stickers_like` returned the empty list.
- Deferred interactions were never marked as responded.
Renames, Deprecation & Removals
- `IntegrationApplication.summary` is removed & deprecated.
- `Application.summary` is removed & deprecated.
- `summary` parameter of `Application.precreate` is deprecated.
- `Guild.region` is removed & deprecated.
- `region` parameter of `Client.guild_create` is deprecated.
- `region` parameter of `Guild.precreate` is deprecated.
- `region` parameter of `Client.guild_edit` is deprecated.
- `Client.emoji_get`'s 2nd parameter is deprecated.
- Deprecate `Client.guild_sync_emojis`.
- `Client.sticker_guild_get`'s 2nd parameter is deprecated.
- Deprecate `Client.guild_sync_stickers`.