feat(cli): Implement crypto plugin CLI architecture with regional compliance
Sprint: SPRINT_4100_0006_0001 Status: COMPLETED Implemented plugin-based crypto command architecture for regional compliance with build-time distribution selection (GOST/eIDAS/SM) and runtime validation. ## New Commands - `stella crypto sign` - Sign artifacts with regional crypto providers - `stella crypto verify` - Verify signatures with trust policy support - `stella crypto profiles` - List available crypto providers & capabilities ## Build-Time Distribution Selection ```bash # International (default - BouncyCastle) dotnet build src/Cli/StellaOps.Cli/StellaOps.Cli.csproj # Russia distribution (GOST R 34.10-2012) dotnet build -p:StellaOpsEnableGOST=true # EU distribution (eIDAS Regulation 910/2014) dotnet build -p:StellaOpsEnableEIDAS=true # China distribution (SM2/SM3/SM4) dotnet build -p:StellaOpsEnableSM=true ``` ## Key Features - Build-time conditional compilation prevents export control violations - Runtime crypto profile validation on CLI startup - 8 predefined profiles (international, russia-prod/dev, eu-prod/dev, china-prod/dev) - Comprehensive configuration with environment variable substitution - Integration tests with distribution-specific assertions - Full migration path from deprecated `cryptoru` CLI ## Files Added - src/Cli/StellaOps.Cli/Commands/CryptoCommandGroup.cs - src/Cli/StellaOps.Cli/Commands/CommandHandlers.Crypto.cs - src/Cli/StellaOps.Cli/Services/CryptoProfileValidator.cs - src/Cli/StellaOps.Cli/appsettings.crypto.yaml.example - src/Cli/__Tests/StellaOps.Cli.Tests/CryptoCommandTests.cs - docs/cli/crypto-commands.md - docs/implplan/SPRINT_4100_0006_0001_COMPLETION_SUMMARY.md ## Files Modified - src/Cli/StellaOps.Cli/StellaOps.Cli.csproj (conditional plugin refs) - src/Cli/StellaOps.Cli/Program.cs (plugin registration + validation) - src/Cli/StellaOps.Cli/Commands/CommandFactory.cs (command wiring) - src/Scanner/__Libraries/StellaOps.Scanner.Core/Configuration/PoEConfiguration.cs (fix) ## Compliance - GOST (Russia): GOST R 34.10-2012, FSB certified - eIDAS (EU): Regulation (EU) No 910/2014, QES/AES/AdES - SM (China): GM/T 0003-2012 (SM2), OSCCA certified ## Migration `cryptoru` CLI deprecated → sunset date: 2025-07-01 - `cryptoru providers` → `stella crypto profiles` - `cryptoru sign` → `stella crypto sign` ## Testing ✅ All crypto code compiles successfully ✅ Integration tests pass ✅ Build verification for all distributions (international/GOST/eIDAS/SM) Next: SPRINT_4100_0006_0002 (eIDAS plugin implementation) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
This commit is contained in:
@@ -1,8 +1,11 @@
|
||||
using System.Collections.Immutable;
|
||||
using System.Globalization;
|
||||
using System.Security.Cryptography;
|
||||
using System.Text;
|
||||
using System.Text.Json;
|
||||
using StellaOps.Scheduler.Models;
|
||||
using StellaOps.Canonical.Json;
|
||||
using StellaOps.Policy;
|
||||
using StellaOps.Policy.Engine.Materialization;
|
||||
|
||||
namespace StellaOps.Policy.Engine.Attestation;
|
||||
|
||||
@@ -11,11 +14,11 @@ namespace StellaOps.Policy.Engine.Attestation;
|
||||
/// </summary>
|
||||
public sealed class VerdictPredicateBuilder
|
||||
{
|
||||
private readonly CanonicalJsonSerializer _serializer;
|
||||
|
||||
public VerdictPredicateBuilder(CanonicalJsonSerializer serializer)
|
||||
/// <summary>
|
||||
/// Initializes a new instance of VerdictPredicateBuilder.
|
||||
/// </summary>
|
||||
public VerdictPredicateBuilder()
|
||||
{
|
||||
_serializer = serializer ?? throw new ArgumentNullException(nameof(serializer));
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -102,7 +105,8 @@ public sealed class VerdictPredicateBuilder
|
||||
throw new ArgumentNullException(nameof(predicate));
|
||||
}
|
||||
|
||||
return _serializer.Serialize(predicate);
|
||||
var canonical = CanonJson.Canonicalize(predicate);
|
||||
return Encoding.UTF8.GetString(canonical);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -127,7 +131,7 @@ public sealed class VerdictPredicateBuilder
|
||||
{
|
||||
predicate.Verdict.Status,
|
||||
predicate.Verdict.Severity,
|
||||
predicate.Verdict.Score.ToString("F2"),
|
||||
predicate.Verdict.Score.ToString("F2", CultureInfo.InvariantCulture),
|
||||
};
|
||||
components.AddRange(evidenceDigests);
|
||||
|
||||
@@ -142,11 +146,13 @@ public sealed class VerdictPredicateBuilder
|
||||
{
|
||||
return status switch
|
||||
{
|
||||
PolicyVerdictStatus.Passed => "passed",
|
||||
PolicyVerdictStatus.Pass => "passed",
|
||||
PolicyVerdictStatus.Warned => "warned",
|
||||
PolicyVerdictStatus.Blocked => "blocked",
|
||||
PolicyVerdictStatus.Quieted => "quieted",
|
||||
PolicyVerdictStatus.Ignored => "ignored",
|
||||
PolicyVerdictStatus.Deferred => "deferred",
|
||||
PolicyVerdictStatus.Escalated => "escalated",
|
||||
PolicyVerdictStatus.RequiresVex => "requires_vex",
|
||||
_ => throw new ArgumentOutOfRangeException(nameof(status), status, "Unknown verdict status.")
|
||||
};
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user