Remora.Discord.Gateway
12.0.2
Prefix Reserved
dotnet add package Remora.Discord.Gateway --version 12.0.2
NuGet\Install-Package Remora.Discord.Gateway -Version 12.0.2
<PackageReference Include="Remora.Discord.Gateway" Version="12.0.2" />
paket add Remora.Discord.Gateway --version 12.0.2
#r "nuget: Remora.Discord.Gateway, 12.0.2"
// Install Remora.Discord.Gateway as a Cake Addin #addin nuget:?package=Remora.Discord.Gateway&version=12.0.2 // Install Remora.Discord.Gateway as a Cake Tool #tool nuget:?package=Remora.Discord.Gateway&version=12.0.2
Remora.Discord.Gateway
This package provides a fully-featured implementation of a Discord gateway client, complete with resume capabilities and user-facing events.
Structure
The package consists of two main parts - the client itself, and the event dispatch system. The latter will be familiar to users of the mediator pattern, wherein an intermediate type handles communication between separate objects; in Remora.Discord.Gateway's case, all incoming Discord events are dispatched and executed concurrently with each other, and the user may register responders to handle these events.
Provided you yourself do not inject services with a shared mutable state, all responders are thread-safe and do not require additional synchronization through semaphores or mutexes.
The client is a singleton service by design.
Usage
First and foremost, the gateway client must be registered with your dependency injection container.
services.AddDiscordGateway(serviceProvider => GetTokenFromSomewhere(serviceProvider));
Two things to note:
- You are not required to call any other methods from dependency libraries
(such as
Remora.Discord.API
) - this call takes care of all transitive dependencies itself. - You must, at this point, provide a way to access your bot's token in plain text. This access only happens after the container is constructed, and an API instance is requested, so you have access to the built container.
After this point, you may inject the gateway client into your own services. In
order to connect and start dispatching events, you must call RunAsync
somewhere, and subsequently either await the task directly or store it for later
use. This task represents the entire lifetime of the gateway client, and will
run until you explicitly request its termination via the cancellation token
passed to this method.
If you wish to explicitly send a gateway command (for example, to update
presence information), you may do so via the SubmitCommand
method on the
client. Note that no validations are performed on this command, so you can cause
unexpected termination of your session if the data is malformed or inappropriate
for the current state of the client.
Responders - the types which react to and handle incoming events - are created
by declaring a class that implements one or more instances of the
IResponder<T>
interface, and then registering these types with the service
container.
public class MyResponder : IResponder<IMessageCreate>
{
public async Task<Result> RespondAsync
(
IMessageCreate gatewayEvent,
CancellationToken ct = default
)
{
// ...
}
}
...
services.AddResponder<MyResponder>();
There are no restrictions placed on how long an individual responder may run, but you should strive to keep it short in order to avoid thread pool exhaustion.
Responders have no guarantees related to sequential execution, but you are able to sort them into one of three "groups", which do run sequentially to one another.
services.AddResponder<MyResponder>(ResponderGroup.Early); // executes before...
services.AddResponder<MyResponder>(ResponderGroup.Normal); // executes before...
services.AddResponder<MyResponder>(ResponderGroup.Late);
This is useful in cases where two responders to the same event depend on each other in some way.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. 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. 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. 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. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.1 is compatible. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | 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.1
- CommunityToolkit.HighPerformance (>= 8.2.2)
- Remora.Discord.Rest (>= 51.0.0)
- Remora.Extensions.Options.Immutable (>= 1.0.8)
- System.Threading.Channels (>= 8.0.0)
-
net6.0
- CommunityToolkit.HighPerformance (>= 8.2.2)
- Remora.Discord.Rest (>= 51.0.0)
- Remora.Extensions.Options.Immutable (>= 1.0.8)
- System.Threading.Channels (>= 8.0.0)
-
net7.0
- CommunityToolkit.HighPerformance (>= 8.2.2)
- Remora.Discord.Rest (>= 51.0.0)
- Remora.Extensions.Options.Immutable (>= 1.0.8)
- System.Threading.Channels (>= 8.0.0)
-
net8.0
- CommunityToolkit.HighPerformance (>= 8.2.2)
- Remora.Discord.Rest (>= 51.0.0)
- Remora.Extensions.Options.Immutable (>= 1.0.8)
- System.Threading.Channels (>= 8.0.0)
NuGet packages (7)
Showing the top 5 NuGet packages that depend on Remora.Discord.Gateway:
Package | Downloads |
---|---|
Remora.Discord.Commands
Glue code for using Remora.Commands with Remora.Discord |
|
Remora.Discord.Hosting
Implementation of a hosted Discord gateway service for the .NET Generic Host |
|
Remora.Discord.Interactivity
Framework for using Discord's interaction-driven message components |
|
Remora.Discord.Extensions
Utilities and components which extend upon Remora.Discord's base resources |
|
Remora.Discord.Caching
Caching implementations of Remora.Discord's services |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated | |
---|---|---|---|
12.0.2 | 42,990 | 5/28/2024 | |
12.0.1 | 26,072 | 2/5/2024 | |
12.0.0 | 47,649 | 11/14/2023 | |
11.1.0 | 29,873 | 7/24/2023 | |
11.0.7 | 19,267 | 5/11/2023 | |
11.0.6 | 2,856 | 3/20/2023 | |
11.0.5 | 3,487 | 1/19/2023 | |
11.0.4 | 2,848 | 1/10/2023 | |
11.0.3 | 3,209 | 12/28/2022 | |
11.0.2 | 5,819 | 12/10/2022 | |
11.0.1 | 3,548 | 10/30/2022 | |
11.0.0 | 19,955 | 9/2/2022 | |
10.1.7 | 3,571 | 8/19/2022 | |
10.1.6 | 3,429 | 7/28/2022 | |
10.1.5 | 3,333 | 7/26/2022 | |
10.1.4 | 3,162 | 7/26/2022 | |
10.1.3 | 7,127 | 6/29/2022 | |
10.1.2 | 3,206 | 6/27/2022 | |
10.1.1 | 3,506 | 6/23/2022 | |
10.1.0 | 4,153 | 6/20/2022 | |
10.0.0 | 3,218 | 6/19/2022 | |
9.0.0 | 3,237 | 6/18/2022 | |
8.1.5 | 3,274 | 6/14/2022 | |
8.1.4 | 3,255 | 6/8/2022 | |
8.1.3 | 3,251 | 6/3/2022 | |
8.1.2 | 3,240 | 5/25/2022 | |
8.1.1 | 3,232 | 5/23/2022 | |
8.1.0 | 3,449 | 5/15/2022 | |
8.0.6 | 3,337 | 5/10/2022 | |
8.0.5 | 5,570 | 5/3/2022 | |
8.0.4 | 6,612 | 4/25/2022 | |
8.0.3 | 4,009 | 4/18/2022 | |
8.0.2 | 2,880 | 4/2/2022 | |
8.0.1 | 5,060 | 4/2/2022 | |
8.0.0 | 3,480 | 3/21/2022 | |
7.2.0 | 3,308 | 3/17/2022 | |
7.1.0 | 2,965 | 3/15/2022 | |
7.0.1 | 4,425 | 2/20/2022 | |
7.0.0 | 3,035 | 2/19/2022 | |
7.0.0-rc1 | 1,179 | 2/14/2022 | |
6.2.10 | 3,081 | 2/14/2022 | |
6.2.9 | 3,284 | 1/27/2022 | |
6.2.7 | 5,170 | 1/11/2022 | |
6.2.6 | 35,520 | 1/2/2022 | |
6.2.5 | 3,175 | 12/23/2021 | |
6.2.4 | 1,403 | 12/21/2021 | |
6.2.3 | 1,627 | 12/16/2021 | |
6.2.2 | 1,498 | 12/11/2021 | |
6.2.1 | 1,661 | 12/5/2021 | |
6.2.0 | 3,286 | 11/26/2021 | |
6.1.0 | 7,199 | 11/24/2021 | |
6.0.0 | 2,524 | 11/20/2021 | |
5.0.4 | 2,196 | 11/9/2021 | |
5.0.3 | 2,000 | 11/6/2021 | |
5.0.2 | 2,310 | 10/30/2021 | |
5.0.1 | 1,667 | 10/28/2021 | |
5.0.0 | 3,901 | 10/15/2021 | |
4.0.15 | 2,281 | 10/7/2021 | |
4.0.13 | 1,823 | 10/3/2021 | |
4.0.12 | 1,633 | 10/2/2021 | |
4.0.11 | 1,571 | 9/30/2021 | |
4.0.10 | 2,203 | 9/26/2021 | |
4.0.9 | 1,649 | 9/24/2021 | |
4.0.8 | 1,663 | 9/23/2021 | |
4.0.7 | 1,649 | 9/16/2021 | |
4.0.6 | 1,726 | 9/15/2021 | |
4.0.5 | 1,795 | 9/8/2021 | |
4.0.4 | 2,988 | 9/4/2021 | |
4.0.3 | 3,339 | 8/21/2021 | |
4.0.2 | 1,831 | 8/18/2021 | |
4.0.1 | 2,761 | 8/12/2021 | |
4.0.0 | 1,468 | 8/11/2021 | |
3.5.8 | 2,010 | 8/11/2021 | |
3.5.7 | 1,882 | 8/2/2021 | |
3.5.6 | 2,118 | 8/2/2021 | |
3.5.5 | 2,179 | 7/31/2021 | |
3.5.4 | 1,714 | 7/29/2021 | |
3.5.3 | 1,644 | 7/28/2021 | |
3.5.2 | 1,565 | 7/28/2021 | |
3.5.1 | 2,082 | 7/22/2021 | |
3.5.0 | 1,713 | 7/17/2021 | |
3.4.6 | 1,647 | 7/14/2021 | |
3.4.5 | 1,784 | 7/12/2021 | |
3.4.4 | 1,684 | 7/11/2021 | |
3.4.3 | 1,688 | 7/5/2021 | |
3.4.2 | 1,544 | 7/3/2021 | |
3.4.1 | 1,554 | 7/1/2021 | |
3.4.0 | 1,871 | 6/14/2021 | |
3.3.1 | 849 | 6/10/2021 | |
3.3.1-beta2 | 1,063 | 5/30/2021 | |
3.3.1-beta1 | 1,471 | 5/28/2021 | |
3.3.0 | 1,545 | 5/23/2021 | |
3.2.1 | 1,721 | 5/20/2021 | |
3.2.0 | 2,052 | 5/4/2021 | |
3.1.14 | 1,700 | 4/22/2021 | |
3.1.13 | 1,676 | 4/15/2021 | |
3.1.12 | 1,690 | 4/10/2021 | |
3.1.11 | 1,847 | 4/5/2021 | |
3.1.10 | 1,748 | 4/4/2021 | |
3.1.9 | 2,351 | 3/28/2021 | |
3.1.8 | 2,603 | 3/25/2021 | |
3.1.7 | 1,462 | 3/25/2021 | |
3.1.6 | 2,202 | 3/16/2021 | |
3.1.5 | 1,660 | 3/14/2021 | |
3.1.4 | 1,628 | 3/13/2021 | |
3.1.3 | 1,645 | 3/11/2021 | |
3.1.2 | 1,953 | 3/6/2021 | |
3.1.1 | 1,737 | 3/1/2021 | |
3.1.0 | 1,711 | 3/1/2021 | |
3.0.7 | 1,803 | 2/28/2021 | |
3.0.6 | 1,517 | 2/23/2021 | |
3.0.5 | 2,103 | 2/22/2021 | |
3.0.4 | 1,654 | 2/21/2021 | |
3.0.3 | 1,353 | 2/16/2021 | |
3.0.2 | 1,766 | 2/13/2021 | |
3.0.1 | 1,972 | 2/11/2021 | |
3.0.0 | 1,671 | 2/10/2021 | |
2.2.3 | 1,507 | 2/6/2021 | |
2.2.2 | 1,557 | 2/5/2021 | |
2.2.1 | 1,489 | 1/29/2021 | |
2.2.0 | 1,466 | 1/27/2021 | |
2.1.1 | 1,802 | 1/21/2021 | |
2.1.0 | 1,679 | 1/17/2021 | |
2.0.1 | 1,582 | 1/10/2021 | |
2.0.0 | 1,693 | 1/10/2021 | |
1.1.2 | 1,633 | 1/9/2021 | |
1.1.1 | 1,779 | 12/31/2020 | |
1.1.0 | 1,649 | 12/27/2020 | |
1.0.1 | 2,201 | 12/25/2020 | |
1.0.0 | 1,467 | 12/25/2020 | |
1.0.0-beta9 | 1,026 | 12/10/2020 | |
1.0.0-beta8 | 1,013 | 11/26/2020 | |
1.0.0-beta7 | 972 | 11/15/2020 | |
1.0.0-beta6 | 966 | 11/14/2020 | |
1.0.0-beta5 | 1,042 | 11/8/2020 | |
1.0.0-beta4 | 460 | 11/8/2020 | |
1.0.0-beta3 | 403 | 10/17/2020 | |
1.0.0-beta2 | 401 | 10/6/2020 | |
1.0.0-beta11 | 943 | 12/23/2020 | |
1.0.0-beta10 | 1,001 | 12/18/2020 | |
1.0.0-beta1 | 409 | 10/6/2020 | |
1.0.0-alpha1 | 402 | 9/27/2020 |
Update dependencies.
Handle reconnection requests on connect.