WTelegramClient.Extensions.Updates
1.1.0
See the version list below for details.
dotnet add package WTelegramClient.Extensions.Updates --version 1.1.0
NuGet\Install-Package WTelegramClient.Extensions.Updates -Version 1.1.0
<PackageReference Include="WTelegramClient.Extensions.Updates" Version="1.1.0" />
paket add WTelegramClient.Extensions.Updates --version 1.1.0
#r "nuget: WTelegramClient.Extensions.Updates, 1.1.0"
// Install WTelegramClient.Extensions.Updates as a Cake Addin #addin nuget:?package=WTelegramClient.Extensions.Updates&version=1.1.0 // Install WTelegramClient.Extensions.Updates as a Cake Tool #tool nuget:?package=WTelegramClient.Extensions.Updates&version=1.1.0
WTelegramClient.Extensions.Updates
Simple Set of Extensions For Easier Update Handling In WTelegramClient
Install
dotnet cli: dotnet add package WTelegramClient.Extensions.Updates --version 1.1.0
nuget: NuGet\Install-Package WTelegramClient.Extensions.Updates -Version 1.1.0
reference: <PackageReference Include="WTelegramClient.Extensions.Updates" Version="1.1.0" />
Examples :
<i> Filter For New Messages From Channel : </i>
var client = new Client(/*provide the config..*/);
await client.LoginUserIfNeeded();
client.RegisterUpdateType<UpdateNewChannelMessage>((channelMessage, updatesBase) =>
{
Console.WriteLine("Message In : " + channelMessage.message.Date.ToString("F"));
});
<i> Or Listen For New Message From Channel <b>AND</b> Deleted Messages : </i>
client.RegisterUpdateType<UpdateNewChannelMessage, UpdateDeleteChannelMessages>(update, updatesBase) =>
{
Console.WriteLine("type of new update is" + p.GetType());
});
<i> You Can Register a Specific Chat Type With Passing a Peer
Type : </i>
await client.RegisterChatTypeAsync<PeerChannel>((update, channel) =>
{
Console.WriteLine($"RegisterChatTypeAsync:PeerChannel: {channel.channel_id} with type : {update.GetType()}");
return Task.CompletedTask;
});
<i> Also You Can Search For A Specific ID
Inside Of Upcoming Updates(Including Update Type) : </i>
client.RegisterUpdateWithId<UpdateUserTyping>(121212, (update, upBase) =>
{
Console.WriteLine($"user is typing : {update.user_id}");
});
Blocking
currently all of the mentioned methods will NOT block the current thread, so they has to be called at the startup
of your application and then the flow of your problem should be blocked somewhere else.
using the *Block
overloads of these methods you can block your current thread:
// this is NOT going to block the current thread
client.RegisterUpdateType<UpdateNewChannelMessage>(async (messages, upBase) =>
{
await Task.Delay(2, cancellationToken);
Console.WriteLine($"new message");
});
//this WILL block the thread so the code will not continue after this point until the cancelation token is requested
client.RegisterUpdateTypeBlocking<UpdateNewChannelMessage>(async (messages, upBase) =>
{
await Task.Delay(2, cancellationToken);
Console.WriteLine($"new message");
}, cancellationToken); // the token is also optional, you can skip it
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. 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. net6.0-windows7.0 is compatible. net7.0 is compatible. 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. net7.0-windows7.0 is compatible. net8.0 is compatible. 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. net8.0-windows7.0 is compatible. |
-
net6.0
- WTelegramClient (>= 3.6.3)
-
net6.0-windows7.0
- WTelegramClient (>= 3.6.3)
-
net7.0
- WTelegramClient (>= 3.6.3)
-
net7.0-windows7.0
- WTelegramClient (>= 3.6.3)
-
net8.0
- WTelegramClient (>= 3.6.3)
-
net8.0-windows7.0
- WTelegramClient (>= 3.6.3)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.2.2 | 647 | 3/18/2024 |
1.2.1 | 120 | 3/18/2024 |
1.2.0 | 100 | 3/18/2024 |
1.1.0 | 274 | 1/8/2024 |
1.0.2 | 741 | 3/8/2023 |
1.0.1 | 441 | 2/10/2023 |
0.1.3-preview | 221 | 10/27/2022 |
0.1.2-preview | 198 | 8/14/2022 |
0.1.1-preview | 196 | 8/7/2022 |
0.1.0-preview | 191 | 8/7/2022 |