With this small framework based around Telegram.Bot, you can easily write Console polling Telegram bot, in particular those that requires sequential inputs.
DISCLAIMER
My fork can (and I think will) have a lot of difference
compared to original repo, so mind your step using my fork :)
Here is an example bot asking sequential questions when the user sends /start in private chat:
public class MyBot : BotBase
{
public MyBot(string MyBotToken) : base(MyBotToken){}
public override async Task OnPrivateChat(UpdateContext ctx)
{
if (ctx.Update.UpdateKind != UpdateKind.NewMessage || ctx.Update.MsgCategory != MsgCategory.Text)
return;
if (ctx.Update.Message.Text == "/start")
{
await Bot.SendTextMessageAsync(ctx.Chat, "What is your first name?");
var firstName = await NewTextMessage(ctx.Update);
await Bot.SendTextMessageAsync(ctx.Chat, "What is your last name?");
var lastName = await NewTextMessage(ctx.Update);
await Bot.SendTextMessageAsync(ctx.Chat, $"Welcome, {firstName} {lastName}!");
}
}
}
To host this bot you can just do the following:
var myBot = new MyBot("MyBotToken");
await myBot.RunAsync();
There are 4 overridable methods on EasyBot, where you can place your code:
- OnPrivateChat: called when something happens on a private chat (initiated with a given user)
- OnGroupChat: called when something happens on a group chat the bot is in (the bot must be added to the group by an admin)
- OnChannel: called when something happens on a channel
- OnOtherEvents: called when something else happens that doesn't fit the above categories
These methods must be marked as async
and typically include a Chat or User parameter telling you where the
event is happening, as well as an UpdateInfo update parameter giving you more detail about the event:
- UpdateKind: tells you if the event is about:
- a new message
- a message that was edited
- a callback query was triggered (a user clicking an inline button)
- or another type of update (typically, the bot or other users joining/leaving the chat)
- Message: the associated message if any.
- MsgCategory: the category of the message (Text, MediaOrDoc, StickerOrDice, Sharing, ChatStatus, VoiceChat or Other)
- CallbackData: the callback query string associated with the inline button
- Update: the full Telegram Update object in case you need to access additional information
It is therefore recommended that the first thing you do in your overriden method is to check what UpdateKind it was called upon.
It can also be a media, document, sticker, etc.. that was posted, or it can be an event concerning the chat (
like creation, change of characteristics, pinned message, voice chat status, etc..). So make sure to check the value
of MsgCategory, Message.Type, or that Message.Text is not null before accessing it.
Once your method is running, EasyBot ensure that execution is sequential for this particular channel/group/private chat. However, two or more versions of your method might be running in parallel if different channels/groups/users are involved.
In your method, you can call await Telegram.XYZAsync()
to send messages or do any other Telegram actions you want.
After you've done handling this update event, you can either:
- return from your method.
The method will be called again for future events concerning this chat. - or continue execution of your method and call:
await NextEvent(update)
to obtain the next sequential update event concerning the current chatawait NewMessage(update)
to obtain the next new message in the current chat
(this method return only real messages in categories Text, MediaOrDoc and StickerOrDice and ignore all other events; it will raise an exception to abort your method if the chat is left)await NewTextMessage(update)
to obtain the next new text message in the current chat (same as above but keeps only Text messages)await ButtonClicked(update, msg)
to wait for the user to click a reply button (from the optional msg) and obtain its callback dataReplyCallback(update, "you clicked!")
to acknowledge the callback query and optionally display a text to the user
After the above await
calls, the update
parameter is filled with the latest update event information.
If you have questions about this EasyBot framework, you can contact me in TelegramBots support group. For additional information please visit original repo