ULinkRPC.Client
0.12.0
dotnet add package ULinkRPC.Client --version 0.12.0
NuGet\Install-Package ULinkRPC.Client -Version 0.12.0
<PackageReference Include="ULinkRPC.Client" Version="0.12.0" />
<PackageVersion Include="ULinkRPC.Client" Version="0.12.0" />
<PackageReference Include="ULinkRPC.Client" />
paket add ULinkRPC.Client --version 0.12.0
#r "nuget: ULinkRPC.Client, 0.12.0"
#:package ULinkRPC.Client@0.12.0
#addin nuget:?package=ULinkRPC.Client&version=0.12.0
#tool nuget:?package=ULinkRPC.Client&version=0.12.0
ULinkRPC.Client
Client runtime implementation for ULinkRPC.
Install
dotnet add package ULinkRPC.Client
Documentation
API reference: https://bruce48x.github.io/ULinkRPC/reference/api/
Generated RpcClient reference: https://bruce48x.github.io/ULinkRPC/reference/generated-client/
Design boundary: https://bruce48x.github.io/ULinkRPC/concepts/design-boundary/
Dependencies
ULinkRPC.Core
ULinkRPC.Client has no hard dependency on concrete serializer or transport implementations.
Includes
RpcClientOptionsRpcClientRuntime- notification diagnostics through
UnhandledNotificationReceivedandNotificationHandlerException
Recommended Entry
ULinkRPC.Client provides the transport-agnostic runtime building blocks.
The user-facing RpcClient type is generated by ULinkRPC.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
- System.Threading.Channels (>= 10.0.0)
- ULinkRPC.Core (>= 0.12.0)
-
net10.0
- ULinkRPC.Core (>= 0.12.0)
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 |
|---|