Changelog

This page keeps a detailed human friendly rendering of what’s new and changed in specific versions.

v2.0.0

This does not Show Changes with discord.py 2.0, for a list go to Migrating to 2.0

Bug Fixes

New Features

v1.7.3

Bug Fixes

v1.7.2

Bug Fixes

v1.7.1

Bug Fixes

  • [ext.commands] Fix Cog.has_error_handler not working as intended.

v1.7.0

This version is mainly for improvements and bug fixes. This is more than likely the last major version in the 1.x series. Work after this will be spent on v2.0. As a result, this is the last version to support Python 3.5. Likewise, this is the last version to support user bots.

Development of v2.0 will have breaking changes and support for newer API features.

New Features

Bug Fixes

Miscellaneous

  • User endpoints and all userbot related functionality has been deprecated and will be removed in the next major version of the library.

  • Permission class methods were updated to match the UI of the Discord client (GH-6476)

  • _ and - characters are now stripped when making a new cog using the discord package (GH-6313)

v1.6.0

This version comes with support for replies and stickers.

New Features

Bug Fixes

Miscellaneous

v1.5.1

Bug Fixes

  • Fix utils.escape_markdown() not escaping quotes properly (GH-5897)

  • Fix Message not being hashable (GH-5901, GH-5866)

  • Fix moving channels to the end of the channel list (GH-5923)

  • Fix seemingly strange behaviour in __eq__ for PermissionOverwrite (GH-5929)

  • Fix aliases showing up in __iter__ for Intents (GH-5945)

  • Fix the bot disconnecting from voice when moving them to another channel (GH-5904)

  • Fix attribute errors when chunking times out sometimes during delayed on_ready dispatching.

  • Ensure that the bot’s own member is not evicted from the cache (GH-5949)

Miscellaneous

v1.5.0

This version came with forced breaking changes that Discord is requiring all bots to go through on October 7th. It is highly recommended to read the documentation on intents, A Primer to Gateway Intents.

API Changes

  • Members and presences will no longer be retrieved due to an API change. See Privileged Intents for more info.

  • As a consequence, fetching offline members is disabled if the members intent is not enabled.

New Features

Bug Fixes

Miscellaneous

  • Webhook requests are now logged (GH-5798)

  • Remove caching layer from AutoShardedClient.shards. This was causing issues if queried before launching shards.

  • Gateway rate limits are now handled.

  • Warnings logged due to missed caches are now changed to DEBUG log level.

  • Some strings are now explicitly interned to reduce memory usage.

  • Usage of namedtuples has been reduced to avoid potential breaking changes in the future (GH-5834)

  • [ext.commands] All BadArgument exceptions from the built-in converters now raise concrete exceptions to better tell them apart (GH-5748)

  • [ext.tasks] Lazily fetch the event loop to prevent surprises when changing event loop policy (GH-5808)

v1.4.2

This is a maintenance release with backports from v1.5.0.

Bug Fixes

Miscellaneous

  • Remove caching layer from AutoShardedClient.shards. This was causing issues if queried before launching shards.

  • [ext.tasks] Lazily fetch the event loop to prevent surprises when changing event loop policy (GH-5808)

v1.4.1

Bug Fixes

  • Properly terminate the connection when Client.close() is called (GH-5207)

  • Fix error being raised when clearing embed author or image when it was already cleared (GH-5210, GH-5212)

  • Fix __path__ to allow editable extensions (GH-5213)

v1.4.0

Another version with a long development time. Features like Intents are slated to be released in a v1.5 release. Thank you for your patience!

New Features

Bug Fixes

Miscellaneous

v1.3.4

Bug Fixes

  • Fix an issue with channel overwrites causing multiple issues including crashes (GH-5109)

v1.3.3

Bug Fixes

  • Change default WS close to 4000 instead of 1000.
    • The previous close code caused sessions to be invalidated at a higher frequency than desired.

  • Fix None appearing in Member.activities. (GH-2619)

v1.3.2

Another minor bug fix release.

Bug Fixes

v1.3.1

Minor bug fix release.

Bug Fixes

  • Fix fetching invites in guilds that the user is not in.

  • Fix the channel returned from Client.fetch_channel() raising when sending messages. (GH-2531)

Miscellaneous

  • Fix compatibility warnings when using the Python 3.9 alpha.

  • Change the unknown event logging from WARNING to DEBUG to reduce noise.

v1.3.0

This version comes with a lot of bug fixes and new features. It’s been in development for a lot longer than was anticipated!

