TelegramBotKit.Hosting
0.3.2
dotnet add package TelegramBotKit.Hosting --version 0.3.2
NuGet\Install-Package TelegramBotKit.Hosting -Version 0.3.2
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="TelegramBotKit.Hosting" Version="0.3.2" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="TelegramBotKit.Hosting" Version="0.3.2" />
<PackageReference Include="TelegramBotKit.Hosting" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add TelegramBotKit.Hosting --version 0.3.2
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: TelegramBotKit.Hosting, 0.3.2"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package TelegramBotKit.Hosting@0.3.2
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=TelegramBotKit.Hosting&version=0.3.2
#tool nuget:?package=TelegramBotKit.Hosting&version=0.3.2
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
TelegramBotKit
TelegramBotKit is a lightweight toolkit for building Telegram bots on .NET with a structured update pipeline, typed handlers, and simple command routing.
📚 Start here: Documentation index
Packages
TelegramBotKit— core pipeline, dispatching, commands, messaging helpers.TelegramBotKit.Hosting— polling/hosting integration.TelegramBotKit.Routing— optional ASP.NET-styleUse*routing sugar.TelegramBotKit.Generators— optional Roslyn source generator for compile-timeAddCommands()registration.
Features
- Middleware pipeline for update processing.
- Typed update payload handlers (
IUpdatePayloadHandler<TPayload>). - Message/text/callback commands (attributes + optional routing sugar).
WaitForUserResponsehelper for request/response flows.IMessageSenderfacade for sending messages.- Optional queued sender to reduce rate-limit errors.
Requirements
- .NET 10 (current target framework is
net10.0).
Installation
dotnet add package TelegramBotKit
dotnet add package TelegramBotKit.Hosting
# optional
dotnet add package TelegramBotKit.Routing
# optional (compile-time AddCommands)
dotnet add package TelegramBotKit.Generators
Quick start (polling)
- Add configuration.
Create appsettings.json:
{
"TelegramBotKit": {
"Token": "PUT_YOUR_BOT_TOKEN_HERE",
"Polling": {
"MaxDegreeOfParallelism": 4,
"Limit": 100,
"TimeoutSeconds": 10,
"AllowedUpdates": []
}
}
}
AllowedUpdates: []means “allow all update types”. If you want only specific types, list them explicitly.
- Create a host.
using Microsoft.Extensions.Hosting;
using TelegramBotKit.DependencyInjection;
using TelegramBotKit.Hosting;
var builder = Host.CreateApplicationBuilder(args);
builder.Configuration.AddJsonFile("appsettings.json", optional: false, reloadOnChange: true);
var bot = builder.Services.AddTelegramBotKit(opt =>
{
builder.Configuration.GetSection("TelegramBotKit").Bind(opt);
});
// Registers attributed commands.
// If TelegramBotKit.Generators is installed, this is compile-time.
// Otherwise it falls back to reflection-based discovery.
builder.Services.AddCommands();
// Optional: queued sender (helps with Telegram rate limits)
bot.UseQueuedMessageSender();
builder.Services.AddTelegramBotKitPolling();
var host = builder.Build();
await host.RunAsync();
Need a custom
HttpClientfor proxy, timeout, or custom handlers? See Quick start.
- Add a command.
using Telegram.Bot.Types;
using TelegramBotKit.Commands;
using TelegramBotKit.Messaging;
namespace MyBot.Commands;
[MessageCommand("/start")]
public sealed class StartCommand : IMessageCommand
{
public Task HandleAsync(Message message, BotContext ctx)
{
return ctx.Sender.SendText(message.Chat.Id, new SendText
{
Text = "Hello."
}, ctx.CancellationToken);
}
}
Documentation
- Documentation index (recommended starting point)
- Quickstart
- Commands and routing
- Updates and payload handlers (custom Update types)
- Middleware
- Hosting / Polling
- Conversations (
WaitForUserResponse) - Keyboards
- Public API notes
- Releasing
Running the sample
dotnet run --project samples/TelegramBotKit.Sample.ConsolePolling
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net10.0
- Microsoft.Extensions.Hosting (>= 10.0.3)
- Microsoft.Extensions.Hosting.Abstractions (>= 10.0.3)
- TelegramBotKit (>= 0.3.2)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.