Commit Graph

477 Commits

Author SHA1 Message Date
StellaOps Bot
335ff7da16 Refactor NuGet package handling across multiple CI runners and documentation. Update paths to use .nuget/packages instead of local-nugets. Enhance README files for clarity on usage and environment setup. Add script to automate the addition of test projects to the solution. 2025-12-26 21:44:32 +02:00
StellaOps Bot
32f9581aa7 Merge branch 'main' of https://git.stella-ops.org/stella-ops.org/git.stella-ops.org 2025-12-26 21:43:56 +02:00
StellaOps Bot
75de089ee8 Refactor compare-view component to use observables for data loading, enhancing performance and responsiveness. Update compare service interfaces and methods for improved delta computation. Modify audit log component to handle optional event properties gracefully. Optimize Monaco editor worker loading to reduce bundle size. Introduce shared SCSS mixins for consistent styling across components. Add Gitea test instance setup and NuGet package publishing test scripts for CI/CD validation. Update documentation paths and ensure all references are accurate. 2025-12-26 21:39:36 +02:00
StellaOps Bot
b4fc66feb6 Refactor code structure and optimize performance across multiple modules 2025-12-26 21:38:12 +02:00
StellaOps Bot
f10d83c444 Refactor code structure and optimize performance across multiple modules 2025-12-26 20:03:41 +02:00
StellaOps Bot
c786faae84 CD/CD consolidation 2025-12-26 18:11:06 +02:00
StellaOps Bot
a866eb6277 Merge branch 'main' of https://git.stella-ops.org/stella-ops.org/git.stella-ops.org 2025-12-26 15:28:15 +02:00
StellaOps Bot
d2ac60c0e6 Merge branch 'main' of https://git.stella-ops.org/stella-ops.org/git.stella-ops.org 2025-12-26 15:28:09 +02:00
StellaOps Bot
07198f9453 Merge branch 'main' of https://git.stella-ops.org/stella-ops.org/git.stella-ops.org 2025-12-26 15:27:37 +02:00
StellaOps Bot
41f3ac7aba Merge branch 'main' of https://git.stella-ops.org/stella-ops.org/git.stella-ops.org 2025-12-26 15:27:29 +02:00
StellaOps Bot
81e4d76fb8 Merge branch 'main' of https://git.stella-ops.org/stella-ops.org/git.stella-ops.org 2025-12-26 15:19:07 +02:00
StellaOps Bot
907783f625 Add property-based tests for SBOM/VEX document ordering and Unicode normalization determinism
- Implement `SbomVexOrderingDeterminismProperties` for testing component list and vulnerability metadata hash consistency.
- Create `UnicodeNormalizationDeterminismProperties` to validate NFC normalization and Unicode string handling.
- Add project file for `StellaOps.Testing.Determinism.Properties` with necessary dependencies.
- Introduce CI/CD template validation tests including YAML syntax checks and documentation content verification.
- Create validation script for CI/CD templates ensuring all required files and structures are present.
2025-12-26 15:17:58 +02:00
StellaOps Bot
c8f3120174 Add property-based tests for SBOM/VEX document ordering and Unicode normalization determinism
- Implement `SbomVexOrderingDeterminismProperties` for testing component list and vulnerability metadata hash consistency.
- Create `UnicodeNormalizationDeterminismProperties` to validate NFC normalization and Unicode string handling.
- Add project file for `StellaOps.Testing.Determinism.Properties` with necessary dependencies.
- Introduce CI/CD template validation tests including YAML syntax checks and documentation content verification.
- Create validation script for CI/CD templates ensuring all required files and structures are present.
2025-12-26 15:17:15 +02:00
StellaOps Bot
7792749bb4 feat: Add archived advisories and implement smart-diff as a core evidence primitive
- Introduced new advisory documents for archived superseded advisories, including detailed descriptions of features already implemented or covered by existing sprints.
- Added "Smart-Diff as a Core Evidence Primitive" advisory outlining the treatment of SBOM diffs as first-class evidence objects, enhancing vulnerability verdicts with deterministic replayability.
- Created "Visual Diffs for Explainable Triage" advisory to improve user experience in understanding policy decisions and reachability changes through visual diffs.
- Implemented "Weighted Confidence for VEX Sources" advisory to rank conflicting vulnerability evidence based on freshness and confidence, facilitating better decision-making.
- Established a signer module charter detailing the mission, expectations, key components, and signing modes for cryptographic signing services in StellaOps.
- Consolidated overlapping concepts from triage UI, visual diffs, and risk budget visualization advisories into a unified specification for better clarity and implementation tracking.
2025-12-26 13:01:43 +02:00
StellaOps Bot
22390057fc stop syncing with TASKS.md 2025-12-26 11:44:40 +02:00
StellaOps Bot
ebce1c80b1 Merge branch 'main' of https://git.stella-ops.org/stella-ops.org/git.stella-ops.org 2025-12-26 11:28:03 +02:00
StellaOps Bot
e95eff2542 Remove global.json and add extensive documentation for SBOM-first supply chain spine, diff-aware releases, binary intelligence graph, reachability proofs, smart-diff evidence, risk budget visualization, and weighted confidence for VEX sources. Introduce solution file for Concelier web service project. 2025-12-26 11:27:52 +02:00
StellaOps Bot
e59b5e257c Remove global.json and add extensive documentation for SBOM-first supply chain spine, diff-aware releases, binary intelligence graph, reachability proofs, smart-diff evidence, risk budget visualization, and weighted confidence for VEX sources. Introduce solution file for Concelier web service project. 2025-12-26 11:27:18 +02:00
StellaOps Bot
4f6dd4de83 Merge branch 'main' of https://git.stella-ops.org/stella-ops.org/git.stella-ops.org 2025-12-26 10:48:56 +02:00
StellaOps Bot
fb17937958 consolidate the tests locations 2025-12-26 10:48:49 +02:00
StellaOps Bot
e0ec5261de consolidate the tests locations 2025-12-26 01:53:44 +02:00
StellaOps Bot
39359da171 consolidate the tests locations 2025-12-26 01:48:24 +02:00
StellaOps Bot
17613acf57 feat: add bulk triage view component and related stories
- Exported BulkTriageViewComponent and its related types from findings module.
- Created a new accessibility test suite for score components using axe-core.
- Introduced design tokens for score components to standardize styling.
- Enhanced score breakdown popover for mobile responsiveness with drag handle.
- Added date range selector functionality to score history chart component.
- Implemented unit tests for date range selector in score history chart.
- Created Storybook stories for bulk triage view and score history chart with date range selector.
2025-12-26 01:01:35 +02:00
StellaOps Bot
ed3079543c save dev progress 2025-12-26 00:32:58 +02:00
StellaOps Bot
aa70af062e save development progress 2025-12-25 23:10:09 +02:00
StellaOps Bot
d71853ad7e Add Christmass advisories 2025-12-25 20:15:19 +02:00
StellaOps Bot
ad7fbc47a1 Merge branch 'main' of https://git.stella-ops.org/stella-ops.org/git.stella-ops.org 2025-12-25 20:14:44 +02:00
StellaOps Bot
702c3106a8 Merge branch 'main' of https://git.stella-ops.org/stella-ops.org/git.stella-ops.org 2025-12-25 20:01:36 +02:00
StellaOps Bot
4dfa1b8e05 Merge branch 'main' of https://git.stella-ops.org/stella-ops.org/git.stella-ops.org 2025-12-25 19:58:42 +02:00
StellaOps Bot
b8b2d83f4a sprints enhancements 2025-12-25 19:52:30 +02:00
StellaOps Bot
ef6ac36323 nuget folder fixes 2025-12-25 19:51:56 +02:00
StellaOps Bot
0103defcff docs consolidation work 2025-12-25 19:09:48 +02:00
StellaOps Bot
82a49f6743 docs consolidation work 2025-12-25 18:50:33 +02:00
StellaOps Bot
2a06f780cf sprints work 2025-12-25 12:19:12 +02:00
StellaOps Bot
223843f1d1 docs consolidation 2025-12-25 12:16:13 +02:00
StellaOps Bot
deb82b4f03 docs consolidation work 2025-12-25 10:54:10 +02:00
StellaOps Bot
b9f71fc7e9 sprints work 2025-12-24 21:46:08 +02:00
StellaOps Bot
43e2af88f6 docs consolidation 2025-12-24 21:45:46 +02:00
StellaOps Bot
4231305fec sprints work 2025-12-24 16:28:46 +02:00
StellaOps Bot
8197588e74 docs consolidation work 2025-12-24 16:26:06 +02:00
StellaOps Bot
2c2bbf1005 product advisories, stella router improval, tests streghthening 2025-12-24 14:20:26 +02:00
StellaOps Bot
5540ce9430 docs consoliation work 2025-12-24 14:19:46 +02:00
StellaOps Bot
40362de568 chore: remove outdated documentation and prep notes
- Deleted several draft and prep documents related to benchmarks, authority DPoP & mTLS implementation, Java analyzer observation, link-not-merge determinism tests, replay operations, and crypto provider registry.
- Updated the merge semver playbook to reflect current database schema usage.
- Cleaned up the technical development README to remove references to obsolete documents and streamline guidance for contributors.
2025-12-24 12:47:50 +02:00
StellaOps Bot
02772c7a27 5100* tests strengthtenen work 2025-12-24 12:38:34 +02:00
StellaOps Bot
9a08d10b89 docs consolidation 2025-12-24 12:38:14 +02:00
StellaOps Bot
7503c19b8f Add determinism tests for verdict artifact generation and update SHA256 sums script
- Implemented comprehensive tests for verdict artifact generation to ensure deterministic outputs across various scenarios, including identical inputs, parallel execution, and change ordering.
- Created helper methods for generating sample verdict inputs and computing canonical hashes.
- Added tests to validate the stability of canonical hashes, proof spine ordering, and summary statistics.
- Introduced a new PowerShell script to update SHA256 sums for files, ensuring accurate hash generation and file integrity checks.
2025-12-24 02:17:34 +02:00
StellaOps Bot
e59921374e Merge branch 'main' of https://git.stella-ops.org/stella-ops.org/git.stella-ops.org 2025-12-24 00:37:11 +02:00
master
491e883653 Add tests for SBOM generation determinism across multiple formats
- Created `StellaOps.TestKit.Tests` project for unit tests related to determinism.
- Implemented `DeterminismManifestTests` to validate deterministic output for canonical bytes and strings, file read/write operations, and error handling for invalid schema versions.
- Added `SbomDeterminismTests` to ensure identical inputs produce consistent SBOMs across SPDX 3.0.1 and CycloneDX 1.6/1.7 formats, including parallel execution tests.
- Updated project references in `StellaOps.Integration.Determinism` to include the new determinism testing library.
2025-12-24 00:36:14 +02:00
master
5590a99a1a Add tests for SBOM generation determinism across multiple formats
- Created `StellaOps.TestKit.Tests` project for unit tests related to determinism.
- Implemented `DeterminismManifestTests` to validate deterministic output for canonical bytes and strings, file read/write operations, and error handling for invalid schema versions.
- Added `SbomDeterminismTests` to ensure identical inputs produce consistent SBOMs across SPDX 3.0.1 and CycloneDX 1.6/1.7 formats, including parallel execution tests.
- Updated project references in `StellaOps.Integration.Determinism` to include the new determinism testing library.
2025-12-23 23:51:58 +02:00
master
7ac70ece71 feat(crypto): Complete Phase 3 - Docker & CI/CD integration for regional deployments
## Summary

