Lakona.Rpc.Client
0.12.0
dotnet add package Lakona.Rpc.Client --version 0.12.0
NuGet\Install-Package Lakona.Rpc.Client -Version 0.12.0
<PackageReference Include="Lakona.Rpc.Client" Version="0.12.0" />
<PackageVersion Include="Lakona.Rpc.Client" Version="0.12.0" />
<PackageReference Include="Lakona.Rpc.Client" />
paket add Lakona.Rpc.Client --version 0.12.0
#r "nuget: Lakona.Rpc.Client, 0.12.0"
#:package Lakona.Rpc.Client@0.12.0
#addin nuget:?package=Lakona.Rpc.Client&version=0.12.0
#tool nuget:?package=Lakona.Rpc.Client&version=0.12.0
Lakona.Rpc.Client
Client runtime implementation for Lakona.Rpc.
Install
dotnet add package Lakona.Rpc.Client
Documentation
API reference: https://bruce48x.github.io/Lakona.Rpc/reference/api/
Generated RpcClient reference: https://bruce48x.github.io/Lakona.Rpc/reference/generated-client/
Design boundary: https://bruce48x.github.io/Lakona.Rpc/concepts/design-boundary/
Dependencies
Lakona.Rpc.Core
Lakona.Rpc.Client has no hard dependency on concrete serializer or transport implementations.
Includes
RpcClientOptionsRpcClientRuntime- notification diagnostics through
UnhandledNotificationReceivedandNotificationHandlerException
Recommended Entry
Lakona.Rpc.Client provides the transport-agnostic runtime building blocks.
The user-facing RpcClient type is generated by Lakona.Rpc.Analyzers for each contract set.
Typical usage looks like this:
using Rpc.Generated;
var options = new RpcClientOptions(transport, serializer)
{
KeepAlive = new RpcKeepAliveOptions
{
Enabled = true,
Interval = TimeSpan.FromSeconds(15),
Timeout = TimeSpan.FromSeconds(45)
}
};
await using var client = new RpcClient(options);
await client.ConnectAsync(ct);
RpcClient.Api is generated per contract set and exposes grouped service clients after the connection is configured.
RpcClientRuntime and the generated RpcClient are single-use connection objects. After disconnecting or disposing, create a new transport, options object, and generated client for reconnect.
Server Notifications
Generated notification binders register one handler per notification method. Duplicate registration fails fast because notifications model a contract implementation, not a general event subscription list.
RpcClientRuntime accepts asynchronous notification handlers through Func<T, ValueTask>. Synchronous handlers can still use the convenience overload.
Notification handler exceptions do not disconnect the transport. Observe them through NotificationHandlerException. Server notification frames without a registered handler are reported through UnhandledNotificationReceived.
KeepAlive
RpcClientOptions.KeepAlive enables connection-level idle ping / pong and timeout detection.
- The client sends ping only when the connection is idle.
- Any inbound frame counts as activity and clears the pending timeout window.
RpcClientRuntimeexposesLastSendAt,LastReceiveAt,LastRtt, andTimedOutByKeepAlivefor diagnostics.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. 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. 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. 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. |
| .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
- Lakona.Rpc.Core (>= 0.12.0)
- System.Threading.Channels (>= 10.0.0)
-
net10.0
- Lakona.Rpc.Core (>= 0.12.0)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Lakona.Rpc.Client:
| Package | Downloads |
|---|---|
|
Lakona.Game.Cluster.Rpc
Lakona.Rpc-based node messenger adapter for Lakona.Game cluster routing. |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 0.12.0 | 35 | 6/7/2026 |