@sdd-method/sdd-cli 0.9.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/LICENSE +201 -0
- package/NOTICE +17 -0
- package/README.md +151 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +8 -0
- package/dist/cli.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +66 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/bundle.d.ts +20 -0
- package/dist/lib/bundle.d.ts.map +1 -0
- package/dist/lib/bundle.js +75 -0
- package/dist/lib/bundle.js.map +1 -0
- package/dist/lib/generate-claude-md/index.d.ts +16 -0
- package/dist/lib/generate-claude-md/index.d.ts.map +1 -0
- package/dist/lib/generate-claude-md/index.js +89 -0
- package/dist/lib/generate-claude-md/index.js.map +1 -0
- package/dist/lib/hooks-seed/entries.d.ts +16 -0
- package/dist/lib/hooks-seed/entries.d.ts.map +1 -0
- package/dist/lib/hooks-seed/entries.js +47 -0
- package/dist/lib/hooks-seed/entries.js.map +1 -0
- package/dist/lib/hooks-seed/index.d.ts +17 -0
- package/dist/lib/hooks-seed/index.d.ts.map +1 -0
- package/dist/lib/hooks-seed/index.js +15 -0
- package/dist/lib/hooks-seed/index.js.map +1 -0
- package/dist/lib/hooks-seed/merge.d.ts +24 -0
- package/dist/lib/hooks-seed/merge.d.ts.map +1 -0
- package/dist/lib/hooks-seed/merge.js +73 -0
- package/dist/lib/hooks-seed/merge.js.map +1 -0
- package/dist/lib/hooks-seed/types.d.ts +27 -0
- package/dist/lib/hooks-seed/types.d.ts.map +1 -0
- package/dist/lib/hooks-seed/types.js +20 -0
- package/dist/lib/hooks-seed/types.js.map +1 -0
- package/dist/lib/init/app.d.ts +21 -0
- package/dist/lib/init/app.d.ts.map +1 -0
- package/dist/lib/init/app.js +132 -0
- package/dist/lib/init/app.js.map +1 -0
- package/dist/lib/init/ci-workflow.d.ts +29 -0
- package/dist/lib/init/ci-workflow.d.ts.map +1 -0
- package/dist/lib/init/ci-workflow.js +78 -0
- package/dist/lib/init/ci-workflow.js.map +1 -0
- package/dist/lib/init/claude-md.d.ts +19 -0
- package/dist/lib/init/claude-md.d.ts.map +1 -0
- package/dist/lib/init/claude-md.js +140 -0
- package/dist/lib/init/claude-md.js.map +1 -0
- package/dist/lib/init/index.d.ts +33 -0
- package/dist/lib/init/index.d.ts.map +1 -0
- package/dist/lib/init/index.js +232 -0
- package/dist/lib/init/index.js.map +1 -0
- package/dist/lib/init/integration.d.ts +53 -0
- package/dist/lib/init/integration.d.ts.map +1 -0
- package/dist/lib/init/integration.js +237 -0
- package/dist/lib/init/integration.js.map +1 -0
- package/dist/lib/init/platform.d.ts +26 -0
- package/dist/lib/init/platform.d.ts.map +1 -0
- package/dist/lib/init/platform.js +188 -0
- package/dist/lib/init/platform.js.map +1 -0
- package/dist/lib/list/discover.d.ts +8 -0
- package/dist/lib/list/discover.d.ts.map +1 -0
- package/dist/lib/list/discover.js +77 -0
- package/dist/lib/list/discover.js.map +1 -0
- package/dist/lib/list/format.d.ts +9 -0
- package/dist/lib/list/format.d.ts.map +1 -0
- package/dist/lib/list/format.js +44 -0
- package/dist/lib/list/format.js.map +1 -0
- package/dist/lib/list/index.d.ts +12 -0
- package/dist/lib/list/index.d.ts.map +1 -0
- package/dist/lib/list/index.js +15 -0
- package/dist/lib/list/index.js.map +1 -0
- package/dist/lib/lock-file.d.ts +14 -0
- package/dist/lib/lock-file.d.ts.map +1 -0
- package/dist/lib/lock-file.js +80 -0
- package/dist/lib/lock-file.js.map +1 -0
- package/dist/lib/mcp/build-info.d.ts +9 -0
- package/dist/lib/mcp/build-info.d.ts.map +1 -0
- package/dist/lib/mcp/build-info.js +10 -0
- package/dist/lib/mcp/build-info.js.map +1 -0
- package/dist/lib/mcp/errors.d.ts +23 -0
- package/dist/lib/mcp/errors.d.ts.map +1 -0
- package/dist/lib/mcp/errors.js +25 -0
- package/dist/lib/mcp/errors.js.map +1 -0
- package/dist/lib/mcp/parse/frontmatter.d.ts +22 -0
- package/dist/lib/mcp/parse/frontmatter.d.ts.map +1 -0
- package/dist/lib/mcp/parse/frontmatter.js +49 -0
- package/dist/lib/mcp/parse/frontmatter.js.map +1 -0
- package/dist/lib/mcp/parse/gate-registry.d.ts +19 -0
- package/dist/lib/mcp/parse/gate-registry.d.ts.map +1 -0
- package/dist/lib/mcp/parse/gate-registry.js +68 -0
- package/dist/lib/mcp/parse/gate-registry.js.map +1 -0
- package/dist/lib/mcp/parse/paths.d.ts +21 -0
- package/dist/lib/mcp/parse/paths.d.ts.map +1 -0
- package/dist/lib/mcp/parse/paths.js +83 -0
- package/dist/lib/mcp/parse/paths.js.map +1 -0
- package/dist/lib/mcp/pin/errors.d.ts +11 -0
- package/dist/lib/mcp/pin/errors.d.ts.map +1 -0
- package/dist/lib/mcp/pin/errors.js +32 -0
- package/dist/lib/mcp/pin/errors.js.map +1 -0
- package/dist/lib/mcp/pin/index.d.ts +18 -0
- package/dist/lib/mcp/pin/index.d.ts.map +1 -0
- package/dist/lib/mcp/pin/index.js +29 -0
- package/dist/lib/mcp/pin/index.js.map +1 -0
- package/dist/lib/mcp/pin/read.d.ts +24 -0
- package/dist/lib/mcp/pin/read.d.ts.map +1 -0
- package/dist/lib/mcp/pin/read.js +64 -0
- package/dist/lib/mcp/pin/read.js.map +1 -0
- package/dist/lib/mcp/pin/resolve.d.ts +12 -0
- package/dist/lib/mcp/pin/resolve.d.ts.map +1 -0
- package/dist/lib/mcp/pin/resolve.js +33 -0
- package/dist/lib/mcp/pin/resolve.js.map +1 -0
- package/dist/lib/mcp/prompts/evaluate-cascade.d.ts +14 -0
- package/dist/lib/mcp/prompts/evaluate-cascade.d.ts.map +1 -0
- package/dist/lib/mcp/prompts/evaluate-cascade.js +147 -0
- package/dist/lib/mcp/prompts/evaluate-cascade.js.map +1 -0
- package/dist/lib/mcp/prompts/index.d.ts +9 -0
- package/dist/lib/mcp/prompts/index.d.ts.map +1 -0
- package/dist/lib/mcp/prompts/index.js +23 -0
- package/dist/lib/mcp/prompts/index.js.map +1 -0
- package/dist/lib/mcp/prompts/propose-adr.d.ts +12 -0
- package/dist/lib/mcp/prompts/propose-adr.d.ts.map +1 -0
- package/dist/lib/mcp/prompts/propose-adr.js +94 -0
- package/dist/lib/mcp/prompts/propose-adr.js.map +1 -0
- package/dist/lib/mcp/prompts/review-data-model-change.d.ts +10 -0
- package/dist/lib/mcp/prompts/review-data-model-change.d.ts.map +1 -0
- package/dist/lib/mcp/prompts/review-data-model-change.js +134 -0
- package/dist/lib/mcp/prompts/review-data-model-change.js.map +1 -0
- package/dist/lib/mcp/prompts/template-loader.d.ts +29 -0
- package/dist/lib/mcp/prompts/template-loader.d.ts.map +1 -0
- package/dist/lib/mcp/prompts/template-loader.js +44 -0
- package/dist/lib/mcp/prompts/template-loader.js.map +1 -0
- package/dist/lib/mcp/prompts/types.d.ts +17 -0
- package/dist/lib/mcp/prompts/types.d.ts.map +1 -0
- package/dist/lib/mcp/prompts/types.js +10 -0
- package/dist/lib/mcp/prompts/types.js.map +1 -0
- package/dist/lib/mcp/prompts/write-capability-spec.d.ts +8 -0
- package/dist/lib/mcp/prompts/write-capability-spec.d.ts.map +1 -0
- package/dist/lib/mcp/prompts/write-capability-spec.js +85 -0
- package/dist/lib/mcp/prompts/write-capability-spec.js.map +1 -0
- package/dist/lib/mcp/prompts/write-feature-spec.d.ts +10 -0
- package/dist/lib/mcp/prompts/write-feature-spec.d.ts.map +1 -0
- package/dist/lib/mcp/prompts/write-feature-spec.js +94 -0
- package/dist/lib/mcp/prompts/write-feature-spec.js.map +1 -0
- package/dist/lib/mcp/prompts/write-work-order.d.ts +7 -0
- package/dist/lib/mcp/prompts/write-work-order.d.ts.map +1 -0
- package/dist/lib/mcp/prompts/write-work-order.js +69 -0
- package/dist/lib/mcp/prompts/write-work-order.js.map +1 -0
- package/dist/lib/mcp/reader.d.ts +37 -0
- package/dist/lib/mcp/reader.d.ts.map +1 -0
- package/dist/lib/mcp/reader.js +93 -0
- package/dist/lib/mcp/reader.js.map +1 -0
- package/dist/lib/mcp/resources/adrs.d.ts +3 -0
- package/dist/lib/mcp/resources/adrs.d.ts.map +1 -0
- package/dist/lib/mcp/resources/adrs.js +97 -0
- package/dist/lib/mcp/resources/adrs.js.map +1 -0
- package/dist/lib/mcp/resources/data-models.d.ts +14 -0
- package/dist/lib/mcp/resources/data-models.d.ts.map +1 -0
- package/dist/lib/mcp/resources/data-models.js +81 -0
- package/dist/lib/mcp/resources/data-models.js.map +1 -0
- package/dist/lib/mcp/resources/gates.d.ts +9 -0
- package/dist/lib/mcp/resources/gates.d.ts.map +1 -0
- package/dist/lib/mcp/resources/gates.js +90 -0
- package/dist/lib/mcp/resources/gates.js.map +1 -0
- package/dist/lib/mcp/resources/glossary.d.ts +16 -0
- package/dist/lib/mcp/resources/glossary.d.ts.map +1 -0
- package/dist/lib/mcp/resources/glossary.js +87 -0
- package/dist/lib/mcp/resources/glossary.js.map +1 -0
- package/dist/lib/mcp/resources/specs.d.ts +23 -0
- package/dist/lib/mcp/resources/specs.d.ts.map +1 -0
- package/dist/lib/mcp/resources/specs.js +151 -0
- package/dist/lib/mcp/resources/specs.js.map +1 -0
- package/dist/lib/mcp/resources/version.d.ts +3 -0
- package/dist/lib/mcp/resources/version.d.ts.map +1 -0
- package/dist/lib/mcp/resources/version.js +45 -0
- package/dist/lib/mcp/resources/version.js.map +1 -0
- package/dist/lib/mcp/server.d.ts +29 -0
- package/dist/lib/mcp/server.d.ts.map +1 -0
- package/dist/lib/mcp/server.js +104 -0
- package/dist/lib/mcp/server.js.map +1 -0
- package/dist/lib/mcp/tools/cascade-impact.d.ts +22 -0
- package/dist/lib/mcp/tools/cascade-impact.d.ts.map +1 -0
- package/dist/lib/mcp/tools/cascade-impact.js +53 -0
- package/dist/lib/mcp/tools/cascade-impact.js.map +1 -0
- package/dist/lib/mcp/tools/find-consumers-of-contract.d.ts +7 -0
- package/dist/lib/mcp/tools/find-consumers-of-contract.d.ts.map +1 -0
- package/dist/lib/mcp/tools/find-consumers-of-contract.js +70 -0
- package/dist/lib/mcp/tools/find-consumers-of-contract.js.map +1 -0
- package/dist/lib/mcp/tools/find-consumers.d.ts +7 -0
- package/dist/lib/mcp/tools/find-consumers.d.ts.map +1 -0
- package/dist/lib/mcp/tools/find-consumers.js +52 -0
- package/dist/lib/mcp/tools/find-consumers.js.map +1 -0
- package/dist/lib/mcp/tools/find-dependencies.d.ts +8 -0
- package/dist/lib/mcp/tools/find-dependencies.d.ts.map +1 -0
- package/dist/lib/mcp/tools/find-dependencies.js +89 -0
- package/dist/lib/mcp/tools/find-dependencies.js.map +1 -0
- package/dist/lib/mcp/tools/find-dependents.d.ts +8 -0
- package/dist/lib/mcp/tools/find-dependents.d.ts.map +1 -0
- package/dist/lib/mcp/tools/find-dependents.js +89 -0
- package/dist/lib/mcp/tools/find-dependents.js.map +1 -0
- package/dist/lib/mcp/tools/find-producers.d.ts +8 -0
- package/dist/lib/mcp/tools/find-producers.d.ts.map +1 -0
- package/dist/lib/mcp/tools/find-producers.js +57 -0
- package/dist/lib/mcp/tools/find-producers.js.map +1 -0
- package/dist/lib/mcp/tools/find-related-specs.d.ts +9 -0
- package/dist/lib/mcp/tools/find-related-specs.d.ts.map +1 -0
- package/dist/lib/mcp/tools/find-related-specs.js +92 -0
- package/dist/lib/mcp/tools/find-related-specs.js.map +1 -0
- package/dist/lib/mcp/tools/list-adrs.d.ts +3 -0
- package/dist/lib/mcp/tools/list-adrs.d.ts.map +1 -0
- package/dist/lib/mcp/tools/list-adrs.js +73 -0
- package/dist/lib/mcp/tools/list-adrs.js.map +1 -0
- package/dist/lib/mcp/tools/query-gate-status.d.ts +3 -0
- package/dist/lib/mcp/tools/query-gate-status.d.ts.map +1 -0
- package/dist/lib/mcp/tools/query-gate-status.js +82 -0
- package/dist/lib/mcp/tools/query-gate-status.js.map +1 -0
- package/dist/lib/mcp/tools/search-specs.d.ts +12 -0
- package/dist/lib/mcp/tools/search-specs.d.ts.map +1 -0
- package/dist/lib/mcp/tools/search-specs.js +151 -0
- package/dist/lib/mcp/tools/search-specs.js.map +1 -0
- package/dist/lib/mcp/workspace.d.ts +25 -0
- package/dist/lib/mcp/workspace.d.ts.map +1 -0
- package/dist/lib/mcp/workspace.js +129 -0
- package/dist/lib/mcp/workspace.js.map +1 -0
- package/dist/lib/mcp-seed/entries.d.ts +19 -0
- package/dist/lib/mcp-seed/entries.d.ts.map +1 -0
- package/dist/lib/mcp-seed/entries.js +14 -0
- package/dist/lib/mcp-seed/entries.js.map +1 -0
- package/dist/lib/mcp-seed/index.d.ts +36 -0
- package/dist/lib/mcp-seed/index.d.ts.map +1 -0
- package/dist/lib/mcp-seed/index.js +28 -0
- package/dist/lib/mcp-seed/index.js.map +1 -0
- package/dist/lib/mcp-seed/merge.d.ts +34 -0
- package/dist/lib/mcp-seed/merge.d.ts.map +1 -0
- package/dist/lib/mcp-seed/merge.js +99 -0
- package/dist/lib/mcp-seed/merge.js.map +1 -0
- package/dist/lib/mcp-seed/types.d.ts +24 -0
- package/dist/lib/mcp-seed/types.d.ts.map +1 -0
- package/dist/lib/mcp-seed/types.js +13 -0
- package/dist/lib/mcp-seed/types.js.map +1 -0
- package/dist/lib/plan/index.d.ts +19 -0
- package/dist/lib/plan/index.d.ts.map +1 -0
- package/dist/lib/plan/index.js +69 -0
- package/dist/lib/plan/index.js.map +1 -0
- package/dist/lib/plan/read-sdd.d.ts +46 -0
- package/dist/lib/plan/read-sdd.d.ts.map +1 -0
- package/dist/lib/plan/read-sdd.js +102 -0
- package/dist/lib/plan/read-sdd.js.map +1 -0
- package/dist/lib/plan/render-template.d.ts +8 -0
- package/dist/lib/plan/render-template.d.ts.map +1 -0
- package/dist/lib/plan/render-template.js +60 -0
- package/dist/lib/plan/render-template.js.map +1 -0
- package/dist/lib/repo-kind.d.ts +20 -0
- package/dist/lib/repo-kind.d.ts.map +1 -0
- package/dist/lib/repo-kind.js +73 -0
- package/dist/lib/repo-kind.js.map +1 -0
- package/dist/lib/scripts.d.ts +2 -0
- package/dist/lib/scripts.d.ts.map +1 -0
- package/dist/lib/scripts.js +7 -0
- package/dist/lib/scripts.js.map +1 -0
- package/dist/lib/sdd-index/cascade.d.ts +46 -0
- package/dist/lib/sdd-index/cascade.d.ts.map +1 -0
- package/dist/lib/sdd-index/cascade.js +91 -0
- package/dist/lib/sdd-index/cascade.js.map +1 -0
- package/dist/lib/sdd-index/contracts.d.ts +29 -0
- package/dist/lib/sdd-index/contracts.d.ts.map +1 -0
- package/dist/lib/sdd-index/contracts.js +216 -0
- package/dist/lib/sdd-index/contracts.js.map +1 -0
- package/dist/lib/sdd-index/data-model.d.ts +13 -0
- package/dist/lib/sdd-index/data-model.d.ts.map +1 -0
- package/dist/lib/sdd-index/data-model.js +23 -0
- package/dist/lib/sdd-index/data-model.js.map +1 -0
- package/dist/lib/sdd-index/execution-map.d.ts +34 -0
- package/dist/lib/sdd-index/execution-map.d.ts.map +1 -0
- package/dist/lib/sdd-index/execution-map.js +105 -0
- package/dist/lib/sdd-index/execution-map.js.map +1 -0
- package/dist/lib/sdd-index/graph.d.ts +28 -0
- package/dist/lib/sdd-index/graph.d.ts.map +1 -0
- package/dist/lib/sdd-index/graph.js +122 -0
- package/dist/lib/sdd-index/graph.js.map +1 -0
- package/dist/lib/sdd-index/index.d.ts +29 -0
- package/dist/lib/sdd-index/index.d.ts.map +1 -0
- package/dist/lib/sdd-index/index.js +79 -0
- package/dist/lib/sdd-index/index.js.map +1 -0
- package/dist/lib/sdd-index/repo-config.d.ts +23 -0
- package/dist/lib/sdd-index/repo-config.d.ts.map +1 -0
- package/dist/lib/sdd-index/repo-config.js +150 -0
- package/dist/lib/sdd-index/repo-config.js.map +1 -0
- package/dist/lib/sdd-index/types.d.ts +106 -0
- package/dist/lib/sdd-index/types.d.ts.map +1 -0
- package/dist/lib/sdd-index/types.js +13 -0
- package/dist/lib/sdd-index/types.js.map +1 -0
- package/dist/lib/sdd-index/watch.d.ts +24 -0
- package/dist/lib/sdd-index/watch.d.ts.map +1 -0
- package/dist/lib/sdd-index/watch.js +112 -0
- package/dist/lib/sdd-index/watch.js.map +1 -0
- package/dist/lib/spawn.d.ts +8 -0
- package/dist/lib/spawn.d.ts.map +1 -0
- package/dist/lib/spawn.js +16 -0
- package/dist/lib/spawn.js.map +1 -0
- package/dist/lib/sync/apply.d.ts +3 -0
- package/dist/lib/sync/apply.d.ts.map +1 -0
- package/dist/lib/sync/apply.js +16 -0
- package/dist/lib/sync/apply.js.map +1 -0
- package/dist/lib/sync/diff.d.ts +8 -0
- package/dist/lib/sync/diff.d.ts.map +1 -0
- package/dist/lib/sync/diff.js +48 -0
- package/dist/lib/sync/diff.js.map +1 -0
- package/dist/lib/sync/index.d.ts +17 -0
- package/dist/lib/sync/index.d.ts.map +1 -0
- package/dist/lib/sync/index.js +184 -0
- package/dist/lib/sync/index.js.map +1 -0
- package/dist/lib/sync/settings-merge.d.ts +45 -0
- package/dist/lib/sync/settings-merge.d.ts.map +1 -0
- package/dist/lib/sync/settings-merge.js +109 -0
- package/dist/lib/sync/settings-merge.js.map +1 -0
- package/dist/lib/sync/source-tag.d.ts +5 -0
- package/dist/lib/sync/source-tag.d.ts.map +1 -0
- package/dist/lib/sync/source-tag.js +34 -0
- package/dist/lib/sync/source-tag.js.map +1 -0
- package/dist/lib/sync/yaml-block-merge.d.ts +50 -0
- package/dist/lib/sync/yaml-block-merge.d.ts.map +1 -0
- package/dist/lib/sync/yaml-block-merge.js +113 -0
- package/dist/lib/sync/yaml-block-merge.js.map +1 -0
- package/dist/lib/validate/aggregate.d.ts +13 -0
- package/dist/lib/validate/aggregate.d.ts.map +1 -0
- package/dist/lib/validate/aggregate.js +35 -0
- package/dist/lib/validate/aggregate.js.map +1 -0
- package/dist/lib/validate/dispatch.d.ts +34 -0
- package/dist/lib/validate/dispatch.d.ts.map +1 -0
- package/dist/lib/validate/dispatch.js +167 -0
- package/dist/lib/validate/dispatch.js.map +1 -0
- package/dist/lib/validate/index.d.ts +13 -0
- package/dist/lib/validate/index.d.ts.map +1 -0
- package/dist/lib/validate/index.js +69 -0
- package/dist/lib/validate/index.js.map +1 -0
- package/dist/lib/validate/runner.d.ts +16 -0
- package/dist/lib/validate/runner.d.ts.map +1 -0
- package/dist/lib/validate/runner.js +66 -0
- package/dist/lib/validate/runner.js.map +1 -0
- package/dist/verbs/generate-claude-md.d.ts +3 -0
- package/dist/verbs/generate-claude-md.d.ts.map +1 -0
- package/dist/verbs/generate-claude-md.js +36 -0
- package/dist/verbs/generate-claude-md.js.map +1 -0
- package/dist/verbs/init.d.ts +3 -0
- package/dist/verbs/init.d.ts.map +1 -0
- package/dist/verbs/init.js +90 -0
- package/dist/verbs/init.js.map +1 -0
- package/dist/verbs/list.d.ts +3 -0
- package/dist/verbs/list.d.ts.map +1 -0
- package/dist/verbs/list.js +43 -0
- package/dist/verbs/list.js.map +1 -0
- package/dist/verbs/mcp.d.ts +3 -0
- package/dist/verbs/mcp.d.ts.map +1 -0
- package/dist/verbs/mcp.js +22 -0
- package/dist/verbs/mcp.js.map +1 -0
- package/dist/verbs/plan.d.ts +3 -0
- package/dist/verbs/plan.d.ts.map +1 -0
- package/dist/verbs/plan.js +41 -0
- package/dist/verbs/plan.js.map +1 -0
- package/dist/verbs/sync.d.ts +3 -0
- package/dist/verbs/sync.d.ts.map +1 -0
- package/dist/verbs/sync.js +27 -0
- package/dist/verbs/sync.js.map +1 -0
- package/dist/verbs/validate.d.ts +3 -0
- package/dist/verbs/validate.d.ts.map +1 -0
- package/dist/verbs/validate.js +21 -0
- package/dist/verbs/validate.js.map +1 -0
- package/package.json +61 -0
- package/scripts/README.md +48 -0
- package/scripts/sync-method-baseline.sh +258 -0
- package/scripts/validate-app-dependencies.sh +289 -0
- package/scripts/validate-app-docs.sh +185 -0
- package/scripts/validate-integration-docs.sh +222 -0
|
@@ -0,0 +1,258 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
#
|
|
3
|
+
# sync-method-baseline.sh
|
|
4
|
+
# Apply a built method baseline bundle to a target repository.
|
|
5
|
+
#
|
|
6
|
+
# Usage:
|
|
7
|
+
# ./orchestration/scripts/sync-method-baseline.sh --bundle dist/method-baseline/method-baseline-v0.1.0.tar.gz
|
|
8
|
+
# ./orchestration/scripts/sync-method-baseline.sh --bundle ... --target-repo /path/to/repo --dry-run
|
|
9
|
+
|
|
10
|
+
set -euo pipefail
|
|
11
|
+
|
|
12
|
+
RED='\033[0;31m'
|
|
13
|
+
GREEN='\033[0;32m'
|
|
14
|
+
BLUE='\033[0;34m'
|
|
15
|
+
NC='\033[0m'
|
|
16
|
+
REPO_KIND_FILE=".sdd-repo-kind"
|
|
17
|
+
PROTECTED_PREFIXES=("content/")
|
|
18
|
+
|
|
19
|
+
log_info() { echo -e "${GREEN}[INFO]${NC} $1"; }
|
|
20
|
+
log_fail() { echo -e "${RED}[FAIL]${NC} $1"; }
|
|
21
|
+
log_pass() { echo -e "${GREEN}[PASS]${NC} $1"; }
|
|
22
|
+
log_section() {
|
|
23
|
+
echo -e "\n${BLUE}═══════════════════════════════════════════════════════════${NC}"
|
|
24
|
+
echo -e "${BLUE} $1${NC}"
|
|
25
|
+
echo -e "${BLUE}═══════════════════════════════════════════════════════════${NC}\n"
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
usage() {
|
|
29
|
+
cat <<USAGE
|
|
30
|
+
Usage: $(basename "$0") --bundle <path.tar.gz> [--target-repo <dir>] [--dry-run] [--allow-overwrite] [--no-delete]
|
|
31
|
+
|
|
32
|
+
Options:
|
|
33
|
+
--bundle Required bundle archive generated by build-method-baseline-bundle.sh
|
|
34
|
+
--target-repo Target repository root (default: current working directory)
|
|
35
|
+
--dry-run Report plan only; do not modify files
|
|
36
|
+
--allow-overwrite Overwrite conflicting managed files (default: fail on conflict)
|
|
37
|
+
--no-delete Do not delete previously managed files removed from the incoming bundle
|
|
38
|
+
USAGE
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
BUNDLE=""
|
|
42
|
+
TARGET_REPO="$(pwd)"
|
|
43
|
+
DRY_RUN=0
|
|
44
|
+
ALLOW_OVERWRITE=0
|
|
45
|
+
NO_DELETE=0
|
|
46
|
+
|
|
47
|
+
while [[ $# -gt 0 ]]; do
|
|
48
|
+
case "$1" in
|
|
49
|
+
--bundle)
|
|
50
|
+
BUNDLE="${2:-}"
|
|
51
|
+
shift 2
|
|
52
|
+
;;
|
|
53
|
+
--target-repo)
|
|
54
|
+
TARGET_REPO="${2:-}"
|
|
55
|
+
shift 2
|
|
56
|
+
;;
|
|
57
|
+
--dry-run)
|
|
58
|
+
DRY_RUN=1
|
|
59
|
+
shift
|
|
60
|
+
;;
|
|
61
|
+
--allow-overwrite)
|
|
62
|
+
ALLOW_OVERWRITE=1
|
|
63
|
+
shift
|
|
64
|
+
;;
|
|
65
|
+
--no-delete)
|
|
66
|
+
NO_DELETE=1
|
|
67
|
+
shift
|
|
68
|
+
;;
|
|
69
|
+
-h|--help)
|
|
70
|
+
usage
|
|
71
|
+
exit 0
|
|
72
|
+
;;
|
|
73
|
+
*)
|
|
74
|
+
log_fail "Unknown argument: $1"
|
|
75
|
+
usage
|
|
76
|
+
exit 1
|
|
77
|
+
;;
|
|
78
|
+
esac
|
|
79
|
+
done
|
|
80
|
+
|
|
81
|
+
if [[ -z "$BUNDLE" ]]; then
|
|
82
|
+
log_fail "--bundle is required"
|
|
83
|
+
usage
|
|
84
|
+
exit 1
|
|
85
|
+
fi
|
|
86
|
+
|
|
87
|
+
if [[ ! -f "$BUNDLE" ]]; then
|
|
88
|
+
log_fail "Bundle not found: $BUNDLE"
|
|
89
|
+
exit 1
|
|
90
|
+
fi
|
|
91
|
+
|
|
92
|
+
if [[ ! -d "$TARGET_REPO" ]]; then
|
|
93
|
+
log_fail "Target repo not found: $TARGET_REPO"
|
|
94
|
+
exit 1
|
|
95
|
+
fi
|
|
96
|
+
|
|
97
|
+
log_section "Sync Method Baseline"
|
|
98
|
+
|
|
99
|
+
TMP_DIR="$(mktemp -d)"
|
|
100
|
+
trap 'rm -rf "$TMP_DIR"' EXIT
|
|
101
|
+
|
|
102
|
+
tar -xzf "$BUNDLE" -C "$TMP_DIR"
|
|
103
|
+
BUNDLE_ROOT="$(find "$TMP_DIR" -mindepth 1 -maxdepth 1 -type d | head -n 1)"
|
|
104
|
+
if [[ -z "$BUNDLE_ROOT" ]]; then
|
|
105
|
+
log_fail "Could not find extracted bundle root"
|
|
106
|
+
exit 1
|
|
107
|
+
fi
|
|
108
|
+
|
|
109
|
+
MANAGED_PATHS_FILE="$BUNDLE_ROOT/MANAGED_PATHS.txt"
|
|
110
|
+
PAYLOAD_DIR="$BUNDLE_ROOT/payload"
|
|
111
|
+
MANIFEST_FILE="$BUNDLE_ROOT/BUNDLE_MANIFEST.yaml"
|
|
112
|
+
LOCK_FILE="$TARGET_REPO/method-baseline.lock"
|
|
113
|
+
|
|
114
|
+
if [[ ! -f "$MANAGED_PATHS_FILE" || ! -d "$PAYLOAD_DIR" || ! -f "$MANIFEST_FILE" ]]; then
|
|
115
|
+
log_fail "Bundle missing required files (MANAGED_PATHS.txt, payload/, or BUNDLE_MANIFEST.yaml)"
|
|
116
|
+
exit 1
|
|
117
|
+
fi
|
|
118
|
+
|
|
119
|
+
BUNDLE_VERSION="$(awk -F': ' '/^bundle_version:/{gsub(/"/,"",$2); print $2}' "$MANIFEST_FILE")"
|
|
120
|
+
SOURCE_COMMIT="$(awk -F': ' '/^source_commit:/{gsub(/"/,"",$2); print $2}' "$MANIFEST_FILE")"
|
|
121
|
+
BUNDLE_NAME="$(awk -F': ' '/^bundle_name:/{gsub(/"/,"",$2); print $2}' "$MANIFEST_FILE")"
|
|
122
|
+
|
|
123
|
+
case "$BUNDLE_NAME" in
|
|
124
|
+
platform-baseline)
|
|
125
|
+
REPO_KIND_VALUE="platform-product"
|
|
126
|
+
;;
|
|
127
|
+
app-baseline)
|
|
128
|
+
REPO_KIND_VALUE="application-product"
|
|
129
|
+
;;
|
|
130
|
+
integration-baseline)
|
|
131
|
+
REPO_KIND_VALUE="integration-product"
|
|
132
|
+
;;
|
|
133
|
+
*)
|
|
134
|
+
log_fail "Unknown bundle_name in manifest: $BUNDLE_NAME"
|
|
135
|
+
exit 1
|
|
136
|
+
;;
|
|
137
|
+
esac
|
|
138
|
+
|
|
139
|
+
mapfile -t INCOMING_PATHS < "$MANAGED_PATHS_FILE"
|
|
140
|
+
|
|
141
|
+
for p in "${INCOMING_PATHS[@]}"; do
|
|
142
|
+
if [[ ! -f "$PAYLOAD_DIR/$p" ]]; then
|
|
143
|
+
log_fail "Missing payload file listed in MANAGED_PATHS.txt: $p"
|
|
144
|
+
exit 1
|
|
145
|
+
fi
|
|
146
|
+
for prefix in "${PROTECTED_PREFIXES[@]}"; do
|
|
147
|
+
if [[ "$p" == "$prefix"* ]]; then
|
|
148
|
+
log_fail "Incoming bundle attempts to manage protected product-owned path: $p"
|
|
149
|
+
log_fail "Method baseline bundles must not manage files under: ${PROTECTED_PREFIXES[*]}"
|
|
150
|
+
exit 1
|
|
151
|
+
fi
|
|
152
|
+
done
|
|
153
|
+
done
|
|
154
|
+
|
|
155
|
+
# Detect conflicts unless caller explicitly allows overwrite.
|
|
156
|
+
CONFLICTS=()
|
|
157
|
+
for p in "${INCOMING_PATHS[@]}"; do
|
|
158
|
+
target_file="$TARGET_REPO/$p"
|
|
159
|
+
incoming_file="$PAYLOAD_DIR/$p"
|
|
160
|
+
if [[ -f "$target_file" ]] && ! cmp -s "$incoming_file" "$target_file"; then
|
|
161
|
+
CONFLICTS+=("$p")
|
|
162
|
+
fi
|
|
163
|
+
done
|
|
164
|
+
|
|
165
|
+
if [[ ${#CONFLICTS[@]} -gt 0 && "$ALLOW_OVERWRITE" -ne 1 ]]; then
|
|
166
|
+
log_fail "Found ${#CONFLICTS[@]} conflicting managed file(s). Re-run with --allow-overwrite to apply."
|
|
167
|
+
printf '%s\n' "${CONFLICTS[@]}" | sed 's/^/ - /'
|
|
168
|
+
exit 1
|
|
169
|
+
fi
|
|
170
|
+
|
|
171
|
+
# Load previously managed paths from lock file (if present).
|
|
172
|
+
PREV_PATHS=()
|
|
173
|
+
if [[ -f "$LOCK_FILE" ]]; then
|
|
174
|
+
while IFS= read -r p; do
|
|
175
|
+
PREV_PATHS+=("$p")
|
|
176
|
+
done < <(awk '
|
|
177
|
+
/^managed_paths:/ {in_list=1; next}
|
|
178
|
+
in_list && /^ - / {sub(/^ - /, ""); print; next}
|
|
179
|
+
in_list && !/^ - / {in_list=0}
|
|
180
|
+
' "$LOCK_FILE")
|
|
181
|
+
fi
|
|
182
|
+
|
|
183
|
+
for p in "${PREV_PATHS[@]}"; do
|
|
184
|
+
for prefix in "${PROTECTED_PREFIXES[@]}"; do
|
|
185
|
+
if [[ "$p" == "$prefix"* ]]; then
|
|
186
|
+
log_fail "Existing lock file contains protected product-owned path: $p"
|
|
187
|
+
log_fail "Resolve this manually before refreshing the method baseline."
|
|
188
|
+
exit 1
|
|
189
|
+
fi
|
|
190
|
+
done
|
|
191
|
+
done
|
|
192
|
+
|
|
193
|
+
# Compute removal set: paths previously managed but not in incoming list.
|
|
194
|
+
REMOVE_PATHS=()
|
|
195
|
+
if [[ "$NO_DELETE" -ne 1 && ${#PREV_PATHS[@]} -gt 0 ]]; then
|
|
196
|
+
for prev in "${PREV_PATHS[@]}"; do
|
|
197
|
+
keep=0
|
|
198
|
+
for cur in "${INCOMING_PATHS[@]}"; do
|
|
199
|
+
if [[ "$prev" == "$cur" ]]; then
|
|
200
|
+
keep=1
|
|
201
|
+
break
|
|
202
|
+
fi
|
|
203
|
+
done
|
|
204
|
+
if [[ "$keep" -eq 0 ]]; then
|
|
205
|
+
REMOVE_PATHS+=("$prev")
|
|
206
|
+
fi
|
|
207
|
+
done
|
|
208
|
+
fi
|
|
209
|
+
|
|
210
|
+
log_info "Incoming managed files: ${#INCOMING_PATHS[@]}"
|
|
211
|
+
log_info "Conflicts: ${#CONFLICTS[@]}"
|
|
212
|
+
log_info "Removals from previous baseline: ${#REMOVE_PATHS[@]}"
|
|
213
|
+
log_info "Protected ownership prefixes: ${PROTECTED_PREFIXES[*]}"
|
|
214
|
+
|
|
215
|
+
if [[ "$DRY_RUN" -eq 1 ]]; then
|
|
216
|
+
log_info "Dry run enabled. No files modified."
|
|
217
|
+
if [[ ${#CONFLICTS[@]} -gt 0 ]]; then
|
|
218
|
+
log_info "Conflicting files:"
|
|
219
|
+
printf '%s\n' "${CONFLICTS[@]}" | sed 's/^/ - /'
|
|
220
|
+
fi
|
|
221
|
+
if [[ ${#REMOVE_PATHS[@]} -gt 0 ]]; then
|
|
222
|
+
log_info "Files that would be removed:"
|
|
223
|
+
printf '%s\n' "${REMOVE_PATHS[@]}" | sed 's/^/ - /'
|
|
224
|
+
fi
|
|
225
|
+
exit 0
|
|
226
|
+
fi
|
|
227
|
+
|
|
228
|
+
# Apply incoming managed files.
|
|
229
|
+
for p in "${INCOMING_PATHS[@]}"; do
|
|
230
|
+
mkdir -p "$TARGET_REPO/$(dirname "$p")"
|
|
231
|
+
cp "$PAYLOAD_DIR/$p" "$TARGET_REPO/$p"
|
|
232
|
+
done
|
|
233
|
+
|
|
234
|
+
# Remove files no longer managed by this baseline.
|
|
235
|
+
for p in "${REMOVE_PATHS[@]}"; do
|
|
236
|
+
rm -f "$TARGET_REPO/$p"
|
|
237
|
+
done
|
|
238
|
+
|
|
239
|
+
printf '%s\n' "$REPO_KIND_VALUE" > "$TARGET_REPO/$REPO_KIND_FILE"
|
|
240
|
+
|
|
241
|
+
SYNCED_AT_UTC="$(date -u +"%Y-%m-%dT%H:%M:%SZ")"
|
|
242
|
+
BUNDLE_SHA="$(sha256sum "$BUNDLE" | awk '{print $1}')"
|
|
243
|
+
|
|
244
|
+
{
|
|
245
|
+
echo "method_repo: sdd-method"
|
|
246
|
+
echo "bundle_version: \"$BUNDLE_VERSION\""
|
|
247
|
+
echo "source_commit: \"$SOURCE_COMMIT\""
|
|
248
|
+
echo "bundle_sha256: \"$BUNDLE_SHA\""
|
|
249
|
+
echo "synced_at_utc: \"$SYNCED_AT_UTC\""
|
|
250
|
+
echo "managed_paths:"
|
|
251
|
+
for p in "${INCOMING_PATHS[@]}"; do
|
|
252
|
+
echo " - $p"
|
|
253
|
+
done
|
|
254
|
+
} > "$LOCK_FILE"
|
|
255
|
+
|
|
256
|
+
log_pass "Method baseline synced to: $TARGET_REPO"
|
|
257
|
+
log_info "Updated lock file: method-baseline.lock"
|
|
258
|
+
log_info "Set repo kind marker: $REPO_KIND_FILE = $REPO_KIND_VALUE"
|
|
@@ -0,0 +1,289 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
#
|
|
3
|
+
# validate-app-dependencies.sh - Validate app platform dependency declarations
|
|
4
|
+
#
|
|
5
|
+
# Usage:
|
|
6
|
+
# ./validate-app-dependencies.sh --app-root <path> --platform-root <path>
|
|
7
|
+
#
|
|
8
|
+
# Checks (for each entry in app-platform-dependencies.yaml):
|
|
9
|
+
# 1. required_stability is a valid value (provisional | locked)
|
|
10
|
+
# 2. service_id exists in platform service-architecture.md
|
|
11
|
+
# 3. contract_path exists (as a file) when required_stability is "locked"
|
|
12
|
+
#
|
|
13
|
+
# Outputs a dependency status table.
|
|
14
|
+
# Used as the Stage 6 lock-in gate in the App Exploration Workflow.
|
|
15
|
+
|
|
16
|
+
set -euo pipefail
|
|
17
|
+
|
|
18
|
+
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
19
|
+
ROOT_DIR="$(cd "$SCRIPT_DIR/../.." && pwd)"
|
|
20
|
+
|
|
21
|
+
RED='\033[0;31m'
|
|
22
|
+
GREEN='\033[0;32m'
|
|
23
|
+
YELLOW='\033[1;33m'
|
|
24
|
+
BLUE='\033[0;34m'
|
|
25
|
+
NC='\033[0m'
|
|
26
|
+
|
|
27
|
+
log_info() { echo -e "${GREEN}[INFO]${NC} $1"; }
|
|
28
|
+
log_warn() { echo -e "${YELLOW}[WARN]${NC} $1"; }
|
|
29
|
+
log_fail() { echo -e "${RED}[FAIL]${NC} $1"; }
|
|
30
|
+
log_pass() { echo -e "${GREEN}[PASS]${NC} $1"; }
|
|
31
|
+
log_section() {
|
|
32
|
+
echo -e "\n${BLUE}═══════════════════════════════════════════════════════════${NC}"
|
|
33
|
+
echo -e "${BLUE} $1${NC}"
|
|
34
|
+
echo -e "${BLUE}═══════════════════════════════════════════════════════════${NC}\n"
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
APP_ROOT=""
|
|
38
|
+
PLATFORM_ROOT=""
|
|
39
|
+
|
|
40
|
+
usage() {
|
|
41
|
+
cat <<USAGE
|
|
42
|
+
Usage: $(basename "$0") --app-root <path> --platform-root <path>
|
|
43
|
+
|
|
44
|
+
Options:
|
|
45
|
+
--app-root Path to the app repository root (must contain app-platform-dependencies.yaml)
|
|
46
|
+
--platform-root Path to the platform repository root (must contain docs/service-architecture.md)
|
|
47
|
+
USAGE
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
while [[ $# -gt 0 ]]; do
|
|
51
|
+
case "$1" in
|
|
52
|
+
--app-root)
|
|
53
|
+
APP_ROOT="${2:-}"
|
|
54
|
+
shift 2
|
|
55
|
+
;;
|
|
56
|
+
--platform-root)
|
|
57
|
+
PLATFORM_ROOT="${2:-}"
|
|
58
|
+
shift 2
|
|
59
|
+
;;
|
|
60
|
+
-h|--help)
|
|
61
|
+
usage
|
|
62
|
+
exit 0
|
|
63
|
+
;;
|
|
64
|
+
*)
|
|
65
|
+
log_fail "Unknown argument: $1"
|
|
66
|
+
usage
|
|
67
|
+
exit 1
|
|
68
|
+
;;
|
|
69
|
+
esac
|
|
70
|
+
done
|
|
71
|
+
|
|
72
|
+
if [[ -z "$APP_ROOT" ]]; then
|
|
73
|
+
log_fail "--app-root is required"
|
|
74
|
+
usage
|
|
75
|
+
exit 1
|
|
76
|
+
fi
|
|
77
|
+
|
|
78
|
+
if [[ -z "$PLATFORM_ROOT" ]]; then
|
|
79
|
+
log_fail "--platform-root is required"
|
|
80
|
+
usage
|
|
81
|
+
exit 1
|
|
82
|
+
fi
|
|
83
|
+
|
|
84
|
+
if [[ ! -d "$APP_ROOT" ]]; then
|
|
85
|
+
log_fail "App root not found: $APP_ROOT"
|
|
86
|
+
exit 1
|
|
87
|
+
fi
|
|
88
|
+
|
|
89
|
+
if [[ ! -d "$PLATFORM_ROOT" ]]; then
|
|
90
|
+
log_fail "Platform root not found: $PLATFORM_ROOT"
|
|
91
|
+
exit 1
|
|
92
|
+
fi
|
|
93
|
+
|
|
94
|
+
APP_DEPS_FILE="$APP_ROOT/app-platform-dependencies.yaml"
|
|
95
|
+
PLATFORM_SERVICE_ARCH="$PLATFORM_ROOT/docs/platform/service-architecture.md"
|
|
96
|
+
|
|
97
|
+
VALID_STABILITY_VALUES=("provisional" "locked")
|
|
98
|
+
|
|
99
|
+
FAILURES=0
|
|
100
|
+
WARNINGS=0
|
|
101
|
+
TOTAL_DEPS=0
|
|
102
|
+
PASSED_DEPS=0
|
|
103
|
+
|
|
104
|
+
# ──────────────────────────────────────────────────────────────────────────────
|
|
105
|
+
check_prerequisites() {
|
|
106
|
+
log_section "Prerequisites"
|
|
107
|
+
|
|
108
|
+
if [[ ! -f "$APP_DEPS_FILE" ]]; then
|
|
109
|
+
log_fail "app-platform-dependencies.yaml not found: $APP_DEPS_FILE"
|
|
110
|
+
exit 1
|
|
111
|
+
fi
|
|
112
|
+
log_pass "app-platform-dependencies.yaml found"
|
|
113
|
+
|
|
114
|
+
if ! command -v yq &>/dev/null; then
|
|
115
|
+
log_fail "yq is required but not installed. Install with: brew install yq"
|
|
116
|
+
exit 1
|
|
117
|
+
fi
|
|
118
|
+
log_pass "yq available"
|
|
119
|
+
|
|
120
|
+
if [[ ! -f "$PLATFORM_SERVICE_ARCH" ]]; then
|
|
121
|
+
log_warn "Platform service-architecture.md not found: $PLATFORM_SERVICE_ARCH"
|
|
122
|
+
log_warn "service_id validation will be skipped"
|
|
123
|
+
PLATFORM_SERVICE_ARCH=""
|
|
124
|
+
else
|
|
125
|
+
log_pass "Platform service-architecture.md found"
|
|
126
|
+
fi
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
# ──────────────────────────────────────────────────────────────────────────────
|
|
130
|
+
validate_dependency() {
|
|
131
|
+
local index="$1"
|
|
132
|
+
local dep_errors=0
|
|
133
|
+
|
|
134
|
+
local capability_id service_id contract_type required_stability contract_path
|
|
135
|
+
|
|
136
|
+
capability_id="$(yq e ".platform_dependencies[$index].capability_id // \"\"" "$APP_DEPS_FILE")"
|
|
137
|
+
service_id="$(yq e ".platform_dependencies[$index].service_id // \"\"" "$APP_DEPS_FILE")"
|
|
138
|
+
contract_type="$(yq e ".platform_dependencies[$index].contract_type // \"\"" "$APP_DEPS_FILE")"
|
|
139
|
+
required_stability="$(yq e ".platform_dependencies[$index].required_stability // \"\"" "$APP_DEPS_FILE")"
|
|
140
|
+
contract_path="$(yq e ".platform_dependencies[$index].contract_path // \"\"" "$APP_DEPS_FILE")"
|
|
141
|
+
|
|
142
|
+
local dep_label="${service_id:-dep[$index]}"
|
|
143
|
+
if [[ -n "$capability_id" && "$capability_id" != "null" ]]; then
|
|
144
|
+
dep_label="$capability_id / $service_id"
|
|
145
|
+
fi
|
|
146
|
+
|
|
147
|
+
# Check 1: required_stability is a valid value
|
|
148
|
+
local stability_valid=0
|
|
149
|
+
for v in "${VALID_STABILITY_VALUES[@]}"; do
|
|
150
|
+
if [[ "$required_stability" == "$v" ]]; then
|
|
151
|
+
stability_valid=1
|
|
152
|
+
break
|
|
153
|
+
fi
|
|
154
|
+
done
|
|
155
|
+
|
|
156
|
+
if [[ "$stability_valid" -eq 0 ]]; then
|
|
157
|
+
log_fail "$dep_label: invalid required_stability '$required_stability' (allowed: ${VALID_STABILITY_VALUES[*]})"
|
|
158
|
+
((dep_errors++))
|
|
159
|
+
fi
|
|
160
|
+
|
|
161
|
+
# Check 2: service_id exists in platform service-architecture.md
|
|
162
|
+
if [[ -n "$PLATFORM_SERVICE_ARCH" ]]; then
|
|
163
|
+
if [[ -z "$service_id" || "$service_id" == "null" ]]; then
|
|
164
|
+
log_fail "$dep_label: service_id is empty or missing"
|
|
165
|
+
((dep_errors++))
|
|
166
|
+
elif ! grep -q "$service_id" "$PLATFORM_SERVICE_ARCH" 2>/dev/null; then
|
|
167
|
+
log_fail "$dep_label: service_id '$service_id' not found in platform service-architecture.md"
|
|
168
|
+
((dep_errors++))
|
|
169
|
+
fi
|
|
170
|
+
fi
|
|
171
|
+
|
|
172
|
+
# Check 3: contract_path exists when required_stability is locked
|
|
173
|
+
if [[ "$required_stability" == "locked" ]]; then
|
|
174
|
+
if [[ -z "$contract_path" || "$contract_path" == "null" ]]; then
|
|
175
|
+
log_fail "$dep_label: required_stability is 'locked' but contract_path is empty"
|
|
176
|
+
((dep_errors++))
|
|
177
|
+
else
|
|
178
|
+
local full_contract_path="$PLATFORM_ROOT/$contract_path"
|
|
179
|
+
if [[ ! -f "$full_contract_path" ]]; then
|
|
180
|
+
log_fail "$dep_label: locked contract_path '$contract_path' does not exist in platform repo"
|
|
181
|
+
((dep_errors++))
|
|
182
|
+
fi
|
|
183
|
+
fi
|
|
184
|
+
elif [[ "$required_stability" == "provisional" ]]; then
|
|
185
|
+
if [[ -n "$contract_path" && "$contract_path" != "null" ]]; then
|
|
186
|
+
local full_contract_path="$PLATFORM_ROOT/$contract_path"
|
|
187
|
+
if [[ ! -f "$full_contract_path" ]]; then
|
|
188
|
+
log_warn "$dep_label: contract_path '$contract_path' declared but not yet present (provisional — acceptable)"
|
|
189
|
+
((WARNINGS++))
|
|
190
|
+
fi
|
|
191
|
+
fi
|
|
192
|
+
fi
|
|
193
|
+
|
|
194
|
+
if [[ "$dep_errors" -eq 0 ]]; then
|
|
195
|
+
log_pass "$dep_label: stability=$required_stability type=$contract_type"
|
|
196
|
+
((PASSED_DEPS++))
|
|
197
|
+
return 0
|
|
198
|
+
fi
|
|
199
|
+
|
|
200
|
+
FAILURES=$((FAILURES + dep_errors))
|
|
201
|
+
return 1
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
# ──────────────────────────────────────────────────────────────────────────────
|
|
205
|
+
print_status_table() {
|
|
206
|
+
log_section "Dependency Status Table"
|
|
207
|
+
|
|
208
|
+
local app_id
|
|
209
|
+
app_id="$(yq e ".app_id // \"unknown\"" "$APP_DEPS_FILE")"
|
|
210
|
+
log_info "App: $app_id"
|
|
211
|
+
|
|
212
|
+
printf "\n %-30s %-15s %-12s %s\n" "Service ID" "Stability" "Contract" "Status"
|
|
213
|
+
printf " %-30s %-15s %-12s %s\n" "──────────────────────────────" "───────────────" "────────────" "──────────"
|
|
214
|
+
|
|
215
|
+
local count
|
|
216
|
+
count="$(yq e ".platform_dependencies | length" "$APP_DEPS_FILE")"
|
|
217
|
+
|
|
218
|
+
for ((i = 0; i < count; i++)); do
|
|
219
|
+
local service_id required_stability contract_type contract_path dep_status
|
|
220
|
+
service_id="$(yq e ".platform_dependencies[$i].service_id // \"(missing)\"" "$APP_DEPS_FILE")"
|
|
221
|
+
required_stability="$(yq e ".platform_dependencies[$i].required_stability // \"(missing)\"" "$APP_DEPS_FILE")"
|
|
222
|
+
contract_type="$(yq e ".platform_dependencies[$i].contract_type // \"(missing)\"" "$APP_DEPS_FILE")"
|
|
223
|
+
contract_path="$(yq e ".platform_dependencies[$i].contract_path // \"\"" "$APP_DEPS_FILE")"
|
|
224
|
+
|
|
225
|
+
# Determine display status
|
|
226
|
+
if [[ "$required_stability" == "locked" ]]; then
|
|
227
|
+
if [[ -n "$contract_path" && "$contract_path" != "null" && -f "$PLATFORM_ROOT/$contract_path" ]]; then
|
|
228
|
+
dep_status="${GREEN}LOCKED OK${NC}"
|
|
229
|
+
else
|
|
230
|
+
dep_status="${RED}LOCKED UNMET${NC}"
|
|
231
|
+
fi
|
|
232
|
+
elif [[ "$required_stability" == "provisional" ]]; then
|
|
233
|
+
dep_status="${YELLOW}PROVISIONAL${NC}"
|
|
234
|
+
else
|
|
235
|
+
dep_status="${RED}INVALID${NC}"
|
|
236
|
+
fi
|
|
237
|
+
|
|
238
|
+
printf " %-30s %-15s %-12s " "$service_id" "$required_stability" "$contract_type"
|
|
239
|
+
echo -e "$dep_status"
|
|
240
|
+
done
|
|
241
|
+
echo ""
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
# ──────────────────────────────────────────────────────────────────────────────
|
|
245
|
+
main() {
|
|
246
|
+
log_section "App Dependency Validation"
|
|
247
|
+
log_info "App root: $APP_ROOT"
|
|
248
|
+
log_info "Platform root: $PLATFORM_ROOT"
|
|
249
|
+
|
|
250
|
+
check_prerequisites
|
|
251
|
+
|
|
252
|
+
log_section "Validating Dependencies"
|
|
253
|
+
|
|
254
|
+
local dep_count
|
|
255
|
+
dep_count="$(yq e ".platform_dependencies | length" "$APP_DEPS_FILE")"
|
|
256
|
+
TOTAL_DEPS="$dep_count"
|
|
257
|
+
|
|
258
|
+
if [[ "$dep_count" -eq 0 ]]; then
|
|
259
|
+
log_warn "No platform_dependencies entries found in app-platform-dependencies.yaml"
|
|
260
|
+
log_info "If this app has no platform deps, this is acceptable."
|
|
261
|
+
exit 0
|
|
262
|
+
fi
|
|
263
|
+
|
|
264
|
+
for ((i = 0; i < dep_count; i++)); do
|
|
265
|
+
validate_dependency "$i" || true
|
|
266
|
+
done
|
|
267
|
+
|
|
268
|
+
print_status_table
|
|
269
|
+
|
|
270
|
+
log_section "Summary"
|
|
271
|
+
log_info "Total dependencies: $TOTAL_DEPS"
|
|
272
|
+
log_info "Passed: $PASSED_DEPS"
|
|
273
|
+
log_info "Warnings: $WARNINGS"
|
|
274
|
+
log_info "Failures: $FAILURES"
|
|
275
|
+
|
|
276
|
+
if [[ "$FAILURES" -gt 0 ]]; then
|
|
277
|
+
log_fail "$FAILURES dependency check(s) failed. Stage 6 lock-in gate NOT met."
|
|
278
|
+
exit 1
|
|
279
|
+
fi
|
|
280
|
+
|
|
281
|
+
if [[ "$WARNINGS" -gt 0 ]]; then
|
|
282
|
+
log_warn "All required checks passed with $WARNINGS warning(s)."
|
|
283
|
+
else
|
|
284
|
+
log_pass "All dependency checks passed. Stage 6 lock-in gate met."
|
|
285
|
+
fi
|
|
286
|
+
exit 0
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
main "$@"
|