Merge.Client
0.0.6
See the version list below for details.
dotnet add package Merge.Client --version 0.0.6
NuGet\Install-Package Merge.Client -Version 0.0.6
<PackageReference Include="Merge.Client" Version="0.0.6" />
paket add Merge.Client --version 0.0.6
#r "nuget: Merge.Client, 0.0.6"
// Install Merge.Client as a Cake Addin #addin nuget:?package=Merge.Client&version=0.0.6 // Install Merge.Client as a Cake Tool #tool nuget:?package=Merge.Client&version=0.0.6
Merge .NET Library
The official Merge C# library, supporting .NET Standard, .NET Core, and .NET Framework.
Documentation
API reference documentation is available here.
Installation
Using the .NET Core command-line interface (CLI) tools:
dotnet add package Merge.Client
Using the NuGet Command Line Interface (CLI):
nuget install Merge.Client
Instantiation
Instantiate the SDK using the MergeClient
class. Note that all
of the SDK methods are awaitable!
using Merge;
using Merge.Ats;
Merge merge = new Merge(
"YOUR_API_KEY", "YOUR_ACCOUNT_TOKEN"
)
Categories
This SDK contains the ATS, HRIS, CRM, Ticketing, Accounting, and File Storage categories. Even if you do not plan on using more than one Merge API category right now, the SDK provides upgrade-flexibility in case you find new Merge API categories useful in the future.
Each category is namespaced:
Merge merge = new Merge(
"YOUR_API_KEY", "YOUR_ACCOUNT_TOKEN"
)
merge.ATS. # APIs specific to the ATS Category
merge.HRIS. # APIs specific to the HRIS Category
HTTP Client
You can override the HttpClient by passing in ClientOptions
.
merge = new Merge("YOUR_API_KEY", "YOUR_ACCOUNT_ID", new ClientOptions{
HttpClient = ... // Override the Http Client
BaseURL = ... // Override the Base URL
})
Exception Handling
When the API returns a non-zero status code, (4xx or 5xx response), a subclass of MergeException will be thrown:
using Merge;
try {
merge.Ats.Candidates.Retrieve(...);
} catch (MergeException e) {
System.Console.WriteLine(e.Message)
System.Console.WriteLine(e.StatusCode)
}
Usage
Below are code snippets of how you can use the C# SDK.
Create Link Token
using Merge;
using Merge.Ats;
Merge merge = new Merge("YOUR_API_KEY", "YOUR_ACCOUNT_TOKEN")
merge.Ats.LinkToken.Create(new EndUserDetailsRequest{
EndUserEmailAddress = "john.smith@gmail.com",
EndUserOrganizationName = "acme",
EndUserOriginId = "1234",
})
Get Employee
using Merge;
using Merge.Hris;
MergeClient merge = new Merge(
"YOUR_API_KEY", "YOUR_ACCOUNT_ID"
)
Employee employee = merge.Hris.Employees.RetrieveAsync("0958cbc6-6040-430a-848e-aafacbadf4ae",
new EmployeesRetrieveRequest{
IncludeRemoteData = true
}
);
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 merge = new Merge("...", 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 merge = new Merge("...", new ClientOptions{
TimeoutInSeconds = 20 // Lower timeout
});
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 merge 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 | 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 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. |
-
net7.0
- OneOf (>= 3.0.263)
- System.Text.Json (>= 8.0.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.0.0 | 41 | 1/23/2025 |
0.2.1 | 4,318 | 8/27/2024 |
0.2.0 | 2,972 | 8/12/2024 |
0.1.0 | 117 | 7/26/2024 |
0.0.12 | 1,598 | 7/1/2024 |
0.0.11 | 117 | 6/27/2024 |
0.0.10 | 155 | 5/31/2024 |
0.0.9 | 146 | 5/28/2024 |
0.0.8 | 122 | 5/27/2024 |
0.0.7 | 129 | 5/23/2024 |
0.0.6 | 126 | 5/22/2024 |
0.0.3 | 174 | 5/10/2024 |
0.0.2 | 462 | 4/5/2024 |
0.0.1 | 120 | 4/5/2024 |