This commit completes Phase 3 (Docker & CI/CD Integration) of the configuration-driven
crypto architecture, enabling "build once, deploy everywhere" with runtime regional
crypto plugin selection.

## Key Changes

### Docker Infrastructure
- **Dockerfile.platform**: Multi-stage build creating runtime-base with ALL crypto plugins
  - Stage 1: SDK build of entire solution + all plugins
  - Stage 2: Runtime base with 14 services (Authority, Signer, Scanner, etc.)
  - Contains all plugin DLLs for runtime selection
- **Dockerfile.crypto-profile**: Regional profile selection via build arguments
  - Accepts CRYPTO_PROFILE build arg (international, russia, eu, china)
  - Mounts regional configuration from etc/appsettings.crypto.{profile}.yaml
  - Sets STELLAOPS_CRYPTO_PROFILE environment variable

### Regional Configurations (4 profiles)
- **International**: Uses offline-verification plugin (NIST algorithms) - PRODUCTION READY
- **Russia**: GOST R 34.10-2012 via openssl.gost/pkcs11.gost/cryptopro.gost - PRODUCTION READY
- **EU**: Temporary offline-verification fallback (eIDAS plugin planned for Phase 4)
- **China**: Temporary offline-verification fallback (SM plugin planned for Phase 4)

