SwarmUI.ApiClient
0.5.0-beta
See the version list below for details.
dotnet add package SwarmUI.ApiClient --version 0.5.0-beta
NuGet\Install-Package SwarmUI.ApiClient -Version 0.5.0-beta
<PackageReference Include="SwarmUI.ApiClient" Version="0.5.0-beta" />
<PackageVersion Include="SwarmUI.ApiClient" Version="0.5.0-beta" />
<PackageReference Include="SwarmUI.ApiClient" />
paket add SwarmUI.ApiClient --version 0.5.0-beta
#r "nuget: SwarmUI.ApiClient, 0.5.0-beta"
#:package SwarmUI.ApiClient@0.5.0-beta
#addin nuget:?package=SwarmUI.ApiClient&version=0.5.0-beta&prerelease
#tool nuget:?package=SwarmUI.ApiClient&version=0.5.0-beta&prerelease
SwarmUI API Client Library
Professional C# client library for SwarmUI API
🚧 v0.5.0-beta 🚧
SwarmUI.ApiClient is a strongly-typed C# wrapper around the SwarmUI API, providing first-class support for text-to-image generation, model management, presets, user data, backends, and admin operations. The core implementation is in place and covered by unit tests; the API surface may still evolve before a 1.0.0 stable release.
Project Structure
SwarmUI.ApiClient/
├── SwarmClient.cs # Main client class
├── ISwarmClient.cs # Main client interface
├── SwarmClientOptions.cs # Configuration options
│
├── Sessions/ # Session management
│ ├── ISessionManager.cs
│ └── SessionManager.cs
│
├── Http/ # HTTP communication
│ ├── ISwarmHttpClient.cs
│ └── SwarmHttpClient.cs
│
├── WebSockets/ # WebSocket streaming
│ ├── ISwarmWebSocketClient.cs
│ └── SwarmWebSocketClient.cs
│
├── Endpoints/ # API endpoint groups
│ ├── Generation/ # Text-to-image generation
│ ├── Models/ # Model management
│ ├── Backends/ # Backend servers
│ ├── Presets/ # Parameter presets
│ ├── User/ # User settings
│ └── Admin/ # Admin operations
│
├── Models/ # Data models
│ ├── Requests/ # Request models
│ ├── Responses/ # Response models
│ └── Common/ # Shared models
│
├── Exceptions/ # Custom exceptions
│ ├── SwarmException.cs
│ ├── SwarmSessionException.cs
│ ├── SwarmAuthenticationException.cs
│ └── SwarmWebSocketException.cs
│
└── Extensions/ # DI extensions
└── ServiceCollectionExtensions.cs
Changelog
This README gives a high level snapshot. For detailed release notes, see:
Highlights for the current beta:
- First beta of
SwarmUI.ApiClient: typed wrapper around SwarmUI HTTP + WebSocket APIs. - Core infrastructure implemented:
SwarmClientOptions,SessionManager,SwarmHttpClient,SwarmWebSocketClient, and theSwarmClientfacade. - Endpoint coverage for generation, models, backends, presets, user, and admin operations.
- Unit tests in the
SwarmTestsproject cover HTTP behavior, sessions, streaming generation, model management, presets, and client wiring.
Upcoming Features
Planned improvements for future releases include:
- Retry and resilience policies using Polly (configurable via
SwarmClientOptions). - Integration tests against a real SwarmUI instance.
- Optional examples project / samples that mirror the docs.
- CI/CD pipeline for automated build, test, pack, and publish to NuGet.
- Potential multi targeting support for additional .NET versions.
Usage
Standalone Usage
SwarmClientOptions options = new SwarmClientOptions
{
BaseUrl = "https://hartsy.ai",
Authorization = "your-api-key"
};
using SwarmClient client = new SwarmClient(options);
GenerationRequest request = new GenerationRequest
{
Prompt = "A beautiful sunset over mountains",
Model = "flux-dev",
Width = 1024,
Height = 768
};
await foreach (GenerationUpdate update in client.Generation.StreamGenerationAsync(request))
{
if (update.Type == "progress")
Console.WriteLine($"Progress: {update.Progress.CurrentPercent}%");
else if (update.Type == "image")
SaveImage(update.Image.Image);
}
Dependency Injection Usage
// Program.cs
builder.Services.AddSwarmClient(options =>
{
options.BaseUrl = "https://hartsy.ai";
options.Authorization = builder.Configuration["SwarmAuth"];
});
// YourService.cs
public class ImageService(ISwarmClient swarm)
{
public async Task GenerateAsync()
{
// Use swarm...
}
}
Contributing
This library follows strict coding guidelines:
- No
varkeyword - always use explicit types - No
privatefields - use publicImplstruct pattern - All public members must have XML documentation
- Follow .NET naming conventions
- Use
ConfigureAwait(false)in library code
See detailed guidelines in Docs/CodingGuidelines.md.
Real-World Usage Examples
The HartsyWeb application uses SwarmUI.ApiClient in production for both internal and external APIs. For example, an ASP.NET Core controller can stream generation updates to the client using Server-Sent Events (SSE):
[ApiController]
[Route("api/swarm")]
public class GenerateController(ISwarmClient swarmClient) : ControllerBase
{
[HttpPost("generate")]
public async Task Generate([FromBody] GenerationRequest request, CancellationToken cancellationToken)
{
Response.Headers.Append("Content-Type", "text/event-stream");
await foreach (GenerationUpdate update in swarmClient.Generation.StreamGenerationAsync(request, cancellationToken))
{
// Write SSE event data and flush the response stream here.
}
}
}
See the HartsyWeb repository for full controller implementations and additional end-to-end examples.
License
MIT License. See the LICENSE file in this folder.
Links
- SwarmUI: https://github.com/mcmonkeyprojects/SwarmUI
- SwarmUI API Docs: https://github.com/mcmonkeyprojects/SwarmUI/blob/master/docs/API.md
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | 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. net10.0 was computed. 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. |
-
net8.0
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.0)
- Microsoft.Extensions.Http (>= 8.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.0)
- Microsoft.Extensions.Options (>= 8.0.0)
- Newtonsoft.Json (>= 13.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 |
|---|---|---|
| 0.6.1-beta | 45 | 6/18/2026 |
| 0.6.0-beta | 68 | 5/13/2026 |
| 0.5.0-beta | 87 | 3/19/2026 |