AssemblyAI 0.0.2-alpha

This is a prerelease version of AssemblyAI.
dotnet add package AssemblyAI --version 0.0.2-alpha                
NuGet\Install-Package AssemblyAI -Version 0.0.2-alpha                
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="AssemblyAI" Version="0.0.2-alpha" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add AssemblyAI --version 0.0.2-alpha                
#r "nuget: AssemblyAI, 0.0.2-alpha"                
#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 AssemblyAI as a Cake Addin
#addin nuget:?package=AssemblyAI&version=0.0.2-alpha&prerelease

// Install AssemblyAI as a Cake Tool
#tool nuget:?package=AssemblyAI&version=0.0.2-alpha&prerelease                

WIP! AssemblyAI C# SDK

NuGet fern shield GitHub License AssemblyAI Twitter AssemblyAI YouTube Discord

[!WARNING]
We are actively working on the .NET SDK for AssemblyAI. Watch the C# SDK repo, specifically the releases, so you get notified when we have our first release. <img width="441" alt="Screenshot 2024-01-25 at 2 27 59 PM" src="https://github.com/AssemblyAI/assemblyai-semantic-kernel/assets/3382717/5e3af901-26f6-4910-bd86-31e4f07deab1">

The official AssemblyAI C# library, supporting .NET Standard 3.0+, .NET Core 3.0+, and .NET Framework 4.6.1+.

Documentation

API reference documentation is available here.

Installation

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

dotnet add package AssemblyAI.Client

Using the NuGet Command Line Interface (CLI):

nuget install AssemblyAI.Client

Using the Package Manager Console:

Install-Package AssemblyAI.Client

Usage

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

  using AssemblyaAI;

  AssemblyAI aai = new AssemblyAI("YOUR_API_KEY")
  TranscriptResponse transcript = 
      await aai.Transcript.get("transcript_id");
  System.Console.WriteLine("Received transcript!", transcript);

HTTP Client

You can override the HttpClient by passing in ClientOptions.

aai = new AssemblyAI("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 AssemblyAIException will be thrown:

try {
  aai.transcript.create(...);    
} catch (AssemblyAIException e) {
  System.Console.WriteLine(e.Message) 
  System.Console.WriteLine(e.StatusCode) 
}

Retries

409 Conflict, 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 aai = new AssemblyAI("...", new ClientOptions{
    MaxRetries = 1 // Only retry once
});
aai.transcript.create(new TranscriptCreateParams{ ... }, new RequestOptions {
    MaxRetries = 0 // Disable retries
});

Timeouts

The SDK defaults to a 60s timeout. You can override this behaviour globally or per-request.

var aai = new AssemblyAI("...", new ClientOptions{
    TimeoutInSeconds = 20 // Lower timeout
});
aai.transcript.create(new TranscriptCreateParams{ ... }, new RequestOptions {
    TimeoutInSeconds = 90 // Raise 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 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. 
.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. 
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
0.0.2-alpha 40 7/16/2024
0.0.1-alpha 52 6/21/2024