- Introduced global usings for Ruby analyzer. - Implemented RubyLockData, RubyLockEntry, and RubyLockParser for handling Gemfile.lock files. - Created RubyPackage and RubyPackageCollector to manage Ruby packages and vendor cache. - Developed RubyAnalyzerPlugin and RubyLanguageAnalyzer for analyzing Ruby projects. - Added tests for Ruby language analyzer with sample Gemfile.lock and expected output. - Included necessary project files and references for the Ruby analyzer. - Added third-party licenses for tree-sitter dependencies.
4.8 KiB
4.8 KiB
Advisory AI Orchestration Pipeline (Planning Notes)
Status: Draft – prerequisite design for AIAI-31-004 integration work.
Audience: Advisory AI guild, WebService/Worker guilds, CLI guild, Docs/QA support teams.
1. Goal
Wire the deterministic pipeline (Summary / Conflict / Remediation flows) into the Advisory AI service, workers, and CLI with deterministic caching, prompt preparation, and guardrail fallback. This document captures the pre-integration checklist and task breakdown so each guild understands their responsibilities before coding begins.
2. Prerequisites
| Area | Requirement | Owner | Status |
|---|---|---|---|
| Toolset | Deterministic comparators, dependency analyzer (IDeterministicToolset, AdvisoryPipelineOrchestrator) |
Advisory AI | ✅ landed (AIAI-31-003) |
| SBOM context | Real SBOM context client delivering timelines + dependency paths | SBOM Service Guild | ⏳ pending (AIAI-31-002) |
| Prompt artifacts | Liquid/Handlebars prompt templates for summary/conflict/remediation | Advisory AI Docs Guild | ⏳ authoring needed |
| Cache strategy | Decision on DSSE or hash-only cache entries, TTLs, and eviction policy | Advisory AI + Platform | 🔲 define |
| Auth scopes | Confirm service account scopes for new API endpoints/worker-to-service calls | Authority Guild | 🔲 define |
Blocking risk: SBOM client and prompt templates must exist (even stubbed) before the orchestrator can produce stable plans.
3. Integration plan (high-level)
- Service layer (WebService / Worker)
- Inject
IAdvisoryPipelineOrchestratorviaAddAdvisoryPipeline. - Define REST endpoint
POST /v1/advisories/{key}/pipeline/{task}(task ∈ summary/conflict/remediation). - Worker consumes queue messages (
advisory.pipeline.execute) -> fetches plan -> executes prompt -> persists output & provenance. - Add metrics:
advisory_pipeline_requests_total,advisory_pipeline_plan_cache_hits_total,advisory_pipeline_latency_seconds.
- Inject
- CLI
- New command
stella advise run <task>with flags for artifact id, profile, policy version,--force-refresh. - Render JSON/Markdown outputs; handle caching hints (print cache key, status).
- New command
- Caching / storage
- Choose storage (Mongo collection vs existing DSSE output store).
- Persist
AdvisoryTaskPlanmetadata + generated output keyed by cache key + policy version. - Expose TTL/force-refresh semantics.
- Docs & QA
- Publish API spec (
docs/advisory-ai/api.md) + CLI docs. - Add golden outputs for deterministic runs; property tests for cache key stability.
- Publish API spec (
4. Task Breakdown
AIAI-31-004A (Service orchestration wiring)
- Scope: WebService/Worker injection, REST/queue plumbing, metrics counters, basic cache stub.
- Dependencies:
AddAdvisoryPipeline, SBOM client stub. - Exit: API responds with plan metadata + queue message; worker logs execution attempt; metrics emitted.
AIAI-31-004B (Prompt assembly & cache persistence)
- Scope: Implement prompt assembler, connect to guardrails, persist cache entries w/ DSSE metadata.
- Dependencies: Prompt templates, cache storage decision, guardrail interface.
- Exit: Deterministic outputs stored; force-refresh honoured; tests cover prompt assembly + caching.
AIAI-31-004C (CLI integration & docs)
- Scope: CLI command + output renderer, docs updates, CLI tests (golden outputs).
- Dependencies: Service endpoints stable, caching semantics documented.
- Exit: CLI command produces deterministic output, docs updated, smoke tests recorded.
Supporting tasks (other guilds)
- AUTH-AIAI-31-004 – Update scopes and DSSE policy (Authority guild).
- DOCS-AIAI-31-003 – Publish API documentation, CLI guide updates (Docs guild).
- QA-AIAI-31-004 – Golden/properties/perf suite for pipeline (QA guild).
5. Acceptance checklist (per task)
| Item | Notes |
|---|---|
| Cache key stability | AdvisoryPipelineOrchestrator hash must remain stable under re-run of identical inputs. |
| Metrics & logging | Request id, cache key, task type, profile, latency; guardrail results logged without sensitive prompt data. |
| Offline readiness | All prompt templates bundled with Offline Kit; CLI works in air-gapped mode with cached data. |
| Policy awareness | Plans encode policy version used; outputs reference policy digest for audit. |
| Testing | Unit tests (plan generation, cache keys, DI), integration (service endpoint, worker, CLI), deterministic golden outputs. |
6. Next steps
- Finalize SBOM context client (AIAI-31-002) and prompt templates.
- Create queue schema spec (
docs/modules/advisory-ai/queue-contracts.md) if not already available. - Schedule cross-guild kickoff to agree on cache store & DSSE policy.
Last updated: 2025-11-02