Courier.Client
0.2.0
dotnet add package Courier.Client --version 0.2.0
NuGet\Install-Package Courier.Client -Version 0.2.0
<PackageReference Include="Courier.Client" Version="0.2.0" />
paket add Courier.Client --version 0.2.0
#r "nuget: Courier.Client, 0.2.0"
// Install Courier.Client as a Cake Addin #addin nuget:?package=Courier.Client&version=0.2.0 // Install Courier.Client as a Cake Tool #tool nuget:?package=Courier.Client&version=0.2.0
Courier .NET Library
The official Courier C# library, supporting .NET Standard, .NET Core, and .NET Framework.
Installation
Using the .NET Core command-line interface (CLI) tools:
dotnet add package Courier.Client
Using the NuGet Command Line Interface (CLI):
nuget install Courier.Client
Documentation
API reference documentation is available here.
Usage
Below are code snippets of how you can use the C# SDK.
using Courier.Client;
Courier courier = new Courier("YOUR_API_KEY")
Agent agent = courier.SendAsync(
new SendMessageRequest {
...
}
);
Exception Handling
When the API returns a non-zero status code, (4xx or 5xx response), a subclass of CourierException will be thrown:
using Courier.Client;
try {
courier.SendAsync(...);
} catch (CourierException e) {
System.Console.WriteLine(e.Message)
System.Console.WriteLine(e.StatusCode)
}
Advanced
Retries
429 Rate Limit, and >=500 Internal errors will all be retried twice with exponential backoff. You can override this behavior globally or per-request.
var courier = new Courier("...", new ClientOptions {
MaxRetries = 1 // Only retry once
});
Timeouts
The SDK defaults to a 60s timeout. You can override this behaviour globally or per-request.
var courier = new Courier("...", new ClientOptions {
TimeoutInSeconds = 20 // Lower timeout
});
HTTP Client
You can override the HttpClient by passing in ClientOptions
.
var courier = new Courier("YOUR_API_KEY", new ClientOptions {
HttpClient = ... // Override the Http Client
BaseURL = ... // Override the Base URL
})
Contributing
While we value open-source contributions to this SDK, this library is generated programmatically. Additions made directly to this library would have to be moved over to our generation code, otherwise they would be overwritten upon the next generated release. Feel free to open a PR as a proof of concept, but know that we will not be able to Courier it as-is. We suggest opening an issue first to discuss with us!
On the other hand, contributions to the README are always very welcome!
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 | 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 is compatible. 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. |
-
.NETFramework 4.6.2
- OneOf (>= 3.0.263)
- OneOf.Extended (>= 3.0.263)
- Portable.System.DateTimeOnly (>= 8.0.1)
- System.Text.Json (>= 8.0.5)
-
.NETStandard 2.0
- OneOf (>= 3.0.263)
- OneOf.Extended (>= 3.0.263)
- Portable.System.DateTimeOnly (>= 8.0.1)
- System.Text.Json (>= 8.0.5)
-
net6.0
- OneOf (>= 3.0.263)
- OneOf.Extended (>= 3.0.263)
- System.Text.Json (>= 8.0.5)
-
net7.0
- OneOf (>= 3.0.263)
- OneOf.Extended (>= 3.0.263)
- System.Text.Json (>= 8.0.5)
-
net8.0
- OneOf (>= 3.0.263)
- OneOf.Extended (>= 3.0.263)
- System.Text.Json (>= 8.0.5)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.