New Features

Bug Fixes

Miscellaneous

  • The library now fully supports Python 3.8 without warnings.

  • Bump the dependency of websockets to 8.0 for those who can use it. (GH-2453)

  • Due to Discord providing Member data in mentions, users will now be upgraded to Member more often if mentioned.

  • utils.escape_markdown() now properly escapes new quote markdown.

  • The message cache can now be disabled by passing None to max_messages in Client.

  • The default message cache size has changed from 5000 to 1000 to accommodate small bots.

  • Lower memory usage by only creating certain objects as needed in Role.

  • There is now a sleep of 5 seconds before re-IDENTIFYing during a reconnect to prevent long loops of session invalidation.

  • The rate limiting code now uses millisecond precision to have more granular rate limit handling.
    • Along with that, the rate limiting code now uses Discord’s response to wait. If you need to use the system clock again for whatever reason, consider passing assume_synced_clock in Client.

  • The performance of Guild.default_role has been improved from O(N) to O(1). (GH-2375)

  • The performance of Member.roles has improved due to usage of caching to avoid surprising performance traps.

  • The GC is manually triggered during things that cause large deallocations (such as guild removal) to prevent memory fragmentation.

  • There have been many changes to the documentation for fixes both for usability, correctness, and to fix some linter errors. Thanks to everyone who contributed to those.

  • The loading of the opus module has been delayed which would make the result of opus.is_loaded() somewhat surprising.

  • [ext.commands] Usernames prefixed with @ inside DMs will properly convert using the User converter. (GH-2498)

  • [ext.tasks] The task sleeping time will now take into consideration the amount of time the task body has taken before sleeping. (GH-2516)

v1.2.5

Bug Fixes

  • Fix a bug that caused crashes due to missing animated field in Emoji structures in reactions.

v1.2.4

Bug Fixes

v1.2.3

Bug Fixes

v1.2.2

Bug Fixes

  • Audit log related attribute access have been fixed to not error out when they shouldn’t have.

v1.2.1

Bug Fixes

  • User.avatar_url and related attributes no longer raise an error.

  • More compatibility shims with the enum.Enum code.

v1.2.0

This update mainly brings performance improvements and various nitro boosting attributes (referred to in the API as “premium guilds”).

New Features

Bug Fixes

Miscellaneous

  • Improve performance of all Enum related code significantly.
    • This was done by replacing the enum.Enum code with an API compatible one.

    • This should not be a breaking change for most users due to duck-typing.

  • Improve performance of message creation by about 1.5x.

  • Improve performance of message editing by about 1.5-4x depending on payload size.

  • Improve performance of attribute access on Member about by 2x.

  • Improve performance of utils.get() by around 4-6x depending on usage.

  • Improve performance of event parsing lookup by around 2.5x.

  • Keyword arguments in Client.start() and Client.run() are now validated (GH-953, GH-2170)

  • The Discord error code is now shown in the exception message for HTTPException.

  • Internal tasks launched by the library will now have their own custom __repr__.

  • All public facing types should now have a proper and more detailed __repr__.

  • [ext.tasks] Errors are now logged via the standard logging module.

v1.1.1

Bug Fixes

  • Webhooks do not overwrite data on retrying their HTTP requests (GH-2140)

Miscellaneous

  • Add back signal handling to Client.run() due to issues some users had with proper cleanup.

v1.1.0

New Features

discord.ext.commands

Bug Fixes

discord.ext.commands

  • Fix lambda converters in a non-module context (e.g. eval).

  • Use message creation time for reference time when computing cooldowns.
    • This prevents cooldowns from triggering during e.g. a RESUME session.

  • Fix the default on_command_error() to work with new-style cogs (GH-2094)

  • DM channels are now recognised as NSFW in is_nsfw() check.

  • Fix race condition with help commands (GH-2123)

  • Fix cog descriptions not showing in MinimalHelpCommand (GH-2139)

Miscellaneous

  • Improve the performance of internal enum creation in the library by about 5x.

  • Make the output of python -m discord --version a bit more useful.

  • The loop cleanup facility has been rewritten again.

  • The signal handling in Client.run() has been removed.

discord.ext.commands

  • Custom exception classes are now used for all default checks in the library (GH-2101)

v1.0.1

Bug Fixes

  • Fix issue with speaking state being cast to int when it was invalid.

  • Fix some issues with loop cleanup that some users experienced on Linux machines.

  • Fix voice handshake race condition (GH-2056, GH-2063)