Loading...
Loading...
Loading...
Loading...
Describes the webhook approach to getting updates.
Loading...
Loading...
Loading...
Ensure thatTelegram.Bots.Extensions.Polling
package is installed. See Installation.
Successful polling requires an implementation of IUpdateHandler
so we will first address that with an example:
Now that an IUpdateHandler
exists, we can create a .NET Core console application with the bot client and polling configured as such:
Run it and try sending a message to the bot.
The main library is available as Telegram.Bots
. It provides all the Types
and Requests
along with the HTTP
and JSON
support.
To add long polling, Telegram.Bots.Extensions.Polling
can be used.
If you use the webhook approach and intend to respond to updates directly by returning the desired method data, you will need to integrate the serializer with your ASP.NET Core project and that can be done via Telegram.Bots.Extensions.AspNetCore
.
Telegram.Bots is a .NET Standard wrapper for the Telegram Bot API.
I wanted to make a Telegram bot for my personal use and C# happened to be a reasonable language to write it in. I tried using the popular .NET Client for Telegram Bot API but found various issues with it during my use of it that I decided to make a wrapper for the Telegram Bot API from scratch, free from the implementation and interface issues I experienced in that library.
Two words: breaking changes. My ideas for the Telegram Bot API wrapper were different enough to warrant breaking changes in that library. I did not want to break it and it would have been unreasonable to expect the caretakers of that library to accept my breaking changes, especially since the library does get its work done in most cases without really needing the changes I wanted in the library.
Sure. I will give three but there are more:
That popular library throws exceptions when the Telegram servers return a failure response. That library also throws exceptions in cases where tasks are canceled or a timeout occurs. Telegram.Bots
, on the other hand, returns the failure response during a failure. Even when a task is canceled or a timeout occurs, a failure response is returned with appropriate information. I found the exception-based approach to require me to learn the ways of the library in order to write resilient code. Telegram.Bots
leaves the exceptions for exceptional cases.
That popular library maps each type made known by the Telegram Bot API documentation in pretty much the same manner as the documentation does. It does improve in some ways, particularly in places where types involve inline message targeting but it is still limited. Telegram.Bots
, on the other hand, uses types in a manner which facilitates pattern matching on the types and allows only the data which is reasonable for any given type. For example, Telegram.Bots
has a TextMessage
type for text messages and StickerMessage
for messages that are stickers, and so on. That popular library has a Message
type to denote all kinds of messages and so there is a relative overhead with respect to object creation as well (since that class is bloated with unnecessary properties for any given type of message).
Telegram.Bots
does not allow you to send useless information. Like, did you know that you can set up the title of an audio only when you are sending it as a file or as an inline audio result? If you send an audio as a URL or as a cached file, setting up the title in the request does not make any difference. Telegram.Bots
takes care of all these cases.
Telegram.Bots
was primarily written to meet my particular aesthetic preferences and simplicity standards and I will be happy if you try it out and see the difference it makes in your journey to make interesting bots. That is why I made it available as a free and open source software and am writing all this documentation to make the process easier for those interested in trying Telegram.Bots
out for themselves.
Telegram.Bots
supports .NET Standard 2.1. Using Telegram.Bots
will be a good idea for you if you are also interested in utilizing the new language and runtime features.
Telegram.Bots
has some niceties which can be leveraged by utilizing the Microsoft.Extensions.DependencyInjection
package. We will use that as it makes the code more manageable.
Here is one way you can get and then print the information about your bot: