SchematicHQ.Client 0.0.11

There is a newer version of this package available.
See the version list below for details.
dotnet add package SchematicHQ.Client --version 0.0.11                
NuGet\Install-Package SchematicHQ.Client -Version 0.0.11                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="SchematicHQ.Client" Version="0.0.11" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add SchematicHQ.Client --version 0.0.11                
#r "nuget: SchematicHQ.Client, 0.0.11"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install SchematicHQ.Client as a Cake Addin
#addin nuget:?package=SchematicHQ.Client&version=0.0.11

// Install SchematicHQ.Client as a Cake Tool
#tool nuget:?package=SchematicHQ.Client&version=0.0.11                

Schematic .NET Library

fern shield

The official Schematic C# library, supporting .NET Standard, .NET Core, and .NET Framework.

Installation

Using the .NET Core command-line interface (CLI) tools:

dotnet add package SchematicHQ.Client

Using the NuGet Command Line Interface (CLI):

nuget install SchematicHQ.Client

Instantiation

Instantiate the SDK using the Schematic client class. Note that all of the SDK methods are awaitable!

using SchematicHQ;

Schematic schematic = new Schematic("YOUR_API_KEY")

HTTP Client

You can override the HttpClient by passing in ClientOptions.

schematic = new Schematic("YOUR_API_KEY", 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 SchematicException will be thrown:

using SchematicHQ;
using SchematicHQ.Accounts;

try {
  schematic.Accounts.ListApiKeysAsync(...);
} catch (SchematicException e) {
  System.Console.WriteLine(e.Message)
  System.Console.WriteLine(e.StatusCode)
}

Usage

Below are code snippets of how you can use the C# SDK.

using SchematicHQ;
using SchematicHQ.Accounts;

SchematicClient schematic = new Schematic("YOUR_API_KEY")
Employee employee = schematic.Accounts.ListApiKeysAsync(
    new ListApiKeysRequest{
        RequireEnvironment = 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 schematic = new Schematic("...", 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 schematic = new Schematic("...", 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 schematic 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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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.2 132 8/16/2024
1.0.1 255 7/22/2024
1.0.0 111 7/1/2024
0.0.14 119 5/30/2024
0.0.13 106 5/23/2024
0.0.12 111 5/23/2024
0.0.11 112 5/22/2024
0.0.10 116 5/20/2024