Some checks failed
AOC Guard CI / aoc-guard (push) Has been cancelled
AOC Guard CI / aoc-verify (push) Has been cancelled
Docs CI / lint-and-preview (push) Has been cancelled
Export Center CI / export-ci (push) Has been cancelled
Findings Ledger CI / build-test (push) Has been cancelled
Findings Ledger CI / migration-validation (push) Has been cancelled
Findings Ledger CI / generate-manifest (push) Has been cancelled
Lighthouse CI / Lighthouse Audit (push) Has been cancelled
Lighthouse CI / Axe Accessibility Audit (push) Has been cancelled
Policy Lint & Smoke / policy-lint (push) Has been cancelled
Reachability Corpus Validation / validate-corpus (push) Has been cancelled
Reachability Corpus Validation / validate-ground-truths (push) Has been cancelled
Scanner Analyzers / Discover Analyzers (push) Has been cancelled
Scanner Analyzers / Validate Test Fixtures (push) Has been cancelled
Signals CI & Image / signals-ci (push) Has been cancelled
Signals Reachability Scoring & Events / reachability-smoke (push) Has been cancelled
Reachability Corpus Validation / determinism-check (push) Has been cancelled
Scanner Analyzers / Build Analyzers (push) Has been cancelled
Scanner Analyzers / Test Language Analyzers (push) Has been cancelled
Scanner Analyzers / Verify Deterministic Output (push) Has been cancelled
Signals Reachability Scoring & Events / sign-and-upload (push) Has been cancelled
- Introduced `all-edge-reasons.json` to test edge resolution reasons in .NET. - Added `all-visibility-levels.json` to validate method visibility levels in .NET. - Created `dotnet-aspnetcore-minimal.json` for a minimal ASP.NET Core application. - Included `go-gin-api.json` for a Go Gin API application structure. - Added `java-spring-boot.json` for the Spring PetClinic application in Java. - Introduced `legacy-no-schema.json` for legacy application structure without schema. - Created `node-express-api.json` for an Express.js API application structure.
165 lines
5.4 KiB
C#
165 lines
5.4 KiB
C#
using System.CommandLine;
|
|
using StellaOps.Cli.Extensions;
|
|
|
|
namespace StellaOps.Cli.Commands;
|
|
|
|
internal static class OfflineCommandGroup
|
|
{
|
|
internal static Command BuildOfflineCommand(
|
|
IServiceProvider services,
|
|
Option<bool> verboseOption,
|
|
CancellationToken cancellationToken)
|
|
{
|
|
var offline = new Command("offline", "Air-gap and offline kit operations.");
|
|
|
|
offline.Add(BuildOfflineImportCommand(services, verboseOption, cancellationToken));
|
|
offline.Add(BuildOfflineStatusCommand(services, verboseOption, cancellationToken));
|
|
|
|
return offline;
|
|
}
|
|
|
|
private static Command BuildOfflineImportCommand(
|
|
IServiceProvider services,
|
|
Option<bool> verboseOption,
|
|
CancellationToken cancellationToken)
|
|
{
|
|
var tenantOption = new Option<string?>("--tenant")
|
|
{
|
|
Description = "Tenant context for the import (defaults to profile/ENV)."
|
|
};
|
|
|
|
var bundleOption = new Option<string>("--bundle", new[] { "-b" })
|
|
{
|
|
Description = "Path to the offline kit payload bundle (.tar.zst).",
|
|
Required = true
|
|
};
|
|
|
|
var manifestOption = new Option<string?>("--manifest", new[] { "-m" })
|
|
{
|
|
Description = "Path to offline manifest JSON (defaults to manifest.json next to the bundle)."
|
|
};
|
|
|
|
var verifyDsseOption = new Option<bool>("--verify-dsse")
|
|
{
|
|
Description = "Verify DSSE signature on the kit statement."
|
|
}.SetDefaultValue(true);
|
|
|
|
var verifyRekorOption = new Option<bool>("--verify-rekor")
|
|
{
|
|
Description = "Verify Rekor receipt (offline mode)."
|
|
}.SetDefaultValue(true);
|
|
|
|
var trustRootOption = new Option<string?>("--trust-root")
|
|
{
|
|
Description = "Path to trust root public key file for DSSE verification."
|
|
};
|
|
|
|
var forceActivateOption = new Option<bool>("--force-activate")
|
|
{
|
|
Description = "Override monotonicity check (requires justification)."
|
|
};
|
|
|
|
var forceReasonOption = new Option<string?>("--force-reason")
|
|
{
|
|
Description = "Justification for force activation (required with --force-activate)."
|
|
};
|
|
|
|
var dryRunOption = new Option<bool>("--dry-run")
|
|
{
|
|
Description = "Validate the kit without activating."
|
|
};
|
|
|
|
var outputOption = new Option<string?>("--output", new[] { "-o" })
|
|
{
|
|
Description = "Output format: table (default), json."
|
|
}.SetDefaultValue("table").FromAmong("table", "json");
|
|
|
|
var command = new Command("import", "Import an offline kit with verification.")
|
|
{
|
|
tenantOption,
|
|
bundleOption,
|
|
manifestOption,
|
|
verifyDsseOption,
|
|
verifyRekorOption,
|
|
trustRootOption,
|
|
forceActivateOption,
|
|
forceReasonOption,
|
|
dryRunOption,
|
|
outputOption,
|
|
verboseOption
|
|
};
|
|
|
|
command.SetAction(parseResult =>
|
|
{
|
|
var tenant = parseResult.GetValue(tenantOption);
|
|
var bundle = parseResult.GetValue(bundleOption) ?? string.Empty;
|
|
var manifest = parseResult.GetValue(manifestOption);
|
|
var verifyDsse = parseResult.GetValue(verifyDsseOption);
|
|
var verifyRekor = parseResult.GetValue(verifyRekorOption);
|
|
var trustRoot = parseResult.GetValue(trustRootOption);
|
|
var forceActivate = parseResult.GetValue(forceActivateOption);
|
|
var forceReason = parseResult.GetValue(forceReasonOption);
|
|
var dryRun = parseResult.GetValue(dryRunOption);
|
|
var output = parseResult.GetValue(outputOption) ?? "table";
|
|
var verbose = parseResult.GetValue(verboseOption);
|
|
|
|
return CommandHandlers.HandleOfflineImportAsync(
|
|
services,
|
|
tenant,
|
|
bundle,
|
|
manifest,
|
|
verifyDsse,
|
|
verifyRekor,
|
|
trustRoot,
|
|
forceActivate,
|
|
forceReason,
|
|
dryRun,
|
|
output,
|
|
verbose,
|
|
cancellationToken);
|
|
});
|
|
|
|
return command;
|
|
}
|
|
|
|
private static Command BuildOfflineStatusCommand(
|
|
IServiceProvider services,
|
|
Option<bool> verboseOption,
|
|
CancellationToken cancellationToken)
|
|
{
|
|
var tenantOption = new Option<string?>("--tenant")
|
|
{
|
|
Description = "Tenant context for the status (defaults to profile/ENV)."
|
|
};
|
|
|
|
var outputOption = new Option<string?>("--output", new[] { "-o" })
|
|
{
|
|
Description = "Output format: table (default), json."
|
|
}.SetDefaultValue("table").FromAmong("table", "json");
|
|
|
|
var command = new Command("status", "Display current offline kit status.")
|
|
{
|
|
tenantOption,
|
|
outputOption,
|
|
verboseOption
|
|
};
|
|
|
|
command.SetAction(parseResult =>
|
|
{
|
|
var tenant = parseResult.GetValue(tenantOption);
|
|
var output = parseResult.GetValue(outputOption) ?? "table";
|
|
var verbose = parseResult.GetValue(verboseOption);
|
|
|
|
return CommandHandlers.HandleOfflineStatusAsync(
|
|
services,
|
|
tenant,
|
|
output,
|
|
verbose,
|
|
cancellationToken);
|
|
});
|
|
|
|
return command;
|
|
}
|
|
}
|
|
|