Webhook
now accepts ashouldSetWebhook
flag which indicates whether thesetWebhook
call to be made implicitly or not.- Made the
url
property optional in Webhook. - Minor tweaks
- 🤖 Bot API 7.6
- Added methods to register callbacks for handling paid media in bot messages:
Bot.onPaidMedia
: Registers a callback for whenever any type of paid media is received in messages.Bot.onPaidMediaVideo
: Registers a callback for whenever paid media videos are received in messages.Bot.onPaidMediaPhoto
: Registers a callback for whenever paid media photos are received in messages.
- New method
RawAPI.sendPaidMedia
is added to send paid media.
- 🥳 Support for Custom Context
- Added detailed usage documentation for custom context here.
- The custom context feature allows you to extend the base functionality of your bot by using your own custom context classes.
- Added
Bot.contextBuilder
method - Refactors across the library to cope with
<CTX extends Context>
- Refactored
Bot
,Handler
,Fetcher
,Menu
,BotError
,Conversation
etc.
- Refactored
- Fixed an issue in
KeyboardMenu
that caused some features not to work. - Added documentation on almost all new classes and typedefs.
- 🧑🏻🔧 Fix in
InlineQueryResultBuilder
methodsvoice
andvideo
. - Improved
Webhook
implementation. Works perfect now! - Added example for building bot with
Webhook
fetcher in Examples Repo - Added detailed documentation for
InlineQueryResultBuilder
andWebhook
classes.
- Minor README fix
- Fixes in documentation comments
- Changed return type of the
Transformer.transform
fromFutureOr<Map<String, dynamic>>
toFuture<Map<String, dynamic>>
because it'll always have to return a Future. - Minor type adjustment on the
typedef PayloadFiles
. - ✨ Two new plugins are released for Televerse: auto_chat_action and parse_mode_setter
⚠️ Changed theTransformer.transform
method definition.- Improved the
Transformer
class - Added new class
Payload
to accept payload to the API calls - Added typedef
APICaller
for the method which actually invokes the API endpoinds.
- 🆕 Support for Middlewares & Transformers
- Middlewares lets you attach handlers that are run before your main handler is executed.
- Added
Middleware
class to create a middleware. - Added
Transformer
class to create a transformer. - A Transformer can be attached to the
RawAPI
which then can alter the request payload. - Added
use
method onBot
,Context
andRawAPI
to attach middlewares. - Added default error handler method. Now, bot will crash with a pretty message.
- Added
Context.middlewareStorage
as aMap<String, dynamic>
to store any output from middleware functions. - ✍️
Bot.onStop
method can now be asynchronous. #257 (Thanks to @devsdocs) ⚠️ Type ofWebhook.certificate
is changed to InputFile as described by the official documentation.- Added examples for Middleware and Transformer usage in Examples repo.
- [Retracted]
- 🤖 Bot API 7.5
- Improved context aware methods
- Added
WithID
abstraction
- Added
considerCaption
parameter inBot.command
mehtod to match commands in the caption of video/photo messages. - 🐞 Fixed: JSON parsing bug in
UsersShared
causing theusers
field to be null and resulting in crashes.
‼️ Strict typing forctx.editMessageMedia
andctx.editMessageReplyMarkup
- Fix:
ChatID
constuctor accepteddynamic
- 🤖 Bot API 7.4 (May 28, 2024)
- Refactors and formatting improvements
- 🤖 Bot API 7.3 (May 6, 2024)
- Added
Keyboard.remove
method to remove Keyboard. - Refactors and improvements
- Removed unnecessary print in the callback setter.
- Fixed
BotLink
link generation.
- Removed usage of
dart:mirrors
- Updated README
- Fix: Forked Handlers caused crash.
- Minor fix in update processing
- Added
businessConnectionId
to Context aware methods.
- Added
Bot.fromAPI
constructor for creating Bot instance fromRawAPI
instance. Bot.command
,Bot.text
,Bot.hears
, and many more methods now listens to all Message types (Message, Channel Posts, and edited messages of both)⚠️ AddedchatId
parameter toBot.shippingQuery
andBot.preCheckoutQuery
.- Refactored code for quality and better readability and added docs.
- Added
ScopeOptions
class that can contain additional info for handler scope. ScopeOptions.forked
to create forked handlers. Forked handlers are run without conditions.ScopeOptions.customPredicate
can be used to set a middleware to check if the update should be processed or skipped.- Migrated to
Dart 3.0.0
Bot.removeScope
can be used to remove already set handlers.- Accepts
ScopeOption
on both menus as well.
- Improved efficiency by removing redundant
getMe
calls while registeringcommand
handlers andwhenMentioned
handlers. - Made
LongPolling.allowedUpdates
nullable, and removed the constant empty list initialization. - Updated the README.
- Introducing
TGException
enum which is a collection of different possible Telegram exceptions binded with their reasons and possible solutions. - Added
LoggerOptions.only
method to turn on logging for ONLY specified actions. - Prints resposne data if any on exception with Logger.
- Prints
StackTrace
along with uncaughtTelegramException
errors.
Context.args
will no longer return null.⚠️ UpdatedRawAPI
constructor- Updated DartDoc comments for the
Bot.command
method. - Added new methods to
Keyboard
for simplicity.
- Added missing methods in the
InlineKeyboard
- Completes the helper class
MessageContentGenerator
for ease of use to createInputMessageContent
. - All types of InputMessageContent can be now generated with the new
MessageContentGenerator
methodstext
,location
,venue
,contact
andinvoice
. - Updated README, and added an example for handling inline queries.
- 🆕
InlineQueryResultBuilder
utility class is added - The
InlineQueryResultBuilder
can be used to build Inline Query Results in a better and easier way. - Made
callback_data
required forInlineMenu.text
- 👨🏻🔧 Fix
createNewStickerSet
(Thanks to @defuera for pointing out the issue.) - Removed unnecessary JSON encodings
- Improved
LoggerOptions
and logging the requests and responses. - Refactors around
ForceReply
,ChatMember
, etc.
- Fix
InputSticker
conversion to json 🤦 (thx @defuera)
- Add missing field
InputStickerFormat
toInputSticker
class. (Thanks to @defuera) - Generic typing removed for
HandlerScope
(This doesn't affect anything on the public API)
- Fix an issue with the
RawAPI.banChatMember
(Thanks to @Sominemo for #223)
- 🤖 Bot API 7.2!
- All changes from the Bot API 7.2 is added to this release.
- Added the methods
Bot.onBusinessConnection
,Bot.onBusinessMessage
,Bot.onBusinessMessageEdited
,Bot.onBusinessMessageDeleted
to handle business messages and connection related updates. - Added
Context.businessConnection
,Context.businessMessage
,Context.editedBusinessMessage
,Context.businessMessageDelete
getters to get the business connection, business message, edited business message, and business message delete updates respectively.
- 🆕 Whole new version of
TeleverseMenu
- Both
InlineMenu
andKeyboardMenu
are now can be used to create menus with all available button types. ‼️ BREAKING: Removed theSession
,SessionManager
, and all Televerse Session related methods and properties.- Refactored the Unix Time to DateTime conversion.
- Added a new property
timeout
toBot
andRawAPI
classes to set the timeout for the API requests. - The timeout does not affect the long polling (getUpdates) requests.
- Added
TeleverseExceptionType
to categorize the exceptions that can be thrown from the Televerse library. - The
TeleverseException
class now has atype
property to represent the type of the exception. - Added
RawAPI.closeClient
method to close the HTTP client. - Removed the
HttpClient
export.
- Fix #212 -
setChatMenuButton
requiredID
instance where it should be optional. - Thanks to @Sominemo for raising this issue.
- 🤖 Bot API 7.1 is here.
- Refer to official changelog here.
- Improved the
Conversation
API to make it easier and more efficient to use. - Added the parameter
clearUnfulfilled
(true by default) to allwaitFor
methods in Conversation which will clear the unfulfilled Conversation listeners when new one is attached. - Added
Conversation.clear
andConversation.clearAll
methods to clear attached listeners. - All conversation method now return nullable
Context
object, this is because when clearing the unfulfilled listeners, the method will returnnull
. - Added
ConversationException
class to represent the exceptions that can be thrown from theConversation
class. For now, the only exception that can possibly be thrown is the Timeout Exception.
- All Televerse listeners are now based on the single
Context
class. - Removed all the different
Context
subclasses, such asMessageContext
,InlineQueryContext
,CallbackQueryContext
etc. - Added context-aware methods for almost all the methods in the
RawAPI
class. Conversation.waitFor
methods no longer accepts generic type. All the methods return theContext
class.
- Now Televerse uses
APIMethod
instead of hard coded strings to call API endpoints. - Cleared missing
APIMethod
implementations and typos. - Cleaned up the code.
- Updated Example File
- Added
ID
parameter totoJson
of manyInlineQueryResult
classes.
- Implemented
MessageOrigin.fromJson
which was part of the Bot API 7.0
- Made almost all models to have const constructors
Bot.inlineQuery
method is updated to acceptPattern query
to listen to inline queries that match the passed pattern. It had an unintended behavior before.- Updated
toString
onInlineQueryResultType
enum for it to work withRawAPI.answerInlineQuery
- Fixed an issue with the
InlineKeyboardButton
class that caused a crash whenwebAppInfo
parameter is set. (#190)
- Bot API 7.0 (December 29, 2023)
- New Context objects,
MessageReactionContext
&MessageReactionCountUpdatedContext
to representmessage_reaction
andmessage_reaction_count
updates respectively. - Added
Televerse.onMessageReaction
andTeleverse.onMessageReactionCount
methods to listen tomessage_reaction
andmessage_reaction_count
updates respectively. - 🆕 Added methods
MessageContext.react
andMessageContext.reactMultiple
to react to a message. - 🆕 Added
Televerse.whenReacted
method to listen to particular reactions on a message.
⚠️ BREAKING: Replaced all usages ofreplyToMessageId
andallowSendingWithoutReply
parameters withreplyParameters
of TypeReplyParameters
.⚠️ Affected methods onRawAPI
:copyMessage
,sendMessage
,sendPhoto
,sendVideo
,sendAnimation
,sendAudio
,sendDocument
,sendSticker
,sendVideoNote
,sendVoice
,sendLocation
,sendVenue
,sendContact
,sendPoll
,sendDice
,sendInvoice
,sendGame
, andsendMediaGroup
.⚠️ Affected methods onMessageContext
:reply
,replyWithPhoto
,replyWithAudio
,replyWithDocument
,replyWithVideo
,replyWithVideoNote
,replyWithVoice
,replyWithMediaGroup
,replyWithLocation
,replyWithVenue
,replyWithContact
,replyWithPoll
,replyWithDice
,replyWithGame
,replyWithAnimation
,replyWithSticker
.
⚠️ BREAKING: Replaced the parameterdisableWebPagePreview
withlinkPreviewOptions
in the methodsRawAPI.sendMessage
andRawAPI.editMessageText
.⚠️ Affected methods on Televerse:ChatJoinRequestContext.replyToUser
,ChatMemberUpdatedContext.replyToUser
,CallbackQueryContext.editMessage
,MessageContext.reply
, andMessageContext.editMessageText
.⚠️ BREAKING:InputTextMessageContent.disableWebPagePreview
is now renamed toInputTextMessageContent.linkPreviewOptions
and the type is changed toLinkPreviewOptions
.
- Added
deleteMessages
,forwardMessages
, andcopyMessages
⚠️ BREAKING:KeyboardButton.requestUser
is now renamed asKeyboardButton.requestUsers
and the type is changed toKeyboardButtonRequestUsers
.- Renamed the class KeyboardButtonRequestUser to KeyboardButtonRequestUsers and added the field max_quantity to it.
- Renamed the field
request_user
in the class KeyboardButton torequest_users
. - Added the class
UsersShared
. - Replaced the field
user_shared
in the class Message with the fieldusers_shared
.
- 🆕 New methods to listen the
ChatBoostUpdated
andChatBoostRemoved
updates, respectivelyTeleverse.onChatBoosted
,Televerse.onChatBoostRemoved
are added. - 🆕 New context objects
ChatBoostUpdatedContext
andChatBoostRemovedContext
are added.
- Updated
Chat
model to reflect the changes in the API. ⚠️ BREAKING: Added the classMessageOrigin
and replaced the fieldsforward_from
,forward_from_chat
,forward_from_message_id
,forward_signature
,forward_sender_name
, andforward_date
with the fieldforwardOrigin
of typeMessageOrigin
in the classMessage
.⚠️ BREAKING:CallbackQuery.message
is now of the typeMaybeInaccessibleMessage
instead ofMessage
.
- Made the parameters inside
OrderInfo
class nullable as per the documentation. - Thanks to @Defuera for the contribution.
- Refactored the code to make it easier to maintain.
- Added
lints
as a dev dependency.
- Added [Televerse.onSuccessfulPayment] method to listen to successful payments service messages #158`, thanks to @Defuera for the suggestion and @GiuseppeFn for the contribution.
- Fixed an issue with the
InlineKeyboardButton
class that caused a crash whenwebAppInfo
parameter is set. - Moved all Telegram Models into one file. This will make it easier to maintain the code.
- 🤖 Telegram Bot API 6.9 (September 22, 2023)
- Examples are now moved to the Examples Repo
- Updated Example files.
- 🤖 Telegram Bot API 6.8 (August 18, 2023)
- Possibly breaking: The
PollAnswer.user
property is now returns a nullableUser
object.
- Using
LoggerOptions
unknowingly caused the bot to crash. This is now fixed. - Thanks to @iamcosmin for raising #148.
- Fixed an issue with the Http client that caused the bot to crash when an exception is received from the Telegram Bot API.
- Thanks to @OttomanDeveloper for raising #151.
- Added
Televerse.onCommand
method to listen to all commands - #150 by @Defuera.
- Added
LoggerOptions
class to configure the logger. - Now the
Televerse
class accepts aLoggerOptions
object to setup logging requests and responses to and from the Telegram Bot API. - Added the
APIMethod
enum to represent the Telegram Bot API methods. - You can pass the List of
APIMethod
to theLoggerOptions
class to log only the specified methods. By default all methods will be logged.
- Added
Televerse.setNextStep
method which can be used to set next step handler. - Catches
DioExceptions
and throws meaningful exceptions.
⚠️ BREAKING CHANGES- Added
BotError
class that will be passed to theTeleverse.onError
handler ⚠️ Televerse.onError
will now only accept one parameter which is instance ofBotError
⚠️ Made theInputFile
constructor private. UseInputFile.fromFile
orInputFile.fromBytes
orInputFile.fromUrl
orInputFile.fromFileId
to create anInputFile
instance.- 🆕 Added the
InputFile.fromBytes
constructor to create anInputFile
instance from aUint8List
object. - ⚙️ Migrated to
dio
instead ofhttp
package. - Refactors & tets
- Fixed a minor formatting issue
- Fix #135 - Methods in
MessageContext
failed to work when message is in a General Topic of a Forum. - Improved error handling.
- All exceptions thrown inside handler methods will now be caught and passed to
the
onError
method. - That is no more unexpected crashes even if you don't handle the exceptions inside the handler methods.
- Removed some unnecessary code.
- Updated long polling error handling.
- Fix #130 -
RawAPI.editMessageMedia
method now works as expected. - Added callback data to
InlineMenu
- #129 (Thanks to @devsdocs). - Now all
RawAPI
methods uses HTTPPOST
/Multipart POST
requests instead ofGET
requests.
- Introducing
Televerse Menu
. - Added
InlineMenu
andKeyboardMenu
classes to represent an inline menu and a keyboard menu respectively. - Added
bot.attachMenu
method to attach a menu to the bot. - Added
bot.removeMenu
method to remove a menu listeners from from the bot. - Usage of
Televerse Menu
is demonstrated in /example/menu_bot.dart. - Fixed an issue with the
MessageContext
andMessageMixin
- #124 - Improved code quality.
- Fixed the incorrect type of
messagThreadId
parameter in multiple methods. - Updated
ChatMemberUpdatedContext
class to support bothchat_member
andmy_chat_member
updates. - Added
bot.me
getter to get the information about the bot. (Thanks to @GiuseppeFn) - Added
bot.getMe
method to get the information about the bot and set it to thebot.me
getter.
- Fixed issue that might cause a crash when
LongPolling.allUpdates
is used. - Rectified the
MessageContext.args
getter. Thanks to @devsdocs for PR #121. - More code improvements. Thanks to @aaxxios for PR #122
- Fixed an issue with the
command
method that crashed the bot when setting up the listener. - Thanks to @GiuseppeFn for reporting this issue.
- Refactored code for better performance.
- Introducing the
Televerse Conversation
! 🎉 - The conversation API lets you create straight forward conversations with the users.
- Added
Conversation
class to represent a conversation. - Added
waitForTextMessage
,waitForPhotoMessage
,waitForVideoMessage
,waitForVoiceMessage
,waitForDocumentMessage
,waitForContactMessage
,waitForLocationMessage
,waitForVenueMessage
,waitForPollMessage
,waitForDiceMessage
,waitForGameMessage
,waitForStickerMessage
,waitForVideoNoteMessage
,waitToStartVideoChat
,waitToEndVideoChat
&waitForCallbackQuery
methods toConversation
class. - Added an example to demonstrate the usage of Televerse conversations in /example/conversation_example.dart.
- Added
MessageContext.args
getter to get the arguments passed to the command. Thanks to @GiuseppeFn for the contribution. #115 - Removed
MessageContext.startParameter
getter as it's no longer needed. - Refactored examples to make it easier to understand.
- Fixed a critical issue that caused bots to crash when an exception other than
TelegramException
is thrown. - The weird thing was that the
onError
method was able to catch the exception but it rethrows it again. - This is now fixed and the
onError
method will not rethrow the exception. - Thanks to @GiuseppeFn for raising this.
- Added a whole bunch of helper methods to listen to updates.
- Namely added:
onAudio
,onDocument
,onPhoto
,onSticker
,onVideo
,onVideoNote
,onVoice
,onContact
,onDice
,onGame
,onPollMessage
,onVenue
,onLocation
,onLiveLocation
,onNewChatTitle
,onNewChatPhoto
,onDeleteChatPhoto
,onPinnedMessage
,onUsrShared
,onChatShared
,whenVideoChatScheduled
,whenVideoChatStarted
,whenVideoChatEnded
,onVideoChatParticipantsInvited
,onForumTopicCreated
,onForumTopicEdited
,onForumTopicClosed
,onForumTopicReopened
,onWebAppData
,onAnimation
,onText
,onCaption
- All of these methods are available on
Televerse
class and can make it easier to listen to variousMessage
updates.
- Fixes the issue which caused the crash of bots when a
ChatJoinRequest
update is received. - Thanks to @iamcosmin for taking effort to fix this issue. #109
- The
messageThreadId
parameter noww be defaulted to themessageThreadId
parameter in the incomingContext
object onreply
method. - This is to make it easier to reply to a message when the discussion is on a Forum Topic. (Fixes #110)
- Fixes an issue that caused none of
onEditedMessage
,onChannelPost
,onEditedChannelPost
, andmyChatMember
to work. - Thanks to [@GiuseppeFn] for rasing #107
- Merged #106
- Fix #104
- When
onMessage
listener is attached it stopped all other listeners from working. This is now fixed. - Updated README (some typos).
- Fix #102
- Commands that tagged with
@botname
will now be matched. - Minor changes on README & Session example.
- Televerse now can support handling updates passed to it as JSON data (without using a fetcher).
- This can be useful when you want to run bot on a serverless environment like AWS Lambda or Google Cloud Functions.
- Thanks to @rohitsangwan01 for the contribution. #99
onError
can now catch errors on the Long Polling.- Replaced all
Exception
withTelegramException
in the library. - Replaced the
Televerse.on
logic to an extension onTeleverse
class.
- Fix around
onError
method.
- Added
Televerse.onStop
to listen when the bot is stopped. (Fix #95) - Added
delayDuration
parameter toLongPolling
class to set the delay duration between each long polling request. - Moved all methods in
SessionFileExtension
andSessionsSaver
toSession
andSessionsManager
classes respectively. - This is to simplify the API and to make it easier to use.
- Updated
http
dependency to^1.0.0
.
- Added
SessionFileExtension
class to represent a file extension. - Added
SessionsSaver
extension onSessionsManager
class to save all sessions to a directory. - Updated /example/session_bot.dart file to reflect the changes.
- Minor breaking change: the initializer function now should accept a
int
as parameter.
- Fixed an issue with sessions that caused crash when not initialized.
- Introducing the
Televerse Session
! 🎉 - Televerse sessions are used to store data for chats.
- This can be used to store data for chats and to make the bot more interactive.
- Added an example to demonstrate the usage of Televerse sessions in
/example/session_bot.dart
. - You should use the
Televerse.initSession
method to initialize the session.
- Added the
Televerse.on
method! 🎉 - Removed the deprecation warning from the
Televerse.on
method.
- BREAKING CHANGES!
⚠️ - Whole new
HandlerScope
class is added to make it efficient handle updates. - All the methods in the
Televerse
class now uses theHandlerScope
class to register handlers. - This is to fix the issue #84 and to make it efficient to handle updates.
- Completely removed the
Event
class and related methods and getters. - The
on
method is now Deprecated. Use the other methods in the library to listen for updates. - All the getters in the
Event
class is now added to theTeleverse
class as methods. - Televerse now relies only on the
onUpdate
stream to listen for updates. - And all the errors can now be handled using the
onError
method.
- Added
UserLink
class to represent a Telegram user link. - Added
LinkText
class. This can be used to send a link with a custom text on chats. - Fixed an issue with the
Televerse.command
that caused to match unexpected commands.- This was because the
Televerse.command
method usedString.startsWith
to match the command. - Thanks to GiuseppeFn for raising the Issue #85
- This was because the
- The
HttpException
class is now renamed toTelegramException
. - This is to include the
ResponseParameters
object in the exception hence to make it easier to handle and retry if needed. - When an exception happens in the long polling, if the error handler is set
using
Televerse.onError
method this will now pauses the long polling till theonError
handler completes its execution.
- Added the
Deeplink
class to represent a Telegram deeplink. - Made it easy to use Telegram deeplinks by adding
BotLink
,GroupBotLink
,ChannelBotLink
,GameLink
,SettingsLinks
andShareLink
classes. - Also added
PhoneNumberLink
,MTProxyLink
,Socks5Link
andUsernameLink
.
- ✨ Simplified mentions.
- Added the new
UserMention
class to represent a user mention. - Added an extension to
User
class to convert it to aUserMention
object. - Added
MessageContext.from
alias toMessage.from
property. - Added
CustomEmoji
class to represent a Telegram custom emoji.
- Added more helper methods on
Televerse
class to listen to updates. - Added
Televerse.onURL
method to listen to messages that contain URLs. - Added
Televerse.onHashtag
method to listen to messages that contain hashtags. - Added
Televerse.onMention
method to listen to messages that contain mentions. - Added
Televerse.onEmail
method to listen to messages that contain email addresses. - Added
Televerse.onPhoneNumber
method to listen to messages that contain phone numbers. - Improved the overall code quality.
- Added
Televerse.whenMentioned
method to listen to messages that contain mentions of the bot.
- Added
PollContext
,PollAnswerContext
classes to represent the context of apoll
andpoll_answer
updates. - Added
Televerse.poll
method to listen topoll
updates. - Added
Televerse.pollAnswer
method to listen topoll_answer
updates. - Now most of the Televerse methods return a
StreamSubscription
instead ofvoid
. - This is to make it easier to cancel the subscription and increase the performance.
- Added
ChosenInlineResultContext
class to represent the context of achosen_inline_result
update andTeleverse.chosenInlineResult
method to listen tochosen_inline_result
updates. - Added
ChatJoinRequestContext
class to represent the context of achat_join_request
update andTeleverse.chatJoinRequest
method to listen tochat_join_request
updates. - Added
ShippingQueryContext
class to represent the context of ashipping_query
update andTeleverse.shippingQuery
method to listen toshipping_query
updates. - Added
PreCheckoutQueryContext
class to represent the context of apre_checkout_query
update andTeleverse.preCheckoutQuery
method to listen topre_checkout_query
updates.
- Added
ChatMemberUpdatedContext
class to represent the context of achat_member
andmy_chat_member
updates. - Added
Televerse.chatMember
andTeleverse.myChatMember
methods to listen tochat_member
andmy_chat_member
updates. - Hot fix: Fixed an issue with the
Event
class that caused unexpected exceptions.
- 🎖️ Televerse now supports listening to Local Bot API Server.
- Added
Televerse.local
method to create a bot instance that listens to a local Bot API Server. - Added
RawAPI.local
method that can be used to createRawAPI
instance that targets a local Bot API Server. - Added
LongPolling.allUpdates
method to listen to all updates. This is to simplify listening to all updates including thechat_member
updates. - Updated
/example/test_bot.dart
file to reflect the changes.
- [BREAKING]
⚠️ - Thechat
getter on theChatID
class is now replaced to be a method of theID
class, and renamed toget()
. - This is to avoid confusion with the
chat
parameter in theChatID
class. - Also, now the
get()
method is available on all theID
classes -ChatID
,SuperGroupID
andChannelID
. - Fixed an issue that caused the Long Polling to fail.
- The issue was with the
Message.fromJson
method which was not able to parse theMessage
object when anewChatPhoto
was present. - Thanks to @deargosep for reporting and fixing this issue.
- [BREAKING]
⚠️ - The parametersname
andlanguageCode
are made positional in thesetMyName
method and thegetMyName
method. - Improved documentation.
- 🤖 Bot API 6.7 is added!
- Read more here.
- [BREAKING] 👨🏻🔧 - The
answerInlineQuery
will no longer acceptswitchPmParameter
orswitchPmText
parameters. - The example files are updated with dartdoc comments.
- ⚗️ BREAKING - The
allowedUpdates
parameter in theLongPolling
object now accepts the list ofUpdateType
instead ofString
- Added methods
requestChat
andrequestUser
inKeyboard
- Added equality operator (
==
) onID
. - Added a test to check equality of two Chat IDs.
- Added missing implementation for
WebhookInfo.toJson
method - Added dartdoc comments for almost every bit of the library.
- Fixed an issue with
RawAPI.copyMessage
method. - Updated the
Televerse.command
method to accept aString
orRegExp
as thecommand
parameter.
- Changed the
data
parameter to accept bothString
andRegExp
usingPattern
type onTeleverse.callbackQuery
method. - This can simplify the code when you want to listen to a callback query with a specific data.
- The test_bot.dart file in the example folder has been updated to reflect this change.
- Added new test cases in the
/test
folder. - There were some
thumb
parameters even though they were changed tothumbnail
in the API documentation. Fixed that. - Fixed an issue with sending media group using local files. More info on #56
- Completely removed the class
MessageOrBoolean
as it was not needed. All methods that return either aMessage
or abool
now split into two methods. One forMessage
and one forbool
. - Updated the
ReplyKeyboardRemove
class to reflect auto set theremove_keyboard
parameter totrue
when theReplyKeyboardRemove
class is created. - Similarly, updated the
ForceReply
class to reflect auto set theforce_reply
parameter totrue
when theForceReply
class is created. - Fixed an issue with
addStickerToSet
method which caused it to fail. More info on #57. - Tested all methods related to Stickers.
- Fixed an issue with
createNewStickerSet
method which caused it to fail. More info on #58.
- Fixed an issue with
RawAPI.sendAudio
method. - Added new test files in example folder.
- More fixes around the
RawAPI
class. - Added missing implementations for
RawAPI.getCustomEmojiStickers
method.
- Fixed an issue with the
RawAPI.sendChatAction
method. - More fixes around the RawAPI class.
- 🤖 Bot API 6.6 (March 9, 2021) 🎉
- A bunch of changes as per the Bot API 6.6
- Added
Televerse.entity
method to listen to entities in messages. - Improved code quality.
- Removed all the different StreamController classes and replaced them with a
single
StreamController<Update>
instance. - All the event streams are now based on the
onUpdate
stream. - Added
Message.getEntityText
method to get the text of the entity. - Updated the televerse_example file to reflect the changes.
- Added
Message.isCommand
getter to check if the message is a command. - Added
Televerse.onError
method to listen to unexpected exceptions.
- A bunch of refactors on the
on
method.
- Added
TeleverseEvent.command
to listen to all commands.
- Added helper methods on
File
class to get the file download URL, download URI, file bytes, and finally to download the file. - Added
File.download
method to download the file. - Added
File.getDownloadUrl
method to get the file download URL asString
. - Added
File.getDownloadURI
method to get theUri
object of the file download URL. - Added
File.getBytes
method to get the file bytes this returns aFuture<Uint8List>
. - Added
File.download
method to download the file. This returns aFuture<io.File>
object. - The working example is available at examples/file_download.dart
- Fixed an issue with the webhook configuration.
- Made it easier to set a custom fetcher. You don't have to pass the
RawAPI
instance to theFetcher
constructor anymore.
- Minor formatting changes.
- 🔥 This is breaking change.
- Added the
RawAPI
class to access the raw Telegram Bot API methods. - Added a
api
getter toTeleverse
class to access theRawAPI
class. - Now it's even easier to access and differentiate between the Telegram Bot API methods and Televerse methods.
- Added dartdoc comments to all the classes.
- Added shorthand methods to setup listners for
/start
,/help
,/settings
commands. - You can now use
Televerse.start
,Televerse.help
, andTeleverse.settings
to listen for these commands. - All these methods accepts a
MessageHandler
as a parameter which is a type alias forFutureOr<void> Function(MessageContext)
. - Added
MessageHandler
,CallbackQueryHandler
, andInlineQueryHandler
type aliases.
- Telegram Bot API 6.5 (February 3, 2023)
- This includes addition of classes like
KeyboardButtonRequestUser
,KeyboardButtonRequestChat
,UserShared
andChatShared
. - Added some missing implementations for Bot API 6.4
- Added
Televerse.instance
getter to get the last instance ofBot
created. - Added
ChatID.chat
getter to get theChat
object from theChatID
object. - Added optional
RegExp? regex
parameter toTeleverse.command
method.
- Added
startParameter
getter toMessageContext
class. This will be automatically set when the bot is started by a user clicking on a deep link such ast.me/MyBot?start=12345
. - Added more tests.
- Whole lot of refactoring.
- New
InlineKeyboard
class is added. This can be very useful in creatingInlineKeyboardMarkup
. - New
Keyboard
class to help with creatingReplyKeyboardMarkup
easily and quickly. - Updated
ReplyKeyboardMarkup
andKeyboardButton
as per the API Documentation (some of the optional parameters were required in the previous version). - Fixed an issue that was causing
sendMessage
to not work when used with any reply markup.
- Added documentation for all most all classes and Televerse things.
- Added
MessageMixin
to supportMessageContext
. - Added
replyWithPhoto
,replyWithVideo
,replyWithAudio
,replyWithDocument
,replyWithVideoNote
,replyWithVoice
,replyWithVenue
,replyWithContact
,replyWithPoll
,replyWithDice
,replyWithChatAction
,replyWithGame
,replyWithAnimation
,replyWithSticker
,editMessageText
, anddeleteMessage
methods toMessageContext
. - Added
ManagementMixin
to supportMessageContext
. - Added
banAuthor
,banSenderChat
,deleteChatPhoto
,promoteAuthor
,restrictAuthor
,exportChatInviteLink
,revokeChatInviteLink
,pinChatMessage
,unpinChatMessage
,getChat
,getChatAdministrators
,getChatMember
, andleaveChat
onManagementMixin
. - Both
MessageMixin
andManagementMixin
are now available onMessageContext
. - Added
CallbackQueryMixin
to supportCallbackQueryContext
. CallbackQueryContext
now hasanswer
andeditMessage
methods available.- Added
InlineQueryMixin
to supportInlineQueryContext
. InlineQueryContext
now hasanswer
, andanswerWithArticles
methods available.
- Fixed an issue with the
on
method that it's not getting called on any filters. - Made official Televerse Wiki available at the GitHub repo.
- Added
TeleverseEvent
enum to make it easy to listen for particular events. - 🔥 Added
on
method accessible onTeleverse
class. This method can be used to listen for particular events as listed inTeleverseEvent
enum. - Edited method
Televerse.callbackQuery
to acceptRegExp? regex
as an optional parameter. This can be used to listen for callback queries that match the passed regex. - Updated RAW API to return
Message
instead ofMessageContext
. - Updated
Context
class to have the associatedUpdate
object with it. - Update
MessageContextOrBoolean
class to beMessageOrBoolean
in places a method sending eitherMessage
orbool
, such aseditMessageLiveLocation
etc.
- Added a lot new methods to
Televerse
class:command
- Can be used to listen for Messages that contain the passed commandtext
- This is a very basic method, which can be used to listen to messages that contain particular text content in itcallbackQuery
- Can be used to listen for callbackQuery updates.chatType
andchatTypes
- Can be used to register callbacks for messages received on particular chat types.filter
- Filter is an advanced method that can be used to listen for messages that pass a given predicate condition.hears
- One of the best picks. Users can pass a RegEx pattern and listen for messages that contain a match.
- Added
MessageContext.id
to get the Chat ID easily - Improved examples
- Initial release
- We're live at Bot API 6.4
MessageContext
class added withreply
method
- On development release. Completely new project.