.. towncrier-draft-entries:: [UPCOMING UPDATE]
Warning
Python 3.8 End of Life: Python 3.8 will reach its end of life (EOL) soon and will no longer be supported by aiogram in the next releases (1-2 months ETA).
Please upgrade to a newer version of Python to ensure compatibility and receive future updates.
- Increase max pydantic version support "<2.9" -> "<2.10" (only For Python >=3.9) #1576
- Bump aiofiles version upper bound to <24.2 #1577
- Fixed Default object annotation resolution using pydantic #1579
- Added updates about purchased paid media, represented by the class
:class:`aiogram.types.paid_media_purchased.PaidMediaPurchased`
and the field
purchased_paid_media
in the class :class:`aiogram.types.update.Update`. - Added the ability to specify a payload in
:class:`aiogram.methods.send_paid_media.SendPaidMedia` that is received back by the bot in
:class:`aiogram.types.transaction_partner_user.TransactionPartnerUser`
and
purchased_paid_media
updates. - Added the field
prize_star_count
to the classes :class:`aiogram.types.giveaway_created.GiveawayCreated`, :class:`aiogram.types.giveaway.Giveaway`, :class:`aiogram.types.giveaway_winners.GiveawayWinners` and :class:`aiogram.types.chat_boost_source_giveaway.ChatBoostSourceGiveaway`. - Added the field
is_star_giveaway
to the class :class:`aiogram.types.giveaway_completed.GiveawayCompleted`.
- Added updates about purchased paid media, represented by the class
:class:`aiogram.types.paid_media_purchased.PaidMediaPurchased`
and the field
Added missing method aliases such as .answer(), .reply(), and others to InaccessibleMessage. This change ensures consistency and improves usability by aligning the functionality of InaccessibleMessage with the Message type. #1574
- Fixed link preview options to use global defaults in various types and methods to use global defaults for link_preview_options. This change ensures consistency and enhances flexibility in handling link preview options across different components. #1543
Added message_thread_id parameter to message.get_url(). #1451
Added getting user from chat_boost with source ChatBoostSourcePremium in UserContextMiddleware for EventContext #1474
Added full support of Bot API 7.8
- Added the ability to send paid media to any chat.
- Added the parameter
business_connection_id
to the method :class:`aiogram.methods.send_paid_media.SendPaidMedia`, allowing bots to send paid media on behalf of a business account. - Added the field
paid_media
to the class :class:`aiogram.types.transaction_partner_user.TransactionPartnerUser` for transactions involving paid media. - Added the method :class:`aiogram.methods.create_chat_subscription_invite_link.CreateChatSubscriptionInviteLink`, allowing bots to create subscription invite links.
- Added the method :class:`aiogram.methods.edit_chat_subscription_invite_link.EditChatSubscriptionInviteLink`, allowing bots to edit the name of subscription invite links.
- Added the field
until_date
to the class :class:`aiogram.types.chat_member_member.ChatMemberMember` for members with an active subscription. - Added support for paid reactions and the class :class:`aiogram.types.reaction_type_paid.ReactionTypePaid`.
- Improved performance of StatesGroup #1507
Added full support of Bot API 7.8
- Added the field
has_main_web_app
to the class :class:`aiogram.types.user.User`, which is returned in the response to :class:`aiogram.methods.get_me.GetMe`. - Added the parameter
business_connection_id
to the methods :class:`aiogram.methods.pin_chat_message.PinChatMessage` and :class:`aiogram.methods.unpin_chat_message.UnpinChatMessage`, allowing bots to manage pinned messages on behalf of a business account.
- Added the field
- Fixed URL path in the "Open" button at the "demo/sendMessage" endpoint in the web_app example. #1546
- Added method :func:`aiogram.types.message.Message.as_reply_parameters`.
Replaced usage of the argument
reply_to_message_id
withreply_parameters
in all Message reply methods. #1538 - Added aiohttp v3.10 ` support. #1548
Added full support of Bot API 7.7
- Added the class :class:`aiogram.types.refunded_payment.RefundedPayment`, containing information about a refunded payment.
- Added the field
refunded_payment
to the class :class:`aiogram.types.message.Message`, describing a service message about a refunded payment.
Added ChatMember resolution tool and updated 2.x migration guide. #1525
Added full support of Bot API 7.6
- Added the classes :class:`aiogram.types.paid_media.PaidMedia`,
- :class:`aiogram.types.paid_media_info.PaidMediaInfo`, :class:`aiogram.types.paid_media_preview.PaidMediaPreview`, :class:`aiogram.types.paid_media_photo.PaidMediaPhoto` and :class:`aiogram.types.paid_media_video.PaidMediaVideo`, containing information about paid media.
- Added the method :class:`aiogram.methods.send_paid_media.SendPaidMedia`
- and the classes :class:`aiogram.types.input_paid_media.InputPaidMedia`, :class:`aiogram.types.input_paid_media_photo.InputPaidMediaPhoto` and :class:`aiogram.types.input_paid_media_video.InputPaidMediaVideo`, to support sending paid media.
- Documented that the methods :class:`aiogram.methods.copy_message.CopyMessage`
- and :class:`aiogram.methods.copy_messages.CopyMessages` cannot be used to copy paid media.
- Added the field
can_send_paid_media
to the class - :class:`aiogram.types.chat_full_info.ChatFullInfo`.
- Added the field
- Added the field
paid_media
to the classes - :class:`aiogram.types.message.Message` and :class:`aiogram.types.external_reply_info.ExternalReplyInfo`.
- Added the field
- Added the class
- :class:`aiogram.types.transaction_partner_telegram_ads.TransactionPartnerTelegramAds`, containing information about Telegram Star transactions involving the Telegram Ads Platform.
- Added the field
invoice_payload
to the class - :class:`aiogram.types.transaction_partner_user.TransactionPartnerUser`, containing the bot-specified invoice payload.
- Added the field
- Changed the default opening mode for Direct Link Mini Apps.
- Added support for launching Web Apps via t.me link in the class
- :class:`aiogram.types.menu_button_web_app.MenuButtonWebApp`.
- Added the field
section_separator_color
to the classThemeParams
.
- Fixed event context resolving for the callback query that is coming from the business account #1520
Added utility to safely deserialize any Telegram object or method to a JSON-compatible object (dict). (:ref:`>> Read more <serialization-tool>`) #1450
Added full support of Bot API 7.5
- Added the classes :class:`aiogram.types.star_transactions.StarTransactions`,
- :class:`aiogram.types.star_transaction.StarTransaction`, :class:`aiogram.types.transaction_partner.TransactionPartner` and :class:`aiogram.types.revenue_withdrawal_state.RevenueWithdrawalState`, containing information about Telegram Star transactions involving the bot.
- Added the method :class:`aiogram.methods.get_star_transactions.GetStarTransactions`
- that can be used to get the list of all Telegram Star transactions for the bot.
- Added support for callback buttons in
- :class:`aiogram.types.inline_keyboard_markup.InlineKeyboardMarkup` for messages sent on behalf of a business account.
- Added support for callback queries originating from a message sent
- on behalf of a business account.
- Added the parameter
business_connection_id
to the methods - :class:`aiogram.methods.edit_message_text.EditMessageText`, :class:`aiogram.methods.edit_message_media.EditMessageMedia`, :class:`aiogram.methods.edit_message_caption.EditMessageCaption`, :class:`aiogram.methods.edit_message_live_location.EditMessageLiveLocation`, :class:`aiogram.methods.stop_message_live_location.StopMessageLiveLocation` and :class:`aiogram.methods.edit_message_reply_markup.EditMessageReplyMarkup`, allowing the bot to edit business messages.
- Added the parameter
- Added the parameter
business_connection_id
to the method - :class:`aiogram.methods.stop_poll.StopPoll`, allowing the bot to stop polls it sent on behalf of a business account.
- Added the parameter
- Increased DNS cache ttl setting to aiohttp session as a workaround for DNS resolution issues in aiohttp. #1500
- Fixed MongoStorage section in the documentation by adding extra dependency to ReadTheDocs configuration. #1501
- Added information about dependency changes to the
2.x --> 3.x
migration guide. #1504
[Only for contributors] Fail redis and mongo tests if incorrect URI provided + some storages tests refactoring
If incorrect URIs provided to "--redis" and/or "--mongo" options tests should fail with errors instead of skipping. Otherwise the next scenario is possible:
- developer breaks RedisStorage and/or MongoStorage code
- tests are run with incorrect redis and/or mongo URIsprovided by "--redis" and "--mongo" options (for example, wrong port specified)
- tests pass because skipping doesn't fail tests run
- developer or reviewer doesn't notice that redis and/or mongo tests were skipped
- broken code gets in codebase
Also some refactorings done (related with storages and storages tests). #1510
- Added new storage
aiogram.fsm.storage.MongoStorage
for Finite State Machine based on Mongo DB (usingmotor
library) #1434 - Added full support of Bot API 7.4 #1498
- Fixed wrong
MarkdownV2
custom emoji parsing inaiogram.utils.text_decorations
#1496
- Removed deprecated arguments from Bot class
parse_mode
,disable_web_page_preview
,protect_content
as previously announced in v3.4.0. #1494
- Improved code consistency and readability in code examples by refactoring imports, adjusting the base webhook URL, modifying bot instance initialization to utilize DefaultBotProperties, and updating router message handlers. #1482
- Added full support of Bot API 7.3 #1480
- Added telegram objects transformation block in 2.x -> 3.x migration guide #1412
Added message_thread_id parameter to ChatActionSender class methods. #1437
Added context manager interface to Bot instance, from now you can use:
async with Bot(...) as bot: ...
instead of
async with Bot(...).context() as bot: ...
- WebAppUser Class Fields: Added missing is_premium, added_to_attachment_menu, and allows_write_to_pm fields to WebAppUser class to align with the Telegram API.
- WebAppChat Class Implementation: Introduced the WebAppChat class with all its fields (id, type, title, username, and photo_url) as specified in the Telegram API, which was previously missing from the library.
- WebAppInitData Class Fields: Included previously omitted fields in the WebAppInitData class: chat, chat_type, chat_instance, to match the official documentation for a complete Telegram Web Apps support.
Fixed poll answer FSM context by handling
voter_chat
forpoll_answer
event #1436Added missing error handling to
_background_feed_update
(when inhandle_in_background=True
webhook mode) #1458
- Added WebAppChat class to WebApp docs, updated uk_UA localisation of WebApp docs. #1433
- Added full support of Bot API 7.2 #1444
- Loosened pydantic version upper restriction from
<2.7
to<2.8
#1460
- Fixed JSON serialization of the
LinkPreviewOptions
class while it is passed as bot-wide default options. #1418
Reworked bot-wide globals like
parse_mode
,disable_web_page_preview
, and others to be more flexible.Warning
Note that the old way of setting these global bot properties is now deprecated and will be removed in the next major release.
A new enum
KeyboardButtonPollTypeType
forKeyboardButtonPollTypeType.type
field has bed added. #1398Added full support of Bot API 7.1
- Added support for the administrator rights
can_post_stories
,can_edit_stories
,can_delete_stories
in supergroups. - Added the class
ChatBoostAdded
and the fieldboost_added
to the classMessage
for service messages about a user boosting a chat. - Added the field
sender_boost_count
to the classMessage
. - Added the field
reply_to_story
to the classMessage
. - Added the fields
chat
andid
to the classStory
. - Added the field
unrestrict_boost_count
to the classChat
. - Added the field
custom_emoji_sticker_set_name
to the classChat
.
- Added support for the administrator rights
- Update KeyboardBuilder utility, fixed type-hints for button method, adjusted limits of the different markup types to real world values. #1399
- Added new
reply_parameters
param tomessage.send_copy
because it hasn't been added there #1403
- Add notion "Working with plural forms" in documentation Utils -> Translation #1395
Added full support of Bot API 7.0
- Reactions
- Replies 2.0
- Link Preview Customization
- Block Quotation
- Multiple Message Actions
- Requests for multiple users
- Chat Boosts
- Giveaway
- Other changes
- Introduced Scenes feature that helps you to simplify user interactions using Finite State Machine. Read more about 👉 :ref:`Scenes <Scenes>`. #1280
- Added the new FSM strategy
CHAT_TOPIC
, which sets the state for the entire topic in the chat, also works in private messages and regular groups without topics. #1343
- Fixed
parse_mode
argument in the inMessage.send_copy
shortcut. Disable by default. #1332 - Added ability to get handler flags from filters. #1360
- Fixed a situation where a
CallbackData
could not be parsed without a default value. #1368
- Corrected grammatical errors, improved sentence structures, translation for migration 2.x-3.x #1302
- Minor typo correction, specifically in module naming + some grammar. #1340
- Added CITATION.cff file for automatic academic citation generation. Now you can copy citation from the GitHub page and paste it into your paper. #1351
- Minor typo correction in middleware docs. #1353
Fixed ResourceWarning in the tests, reworked
RedisEventsIsolation
fixture to use Redis connection fromRedisStorage
#1320Updated dependencies, bumped minimum required version:
magic-filter
- fixed .resolve operationpydantic
- fixed compatibility (broken in 2.4)aiodns
- added new dependency to thefast
extras (pip install aiogram[fast]
)- others...
Prevent update handling task pointers from being garbage collected, backport from 2.x #1331
Updated
typing-extensions
package version range in dependencies to fix compatibility withFastAPI
#1347Introduce Python 3.12 support #1354
Speeded up CallableMixin processing by caching references to nested objects and simplifying kwargs assembly. #1357
Added
pydantic
v2.5 support. #1361Updated
thumbnail
fields type toInputFile
only #1372
- Fixed pydantic version <2.4, since 2.4 has breaking changes. #1322
- Added support for custom encoders/decoders for payload (and also for deep-linking). #1262
- Added :class:`aiogram.utils.input_media.MediaGroupBuilder` for media group construction. #1293
- Added full support of Bot API 6.9 #1319
- Added actual param hints for InlineKeyboardBuilder and ReplyKeyboardBuilder. #1303
- Fixed priority of events isolation, now user state will be loaded only after lock is acquired #1317
- Replaced
datetime.datetime
with DateTime type wrapper across types to make dumped JSONs object more compatible with data that is sent by Telegram. #1277 - Fixed magic
.as_(...)
operation for values that can be interpreted as False (e.g. 0). #1281 - Italic markdown from utils now uses correct decorators #1282
- Fixed method
Message.send_copy
for stickers. #1284 - Fixed
Message.send_copy
method, which was not working properly with stories, so not you can copy stories too (forwards messages). #1286 - Fixed error overlapping when validation error is caused by remove_unset root validator in base types and methods. #1290
- Fixed missing message content types (
ContentType.USER_SHARED
,ContentType.CHAT_SHARED
) #1252 - Fixed nested hashtag, cashtag and email message entities not being parsed correctly when these entities are inside another entity. #1259
- Moved global filters check placement into router to add chance to pass context from global filters into handlers in the same way as it possible in other places #1266
- Added error handling example examples/error_handling.py #1099
- Added a few words about skipping pending updates #1251
- Added a section on Dependency Injection technology #1253
- This update includes the addition of a multi-file bot example to the repository. #1254
- Refactored examples code to use aiogram enumerations and enhanced chat messages with markdown beautification's for a more user-friendly display. #1256
- Supplemented "Finite State Machine" section in Migration FAQ #1264
- Removed extra param in docstring of TelegramEventObserver's filter method and fixed typo in I18n documentation. #1268
- Enhanced the warning message in dispatcher to include a JSON dump of the update when update type is not known. #1269
- Added support for Bot API 6.8 #1275
Added Currency enum. You can use it like this:
from aiogram.enums import Currency await bot.send_invoice( ..., currency=Currency.USD, ... )
Updated keyboard builders with new methods for integrating buttons and keyboard creation more seamlessly. Added functionality to create buttons from existing markup and attach another builder. This improvement aims to make the keyboard building process more user-friendly and flexible. #1236
Added support for message_thread_id in ChatActionSender #1249
Fixed polling startup when "bot" key is passed manually into dispatcher workflow data #1242
Added codegen configuration for lost shortcuts:
- ShippingQuery.answer
- PreCheckoutQuery.answer
- Message.delete_reply_markup
- Added documentation for webhook and polling modes. #1241
- Reworked InputFile reading, removed
__aiter__
method, added bot: Bot argument to the.read(...)
method, so, from now URLInputFile can be used without specifying bot instance. #1238 - Code-generated
__init__
typehints in types and methods to make IDE happy without additional pydantic plugin #1245
- Added new shortcuts for :class:`aiogram.types.chat_member_updated.ChatMemberUpdated` to send message to chat that member joined/left. #1234
- Added new shortcuts for :class:`aiogram.types.chat_join_request.ChatJoinRequest` to make easier access to sending messages to users who wants to join to chat. #1235
- Fixed bot assignment in the
Message.send_copy
shortcut #1232 - Added model validation to remove UNSET before field validation. This change was necessary to correctly handle parse_mode where 'UNSET' is used as a sentinel value. Without the removal of 'UNSET', it would create issues when passed to model initialization from Bot.method_name. 'UNSET' was also added to typing. #1233
- Updated pydantic to 2.1 with few bugfixes
- Improved docs, added basic migration guide (will be expanded later) #1143
- Removed the use of the context instance (Bot.get_current) from all placements that were used previously. This is to avoid the use of the context instance in the wrong place. #1230
Added possibility to use custom events in routers (If router does not support custom event it does not break and passes it to included routers). #1147
Added support for FSM in Forum topics.
The strategy can be changed in dispatcher:
from aiogram.fsm.strategy import FSMStrategy ... dispatcher = Dispatcher( fsm_strategy=FSMStrategy.USER_IN_TOPIC, storage=..., # Any persistent storage )
Note
If you have implemented you own storages you should extend record key generation with new one attribute -
thread_id
Improved CallbackData serialization.
- Minimized UUID (hex without dashes)
- Replaced bool values with int (true=1, false=0)
Added a tool to make text formatting flexible and easy. More details on the :ref:`corresponding documentation page <formatting-tool>` #1172
Added
X-Telegram-Bot-Api-Secret-Token
header check #1173Made
allowed_updates
list to revolve automatically in start_polling method if not set explicitly. #1178Added possibility to pass custom headers to :class:`URLInputFile` object #1191
Change type of result in InlineQueryResult enum for
InlineQueryResultCachedMpeg4Gif
andInlineQueryResultMpeg4Gif
to more correct according to documentation.Change regexp for entities parsing to more correct (
InlineQueryResultType.yml
). #1146Fixed signature of startup/shutdown events to include the
**dispatcher.workflow_data
as the handler arguments. #1155Added missing
FORUM_TOPIC_EDITED
value to content_type property #1160Fixed compatibility with Python 3.8-3.9 (from previous release) #1162
Fixed the markdown spoiler parser. #1176
Fixed workflow data propagation #1196
Fixed the serialization error associated with nested subtypes like InputMedia, ChatMember, etc.
The previously generated code resulted in an invalid schema under pydantic v2, which has stricter type parsing. Hence, subtypes without the specification of all subtype unions were generating an empty object. This has been rectified now. #1213
- Changed small grammar typos for
upload_file
#1133
Removed text filter in due to is planned to remove this filter few versions ago.
Use
F.text
instead #1170
Added full support of Bot API 6.6
!DANGER!
Note that this issue has breaking changes described in the Bot API changelog, this changes is not breaking in the API but breaking inside aiogram because Beta stage is not finished.
Added full support of Bot API 6.7
Warning
Note that arguments switch_pm_parameter and switch_pm_text was deprecated and should be changed to button argument as described in API docs.
Updated Pydantic to V2
Warning
Be careful, not all libraries is already updated to using V2
Added global defaults
disable_web_page_preview
andprotect_content
in addition toparse_mode
to the Bot instance, reworked internal request builder mechanism. #1142Removed bot parameters from storages #1144
Replaced ContextVar's with a new feature called Validation Context in Pydantic to improve the clarity, usability, and versatility of handling the Bot instance within method shortcuts.
!DANGER!
Breaking: The 'bot' argument now is required in URLInputFile
Updated magic-filter with new features
- Added hint for
len(F)
error - Added not in operation
- Added hint for
Warning
Note that this version has incompatibility with Python 3.8-3.9 in case when you create an instance of Dispatcher outside of the any coroutine.
Sorry for the inconvenience, it will be fixed in the next version.
This code will not work:
dp = Dispatcher()
def main():
...
dp.run_polling(...)
main()
But if you change it like this it should works as well:
router = Router()
async def main():
dp = Dispatcher()
dp.include_router(router)
...
dp.start_polling(...)
asyncio.run(main())
Added missing shortcuts, new enums, reworked old stuff
Breaking All previously added enums is re-generated in new place - aiogram.enums instead of aiogram.types
- Added enums: :class:`aiogram.enums.bot_command_scope_type.BotCommandScopeType`,
:class:`aiogram.enums.chat_action.ChatAction`, :class:`aiogram.enums.chat_member_status.ChatMemberStatus`, :class:`aiogram.enums.chat_type.ChatType`, :class:`aiogram.enums.content_type.ContentType`, :class:`aiogram.enums.dice_emoji.DiceEmoji`, :class:`aiogram.enums.inline_query_result_type.InlineQueryResultType`, :class:`aiogram.enums.input_media_type.InputMediaType`, :class:`aiogram.enums.mask_position_point.MaskPositionPoint`, :class:`aiogram.enums.menu_button_type.MenuButtonType`, :class:`aiogram.enums.message_entity_type.MessageEntityType`, :class:`aiogram.enums.parse_mode.ParseMode`, :class:`aiogram.enums.poll_type.PollType`, :class:`aiogram.enums.sticker_type.StickerType`, :class:`aiogram.enums.topic_icon_color.TopicIconColor`, :class:`aiogram.enums.update_type.UpdateType`,
Added shortcuts:
- Chat :meth:`aiogram.types.chat.Chat.get_administrators`,
- :meth:`aiogram.types.chat.Chat.delete_message`, :meth:`aiogram.types.chat.Chat.revoke_invite_link`, :meth:`aiogram.types.chat.Chat.edit_invite_link`, :meth:`aiogram.types.chat.Chat.create_invite_link`, :meth:`aiogram.types.chat.Chat.export_invite_link`, :meth:`aiogram.types.chat.Chat.do`, :meth:`aiogram.types.chat.Chat.delete_sticker_set`, :meth:`aiogram.types.chat.Chat.set_sticker_set`, :meth:`aiogram.types.chat.Chat.get_member`, :meth:`aiogram.types.chat.Chat.get_member_count`, :meth:`aiogram.types.chat.Chat.leave`, :meth:`aiogram.types.chat.Chat.unpin_all_messages`, :meth:`aiogram.types.chat.Chat.unpin_message`, :meth:`aiogram.types.chat.Chat.pin_message`, :meth:`aiogram.types.chat.Chat.set_administrator_custom_title`, :meth:`aiogram.types.chat.Chat.set_permissions`, :meth:`aiogram.types.chat.Chat.promote`, :meth:`aiogram.types.chat.Chat.restrict`, :meth:`aiogram.types.chat.Chat.unban`, :meth:`aiogram.types.chat.Chat.ban`, :meth:`aiogram.types.chat.Chat.set_description`, :meth:`aiogram.types.chat.Chat.set_title`, :meth:`aiogram.types.chat.Chat.delete_photo`, :meth:`aiogram.types.chat.Chat.set_photo`,
- User: :meth:`aiogram.types.user.User.get_profile_photos`
Added :ref:`callback answer <callback-answer-util>` feature #1091
Added a method that allows you to compactly register routers #1117
- Check status code when downloading file #816
- Fixed ignore_case parameter in :obj:`aiogram.filters.command.Command` filter #1106
Added integration with new code-generator named Butcher #1069
Added full support of Bot API 6.4 #1088
Updated package metadata, moved build internals from Poetry to Hatch, added contributing guides. #1095
Added full support of Bot API 6.5
!DANGER!
Note that :obj:`aiogram.types.chat_permissions.ChatPermissions` is updated without backward compatibility, so now this object has no
can_send_media_messages
attributeReplaced error
TypeError: TelegramEventObserver.__call__() got an unexpected keyword argument '<name>'
with a more understandable one for developers and with a link to the documentation. #1114Added possibility to reply into webhook with files #1120
Reworked graceful shutdown. Added method to stop polling. Now polling started from dispatcher can be stopped by signals gracefully without errors (on Linux and Mac). #1124
(again) Added possibility to combine filters with an and/or operations.
Read more in ":ref:`Combining filters <combining-filters>`" documentation section #1018
Added following methods to
Message
class:Message.forward(...)
Message.edit_media(...)
Message.edit_live_location(...)
Message.stop_live_location(...)
Message.pin(...)
Message.unpin()
Added following methods to
User
class:User.mention_markdown(...)
User.mention_html(...)
Added full support of Bot API 6.3 #1057
Fixed
Message.send_invoice
andMessage.reply_invoice
, added missing arguments #1047Fixed copy and forward in:
Message.answer(...)
Message.copy_to(...)
- Fixed UA translations in index.po #1017
- Fix typehints for
Message
,reply_media_group
andanswer_media_group
methods #1029 - Removed an old now non-working feature #1060
- Enabled testing on Python 3.11 #1044
- Added a mandatory dependency
certifi
in due to in some cases on systems that doesn't have updated ca-certificates the requests to Bot API fails with reason[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: self signed certificate in certificate chain
#1066
- Add PyPy support and run tests under PyPy #985
- Added message text to aiogram exceptions representation #988
- Added warning about using magic filter from magic_filter instead of aiogram's ones. Is recommended to use from aiogram import F instead of from magic_filter import F #990
- Added more detailed error when server response can't be deserialized. This feature will help to debug unexpected responses from the Server #1014
- Reworked error event, introduced :class:`aiogram.types.error_event.ErrorEvent` object. #898
- Fixed escaping markdown in aiogram.utils.markdown module #903
- Fixed polling crash when Telegram Bot API raises HTTP 429 status-code. #995
- Fixed empty mention in command parsing, now it will be None instead of an empty string #1013
- Initialized Docs translation (added Ukrainian language) #925
- Removed filters factory as described in corresponding issue. #942
- Now Router/Dispatcher accepts only keyword arguments. #982
Add class helper ChatAction for constants that Telegram BotAPI uses in sendChatAction request. In my opinion, this will help users and will also improve compatibility with 2.x version where similar class was called "ChatActions". #803
Added possibility to combine filters or invert result
Example:
Text(text="demo") | Command(commands=["demo"]) MyFilter() & AnotherFilter() ~StateFilter(state='my-state')
Fixed type hints for redis TTL params. #922
Added full_name shortcut for Chat object #929
Fixed false-positive coercing of Union types in API methods #901
Added 3 missing content types:
- proximity_alert_triggered
- supergroup_chat_created
- channel_chat_created
Fixed the ability to compare the state, now comparison to copy of the state will return True. #927
Fixed default lock kwargs in RedisEventIsolation. #972
Restrict including routers with strings #896
Changed CommandPatterType to CommandPatternType in aiogram/dispatcher/filters/command.py #907
Added full support of Bot API 6.1 #936
Breaking! More flat project structure
These packages was moved, imports in your code should be fixed:
aiogram.dispatcher.filters
->aiogram.filters
aiogram.dispatcher.fsm
->aiogram.fsm
aiogram.dispatcher.handler
->aiogram.handler
aiogram.dispatcher.webhook
->aiogram.webhook
aiogram.dispatcher.flags/*
->aiogram.dispatcher.flags
(single module instead of package)
Removed deprecated
router.<event>_handler
androuter.register_<event>_handler
methods. #941Deprecated filters factory. It will be removed in next Beta (3.0b5) #942
MessageEntity method get_text was removed and extract was renamed to extract_from #944
Added full support of Bot API 6.2 #975
- Added possibility to get command magic result as handler argument #889
- Added full support of Telegram Bot API 6.0 #890
- Fixed I18n lazy-proxy. Disabled caching. #839
- Added parsing of spoiler message entity #865
- Fixed default parse_mode for Message.copy_to() method. #876
- Fixed CallbackData factory parsing IntEnum's #885
- Added automated check that pull-request adds a changes description to CHANGES directory #873
- Changed
Message.html_text
andMessage.md_text
attributes behaviour when message has no text. The empty string will be used instead of raising error. #874 - Used redis-py instead of aioredis package in due to this packages was merged into single one #882
- Solved common naming problem with middlewares that confusing too much developers - now you can't see the middleware and middlewares attributes at the same point because this functionality encapsulated to special interface. #883
Added possibility to pass additional arguments into the aiohttp webhook handler to use this arguments inside handlers as the same as it possible in polling mode. #785
Added possibility to add handler flags via decorator (like pytest.mark decorator but aiogram.flags) #836
Added
ChatActionSender
utility to automatically sends chat action while long process is running.It also can be used as message middleware and can be customized via
chat_action
flag. #837
- Logger name for processing events is changed to
aiogram.events
. #830 - Added full support of Telegram Bot API 5.6 and 5.7 #835
- BREAKING Events isolation mechanism is moved from FSM storages to standalone managers #838
Added new custom operation for MagicFilter named
as_
Now you can use it to get magic filter result as handler argument
from aiogram import F ... @router.message(F.text.regexp(r"^(\d+)$").as_("digits")) async def any_digits_handler(message: Message, digits: Match[str]): await message.answer(html.quote(str(digits))) @router.message(F.photo[-1].as_("photo")) async def download_photos_handler(message: Message, photo: PhotoSize, bot: Bot): content = await bot.download(photo)
- Fixed: Missing
ChatMemberHandler
import inaiogram/dispatcher/handler
#751
- Check
destiny
in case of nowith_destiny
enabled in RedisStorage key builder #776 - Added full support of Bot API 5.5 #777
- Stop using feature from #336. From now settings of client-session should be placed as initializer arguments instead of changing instance attributes. #778
- Make TelegramAPIServer files wrapper in local mode bi-directional (server-client, client-server) Now you can convert local path to server path and server path to local path. #779
Breaking: Changed the signature of the session middlewares Breaking: Renamed AiohttpSession.make_request method parameter from call to method to match the naming in the base class Added middleware for logging outgoing requests #716
Improved description of filters resolving error. For example when you try to pass wrong type of argument to the filter but don't know why filter is not resolved now you can get error like this:
aiogram.exceptions.FiltersResolveError: Unknown keyword filters: {'content_types'} Possible cases: - 1 validation error for ContentTypesFilter content_types Invalid content types {'42'} is not allowed here (type=value_error)
Breaking internal API change Reworked FSM Storage record keys propagation #723
Implemented new filter named
MagicData(magic_data)
that helps to filter event by data from middlewares or other filtersFor example your bot is running with argument named
config
that contains the application config then you can filter event by value from this config:@router.message(magic_data=F.event.from_user.id == F.config.admin_id) ...
- Fixed I18n context inside error handlers #726
- Fixed bot session closing before emit shutdown #734
- Fixed: bound filter resolving does not require children routers #736
Enabled testing on Python 3.10 Removed async_lru dependency (is incompatible with Python 3.10) and replaced usage with protected property #719
Converted README.md to README.rst and use it as base file for docs #725
Rework filters resolving:
- Automatically apply Bound Filters with default values to handlers
- Fix data transfer from parent to included routers filters
Added full support of Bot API 5.4 https://core.telegram.org/bots/api-changelog#november-5-2021 #744
- Added
html_text
andmd_text
to Message object #708 - Refactored I18n, added context managers for I18n engine and current locale #709
Added support of local Bot API server files downloading
When Local API is enabled files can be downloaded via bot.download/bot.download_file methods. #698
Implemented I18n & L10n support #701
Covered by tests and docs KeyboardBuilder util #699
Breaking!!!. Refactored and renamed exceptions.
- Exceptions module was moved from
aiogram.utils.exceptions
toaiogram.exceptions
- Added prefix Telegram for all error classes
- Exceptions module was moved from
Replaced all
pragma: no cover
marks via global.coveragerc
config #702Updated dependencies.
Breaking for framework developers Now all optional dependencies should be installed as extra: poetry install -E fast -E redis -E proxy -E i18n -E docs #703
- Ability to iterate over all states in StatesGroup. Aiogram already had in check for states group so this is relative feature. #666
- Fixed incorrect type checking in the :class:`aiogram.utils.keyboard.KeyboardBuilder` #674
- Disable ContentType filter by default #668
- Moved update type detection from Dispatcher to Update object #669
- Updated pre-commit config #681
- Reworked handlers_in_use util. Function moved to Router as method .resolve_used_update_types() #682
- add aliases for edit/delete reply markup to Message #662
- Reworked outer middleware chain. Prevent to call many times the outer middleware for each nested router #664
- Prepare parse mode for InputMessageContent in AnswerInlineQuery method #660
- Added integration with
towncrier
#602