WTelegramClient 1.8.3
See the version list below for details.
dotnet add package WTelegramClient --version 1.8.3
NuGet\Install-Package WTelegramClient -Version 1.8.3
<PackageReference Include="WTelegramClient" Version="1.8.3" />
paket add WTelegramClient --version 1.8.3
#r "nuget: WTelegramClient, 1.8.3"
// Install WTelegramClient as a Cake Addin #addin nuget:?package=WTelegramClient&version=1.8.3 // Install WTelegramClient as a Cake Tool #tool nuget:?package=WTelegramClient&version=1.8.3
a Telegram Client API library written 100% in C# and .NET Standard
How to use
⚠️ This library relies on asynchronous C# programming (
async/await
) so make sure you are familiar with this advanced topic before proceeding.
If you are a beginner in C#, starting a project based on this library might not be a great idea.
After installing WTelegramClient through Nuget, your first Console program will be as simple as:
static async Task Main(string[] _)
{
using var client = new WTelegram.Client();
var user = await client.LoginUserIfNeeded();
Console.WriteLine($"We are logged-in as {user.username ?? user.first_name + " " + user.last_name} (id {user.id})");
}
When run, this will prompt you interactively for your App api_id and api_hash (that you obtain through Telegram's API development tools page) and try to connect to Telegram servers.
Then it will attempt to sign-in as a user for which you must enter the phone_number and the verification_code that will be sent to this user (for example through SMS or another Telegram client app the user is connected to).
If the verification succeeds but the phone number is unknown to Telegram, the user might be prompted to sign-up (accepting the Terms of Service) and enter their first_name and last_name.
And that's it, you now have access to the full range of Telegram services, mainly through calls to await client.Some_TL_Method(...)
Saved session
If you run this program again, you will notice that only api_id and api_hash are requested, the other prompts are gone and you are automatically logged-on and ready to go.
This is because WTelegramClient saves (typically in the encrypted file bin\WTelegram.session) its state and the authentication keys that were negociated with Telegram so that you needn't sign-in again every time.
That file path is configurable, and under various circumstances (changing user or server address) you may want to change it or simply delete the existing session file in order to restart the authentification process.
Non-interactive configuration
Your next step will probably be to provide a configuration to the client so that the required elements (in bold above) are not prompted through the Console but answered by your program.
To do this, you need to write a method that will provide the answers, and pass it on the constructor:
static string Config(string what)
{
switch (what)
{
case "api_id": return "YOUR_API_ID";
case "api_hash": return "YOUR_API_HASH";
case "phone_number": return "+12025550156";
case "verification_code": Console.Write("Code: "); return Console.ReadLine();
case "first_name": return "John"; // if sign-up is required
case "last_name": return "Doe"; // if sign-up is required
case "password": return "secret!"; // if user has enabled 2FA
default: return null; // let WTelegramClient decide the default config
}
}
...
using var client = new WTelegram.Client(Config);
There are other configuration items that are queried to your method but returning null
let WTelegramClient choose a default adequate value.
Those shown above are the only ones that have no default values and should be provided by your method.
Returning null
for verification_code or password will show a prompt for console apps, or an error otherwise.
Returning an empty string for verification_code requests resending the code through another method (SMS or Call).
Another simple approach is to pass Environment.GetEnvironmentVariable
as the config callback and define the configuration items as environment variables.
Undefined variables get the default null
behavior.
Finally, if you want to redirect the library logs to your logger instead of the Console, you can install a delegate in the WTelegram.Helpers.Log
static property.
Its int
argument is the log severity, compatible with the classic LogLevel enum
Example of API call
ℹ️ The Telegram API makes extensive usage of base and derived classes, so be ready to use the various syntaxes C# offer to check/cast base classes into the more useful derived classes (
is
,as
,case DerivedType
)
All the Telegram API classes/methods are fully documented through Intellisense: Place your mouse over a class/method name, or start typing the call arguments to see a tooltip display their description, the list of derived classes and a web link to the official API page.
The Telegram API object classes are defined in the TL
namespace, and the API functions are available as async methods of Client
.
Below is an example of calling the messages.getAllChats API function and enumerating the various groups/channels the user is in, and then using client.SendMessageAsync
helper function to easily send a message:
using TL;
...
var chats = await client.Messages_GetAllChats(null);
Console.WriteLine("This user has joined the following:");
foreach (var (id, chat) in chats.chats)
switch (chat) // example of downcasting to their real classes:
{
case Chat smallgroup when smallgroup.IsActive:
Console.WriteLine($"{id}: Small group: {smallgroup.title} with {smallgroup.participants_count} members");
break;
case Channel group when group.IsGroup:
Console.WriteLine($"{id}: Group {group.username}: {group.title}");
break;
case Channel channel:
Console.WriteLine($"{id}: Channel {channel.username}: {channel.title}");
break;
}
Console.Write("Type a chat ID to send a message: ");
long chatId = long.Parse(Console.ReadLine());
var target = chats.chats[chatId];
Console.WriteLine($"Sending a message in chat {chatId}: {target.Title}");
await client.SendMessageAsync(target, "Hello, World");
➡️ You can find more useful code snippets in EXAMPLES.md and in the Examples subdirectory.
<a name="terminology"></a>
Terminology in Telegram Client API
In the API, Telegram uses some terms/classnames that can be confusing as they differ from the terms shown to end-users:
Channel
: A (large or public) chat group (sometimes called supergroup) or a broadcast channel (thebroadcast
flag differenciate those)Chat
: A private simple chat group with less than 200 members (it may be migrated to a supergroupChannel
with a new ID when it gets bigger or public, in which case the oldChat
will still exist but bedeactivated
)
⚠️ Most chat groups you see are really of typeChannel
, notChat
!- chats : In plural or general meaning, it means either
Chat
orChannel
Peer
: Either aChat
,Channel
or a private chat with aUser
- Dialog : The current status of a chat with a
Peer
(draft, last message, unread count, pinned...) - DC (DataCenter) : There are a few datacenters depending on where in the world the user (or an uploaded media file) is from.
- Access Hash : Telegram requires you to provide a specific
access_hash
for users, channels, and other resources before interacting with them. See FAQ #4 to learn more about it.
Other things to know
The Client class also offers an Update
event that is triggered when Telegram servers sends unsollicited Updates or notifications/information/status/service messages, independently of your API requests. See Examples/Program_ListenUpdates.cs
An invalid API request can result in a RpcException
being raised, reflecting the error code and status text of the problem.
The other configuration items that you can override include: session_pathname, server_address, device_model, system_version, app_version, system_lang_code, lang_pack, lang_code, user_id
Optional API parameters have a default value of null
when unset. Passing null
for a required string/array is the same as empty (0-length). Required API parameters/fields can sometimes be set to 0 or null
when unused (check API documentation or experiment).
I've added several useful converters, implicit cast or helper properties to various API object so that they are more easy to manipulate.
Beyond the TL async methods, the Client class offers a few other methods to simplify the sending/receiving of files, medias or messages.
This library works best with .NET 5.0+ and is also available for .NET Standard 2.0 (.NET Framework 4.6.1+ & .NET Core 2.0+)
Library uses and limitations
This library can be used for any Telegram scenarios including:
- Sequential or parallel automated steps based on API requests/responses
- Real-time monitoring of incoming Updates/Messages
- Download/upload of files/media
- or even a full-featured interactive client
It has been tested in a Console app, in a WinForms app, in ASP.NET webservice.
Secret chats (end-to-end encryption, PFS) and connection to CDN DCs have not been tested yet.
Please don't use this library for Spam or Scam. Respect Telegram Terms of Service as well as the API Terms of Service or you might get banned from Telegram servers.
Developers feedback is welcome in the Telegram support group @WTelegramClient
You can also check our 📖 Frequently Asked Questions for more help and troubleshooting guide.
If you like this library, please consider a donation.❤ This will help the project keep going.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 is compatible. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- IndexRange (>= 1.0.0)
- Microsoft.Bcl.HashCode (>= 1.1.1)
- System.Formats.Asn1 (>= 5.0.0)
- System.Memory (>= 4.5.4)
- System.Text.Json (>= 5.0.2)
-
net5.0
- No dependencies.
NuGet packages (6)
Showing the top 5 NuGet packages that depend on WTelegramClient:
Package | Downloads |
---|---|
WTelegramClient.Extensions.Updates
Extensions over WtelegramClient For Dealing With Updates |
|
WTelegramBot
Telegram Bot API (local server) library providing more extended features Release Notes: The best of both worlds |
|
MTProto
A MTProto client library based on wiz0u/WTelegramClient |
|
WTC.Abstractions.Types
Telegram Type Abstractions For WTelegramClient |
|
ProfitSniper.Profitview
Package Description |
GitHub repositories (2)
Showing the top 2 popular GitHub repositories that depend on WTelegramClient:
Repository | Stars |
---|---|
yiyungent/KnifeHub
🧰 简单易用的效率工具平台
|
|
DamianMorozov/TgDownloader
Telegram Downloader
|
Version | Downloads | Last updated |
---|---|---|
4.1.10-dev.2 | 0 | 9/7/2024 |
4.1.10-dev.1 | 0 | 9/7/2024 |
4.1.9 | 44 | 9/7/2024 |
4.1.9-dev.2 | 36 | 9/6/2024 |
4.1.9-dev.1 | 48 | 9/5/2024 |
4.1.8 | 1,802 | 8/14/2024 |
4.1.7 | 507 | 8/10/2024 |
4.1.7-dev.1 | 34 | 8/10/2024 |
4.1.6 | 897 | 7/31/2024 |
4.1.6-dev.1 | 30 | 7/29/2024 |
4.1.5 | 1,236 | 7/20/2024 |
4.1.5-dev.2 | 49 | 7/20/2024 |
4.1.5-dev.1 | 80 | 7/12/2024 |
4.1.4 | 1,029 | 7/7/2024 |
4.1.3 | 274 | 7/6/2024 |
4.1.2 | 435 | 7/2/2024 |
4.1.2-dev.8 | 55 | 7/1/2024 |
4.1.2-dev.7 | 158 | 6/15/2024 |
4.1.2-dev.6 | 48 | 6/15/2024 |
4.1.2-dev.5 | 134 | 6/4/2024 |
4.1.2-dev.4 | 74 | 5/28/2024 |
4.1.2-dev.3 | 48 | 5/27/2024 |
4.1.2-dev.2 | 166 | 5/7/2024 |
4.1.2-dev.1 | 67 | 5/1/2024 |
4.1.1 | 7,987 | 4/28/2024 |
4.1.1-dev.5 | 52 | 4/28/2024 |
4.1.1-dev.2 | 54 | 4/27/2024 |
4.1.1-dev.1 | 49 | 4/27/2024 |
4.0.1 | 1,174 | 4/24/2024 |
4.0.1-dev.6 | 72 | 4/22/2024 |
4.0.1-dev.5 | 58 | 4/18/2024 |
4.0.1-dev.4 | 48 | 4/17/2024 |
4.0.1-dev.3 | 56 | 4/16/2024 |
4.0.1-dev.2 | 55 | 4/14/2024 |
4.0.1-dev.1 | 60 | 4/13/2024 |
4.0.0 | 2,269 | 4/5/2024 |
4.0.0-dev.8 | 56 | 4/4/2024 |
4.0.0-dev.7 | 48 | 4/3/2024 |
4.0.0-dev.6 | 86 | 3/30/2024 |
4.0.0-dev.5 | 57 | 3/29/2024 |
4.0.0-dev.4 | 66 | 3/28/2024 |
4.0.0-dev.2 | 73 | 3/26/2024 |
4.0.0-dev.1 | 66 | 3/26/2024 |
3.7.2 | 1,432 | 3/24/2024 |
3.7.2-dev.3 | 65 | 3/23/2024 |
3.7.2-dev.2 | 76 | 3/19/2024 |
3.7.2-dev.1 | 73 | 3/13/2024 |
3.7.1 | 3,304 | 3/8/2024 |
3.6.7-dev.13 | 49 | 3/8/2024 |
3.6.7-dev.12 | 50 | 3/8/2024 |
3.6.7-dev.11 | 46 | 3/8/2024 |
3.6.7-dev.9 | 61 | 3/8/2024 |
3.6.7-dev.8 | 66 | 3/4/2024 |
3.6.7-dev.7 | 112 | 2/25/2024 |
3.6.7-dev.6 | 81 | 2/21/2024 |
3.6.7-dev.5 | 61 | 2/19/2024 |
3.6.7-dev.4 | 69 | 2/18/2024 |
3.6.7-dev.3 | 60 | 2/18/2024 |
3.6.7-dev.1 | 50 | 2/18/2024 |
3.6.6 | 2,394 | 2/1/2024 |
3.6.5 | 2,781 | 1/18/2024 |
3.6.4 | 532 | 1/16/2024 |
3.6.4-dev.2 | 60 | 1/16/2024 |
3.6.4-dev.1 | 55 | 1/15/2024 |
3.6.3 | 3,960 | 12/31/2023 |
3.6.3-dev.1 | 73 | 12/31/2023 |
3.6.2 | 1,205 | 12/23/2023 |
3.6.2-dev.2 | 68 | 12/23/2023 |
3.6.2-dev.1 | 96 | 12/17/2023 |
3.6.1 | 2,629 | 11/30/2023 |
3.6.1-dev.7 | 58 | 11/30/2023 |
3.6.1-dev.6 | 63 | 11/29/2023 |
3.6.1-dev.2 | 88 | 11/25/2023 |
3.6.1-dev.1 | 149 | 11/17/2023 |
3.5.10-dev.1 | 98 | 11/11/2023 |
3.5.9 | 2,669 | 11/6/2023 |
3.5.8 | 1,493 | 10/28/2023 |
3.5.8-dev.5 | 70 | 10/28/2023 |
3.5.8-dev.4 | 125 | 10/24/2023 |
3.5.8-dev.3 | 72 | 10/24/2023 |
3.5.8-dev.2 | 104 | 10/19/2023 |
3.5.8-dev.1 | 107 | 10/9/2023 |
3.5.7 | 2,448 | 10/4/2023 |
3.5.6 | 1,389 | 9/22/2023 |
3.5.5 | 1,054 | 9/18/2023 |
3.5.5-dev.1 | 63 | 9/18/2023 |
3.5.4 | 2,829 | 9/6/2023 |
3.5.4-dev.2 | 75 | 9/6/2023 |
3.5.3 | 7,370 | 7/21/2023 |
3.5.2-dev.21 | 81 | 7/21/2023 |
3.5.2-dev.20 | 170 | 7/7/2023 |
3.5.2-dev.19 | 95 | 7/6/2023 |
3.5.2-dev.16 | 81 | 7/5/2023 |
3.5.2-dev.15 | 130 | 6/27/2023 |
3.5.2-dev.3 | 893 | 5/18/2023 |
3.5.2-dev.1 | 76 | 5/17/2023 |
3.5.1 | 21,770 | 5/17/2023 |
3.5.1-dev.4 | 79 | 5/17/2023 |
3.5.1-dev.3 | 469 | 5/9/2023 |
3.5.1-dev.2 | 142 | 5/5/2023 |
3.5.1-dev.1 | 97 | 5/2/2023 |
3.4.3-dev.4 | 84 | 5/1/2023 |
3.4.3-dev.3 | 92 | 4/29/2023 |
3.4.3-dev.2 | 171 | 4/25/2023 |
3.4.3-dev.1 | 107 | 4/25/2023 |
3.4.2 | 4,627 | 4/24/2023 |
3.4.2-dev.2 | 79 | 4/24/2023 |
3.4.2-dev.1 | 94 | 4/23/2023 |
3.4.1 | 1,060 | 4/21/2023 |
3.4.1-dev.5 | 77 | 4/21/2023 |
3.4.1-dev.4 | 158 | 4/9/2023 |
3.4.1-dev.2 | 82 | 4/8/2023 |
3.4.1-dev.1 | 106 | 4/2/2023 |
3.3.4-dev.1 | 93 | 4/1/2023 |
3.3.3 | 2,262 | 3/26/2023 |
3.3.3-dev.2 | 103 | 3/26/2023 |
3.3.3-dev.1 | 149 | 3/16/2023 |
3.3.2 | 1,929 | 3/9/2023 |
3.3.2-dev.2 | 86 | 3/9/2023 |
3.3.2-dev.1 | 89 | 3/9/2023 |
3.3.1 | 914 | 3/8/2023 |
3.3.1-dev.1 | 89 | 3/8/2023 |
3.2.3-dev.5 | 192 | 2/26/2023 |
3.2.3-dev.4 | 134 | 2/17/2023 |
3.2.3-dev.3 | 92 | 2/15/2023 |
3.2.3-dev.2 | 91 | 2/14/2023 |
3.2.3-dev.1 | 89 | 2/13/2023 |
3.2.2 | 9,470 | 2/6/2023 |
3.2.2-dev.7 | 104 | 2/5/2023 |
3.2.2-dev.6 | 111 | 2/4/2023 |
3.2.2-dev.5 | 122 | 1/26/2023 |
3.2.2-dev.4 | 167 | 1/12/2023 |
3.2.2-dev.3 | 121 | 1/9/2023 |
3.2.2-dev.2 | 112 | 1/7/2023 |
3.2.2-dev.1 | 117 | 1/6/2023 |
3.2.1 | 3,591 | 12/29/2022 |
3.2.1-dev.2 | 107 | 12/29/2022 |
3.2.1-dev.1 | 102 | 12/29/2022 |
3.1.6-dev.2 | 132 | 12/19/2022 |
3.1.6-dev.1 | 102 | 12/15/2022 |
3.1.5 | 2,381 | 12/7/2022 |
3.1.4-dev.6 | 94 | 12/7/2022 |
3.1.4-dev.5 | 96 | 12/5/2022 |
3.1.4-dev.4 | 112 | 12/2/2022 |
3.1.4-dev.3 | 117 | 11/26/2022 |
3.1.4-dev.2 | 97 | 11/26/2022 |
3.1.4-dev.1 | 99 | 11/26/2022 |
3.1.3 | 2,037 | 11/23/2022 |
3.1.3-dev.5 | 95 | 11/23/2022 |
3.1.3-dev.3 | 102 | 11/20/2022 |
3.1.2 | 1,782 | 11/12/2022 |
3.0.3 | 1,866 | 11/1/2022 |
3.0.2 | 2,011 | 10/26/2022 |
3.0.1 | 1,279 | 10/21/2022 |
3.0.0 | 3,249 | 10/8/2022 |
2.6.4 | 4,307 | 9/14/2022 |
2.6.3 | 1,801 | 9/2/2022 |
2.6.2 | 4,202 | 8/6/2022 |
2.5.2 | 3,924 | 7/1/2022 |
2.5.1 | 18,883 | 6/15/2022 |
2.4.1 | 23,587 | 5/20/2022 |
2.3.3 | 1,670 | 5/14/2022 |
2.3.2 | 1,969 | 5/7/2022 |
2.3.1 | 3,806 | 4/13/2022 |
2.2.1 | 4,770 | 3/28/2022 |
2.1.4 | 1,309 | 3/23/2022 |
2.1.3 | 1,390 | 3/18/2022 |
2.1.2 | 31,253 | 2/27/2022 |
2.1.1 | 2,980 | 2/13/2022 |
2.0.3 | 1,672 | 2/7/2022 |
2.0.2 | 1,160 | 2/4/2022 |
2.0.1 | 1,564 | 1/30/2022 |
2.0.0 | 1,587 | 1/24/2022 |
1.9.4 | 1,367 | 1/19/2022 |
1.9.3 | 1,179 | 1/17/2022 |
1.9.2 | 3,272 | 1/11/2022 |
1.9.1 | 1,187 | 1/3/2022 |
1.8.3 | 995 | 12/30/2021 |
1.8.2 | 1,674 | 12/25/2021 |
1.8.1 | 1,085 | 12/21/2021 |
1.7.6 | 1,287 | 12/12/2021 |
1.7.5 | 1,241 | 12/6/2021 |
1.7.4 | 1,549 | 12/1/2021 |
1.7.3 | 2,151 | 11/27/2021 |
1.7.2 | 1,529 | 11/20/2021 |
1.7.1 | 992 | 11/10/2021 |
1.6.4 | 1,049 | 11/6/2021 |
1.6.3 | 957 | 11/3/2021 |
1.6.2 | 957 | 10/31/2021 |
1.6.1 | 978 | 10/31/2021 |
1.5.1 | 999 | 10/25/2021 |
1.4.1 | 938 | 10/20/2021 |
1.3.1 | 930 | 10/19/2021 |
1.3.0 | 999 | 10/17/2021 |
1.0.2 | 986 | 10/15/2021 |
1.0.1 | 911 | 10/11/2021 |
1.0.0 | 1,056 | 9/30/2021 |
0.9.5 | 1,028 | 9/1/2021 |
0.9.4 | 931 | 8/29/2021 |
0.9.3 | 913 | 8/24/2021 |
0.9.2 | 922 | 8/19/2021 |
0.9.1 | 969 | 8/16/2021 |
0.8.1 | 972 | 8/13/2021 |
0.7.4 | 965 | 8/10/2021 |
0.7.3 | 919 | 8/9/2021 |
0.7.1 | 1,025 | 8/8/2021 |