All configs updated:
- Corrected ManifestPath to /app/etc/crypto-plugins-manifest.json
- Updated plugin IDs to match manifest entries
- Added TODOs for missing regional plugins (eIDAS, SM)

### Docker Compose Files (4 regional deployments)
- **docker-compose.international.yml**: 14 services with international crypto profile
- **docker-compose.russia.yml**: 14 services with GOST crypto profile
- **docker-compose.eu.yml**: 14 services with EU crypto profile (temp fallback)
- **docker-compose.china.yml**: 14 services with China crypto profile (temp fallback)

Each file:
- Mounts regional crypto configuration
- Sets STELLAOPS_CRYPTO_PROFILE env var
- Includes crypto-env anchor for consistent configuration
- Adds crypto profile labels

### CI/CD Automation
- **Workflow**: .gitea/workflows/docker-regional-builds.yml
- **Build Strategy**:
  1. Build platform image once (contains all plugins)
  2. Build 56 regional service images (4 profiles × 14 services)
  3. Validate regional configurations (YAML syntax, required fields)
  4. Generate build summary
- **Triggers**: push to main, PR affecting Docker/crypto files, manual dispatch

### Documentation
- **Regional Deployments Guide**: docs/operations/regional-deployments.md (600+ lines)
  - Quick start for each region
  - Architecture diagrams
  - Configuration examples
  - Operations guide
  - Troubleshooting
  - Migration guide
  - Security considerations

