mirror of
https://github.com/teloxide/teloxide.git
synced 2025-01-24 09:16:12 +01:00
5.3 KiB
5.3 KiB
Changelog
All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
[unreleased]
Added
- Allow arbitrary error types to be returned from (sub)transitions (issue 242).
- The
respond
function, a shortcut forResponseResult::Ok(())
.
Changed
- Allow
bot_name
beN
, whereN: Into<String> + ...
incommands_repl
&commands_repl_with_listener
. - 'Edit methods' (namely
edit_message_live_location
,stop_message_live_location
,edit_message_text
,edit_message_caption
,edit_message_media
andedit_message_reply_markup
) are split into common and inline versions (e.g.:edit_message_text
andedit_inline_message_text
). Instead ofChatOrInlineMessage
common versions acceptchat_id: impl Into<ChatId>
andmessage_id: i32
whereas inline versions acceptinline_message_id: impl Into<String>
. Also note that return type of inline versions isTrue
(issue 253, pr 257) ChatOrInlineMessage
is renamed toTargetMessage
, it's::Chat
variant is renamed to::Common
,#[non_exhaustive]
annotation is removed from the enum, type ofTargetMessage::Inline::inline_message_id
changedi32
=>String
.TargetMessage
now implementsFrom<String>
,get_game_high_scores
andset_game_score
useInto<TargetMessage>
to acceptString
s. (issue 253, pr 257)
[0.3.0] - 2020-07-31
Added
- Support for typed bot commands (issue 152).
BotBuilder
, which allows setting a defaultParseMode
.- The
Transition
,Subtransition
,SubtransitionOutputType
traits. - A nicer approach to manage dialogues via
#[derive(Transition)]
+#[teloxide(subtransition)]
(seeexamples/dialogue_bot
). - The
redis-storage
feature -- enables the Redis support. - The
cbor-serializer
feature -- enables theCBOR
serializer for dialogues. - The
bincode-serializer
feature -- enables theBincode
serializer for dialogues. - The
frunk
feature -- enablesteloxide::utils::UpState
, which allows mapping from a structure offield1, ..., fieldN
to a structure offield1, ..., fieldN, fieldN+1
. - Upgrade to v4.9 Telegram bots API.
teloxide::utils::client_from_env
-- constructs a client from theTELOXIDE_TOKEN
environmental variable.- Import
Transition
,TransitionIn
,TransitionOut
,UpState
toteloxide::prelude
. - Import
repl
,commands_repl
toteloxide
. - Let users inspect an unknown API error using
ApiErrorKind::Unknown(String)
. All the known API errors are placed intoKnownApiErrorKind
. - Setters to all the API types.
teloxide::dispatching::dialogue::serializer
-- various serializers for memory storages. TheSerializer
trait,Bincode
,CBOR
,JSON
.teloxide::{repl, repl_with_listener, commands_repl, commands_repl_with_listener, dialogues_repl, dialogues_repl_with_listener}
InputFile::Memory
- Option to hide a command from description (issue 217).
- Respect the
TELOXIDE_PROXY
environment variable inBot::from_env
.
Deprecated
Bot::{from_env_with_client, new, with_client}
Changed
DialogueDispatcherHandlerCx
->DialogueWithCx
.DispatcherHandlerCx
->UpdateWithCx
.- Now provided description of unknown telegram error, by splitting ApiErrorKind at
ApiErrorKind
andApiErrorKindKnown
enums (issue 199). - Extract
Bot
fromArc
(issue 216). - Mark all the API types as
#[non_exhaustive]
. - Replace all
mime_type: String
withMimeWrapper
.
Fixed
- Now methods which can send file to Telegram returns
tokio::io::Result<T>
. Early its could panic (issue 216). - If a bot wasn't triggered for several days, it stops responding (issue 223).
[0.2.0] - 2020-02-25
Added
- The functionality to parse commands only with a correct bot's name (breaks backwards compatibility) (Issue 168).
- This
CHANGELOG.md
.
Fixed
- Fix parsing a pinned message (Issue 167).
- Replace
LanguageCode
withString
, because the official Telegram documentation doesn't specify a concrete version of IETF language tag. - Problems with the
poll_type
field (Issue 178). - Make
polling_default
actually a long polling update listener (PR 182).
Removed
- either from the dependencies in
Cargo.toml
. teloxide-macros
migrated into the separate repository to easier releases and testing.
[0.1.0] - 2020-02-19
Added
- This project.