HagiCode.Libs.Providers
0.1.1-dev.30.1
See the version list below for details.
dotnet add package HagiCode.Libs.Providers --version 0.1.1-dev.30.1
NuGet\Install-Package HagiCode.Libs.Providers -Version 0.1.1-dev.30.1
<PackageReference Include="HagiCode.Libs.Providers" Version="0.1.1-dev.30.1" />
<PackageVersion Include="HagiCode.Libs.Providers" Version="0.1.1-dev.30.1" />
<PackageReference Include="HagiCode.Libs.Providers" />
paket add HagiCode.Libs.Providers --version 0.1.1-dev.30.1
#r "nuget: HagiCode.Libs.Providers, 0.1.1-dev.30.1"
#:package HagiCode.Libs.Providers@0.1.1-dev.30.1
#addin nuget:?package=HagiCode.Libs.Providers&version=0.1.1-dev.30.1&prerelease
#tool nuget:?package=HagiCode.Libs.Providers&version=0.1.1-dev.30.1&prerelease
HagiCode.Libs.Providers
HagiCode.Libs.Providers builds on HagiCode.Libs.Core and adds reusable provider abstractions plus built-in integrations for Claude Code, Copilot, Codex, DeepAgents, CodeBuddy, Hermes, Kimi, Kiro, and QoderCLI.
What is included
- The
ICliProviderandICliProvider<TOptions>contracts for provider-oriented integrations - Built-in provider implementations for the supported HagiCode CLI backends
AddHagiCodeLibs()for dependency injection registration- A provider registry for resolving providers by name or alias
- Registration of the shared
ICliExecutionFacadefor provider-side probes or adapters - Registration of the shared
CliProviderPoolCoordinator, provider-scoped pool defaults, and ACP/runtime reuse backends
Install
dotnet add package HagiCode.Libs.Providers
If your application uses dependency injection, also reference Microsoft.Extensions.DependencyInjection.
Dependency injection entry point
using HagiCode.Libs.Core.Execution;
using HagiCode.Libs.Providers;
using HagiCode.Libs.Providers.Codebuddy;
using HagiCode.Libs.Providers.Copilot;
using HagiCode.Libs.Providers.Codex;
using HagiCode.Libs.Providers.DeepAgents;
using HagiCode.Libs.Providers.Hermes;
using HagiCode.Libs.Providers.Kimi;
using HagiCode.Libs.Providers.Kiro;
using Microsoft.Extensions.DependencyInjection;
var services = new ServiceCollection();
services.AddHagiCodeLibs();
await using var serviceProvider = services.BuildServiceProvider();
var executionFacade = serviceProvider.GetRequiredService<ICliExecutionFacade>();
var codebuddy = serviceProvider.GetRequiredService<ICliProvider<CodebuddyOptions>>();
var copilot = serviceProvider.GetRequiredService<ICliProvider<CopilotOptions>>();
var codex = serviceProvider.GetRequiredService<ICliProvider<CodexOptions>>();
var deepAgents = serviceProvider.GetRequiredService<ICliProvider<DeepAgentsOptions>>();
var hermes = serviceProvider.GetRequiredService<ICliProvider<HermesOptions>>();
var kimi = serviceProvider.GetRequiredService<ICliProvider<KimiOptions>>();
var kiro = serviceProvider.GetRequiredService<ICliProvider<KiroOptions>>();
The same DI graph also exposes the shared pool services when advanced callers need diagnostics or explicit cleanup:
using HagiCode.Libs.Providers.Pooling;
var poolCoordinator = serviceProvider.GetRequiredService<CliProviderPoolCoordinator>();
var poolDefaults = serviceProvider.GetRequiredService<CliProviderPoolConfigurationRegistry>();
Shared adapter parity
Claude Code、CodeBuddy、Hermes 现在与 hagicode-core 的对应 provider 薄适配层共享同一套 libs-backed 实现。重点是:
Claude Code继续保留 raw stream / resume 语义,但真实执行与 warm transport reuse 统一落在ClaudeCodeProviderCodeBuddy的 ACP session reuse、tool update 归一化与 permission-mode 映射统一落在CodebuddyProviderHermes的 ACP session reuse、fallback 文本聚合与 lifecycle 诊断统一落在HermesProvider
ProviderRegistry 的规范名称与兼容别名也已统一:
claude-code→claude,claudecode,anthropic-claudecodebuddy→codebuddy-clideepagents→deepagents-acphermes→hermes-cli
Provider usage
using HagiCode.Libs.Providers.Copilot;
using HagiCode.Libs.Providers.Codex;
using HagiCode.Libs.Providers.Codebuddy;
using HagiCode.Libs.Providers.DeepAgents;
using HagiCode.Libs.Providers.Hermes;
using HagiCode.Libs.Providers.Kimi;
using HagiCode.Libs.Providers.Kiro;
var codebuddyOptions = new CodebuddyOptions
{
WorkingDirectory = "/path/to/repo",
SessionId = "codebuddy-session-123",
ModeId = "plan",
Model = "glm-4.7"
};
await foreach (var message in codebuddy.ExecuteAsync(codebuddyOptions, "Reply with exactly the word 'pong'"))
{
Console.WriteLine($"{message.Type}: {message.Content}");
}
var hermesOptions = new HermesOptions
{
WorkingDirectory = "/path/to/repo",
SessionId = "hermes-session-123",
ModeId = "analysis",
Model = "hermes/default",
Arguments = ["acp"]
};
await foreach (var message in hermes.ExecuteAsync(hermesOptions, "Reply with exactly the word 'pong'"))
{
Console.WriteLine($"{message.Type}: {message.Content}");
}
var copilotOptions = new CopilotOptions
{
WorkingDirectory = "/path/to/repo",
Model = "claude-sonnet-4.5",
SessionId = "copilot-session-123",
Permissions = new CopilotPermissionOptions
{
AllowAllTools = true,
AllowedPaths = ["/path/to/repo"]
},
AdditionalArgs = ["--config-dir", "/path/to/.copilot"]
};
await foreach (var message in copilot.ExecuteAsync(copilotOptions, "Reply with exactly the word 'pong'"))
{
Console.WriteLine($"{message.Type}: {message.Content}");
}
// Reuse a persisted provider-native Copilot conversation on the next call.
var resumedOptions = copilotOptions with { SessionId = "copilot-session-123" };
// Without SessionId, Copilot requests stay anonymous; WorkingDirectory only affects
// compatibility checks and will not hit the shared pool by itself.
var options = new CodexOptions
{
WorkingDirectory = "/path/to/repo",
Model = "gpt-5-codex",
SandboxMode = "workspace-write",
ApprovalPolicy = "never",
LogicalSessionKey = "session-123|/path/to/repo|codex|gpt-5-codex",
AddDirectories = ["/path/to/repo"],
SkipGitRepositoryCheck = true,
};
await foreach (var message in codex.ExecuteAsync(options, "Reply with exactly the word 'pong'"))
{
Console.WriteLine($"{message.Type}: {message.Content}");
}
var deepAgentsOptions = new DeepAgentsOptions
{
Model = "glm-5.1",
WorkspaceRoot = "/path/to/repo",
AgentName = "coding-assistant",
AgentDescription = "Repo-aware DeepAgents ACP runner",
SkillsDirectories = ["/path/to/skills"],
ExtraArguments = ["--debug"]
};
await foreach (var message in deepAgents.ExecuteAsync(deepAgentsOptions, "Reply with exactly the word 'pong'"))
{
Console.WriteLine($"{message.Type}: {message.Content}");
}
// Reuse the same logical Codex session key to keep thread continuity on later calls.
// If LogicalSessionKey and ThreadId are both absent, the request remains anonymous
// even when WorkingDirectory matches a previous call.
var kimiOptions = new KimiOptions
{
WorkingDirectory = "/path/to/repo",
Model = "kimi-k2.5",
AuthenticationMethod = "token",
AuthenticationToken = "<token>",
ExtraArguments = ["--profile", "smoke"]
};
await foreach (var message in kimi.ExecuteAsync(kimiOptions, "Reply with exactly the word 'pong'"))
{
Console.WriteLine($"{message.Type}: {message.Content}");
}
var kiroOptions = new KiroOptions
{
WorkingDirectory = "/path/to/repo",
Model = "kiro-default",
AuthenticationMethod = "token",
AuthenticationToken = "<token>",
ExtraArguments = ["--profile", "smoke"]
};
await foreach (var message in kiro.ExecuteAsync(kiroOptions, "Reply with exactly the word 'pong'"))
{
Console.WriteLine($"{message.Type}: {message.Content}");
}
Pool controls
Every built-in provider option record now exposes PoolSettings:
var qoderOptions = new QoderCliOptions
{
SessionId = "demo-session",
WorkingDirectory = "/path/to/repo",
PoolSettings = new CliPoolSettings
{
Enabled = true,
IdleTimeout = TimeSpan.FromMinutes(10),
MaxActiveSessions = 50,
KeepAnonymousSessions = false
}
};
Practical boundaries:
CodeBuddy,Gemini,Hermes,Kimi,Kiro, andQoderCLIpool live ACP sessions.DeepAgentspools live ACP sessions and fingerprints workspace plus managed launcher arguments before warm reuse.Claude Codepools warm stdio transports keyed by session or resume identity plus its effective startup shape.Codexpools workspace/thread bindings so follow-up requests can reuse the last known thread id.Copilotpools SDK runtimes per compatible workspace/configuration pair.CodeBuddyandHermesnow includeModeIdin their reuse fingerprint and re-apply it aftersession/newor warm reuse.- Pooling can be disabled per provider call, which falls back to the original one-shot behavior without changing message semantics.
- Idle eviction is lazy and deterministic; if a lease faults, the coordinator disposes that entry immediately rather than returning it to the warm set.
Adoption boundaries
- Interactive provider transports still use
CliProcessManagerdirectly because they need open stdio sessions. - The new execution facade is intended for provider-facing adapters, diagnostics, and one-shot probes such as version checks.
- Provider callers should continue passing structured option models; the new facade is additive and does not replace provider-specific option records.
geminiis the canonical built-in provider name;ProviderRegistryand the dedicated console also acceptgemini-clias an alias.deepagentsis the canonical built-in provider name;ProviderRegistryand the dedicated console also acceptdeepagents-acpas an alias.kimiis the canonical built-in provider name;ProviderRegistryand the dedicated console also acceptkimi-clias an alias.kirois the canonical built-in provider name;ProviderRegistryand the dedicated console also acceptkiro-clias an alias.CliInstallRegistrymarks DeepAgents as publicly installable viadeepagents-acp@0.1.7, while Gemini, Kimi, and Kiro remain local-only validation metadata (IsPubliclyInstallable = false).
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net10.0 is compatible. 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. |
-
net10.0
- GitHub.Copilot.SDK (>= 0.1.32)
- HagiCode.Libs.Core (>= 0.1.1-dev.30.1)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.2)
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.2.0 | 36 | 4/2/2026 |
| 0.1.1-dev.31.1 | 27 | 4/2/2026 |
| 0.1.1-dev.30.1 | 28 | 4/1/2026 |
| 0.1.0 | 84 | 3/29/2026 |
| 0.1.0-dev.28.1 | 37 | 3/29/2026 |
| 0.1.0-dev.27.1 | 39 | 3/29/2026 |
| 0.1.0-dev.26.1 | 38 | 3/29/2026 |
| 0.1.0-dev.25.1 | 39 | 3/29/2026 |
| 0.1.0-dev.24.1 | 49 | 3/28/2026 |
| 0.1.0-dev.23.1 | 48 | 3/27/2026 |
| 0.1.0-dev.22.1 | 44 | 3/27/2026 |
| 0.1.0-dev.21.1 | 46 | 3/27/2026 |
| 0.1.0-dev.20.1 | 36 | 3/26/2026 |
| 0.1.0-dev.19.1 | 35 | 3/25/2026 |
| 0.1.0-dev.18.1 | 33 | 3/25/2026 |
| 0.1.0-dev.17.1 | 38 | 3/23/2026 |
| 0.1.0-dev.16.1 | 42 | 3/22/2026 |
| 0.1.0-dev.15.1 | 34 | 3/22/2026 |
| 0.1.0-dev.14.1 | 35 | 3/22/2026 |
| 0.1.0-dev.13.1 | 33 | 3/22/2026 |