## Architecture Benefits

 **Build Once, Deploy Everywhere**
- Single platform image with all plugins
- No region-specific builds needed
- Regional selection at runtime via configuration

 **Configuration-Driven**
- Zero hardcoded regional logic
- All crypto provider selection via YAML
- Jurisdiction enforcement configurable

 **CI/CD Automated**
- Parallel builds of 56 regional images
- Configuration validation in CI
- Docker layer caching for efficiency

 **Production-Ready**
- International profile ready for deployment
- Russia (GOST) profile ready (requires SDK installation)
- EU and China profiles functional with fallbacks

## Files Created

**Docker Infrastructure** (11 files):
- deploy/docker/Dockerfile.platform
- deploy/docker/Dockerfile.crypto-profile
- deploy/compose/docker-compose.international.yml
- deploy/compose/docker-compose.russia.yml
- deploy/compose/docker-compose.eu.yml
- deploy/compose/docker-compose.china.yml

**CI/CD**:
- .gitea/workflows/docker-regional-builds.yml

**Documentation**:
- docs/operations/regional-deployments.md
- docs/implplan/SPRINT_1000_0007_0003_crypto_docker_cicd.md

**Modified** (4 files):
- etc/appsettings.crypto.international.yaml (plugin ID, manifest path)
- etc/appsettings.crypto.russia.yaml (manifest path)
- etc/appsettings.crypto.eu.yaml (fallback config, manifest path)
- etc/appsettings.crypto.china.yaml (fallback config, manifest path)

## Deployment Instructions

### International (Default)
```bash
docker compose -f deploy/compose/docker-compose.international.yml up -d
```

### Russia (GOST)
```bash
# Requires: OpenSSL GOST engine installed on host
docker compose -f deploy/compose/docker-compose.russia.yml up -d
```

### EU (eIDAS - Temporary Fallback)
```bash
docker compose -f deploy/compose/docker-compose.eu.yml up -d
```

### China (SM - Temporary Fallback)
```bash
docker compose -f deploy/compose/docker-compose.china.yml up -d
```

## Testing

Phase 3 focuses on **build validation**:
-  Docker images build without errors
-  Regional configurations are syntactically valid
-  Plugin DLLs present in runtime image
- ⏭️ Runtime crypto operation testing (Phase 4)
- ⏭️ Integration testing (Phase 4)

## Sprint Status

**Phase 3**: COMPLETE 
- 12/12 tasks completed (100%)
- 5/5 milestones achieved (100%)
- All deliverables met

**Next Phase**: Phase 4 - Validation & Testing
- Integration tests for each regional profile
- Deployment validation scripts
- Health check endpoints
- Production runbooks

## Metrics

- **Development Time**: Single session (2025-12-23)
- **Docker Images**: 57 total (1 platform + 56 regional services)
- **Configuration Files**: 4 regional profiles
- **Docker Compose Services**: 56 service definitions
- **Documentation**: 600+ lines

## Related Work

- Phase 1 (SPRINT_1000_0007_0001): Plugin Loader Infrastructure  COMPLETE
- Phase 2 (SPRINT_1000_0007_0002): Code Refactoring  COMPLETE
- Phase 3 (SPRINT_1000_0007_0003): Docker & CI/CD  COMPLETE (this commit)
- Phase 4 (SPRINT_1000_0007_0004): Validation & Testing (NEXT)

Master Plan: docs/implplan/CRYPTO_CONFIGURATION_DRIVEN_ARCHITECTURE.md

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-23 18:49:40 +02:00