ultimate-pi 0.18.0 → 0.19.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.agents/skills/harness-debate-plan/SKILL.md +1 -1
- package/.agents/skills/harness-decisions/SKILL.md +2 -3
- package/.agents/skills/harness-governor/SKILL.md +6 -5
- package/.agents/skills/harness-orchestration/SKILL.md +4 -4
- package/.agents/skills/harness-review/SKILL.md +7 -7
- package/.agents/skills/harness-sentrux-setup/SKILL.md +4 -3
- package/.agents/skills/harness-steer/SKILL.md +1 -1
- package/.agents/skills/sentrux/SKILL.md +9 -9
- package/.pi/PACKAGING.md +4 -4
- package/.pi/SYSTEM.md +54 -120
- package/.pi/agents/harness/incident-recorder.md +0 -1
- package/.pi/agents/harness/planning/decompose.md +1 -3
- package/.pi/agents/harness/planning/execution-plan-author.md +0 -2
- package/.pi/agents/harness/planning/hypothesis-validator.md +0 -2
- package/.pi/agents/harness/planning/hypothesis.md +0 -2
- package/.pi/agents/harness/planning/implementation-researcher.md +0 -2
- package/.pi/agents/harness/planning/plan-adversary.md +0 -2
- package/.pi/agents/harness/planning/plan-evaluator.md +1 -3
- package/.pi/agents/harness/planning/planning-context.md +0 -2
- package/.pi/agents/harness/planning/review-integrator.md +0 -2
- package/.pi/agents/harness/planning/sprint-contract-auditor.md +0 -2
- package/.pi/agents/harness/planning/stack-researcher.md +0 -2
- package/.pi/agents/harness/{adversary.md → reviewing/adversary.md} +0 -2
- package/.pi/agents/harness/{evaluator.md → reviewing/evaluator.md} +0 -2
- package/.pi/agents/harness/{tie-breaker.md → reviewing/tie-breaker.md} +0 -2
- package/.pi/agents/harness/{executor.md → running/executor.md} +0 -2
- package/.pi/agents/harness/sentrux-bootstrap.md +0 -1
- package/.pi/agents/harness/sentrux-steward.md +0 -2
- package/.pi/agents/harness/trace-librarian.md +0 -1
- package/.pi/extensions/00-harness-project-control.ts +133 -0
- package/.pi/extensions/00-posthog-network-bootstrap.ts +1 -1
- package/.pi/extensions/agt-kill-switch.ts +57 -0
- package/.pi/extensions/agt-prompt-guard.ts +32 -0
- package/.pi/extensions/budget-guard.ts +2 -0
- package/.pi/extensions/custom-footer.ts +46 -145
- package/.pi/extensions/custom-header.ts +1 -1
- package/.pi/extensions/custom-system-prompt.ts +1 -1
- package/.pi/extensions/debate-orchestrator.ts +7 -5
- package/.pi/extensions/harness-ask-user.ts +8 -8
- package/.pi/extensions/harness-debate-tools.ts +27 -43
- package/.pi/extensions/harness-lens.ts +94 -0
- package/.pi/extensions/harness-live-widget.ts +33 -2
- package/.pi/extensions/harness-plan-approval.ts +12 -12
- package/.pi/extensions/harness-run-context.ts +1214 -852
- package/.pi/extensions/harness-subagent-governance.ts +8 -0
- package/.pi/extensions/harness-subagent-submit.ts +36 -164
- package/.pi/extensions/harness-subagents.ts +4 -4
- package/.pi/extensions/harness-telemetry.ts +3 -1
- package/.pi/extensions/harness-web-tools.ts +3 -3
- package/.pi/extensions/observation-bus.ts +2 -0
- package/.pi/extensions/policy-gate.ts +27 -5
- package/.pi/extensions/review-integrity.ts +91 -10
- package/.pi/extensions/sentrux-rules-sync.ts +3 -1
- package/.pi/extensions/subagent-governance.ts +92 -0
- package/.pi/extensions/test-diff-integrity.ts +1 -0
- package/.pi/extensions/trace-recorder.ts +3 -1
- package/.pi/extensions/{ultimate-pi-vcc.ts → vcc-compaction.ts} +1 -1
- package/.pi/harness/README.md +6 -2
- package/.pi/harness/agents.manifest.json +38 -49
- package/.pi/harness/agents.policy.yaml +275 -0
- package/.pi/harness/corpus/graphify-kb-updater.config.json +55 -0
- package/.pi/harness/docs/adrs/0006-sentrux-dual-layer.md +2 -1
- package/.pi/harness/docs/adrs/0030-inhouse-vcc-compaction.md +1 -1
- package/.pi/harness/docs/adrs/0035-plan-phase-review-gate.md +1 -1
- package/.pi/harness/docs/adrs/0044-harness-steer-loop.md +3 -2
- package/.pi/harness/docs/adrs/0045-harness-lens-minimal-contract.md +49 -0
- package/.pi/harness/docs/adrs/0045-phase-scoped-agent-directories.md +33 -0
- package/.pi/harness/docs/adrs/0046-agt-policy-engine.md +51 -0
- package/.pi/harness/docs/adrs/0047-agt-layered-security.md +39 -0
- package/.pi/harness/docs/adrs/0048-tool-call-hook-order.md +25 -0
- package/.pi/harness/docs/adrs/0049-agents-policy-manifest.md +36 -0
- package/.pi/harness/docs/adrs/README.md +6 -0
- package/.pi/harness/docs/graphify-kb-updater-runbook.md +11 -5
- package/.pi/harness/docs/practice-map.md +2 -2
- package/.pi/harness/evolution/README.md +1 -2
- package/.pi/harness/examples/agents.policy.project.yaml +19 -0
- package/.pi/harness/examples/policies/custom-deny-bash.yaml +9 -0
- package/.pi/harness/policies/bash-denylists.yaml +5 -0
- package/.pi/harness/policies/defaults.yaml +51 -0
- package/.pi/harness/policies/orchestrator.yaml +18 -0
- package/.pi/harness/policies/phases.yaml +10 -0
- package/.pi/harness/policies/roles.yaml +5 -0
- package/.pi/harness/policies/web-guard.yaml +5 -0
- package/.pi/harness/policies/workflow-sequences.yaml +9 -0
- package/.pi/harness/sentrux/architecture.manifest.json +26 -4
- package/.pi/harness/specs/harness-spawn-context.schema.json +1 -1
- package/.pi/harness/specs/observation.schema.json +2 -1
- package/.pi/lib/agents-policy.d.mts +70 -0
- package/.pi/lib/agents-policy.mjs +325 -0
- package/.pi/lib/agents-policy.ts +19 -0
- package/.pi/lib/agt/audit-run-sink.ts +52 -0
- package/.pi/lib/agt/build-evaluation-context.ts +285 -0
- package/.pi/lib/agt/config.ts +28 -0
- package/.pi/lib/agt/delegation.ts +69 -0
- package/.pi/lib/agt/evaluate-policy.ts +56 -0
- package/.pi/lib/agt/identity-registry.ts +41 -0
- package/.pi/lib/agt/index.ts +55 -0
- package/.pi/lib/agt/kill-switch-state.ts +11 -0
- package/.pi/lib/agt/legacy-evaluate.ts +101 -0
- package/.pi/lib/agt/policy-engine.ts +154 -0
- package/.pi/lib/agt/rings.ts +21 -0
- package/.pi/lib/agt/sre-hooks.ts +45 -0
- package/.pi/lib/agt/trust-run-store.ts +26 -0
- package/.pi/lib/agt/workflow-history.ts +29 -0
- package/.pi/lib/agt-governance-active.ts +14 -0
- package/.pi/lib/agt-tool-guard.ts +78 -0
- package/.pi/lib/ask-user/dialog.ts +314 -0
- package/.pi/{extensions/lib → lib}/debate-bus-core.ts +10 -10
- package/.pi/{extensions/lib → lib}/debate-bus-state.ts +1 -1
- package/.pi/{extensions/lib → lib}/extension-load-guard.ts +21 -0
- package/.pi/lib/harness-agt-tool-guard.ts +5 -0
- package/.pi/{extensions/lib → lib}/harness-artifact-gate.ts +6 -16
- package/.pi/lib/harness-debate-core-deps.ts +14 -0
- package/.pi/lib/harness-debate-workflow-deps.ts +43 -0
- package/.pi/lib/harness-lens/.gitattributes +1 -0
- package/.pi/lib/harness-lens/clients/edit-autopatch.ts +88 -0
- package/.pi/lib/harness-lens/clients/file-kinds.ts +380 -0
- package/.pi/lib/harness-lens/clients/file-time.ts +215 -0
- package/.pi/lib/harness-lens/clients/file-utils.ts +484 -0
- package/.pi/lib/harness-lens/clients/format-service.ts +276 -0
- package/.pi/lib/harness-lens/clients/formatters.ts +1000 -0
- package/.pi/lib/harness-lens/clients/git-guard.ts +31 -0
- package/.pi/lib/harness-lens/clients/indent-retarget.ts +90 -0
- package/.pi/lib/harness-lens/clients/installer/index.ts +2368 -0
- package/.pi/lib/harness-lens/clients/latency-logger.ts +80 -0
- package/.pi/lib/harness-lens/clients/lens-config.ts +43 -0
- package/.pi/lib/harness-lens/clients/lens-events.ts +164 -0
- package/.pi/lib/harness-lens/clients/lsp/aggregation.ts +91 -0
- package/.pi/lib/harness-lens/clients/lsp/client.ts +1466 -0
- package/.pi/lib/harness-lens/clients/lsp/config.ts +216 -0
- package/.pi/lib/harness-lens/clients/lsp/edits.ts +297 -0
- package/.pi/lib/harness-lens/clients/lsp/index.ts +1355 -0
- package/.pi/lib/harness-lens/clients/lsp/interactive-install.ts +424 -0
- package/.pi/lib/harness-lens/clients/lsp/language.ts +223 -0
- package/.pi/lib/harness-lens/clients/lsp/launch.ts +939 -0
- package/.pi/lib/harness-lens/clients/lsp/lsp-index.ts +11 -0
- package/.pi/lib/harness-lens/clients/lsp/path-utils.ts +12 -0
- package/.pi/lib/harness-lens/clients/lsp/server-strategies.ts +81 -0
- package/.pi/lib/harness-lens/clients/lsp/server.ts +1971 -0
- package/.pi/lib/harness-lens/clients/path-utils.ts +182 -0
- package/.pi/lib/harness-lens/clients/pipeline.ts +360 -0
- package/.pi/lib/harness-lens/clients/project-profile.ts +117 -0
- package/.pi/lib/harness-lens/clients/runtime-agent-end.ts +112 -0
- package/.pi/lib/harness-lens/clients/runtime-config.ts +33 -0
- package/.pi/lib/harness-lens/clients/runtime-coordinator.ts +186 -0
- package/.pi/lib/harness-lens/clients/runtime-tool-result.ts +171 -0
- package/.pi/lib/harness-lens/clients/safe-spawn.ts +339 -0
- package/.pi/lib/harness-lens/clients/secrets-scanner.ts +214 -0
- package/.pi/lib/harness-lens/clients/tool-policy.ts +2072 -0
- package/.pi/lib/harness-lens/clients/types.ts +59 -0
- package/.pi/lib/harness-lens/clients/widget-state.ts +283 -0
- package/.pi/lib/harness-lens/index.ts +532 -0
- package/.pi/lib/harness-lens/tools/lsp-diagnostics.ts +706 -0
- package/.pi/lib/harness-lens/tools/lsp-navigation.ts +1246 -0
- package/.pi/{extensions/lib → lib}/harness-posthog.ts +3 -0
- package/.pi/lib/harness-project-config.ts +91 -0
- package/.pi/lib/harness-run-context-responses.ts +9 -0
- package/.pi/lib/harness-run-context.ts +1 -3
- package/.pi/{extensions/lib/spawn-policy.ts → lib/harness-spawn-policy.ts} +4 -3
- package/.pi/{extensions/lib → lib}/harness-spawn-topology.ts +5 -28
- package/.pi/lib/harness-subagent-auth.ts +51 -0
- package/.pi/{extensions/lib → lib}/harness-subagent-precheck.ts +13 -10
- package/.pi/{extensions/lib → lib}/harness-subagent-submit-pipeline.ts +3 -3
- package/.pi/lib/harness-subagent-submit-register.ts +163 -0
- package/.pi/{extensions/lib → lib}/harness-subagent-submit-registry.ts +1 -55
- package/.pi/{extensions/lib → lib}/harness-subagents-bridge.ts +53 -14
- package/.pi/{extensions/lib → lib}/harness-subprocess-bootstrap.ts +1 -1
- package/.pi/lib/harness-ui-state.ts +27 -12
- package/.pi/{extensions/lib → lib}/plan-approval/create-plan.ts +2 -2
- package/.pi/{extensions/lib → lib}/plan-approval/format-plan.ts +2 -2
- package/.pi/{extensions/lib → lib}/plan-approval/plan-review.ts +162 -201
- package/.pi/{extensions/lib → lib}/plan-approval/render.ts +1 -1
- package/.pi/{extensions/lib → lib}/plan-approval/resolve-disk.ts +2 -2
- package/.pi/{extensions/lib → lib}/plan-approval/types.ts +1 -1
- package/.pi/{extensions/lib → lib}/plan-approval/validate.ts +3 -3
- package/.pi/{extensions/lib → lib}/plan-approval-readiness.ts +3 -52
- package/.pi/{extensions/lib → lib}/plan-debate-envelope.ts +1 -1
- package/.pi/{extensions/lib → lib}/plan-debate-gate.ts +1 -1
- package/.pi/{extensions/lib → lib}/plan-debate-lane.ts +1 -4
- package/.pi/{extensions/lib → lib}/plan-messenger.ts +1 -1
- package/.pi/prompts/harness-auto.md +2 -2
- package/.pi/prompts/harness-plan.md +4 -6
- package/.pi/prompts/harness-review.md +9 -9
- package/.pi/prompts/harness-run.md +7 -7
- package/.pi/prompts/harness-setup.md +42 -68
- package/.pi/prompts/harness-steer.md +2 -2
- package/.pi/scripts/README.md +3 -5
- package/.pi/scripts/generate-agents-policy-yaml.mjs +148 -0
- package/.pi/scripts/graphify-kb-updater.mjs +48 -8
- package/.pi/scripts/harness-agents-manifest.mjs +61 -4
- package/.pi/scripts/harness-agt-doctor.ts +36 -0
- package/.pi/scripts/harness-cli-verify.sh +9 -2
- package/.pi/scripts/harness-project-toggle.mjs +129 -0
- package/.pi/scripts/harness-sentrux-cli.mjs +142 -0
- package/.pi/scripts/harness-verify.mjs +113 -39
- package/.pi/scripts/harness-web-policy-guard.mjs +2 -2
- package/.pi/scripts/validate-plan-dag.mjs +65 -74
- package/.pi/scripts/vendor-pi-vcc-settings.stub.ts +2 -2
- package/.pi/scripts/vendor-sync-pi-vcc.sh +1 -1
- package/.pi/skills/architecture/broker-domain/SKILL.md +65 -0
- package/.pi/skills/architecture/cqrs/SKILL.md +63 -0
- package/.pi/skills/architecture/event-driven/SKILL.md +60 -0
- package/.pi/skills/architecture/hexagonal-ports-adapters/SKILL.md +66 -0
- package/.pi/skills/architecture/layered/SKILL.md +68 -0
- package/.pi/skills/architecture/microkernel/SKILL.md +62 -0
- package/.pi/skills/architecture/microservices/SKILL.md +64 -0
- package/.pi/skills/architecture/modular-monolith/SKILL.md +65 -0
- package/.pi/skills/architecture/orchestration-driven-soa/SKILL.md +61 -0
- package/.pi/skills/architecture/pipeline/SKILL.md +63 -0
- package/.pi/skills/architecture/service-based/SKILL.md +64 -0
- package/.pi/skills/architecture/service-mesh/SKILL.md +60 -0
- package/.pi/skills/architecture/space-based/SKILL.md +60 -0
- package/.pi/skills/ast-grep/SKILL.md +40 -321
- package/.pi/skills/delivery/debugging-discipline/SKILL.md +36 -0
- package/.pi/skills/delivery/documentation-update/SKILL.md +33 -0
- package/.pi/skills/delivery/requirements-to-implementation/SKILL.md +34 -0
- package/.pi/skills/delivery/risk-based-verification/SKILL.md +43 -0
- package/.pi/skills/delivery/tradeoff-analysis/SKILL.md +34 -0
- package/.pi/skills/engineering/api-contract-design/SKILL.md +38 -0
- package/.pi/skills/engineering/cohesion-coupling/SKILL.md +43 -0
- package/.pi/skills/engineering/complexity-control/SKILL.md +31 -0
- package/.pi/skills/engineering/defensive-programming/SKILL.md +38 -0
- package/.pi/skills/engineering/dependency-management/SKILL.md +29 -0
- package/.pi/skills/engineering/domain-modeling/SKILL.md +32 -0
- package/.pi/skills/engineering/error-handling/SKILL.md +37 -0
- package/.pi/skills/engineering/legacy-code-seams/SKILL.md +35 -0
- package/.pi/skills/engineering/naming-and-intent/SKILL.md +29 -0
- package/.pi/skills/engineering/refactoring-safe-evolution/SKILL.md +35 -0
- package/.pi/skills/engineering/routine-function-design/SKILL.md +34 -0
- package/.pi/skills/engineering/small-change-discipline/SKILL.md +35 -0
- package/.pi/skills/lsp-navigation/SKILL.md +89 -0
- package/.pi/skills/quality/code-review-self-check/SKILL.md +35 -0
- package/.pi/skills/quality/privacy-data-handling/SKILL.md +26 -0
- package/.pi/skills/quality/security-review/SKILL.md +34 -0
- package/.pi/skills/quality/test-strategy/SKILL.md +33 -0
- package/.pi/skills/quality/testability-design/SKILL.md +33 -0
- package/.pi/skills/systems/concurrency-safety/SKILL.md +32 -0
- package/.pi/skills/systems/data-modeling-migrations/SKILL.md +31 -0
- package/.pi/skills/systems/observability-instrumentation/SKILL.md +32 -0
- package/.pi/skills/systems/performance-measurement/SKILL.md +35 -0
- package/.pi/skills/systems/reliability-design/SKILL.md +32 -0
- package/.sentrux/rules.toml +20 -4
- package/AGENTS.md +5 -0
- package/CHANGELOG.md +26 -0
- package/README.md +85 -58
- package/THIRD_PARTY_NOTICES.md +12 -21
- package/package.json +15 -7
- package/vendor/pi-subagents/src/agents.ts +45 -1
- package/vendor/pi-subagents/src/subagents.ts +866 -811
- package/vendor/pi-vcc/src/core/brief.ts +68 -99
- package/vendor/pi-vcc/src/core/settings.ts +2 -2
- package/.agents/skills/caveman/SKILL.md +0 -67
- package/.pi/agents/harness/meta-optimizer.md +0 -36
- package/.pi/agents/harness/planning/scout-graphify.md +0 -39
- package/.pi/agents/harness/planning/scout-semantic.md +0 -41
- package/.pi/agents/harness/planning/scout-structure.md +0 -37
- package/.pi/extensions/lib/ask-user/dialog.ts +0 -260
- package/.pi/extensions/lib/harness-subagent-auth.ts +0 -209
- package/.pi/extensions/lib/harness-subagent-policy.ts +0 -236
- package/.pi/extensions/pi-model-router-harness.ts +0 -42
- package/.pi/harness/evolution/meta-optimizer.mjs +0 -99
- package/.pi/harness/specs/router-tuning-proposal.schema.json +0 -114
- package/.pi/model-router.example.json +0 -36
- package/.pi/prompts/harness-critic.md +0 -10
- package/.pi/prompts/harness-eval.md +0 -10
- package/.pi/prompts/harness-router-tune.md +0 -52
- package/.pi/scripts/harness-generate-model-router.mjs +0 -327
- package/.pi/scripts/harness-model-router-routing.test.mjs +0 -97
- package/.pi/scripts/harness-sync-model-router.mjs +0 -97
- package/.pi/scripts/vendor-sync-pi-model-router.sh +0 -47
- package/vendor/pi-model-router/.prettierignore +0 -4
- package/vendor/pi-model-router/.prettierrc +0 -5
- package/vendor/pi-model-router/AGENTS.md +0 -39
- package/vendor/pi-model-router/LICENSE +0 -21
- package/vendor/pi-model-router/README.md +0 -99
- package/vendor/pi-model-router/UPSTREAM_PIN.md +0 -10
- package/vendor/pi-model-router/docs/ARCHITECTURE.md +0 -54
- package/vendor/pi-model-router/extensions/commands.ts +0 -720
- package/vendor/pi-model-router/extensions/config.ts +0 -348
- package/vendor/pi-model-router/extensions/constants.ts +0 -1
- package/vendor/pi-model-router/extensions/index.ts +0 -478
- package/vendor/pi-model-router/extensions/provider.ts +0 -580
- package/vendor/pi-model-router/extensions/routing.ts +0 -564
- package/vendor/pi-model-router/extensions/state.ts +0 -52
- package/vendor/pi-model-router/extensions/types.ts +0 -95
- package/vendor/pi-model-router/extensions/ui.ts +0 -144
- package/vendor/pi-model-router/model-router.example.json +0 -48
- package/vendor/pi-model-router/package.json +0 -48
- package/vendor/pi-model-router/tsconfig.json +0 -16
- /package/.pi/{prompts → harness/docs}/planning-rubrics.md +0 -0
- /package/.pi/{extensions/lib → lib}/ask-user/fallback.ts +0 -0
- /package/.pi/{extensions/lib → lib}/ask-user/render.ts +0 -0
- /package/.pi/{extensions/lib → lib}/ask-user/schema.ts +0 -0
- /package/.pi/{extensions/lib → lib}/ask-user/types.ts +0 -0
- /package/.pi/{extensions/lib → lib}/ask-user/validate-core.mjs +0 -0
- /package/.pi/{extensions/lib → lib}/ask-user/validate.ts +0 -0
- /package/.pi/{extensions/lib → lib}/harness-cocoindex-refresh.ts +0 -0
- /package/.pi/{extensions/lib → lib}/harness-paths.ts +0 -0
- /package/.pi/{extensions/lib → lib}/harness-spawn-budget.ts +0 -0
- /package/.pi/{extensions/lib → lib}/harness-vcc-settings.ts +0 -0
- /package/.pi/{extensions/lib → lib}/harness-web/run-cli.ts +0 -0
- /package/.pi/{extensions/lib → lib}/plan-approval/dialog.ts +0 -0
- /package/.pi/{extensions/lib → lib}/plan-approval/schema.ts +0 -0
- /package/.pi/{extensions/lib → lib}/plan-debate-eligibility.ts +0 -0
- /package/.pi/{extensions/lib → lib}/plan-debate-focus.ts +0 -0
- /package/.pi/{extensions/lib → lib}/plan-debate-id.ts +0 -0
- /package/.pi/{extensions/lib → lib}/plan-debate-lanes.ts +0 -0
- /package/.pi/{extensions/lib → lib}/plan-debate-round-status.ts +0 -0
- /package/.pi/{extensions/lib → lib}/plan-debate-write-guard.ts +0 -0
- /package/.pi/{extensions/lib → lib}/plan-review-gate.ts +0 -0
- /package/.pi/{extensions/lib → lib}/plan-review-integrator-rules.ts +0 -0
- /package/.pi/{extensions/lib → lib}/plan-scope-guard.ts +0 -0
- /package/.pi/{extensions/lib → lib}/posthog-client.ts +0 -0
- /package/.pi/{extensions/lib → lib}/posthog-node.d.ts +0 -0
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: cqrs
|
|
3
|
+
description: "Use when implementing CQRS: separate command and query models, explicit write invariants, optimized read projections, consistency boundaries, projection rebuilds, and tests for command/query behavior."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# CQRS
|
|
7
|
+
|
|
8
|
+
Use this skill when reads and writes need different models, scaling, permissions, or performance profiles.
|
|
9
|
+
|
|
10
|
+
## Fit
|
|
11
|
+
|
|
12
|
+
Use for complex domains with strong write invariants and read-heavy/query-specific views.
|
|
13
|
+
Avoid when simple CRUD is adequate; CQRS can double code paths and consistency work.
|
|
14
|
+
|
|
15
|
+
## Agent Workflow
|
|
16
|
+
|
|
17
|
+
1. Read `graphify-out/GRAPH_REPORT.md`.
|
|
18
|
+
2. Run `graphify query "CQRS command query responsibility segregation projections events"`.
|
|
19
|
+
3. Identify commands that change state and queries that read views.
|
|
20
|
+
4. Separate write model from read model incrementally.
|
|
21
|
+
5. Define consistency and projection rebuild rules.
|
|
22
|
+
6. Add tests for commands, projections, and stale reads.
|
|
23
|
+
|
|
24
|
+
## Target Shape
|
|
25
|
+
|
|
26
|
+
```text
|
|
27
|
+
codebase/<bounded-context>/
|
|
28
|
+
commands/
|
|
29
|
+
handlers/
|
|
30
|
+
model/
|
|
31
|
+
queries/
|
|
32
|
+
handlers/
|
|
33
|
+
projections/
|
|
34
|
+
events/ # optional but common
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
## Implementation Rules
|
|
38
|
+
|
|
39
|
+
- Commands express intent and enforce invariants through the write model.
|
|
40
|
+
- Queries never mutate state.
|
|
41
|
+
- Read models are optimized for consumers and may be denormalized.
|
|
42
|
+
- Projection lag and stale-read behavior must be explicit.
|
|
43
|
+
- Do not expose write entities directly as read DTOs.
|
|
44
|
+
- Keep command and query contracts versioned if external.
|
|
45
|
+
|
|
46
|
+
## Migration Steps
|
|
47
|
+
|
|
48
|
+
1. Pick one painful read or one complex command.
|
|
49
|
+
2. Create command handler and query handler folders.
|
|
50
|
+
3. Move invariant logic into command handler/write model.
|
|
51
|
+
4. Create a read projection or query representation.
|
|
52
|
+
5. Wire projection update from transaction, event, or scheduled rebuild.
|
|
53
|
+
6. Add tests for stale/missing projection behavior.
|
|
54
|
+
|
|
55
|
+
## Verification
|
|
56
|
+
|
|
57
|
+
- Use graphify to confirm query handlers do not call command mutation paths.
|
|
58
|
+
- Test command invariants independently from query projection shape.
|
|
59
|
+
- Test projection rebuild from durable source.
|
|
60
|
+
|
|
61
|
+
## Output Contract
|
|
62
|
+
|
|
63
|
+
Return: command/query split, consistency model, projection path, migration patch, and verification evidence.
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: event-driven
|
|
3
|
+
description: "Use when implementing event-driven architecture: domain/integration events, producers, consumers, broker or mediator topology, eventual consistency, idempotency, ordering, retries, and observable asynchronous flows."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Event-Driven Architecture
|
|
7
|
+
|
|
8
|
+
Use this skill when agents need to decouple producers and consumers with events safely.
|
|
9
|
+
|
|
10
|
+
## Fit
|
|
11
|
+
|
|
12
|
+
Use for asynchronous workflows, multi-consumer reactions, integration boundaries, audit trails, and high-throughput decoupling.
|
|
13
|
+
Avoid when immediate consistency and simple request/response are enough.
|
|
14
|
+
|
|
15
|
+
## Agent Workflow
|
|
16
|
+
|
|
17
|
+
1. Read `graphify-out/GRAPH_REPORT.md`.
|
|
18
|
+
2. Run `graphify query "event-driven architecture broker mediator topology eventual consistency"`.
|
|
19
|
+
3. Identify facts worth publishing, not commands disguised as events.
|
|
20
|
+
4. Choose broker/choreography or mediator/orchestration intentionally.
|
|
21
|
+
5. Implement one event path end to end.
|
|
22
|
+
6. Add idempotency, retry, and observability before expanding.
|
|
23
|
+
|
|
24
|
+
## Target Shape
|
|
25
|
+
|
|
26
|
+
```text
|
|
27
|
+
codebase/events/
|
|
28
|
+
contracts/ # event schemas and versions
|
|
29
|
+
event-bus # publish/subscribe port
|
|
30
|
+
handlers/ # consumers
|
|
31
|
+
outbox/ # reliable publish if DB-backed
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
## Implementation Rules
|
|
35
|
+
|
|
36
|
+
- Events are past-tense facts: `OrderPlaced`, not `PlaceOrder`.
|
|
37
|
+
- Event schemas are versioned and backward-compatible.
|
|
38
|
+
- Consumers are idempotent and handle duplicate/out-of-order delivery.
|
|
39
|
+
- Use an outbox/inbox pattern when database state and publishing must be reliable.
|
|
40
|
+
- Prefer correlation IDs and causation IDs for traceability.
|
|
41
|
+
- Do not hide core business invariants in eventually consistent consumers.
|
|
42
|
+
|
|
43
|
+
## Migration Steps
|
|
44
|
+
|
|
45
|
+
1. Name one event from a real business fact.
|
|
46
|
+
2. Define schema, version, producer, and consumers.
|
|
47
|
+
3. Publish after the owning transaction commits.
|
|
48
|
+
4. Add one consumer with idempotency storage.
|
|
49
|
+
5. Add retry/dead-letter behavior.
|
|
50
|
+
6. Add tests for duplicate, missing, and stale events.
|
|
51
|
+
|
|
52
|
+
## Verification
|
|
53
|
+
|
|
54
|
+
- `graphify explain "<event name>"` should show producer and consumers.
|
|
55
|
+
- Contract-test event schema compatibility.
|
|
56
|
+
- Test retry and idempotency paths.
|
|
57
|
+
|
|
58
|
+
## Output Contract
|
|
59
|
+
|
|
60
|
+
Return: event catalog, topology choice, producer/consumer patch, consistency guarantees, failure handling, and verification.
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: hexagonal-ports-adapters
|
|
3
|
+
description: "Use when implementing hexagonal architecture / ports and adapters: domain core isolated from delivery and infrastructure mechanisms, inbound and outbound ports, adapters for external interfaces, dependency inversion, and testable business logic."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Hexagonal Architecture / Ports and Adapters
|
|
7
|
+
|
|
8
|
+
Use this skill to make business logic independent of delivery mechanisms and infrastructure.
|
|
9
|
+
|
|
10
|
+
## Fit
|
|
11
|
+
|
|
12
|
+
Use when domain logic is valuable, tests are brittle due to delivery/infrastructure coupling, or adapters change often.
|
|
13
|
+
Avoid if the system is a tiny CRUD wrapper where abstraction would be ceremony.
|
|
14
|
+
|
|
15
|
+
## Agent Workflow
|
|
16
|
+
|
|
17
|
+
1. Read `graphify-out/GRAPH_REPORT.md`.
|
|
18
|
+
2. Run `graphify query "hexagonal architecture ports adapters domain operational coupling"`.
|
|
19
|
+
3. Identify the core domain/application use case.
|
|
20
|
+
4. Define inbound and outbound ports around it.
|
|
21
|
+
5. Move delivery/infrastructure-specific code to adapters.
|
|
22
|
+
6. Test the core through ports without infrastructure.
|
|
23
|
+
|
|
24
|
+
## Target Shape
|
|
25
|
+
|
|
26
|
+
```text
|
|
27
|
+
codebase/
|
|
28
|
+
core/
|
|
29
|
+
domain/
|
|
30
|
+
application/
|
|
31
|
+
ports/
|
|
32
|
+
inbound-port
|
|
33
|
+
outbound-port
|
|
34
|
+
adapters/
|
|
35
|
+
inbound/external-interface/
|
|
36
|
+
inbound/operator-interface/
|
|
37
|
+
outbound/persistence/
|
|
38
|
+
outbound/messaging/
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
## Implementation Rules
|
|
42
|
+
|
|
43
|
+
- Core owns domain and application behavior.
|
|
44
|
+
- Inbound adapters translate external requests into use-case calls.
|
|
45
|
+
- Outbound adapters implement core-defined ports for persistence, messaging, time, IDs, and external APIs.
|
|
46
|
+
- Dependencies point inward: adapters reference core, core does not reference adapters.
|
|
47
|
+
- Use dependency injection/composition at the edge.
|
|
48
|
+
|
|
49
|
+
## Migration Steps
|
|
50
|
+
|
|
51
|
+
1. Pick one use case entangled with delivery or persistence infrastructure.
|
|
52
|
+
2. Extract its input/output contracts and port interfaces into core.
|
|
53
|
+
3. Move business decisions into application/domain.
|
|
54
|
+
4. Wrap existing persistence/integration code as an outbound adapter.
|
|
55
|
+
5. Wire adapters in the composition root.
|
|
56
|
+
6. Add core tests with fake outbound ports.
|
|
57
|
+
|
|
58
|
+
## Verification
|
|
59
|
+
|
|
60
|
+
- `graphify explain "core"` should show no outbound adapter or infrastructure references.
|
|
61
|
+
- Search core paths for delivery, persistence, messaging, filesystem, environment, or platform dependencies.
|
|
62
|
+
- Test core without starting external infrastructure.
|
|
63
|
+
|
|
64
|
+
## Output Contract
|
|
65
|
+
|
|
66
|
+
Return: core boundary, ports, adapters, composition root change, tests, and remaining coupling.
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: layered
|
|
3
|
+
description: "Use when designing, refactoring, or validating a codebase as layered architecture: delivery/interface, application/use-case, domain, and infrastructure/data layers with one-way dependency rules and minimal cross-layer coupling."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Layered Architecture
|
|
7
|
+
|
|
8
|
+
Use this skill to help an agent implement layered architecture, not just describe it.
|
|
9
|
+
|
|
10
|
+
## Fit
|
|
11
|
+
|
|
12
|
+
Use when the system is mostly CRUD, workflow-oriented, or policy-heavy and benefits from clear dependency direction.
|
|
13
|
+
Avoid when independent deployment, high autonomous scaling, or highly asynchronous collaboration is the main driver.
|
|
14
|
+
|
|
15
|
+
## Agent Workflow
|
|
16
|
+
|
|
17
|
+
1. Read `graphify-out/GRAPH_REPORT.md` before source files.
|
|
18
|
+
2. Run `graphify query "layered architecture dependencies presentation application domain infrastructure"`.
|
|
19
|
+
3. Infer the actual layers from packages, modules, and graph communities.
|
|
20
|
+
4. Define allowed dependencies before moving code.
|
|
21
|
+
5. Make the smallest refactor that improves directionality.
|
|
22
|
+
6. Add a fitness check that prevents backsliding.
|
|
23
|
+
|
|
24
|
+
## Target Shape
|
|
25
|
+
|
|
26
|
+
Typical dependency direction:
|
|
27
|
+
|
|
28
|
+
```text
|
|
29
|
+
presentation/api -> application/use-cases -> domain -> infrastructure interfaces
|
|
30
|
+
infrastructure adapters -> domain/application ports
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
Prefer these directories when introducing structure:
|
|
34
|
+
|
|
35
|
+
```text
|
|
36
|
+
codebase/
|
|
37
|
+
delivery/ # external-interface adapters
|
|
38
|
+
application/ # use cases, commands, queries, units of work
|
|
39
|
+
domain/ # entities, value objects, policies, domain services
|
|
40
|
+
infrastructure/ # persistence, network, messaging, filesystem, platform adapters
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
## Implementation Rules
|
|
44
|
+
|
|
45
|
+
- Domain code must not reference delivery mechanisms, persistence tooling, messaging systems, clocks, environment, or global configuration.
|
|
46
|
+
- Application code orchestrates use cases and owns transaction boundaries.
|
|
47
|
+
- Delivery/interface code maps external contracts to application inputs; it does not hold business rules.
|
|
48
|
+
- Infrastructure implements interfaces/ports declared inward.
|
|
49
|
+
- Shared utilities must be boring, stable, and dependency-free; do not create a junk drawer.
|
|
50
|
+
|
|
51
|
+
## Migration Steps
|
|
52
|
+
|
|
53
|
+
1. Pick one vertical use case.
|
|
54
|
+
2. Move business decisions from entrypoint handlers into `domain/`.
|
|
55
|
+
3. Create an application use-case routine around it.
|
|
56
|
+
4. Place infrastructure behind explicit interfaces.
|
|
57
|
+
5. Leave old entrypoints as thin adapters.
|
|
58
|
+
6. Repeat by use case, not by sweeping folders.
|
|
59
|
+
|
|
60
|
+
## Verification
|
|
61
|
+
|
|
62
|
+
- Use `graphify explain "<domain symbol>"` to confirm it has no outbound delivery/infrastructure edges.
|
|
63
|
+
- Search domain paths for forbidden references to delivery, persistence, messaging, environment, or platform mechanisms.
|
|
64
|
+
- Add dependency-boundary tests with the repo's existing verification tooling.
|
|
65
|
+
|
|
66
|
+
## Output Contract
|
|
67
|
+
|
|
68
|
+
Return: inferred layers, violations, minimal migration patch, verification run, and remaining risks.
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: microkernel
|
|
3
|
+
description: "Use when building plugin or extension architecture: a stable core kernel with explicit extension points, plugin contracts, registration, isolation, versioning, and compatibility checks."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Microkernel / Plugin Architecture
|
|
7
|
+
|
|
8
|
+
Use this skill when the codebase needs a small core and independently variable plugins.
|
|
9
|
+
|
|
10
|
+
## Fit
|
|
11
|
+
|
|
12
|
+
Use for CLIs, editors, rules engines, integrations, workflow engines, agent tools, and product variants.
|
|
13
|
+
Avoid when variation is low or plugin isolation would add more complexity than it removes.
|
|
14
|
+
|
|
15
|
+
## Agent Workflow
|
|
16
|
+
|
|
17
|
+
1. Read `graphify-out/GRAPH_REPORT.md`.
|
|
18
|
+
2. Run `graphify query "microkernel plugin extension points core adapters"`.
|
|
19
|
+
3. Identify stable core responsibilities versus variable behavior.
|
|
20
|
+
4. Define extension contracts before extracting plugins.
|
|
21
|
+
5. Move one variable feature behind a plugin boundary.
|
|
22
|
+
6. Add compatibility and registration checks.
|
|
23
|
+
|
|
24
|
+
## Target Shape
|
|
25
|
+
|
|
26
|
+
```text
|
|
27
|
+
codebase/kernel/
|
|
28
|
+
contracts # plugin interfaces, capabilities, lifecycle
|
|
29
|
+
registry # discovery, validation, ordering
|
|
30
|
+
runtime # core orchestration
|
|
31
|
+
codebase/plugins/
|
|
32
|
+
<plugin-name>/
|
|
33
|
+
entrypoint # manifest + implementation
|
|
34
|
+
tests/
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
## Implementation Rules
|
|
38
|
+
|
|
39
|
+
- Kernel owns orchestration, lifecycle, contracts, capability negotiation, and safe defaults.
|
|
40
|
+
- Plugins own optional behavior only; they must not mutate kernel internals.
|
|
41
|
+
- Plugin APIs are versioned and narrow.
|
|
42
|
+
- Registration validates name, version, capabilities, dependencies, and conflicts.
|
|
43
|
+
- Side effects are exposed through kernel-provided services, not global imports.
|
|
44
|
+
|
|
45
|
+
## Migration Steps
|
|
46
|
+
|
|
47
|
+
1. Name the extension point.
|
|
48
|
+
2. Create contract and manifest types.
|
|
49
|
+
3. Implement an in-process registry.
|
|
50
|
+
4. Wrap one existing variation as the first built-in plugin.
|
|
51
|
+
5. Replace direct branching with registry dispatch.
|
|
52
|
+
6. Add contract tests reused by every plugin.
|
|
53
|
+
|
|
54
|
+
## Verification
|
|
55
|
+
|
|
56
|
+
- `graphify explain "registry"` should show kernel-to-plugin direction, not plugin-to-kernel internals.
|
|
57
|
+
- Add tests for plugin registration, invalid manifests, lifecycle failures, and version mismatch.
|
|
58
|
+
- Search for plugin imports of kernel private paths.
|
|
59
|
+
|
|
60
|
+
## Output Contract
|
|
61
|
+
|
|
62
|
+
Return: kernel boundary, extension points, plugin contract, migrated plugin, compatibility tests, and known limitations.
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: microservices
|
|
3
|
+
description: "Use when designing, extracting, or repairing microservices: independently deployable bounded-context services with owned data, explicit contracts, observability, resilience, distributed workflow choices, and operational readiness checks."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Microservices Architecture
|
|
7
|
+
|
|
8
|
+
Use this skill only when service independence is worth distributed-system cost.
|
|
9
|
+
|
|
10
|
+
## Fit
|
|
11
|
+
|
|
12
|
+
Use when services need independent deployability, independent scaling, domain autonomy, and separate data ownership.
|
|
13
|
+
Avoid when boundaries are unclear, teams cannot operate services, or a modular monolith would solve the problem.
|
|
14
|
+
|
|
15
|
+
## Agent Workflow
|
|
16
|
+
|
|
17
|
+
1. Read `graphify-out/GRAPH_REPORT.md`.
|
|
18
|
+
2. Run `graphify query "microservices bounded context data isolation choreography orchestration sagas"`.
|
|
19
|
+
3. Identify bounded contexts and fracture planes.
|
|
20
|
+
4. Choose one extraction candidate with high cohesion and low coupling.
|
|
21
|
+
5. Define API/events/data ownership before moving code.
|
|
22
|
+
6. Add production-readiness controls with the first extraction.
|
|
23
|
+
|
|
24
|
+
## Target Shape
|
|
25
|
+
|
|
26
|
+
```text
|
|
27
|
+
services/
|
|
28
|
+
orders/
|
|
29
|
+
code/
|
|
30
|
+
contract/ # API specs, event schemas
|
|
31
|
+
migrations/
|
|
32
|
+
deploy/
|
|
33
|
+
billing/
|
|
34
|
+
...
|
|
35
|
+
shared/ # generated clients/contracts only; no shared domain model
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
## Implementation Rules
|
|
39
|
+
|
|
40
|
+
- Each service owns its data; no cross-service table writes.
|
|
41
|
+
- Contracts are explicit: API schema, event schema, or generated client.
|
|
42
|
+
- Distributed workflows use choreography, orchestration, or saga intentionally.
|
|
43
|
+
- Every network call has timeout, retry policy, circuit breaker/backoff as appropriate, and observability.
|
|
44
|
+
- Avoid shared domain libraries; share contracts, not internals.
|
|
45
|
+
- Extraction must include deployment, rollback, monitoring, and incident path.
|
|
46
|
+
|
|
47
|
+
## Migration Steps
|
|
48
|
+
|
|
49
|
+
1. Prove the boundary with a modular monolith facade first when possible.
|
|
50
|
+
2. Create service contract and data ownership doc.
|
|
51
|
+
3. Duplicate or migrate data behind an anti-corruption layer.
|
|
52
|
+
4. Route one use case through the new service.
|
|
53
|
+
5. Add contract tests and consumer-driven compatibility checks.
|
|
54
|
+
6. Add traces, metrics, logs, health checks, and rollback.
|
|
55
|
+
|
|
56
|
+
## Verification
|
|
57
|
+
|
|
58
|
+
- `graphify explain "<service>"` should show contract edges, not private code sharing.
|
|
59
|
+
- Test API compatibility, idempotency, failure, timeout, and degraded dependency behavior.
|
|
60
|
+
- Verify no direct database access across service boundaries.
|
|
61
|
+
|
|
62
|
+
## Output Contract
|
|
63
|
+
|
|
64
|
+
Return: service boundary, contracts, data ownership, extraction patch, resilience controls, verification, and ops risks.
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: modular-monolith
|
|
3
|
+
description: "Use when designing, splitting, or repairing a modular monolith: one deployable application with explicit business modules, bounded contexts, private internals, stable module APIs, and database boundaries that can later support service extraction."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Modular Monolith
|
|
7
|
+
|
|
8
|
+
Use this skill when an agent should preserve monolith simplicity while creating real architectural boundaries.
|
|
9
|
+
|
|
10
|
+
## Fit
|
|
11
|
+
|
|
12
|
+
Use when one deployable is acceptable but the codebase needs independent business modules, lower coupling, and clearer ownership.
|
|
13
|
+
Avoid premature microservices when deployment independence, team autonomy, and operational maturity are not proven.
|
|
14
|
+
|
|
15
|
+
## Agent Workflow
|
|
16
|
+
|
|
17
|
+
1. Read `graphify-out/GRAPH_REPORT.md`.
|
|
18
|
+
2. Run `graphify query "modular monolith bounded context module boundaries coupling"`.
|
|
19
|
+
3. Identify business capabilities and their current code communities.
|
|
20
|
+
4. Pick one module boundary to harden.
|
|
21
|
+
5. Introduce module APIs before moving persistence or transport code.
|
|
22
|
+
6. Verify no private internals leak across modules.
|
|
23
|
+
|
|
24
|
+
## Target Shape
|
|
25
|
+
|
|
26
|
+
```text
|
|
27
|
+
codebase/modules/
|
|
28
|
+
billing/
|
|
29
|
+
public-api # exported commands/events/types only
|
|
30
|
+
application/
|
|
31
|
+
domain/
|
|
32
|
+
infrastructure/
|
|
33
|
+
internal/ # never imported by other modules
|
|
34
|
+
identity/
|
|
35
|
+
public-api
|
|
36
|
+
...
|
|
37
|
+
codebase/shared-kernel/ # tiny, stable cross-module primitives only
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
## Implementation Rules
|
|
41
|
+
|
|
42
|
+
- Modules communicate through an explicit public API/facade, application commands, domain events, or explicit query APIs.
|
|
43
|
+
- No module imports another module's `internal/`, `domain/`, or infrastructure files.
|
|
44
|
+
- Keep one process and one deployment until extraction pressure is real.
|
|
45
|
+
- Prefer per-module schemas/tables or clear ownership comments for shared DBs.
|
|
46
|
+
- Shared kernel must be small; duplicated domain language is often better than false sharing.
|
|
47
|
+
|
|
48
|
+
## Migration Steps
|
|
49
|
+
|
|
50
|
+
1. Name the bounded context using domain vocabulary.
|
|
51
|
+
2. Create the module directory and public API/facade.
|
|
52
|
+
3. Move one cohesive use case behind the facade.
|
|
53
|
+
4. Replace external imports with facade calls.
|
|
54
|
+
5. Add a dependency-boundary rule.
|
|
55
|
+
6. Document the module's owned data and events.
|
|
56
|
+
|
|
57
|
+
## Verification
|
|
58
|
+
|
|
59
|
+
- `graphify explain "<module name>"` should show few cross-module private edges.
|
|
60
|
+
- Use structural search for imports from `modules/*/internal`, `domain`, or `infrastructure` across module boundaries.
|
|
61
|
+
- Add tests at module API boundaries, not only end-to-end tests.
|
|
62
|
+
|
|
63
|
+
## Output Contract
|
|
64
|
+
|
|
65
|
+
Return: proposed modules, public APIs, forbidden imports, migration patch, fitness check, and extraction readiness notes.
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: orchestration-driven-soa
|
|
3
|
+
description: "Use when implementing orchestration-driven service-oriented architecture: central workflow orchestration across services, explicit process models, compensations, service contracts, long-running transactions, and governance boundaries."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Orchestration-Driven SOA
|
|
7
|
+
|
|
8
|
+
Use this skill when a central process coordinator is the clearest way to manage cross-service workflows.
|
|
9
|
+
|
|
10
|
+
## Fit
|
|
11
|
+
|
|
12
|
+
Use for long-running business processes, compliance-heavy flows, and integrations where visibility and control matter more than local autonomy.
|
|
13
|
+
Avoid when simple choreography is sufficient or a central orchestrator would become a god service.
|
|
14
|
+
|
|
15
|
+
## Agent Workflow
|
|
16
|
+
|
|
17
|
+
1. Read `graphify-out/GRAPH_REPORT.md`.
|
|
18
|
+
2. Run `graphify query "orchestration driven service oriented architecture workflow compensation"`.
|
|
19
|
+
3. Identify the end-to-end business process and participating services.
|
|
20
|
+
4. Model the workflow states before code.
|
|
21
|
+
5. Implement the orchestrator as a thin state machine, not a business blob.
|
|
22
|
+
6. Add compensation and timeout behavior.
|
|
23
|
+
|
|
24
|
+
## Target Shape
|
|
25
|
+
|
|
26
|
+
```text
|
|
27
|
+
codebase/workflows/
|
|
28
|
+
<workflow>/
|
|
29
|
+
states
|
|
30
|
+
orchestrator
|
|
31
|
+
participants
|
|
32
|
+
compensations
|
|
33
|
+
tests/
|
|
34
|
+
codebase/services/*/contract
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
## Implementation Rules
|
|
38
|
+
|
|
39
|
+
- Orchestrator owns process state, sequencing, timeouts, and compensation.
|
|
40
|
+
- Domain services own local business invariants and data.
|
|
41
|
+
- Participant contracts are explicit and versioned.
|
|
42
|
+
- Every remote step has timeout, retry, and compensation semantics.
|
|
43
|
+
- Avoid embedding service internals in the orchestrator.
|
|
44
|
+
|
|
45
|
+
## Migration Steps
|
|
46
|
+
|
|
47
|
+
1. Draw the workflow as states and transitions.
|
|
48
|
+
2. Define participant ports/contracts.
|
|
49
|
+
3. Implement a state store for workflow instances.
|
|
50
|
+
4. Move cross-service sequencing into the orchestrator.
|
|
51
|
+
5. Add compensating actions for partial failure.
|
|
52
|
+
6. Add trace IDs across all participant calls.
|
|
53
|
+
|
|
54
|
+
## Verification
|
|
55
|
+
|
|
56
|
+
- `graphify explain "orchestrator"` should show workflow-to-contract dependencies, not service internals.
|
|
57
|
+
- Test happy path, participant failure, retry exhaustion, timeout, compensation failure, and resume after crash.
|
|
58
|
+
|
|
59
|
+
## Output Contract
|
|
60
|
+
|
|
61
|
+
Return: workflow state model, participant contracts, orchestrator patch, compensation matrix, and verification evidence.
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: pipeline
|
|
3
|
+
description: "Use when implementing pipeline architecture: data or task processing split into ordered filters/stages with explicit inputs, outputs, composition, error handling, and observability across the flow."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Pipeline Architecture
|
|
7
|
+
|
|
8
|
+
Use this skill to transform tangled sequential processing into composable stages.
|
|
9
|
+
|
|
10
|
+
## Fit
|
|
11
|
+
|
|
12
|
+
Use for compilers, ETL, media/document processing, validation chains, enrichment, agent workflows, and deterministic multi-step transformations.
|
|
13
|
+
Avoid when stages require heavy bidirectional coordination or shared mutable state.
|
|
14
|
+
|
|
15
|
+
## Agent Workflow
|
|
16
|
+
|
|
17
|
+
1. Read `graphify-out/GRAPH_REPORT.md`.
|
|
18
|
+
2. Run `graphify query "pipeline stages filters processing flow"`.
|
|
19
|
+
3. Identify the current implicit sequence and data passed between steps.
|
|
20
|
+
4. Define a typed stage contract.
|
|
21
|
+
5. Extract one stage at a time.
|
|
22
|
+
6. Add tests per stage and for the assembled pipeline.
|
|
23
|
+
|
|
24
|
+
## Target Shape
|
|
25
|
+
|
|
26
|
+
```text
|
|
27
|
+
codebase/pipeline/
|
|
28
|
+
stage-contract # Stage<Input, Output>, context, errors
|
|
29
|
+
stages/
|
|
30
|
+
parse
|
|
31
|
+
validate
|
|
32
|
+
enrich
|
|
33
|
+
persist
|
|
34
|
+
compose # ordering and short-circuit rules
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
## Implementation Rules
|
|
38
|
+
|
|
39
|
+
- Each stage has one responsibility and explicit input/output.
|
|
40
|
+
- Stages do not reach backward into previous stages' internals.
|
|
41
|
+
- Shared context is read-mostly; stage outputs carry facts forward.
|
|
42
|
+
- Treat retries, dead letters, partial failures, and idempotency as first-class.
|
|
43
|
+
- Put composition outside stages so ordering is visible.
|
|
44
|
+
|
|
45
|
+
## Migration Steps
|
|
46
|
+
|
|
47
|
+
1. Write the stage interface.
|
|
48
|
+
2. Wrap the existing process as one stage-preserving facade.
|
|
49
|
+
3. Extract the first pure transformation.
|
|
50
|
+
4. Add fixture tests for that stage.
|
|
51
|
+
5. Extract side-effecting stages behind ports/adapters.
|
|
52
|
+
6. Make observability emit stage name, duration, input id, and failure class.
|
|
53
|
+
|
|
54
|
+
## Verification
|
|
55
|
+
|
|
56
|
+
- Use `graphify explain "compose"` or the pipeline entrypoint to inspect stage dependencies.
|
|
57
|
+
- Test stages independently with fixtures.
|
|
58
|
+
- Test full ordering with one integration test.
|
|
59
|
+
- Confirm stages do not directly depend on each other except through composition.
|
|
60
|
+
|
|
61
|
+
## Output Contract
|
|
62
|
+
|
|
63
|
+
Return: stage map, stage contracts, extracted stage patch, failure semantics, and verification evidence.
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: service-based
|
|
3
|
+
description: "Use when implementing service-based architecture: coarse-grained domain services inside a mostly centralized system, with explicit service contracts, transaction boundaries, shared infrastructure discipline, and fewer operational costs than microservices."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Service-Based Architecture
|
|
7
|
+
|
|
8
|
+
Use this skill to carve coarse domain services without forcing full microservice overhead.
|
|
9
|
+
|
|
10
|
+
## Fit
|
|
11
|
+
|
|
12
|
+
Use when modules need clearer runtime/service boundaries but can share deployment, database infrastructure, or platform operations.
|
|
13
|
+
Avoid when independent deployability and data ownership per service are already mandatory.
|
|
14
|
+
|
|
15
|
+
## Agent Workflow
|
|
16
|
+
|
|
17
|
+
1. Read `graphify-out/GRAPH_REPORT.md`.
|
|
18
|
+
2. Run `graphify query "service-based architecture coarse services database boundaries transactions"`.
|
|
19
|
+
3. Identify coarse business services and shared resources.
|
|
20
|
+
4. Define service contracts and transaction ownership.
|
|
21
|
+
5. Extract one service facade and move callers behind it.
|
|
22
|
+
6. Add contract and dependency checks.
|
|
23
|
+
|
|
24
|
+
## Target Shape
|
|
25
|
+
|
|
26
|
+
```text
|
|
27
|
+
codebase/services/
|
|
28
|
+
customer/
|
|
29
|
+
contract
|
|
30
|
+
service
|
|
31
|
+
data-access
|
|
32
|
+
order/
|
|
33
|
+
contract
|
|
34
|
+
service
|
|
35
|
+
data-access
|
|
36
|
+
codebase/platform/ # shared runtime, config, logging, persistence connection
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
## Implementation Rules
|
|
40
|
+
|
|
41
|
+
- Services are coarse-grained and domain-aligned, not one service per entity.
|
|
42
|
+
- Services expose contracts; callers do not reach into service internals.
|
|
43
|
+
- Transaction boundaries are explicit and usually owned by the called service.
|
|
44
|
+
- Shared DB is allowed, but table ownership and cross-service writes must be documented.
|
|
45
|
+
- Avoid distributed systems ceremony unless deployment separation is real.
|
|
46
|
+
|
|
47
|
+
## Migration Steps
|
|
48
|
+
|
|
49
|
+
1. Pick one domain service with many scattered callers.
|
|
50
|
+
2. Create the service contract and service facade.
|
|
51
|
+
3. Move behavior behind the facade.
|
|
52
|
+
4. Replace direct data writes from other areas with service calls.
|
|
53
|
+
5. Document data ownership.
|
|
54
|
+
6. Add tests for service contract and transaction behavior.
|
|
55
|
+
|
|
56
|
+
## Verification
|
|
57
|
+
|
|
58
|
+
- Use `graphify explain "<service name>"` to inspect inbound/outbound coupling.
|
|
59
|
+
- Search for cross-service imports into internal files.
|
|
60
|
+
- Test that callers use contracts and cannot mutate owned data directly.
|
|
61
|
+
|
|
62
|
+
## Output Contract
|
|
63
|
+
|
|
64
|
+
Return: service boundaries, contracts, transaction rules, migrated callers, verification, and microservice-readiness caveats.
|