hivemind-pipeline 0.1.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 +63 -0
- package/README.md +352 -0
- package/dist/bin/swarm.d.ts +3 -0
- package/dist/bin/swarm.d.ts.map +1 -0
- package/dist/bin/swarm.js +293 -0
- package/dist/bin/swarm.js.map +1 -0
- package/dist/dashboard/assets/index-Cf_KwDES.js +359 -0
- package/dist/dashboard/assets/index-SatEQz0u.css +1 -0
- package/dist/dashboard/index.html +16 -0
- package/dist/prompts/Architect-Go.md +455 -0
- package/dist/prompts/Architect-Node.md +379 -0
- package/dist/prompts/Architect-Python.md +63 -0
- package/dist/prompts/Architect-React.md +352 -0
- package/dist/prompts/Architect-Rust.md +63 -0
- package/dist/prompts/Architect-Swift.md +61 -0
- package/dist/prompts/Software-engineer-go.md +254 -0
- package/dist/prompts/Software-engineer-node.md +241 -0
- package/dist/prompts/Software-engineer-python.md +70 -0
- package/dist/prompts/Software-engineer-react.md +167 -0
- package/dist/prompts/Software-engineer-rust.md +69 -0
- package/dist/prompts/Software-engineer-swift.md +69 -0
- package/dist/prompts/Software-lead-go.md +247 -0
- package/dist/prompts/Software-lead-node.md +238 -0
- package/dist/prompts/Software-lead-python.md +53 -0
- package/dist/prompts/Software-lead-react.md +229 -0
- package/dist/prompts/Software-lead-rust.md +53 -0
- package/dist/prompts/Software-lead-swift.md +53 -0
- package/dist/prompts/analyst-go.md +351 -0
- package/dist/prompts/analyst-node.md +317 -0
- package/dist/prompts/analyst-python.md +139 -0
- package/dist/prompts/analyst-react.md +428 -0
- package/dist/prompts/analyst-rust.md +125 -0
- package/dist/prompts/analyst-swift.md +125 -0
- package/dist/prompts/test-engineer-go.md +99 -0
- package/dist/prompts/test-engineer-node.md +97 -0
- package/dist/prompts/test-engineer-python.md +61 -0
- package/dist/prompts/test-engineer-react.md +104 -0
- package/dist/prompts/test-engineer-rust.md +62 -0
- package/dist/prompts/test-engineer-swift.md +66 -0
- package/dist/src/__tests__/commands/analyze.test.d.ts +2 -0
- package/dist/src/__tests__/commands/analyze.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/analyze.test.js +61 -0
- package/dist/src/__tests__/commands/analyze.test.js.map +1 -0
- package/dist/src/__tests__/commands/architect.test.d.ts +2 -0
- package/dist/src/__tests__/commands/architect.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/architect.test.js +46 -0
- package/dist/src/__tests__/commands/architect.test.js.map +1 -0
- package/dist/src/__tests__/commands/build.test.d.ts +2 -0
- package/dist/src/__tests__/commands/build.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/build.test.js +69 -0
- package/dist/src/__tests__/commands/build.test.js.map +1 -0
- package/dist/src/__tests__/commands/dashboard.test.d.ts +2 -0
- package/dist/src/__tests__/commands/dashboard.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/dashboard.test.js +95 -0
- package/dist/src/__tests__/commands/dashboard.test.js.map +1 -0
- package/dist/src/__tests__/commands/doctor.test.d.ts +2 -0
- package/dist/src/__tests__/commands/doctor.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/doctor.test.js +69 -0
- package/dist/src/__tests__/commands/doctor.test.js.map +1 -0
- package/dist/src/__tests__/commands/fix.test.d.ts +2 -0
- package/dist/src/__tests__/commands/fix.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/fix.test.js +147 -0
- package/dist/src/__tests__/commands/fix.test.js.map +1 -0
- package/dist/src/__tests__/commands/init.test.d.ts +2 -0
- package/dist/src/__tests__/commands/init.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/init.test.js +79 -0
- package/dist/src/__tests__/commands/init.test.js.map +1 -0
- package/dist/src/__tests__/commands/learn.test.d.ts +2 -0
- package/dist/src/__tests__/commands/learn.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/learn.test.js +64 -0
- package/dist/src/__tests__/commands/learn.test.js.map +1 -0
- package/dist/src/__tests__/commands/mayday.test.d.ts +2 -0
- package/dist/src/__tests__/commands/mayday.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/mayday.test.js +115 -0
- package/dist/src/__tests__/commands/mayday.test.js.map +1 -0
- package/dist/src/__tests__/commands/memory.test.d.ts +2 -0
- package/dist/src/__tests__/commands/memory.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/memory.test.js +80 -0
- package/dist/src/__tests__/commands/memory.test.js.map +1 -0
- package/dist/src/__tests__/commands/plan.test.d.ts +2 -0
- package/dist/src/__tests__/commands/plan.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/plan.test.js +46 -0
- package/dist/src/__tests__/commands/plan.test.js.map +1 -0
- package/dist/src/__tests__/commands/pr.test.d.ts +2 -0
- package/dist/src/__tests__/commands/pr.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/pr.test.js +170 -0
- package/dist/src/__tests__/commands/pr.test.js.map +1 -0
- package/dist/src/__tests__/commands/refactor.test.d.ts +2 -0
- package/dist/src/__tests__/commands/refactor.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/refactor.test.js +107 -0
- package/dist/src/__tests__/commands/refactor.test.js.map +1 -0
- package/dist/src/__tests__/commands/review.test.d.ts +2 -0
- package/dist/src/__tests__/commands/review.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/review.test.js +125 -0
- package/dist/src/__tests__/commands/review.test.js.map +1 -0
- package/dist/src/__tests__/commands/shared.test.d.ts +2 -0
- package/dist/src/__tests__/commands/shared.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/shared.test.js +112 -0
- package/dist/src/__tests__/commands/shared.test.js.map +1 -0
- package/dist/src/__tests__/commands/spike.test.d.ts +2 -0
- package/dist/src/__tests__/commands/spike.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/spike.test.js +75 -0
- package/dist/src/__tests__/commands/spike.test.js.map +1 -0
- package/dist/src/__tests__/commands/stats.test.d.ts +2 -0
- package/dist/src/__tests__/commands/stats.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/stats.test.js +82 -0
- package/dist/src/__tests__/commands/stats.test.js.map +1 -0
- package/dist/src/__tests__/commands/status.test.d.ts +2 -0
- package/dist/src/__tests__/commands/status.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/status.test.js +60 -0
- package/dist/src/__tests__/commands/status.test.js.map +1 -0
- package/dist/src/__tests__/commands/test-cmd.test.d.ts +2 -0
- package/dist/src/__tests__/commands/test-cmd.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/test-cmd.test.js +76 -0
- package/dist/src/__tests__/commands/test-cmd.test.js.map +1 -0
- package/dist/src/__tests__/commands/test-gen.test.d.ts +2 -0
- package/dist/src/__tests__/commands/test-gen.test.d.ts.map +1 -0
- package/dist/src/__tests__/commands/test-gen.test.js +151 -0
- package/dist/src/__tests__/commands/test-gen.test.js.map +1 -0
- package/dist/src/__tests__/core/agent-manager.test.d.ts +2 -0
- package/dist/src/__tests__/core/agent-manager.test.d.ts.map +1 -0
- package/dist/src/__tests__/core/agent-manager.test.js +167 -0
- package/dist/src/__tests__/core/agent-manager.test.js.map +1 -0
- package/dist/src/__tests__/core/agent-process.test.d.ts +2 -0
- package/dist/src/__tests__/core/agent-process.test.d.ts.map +1 -0
- package/dist/src/__tests__/core/agent-process.test.js +178 -0
- package/dist/src/__tests__/core/agent-process.test.js.map +1 -0
- package/dist/src/__tests__/core/guardrails.test.d.ts +2 -0
- package/dist/src/__tests__/core/guardrails.test.d.ts.map +1 -0
- package/dist/src/__tests__/core/guardrails.test.js +249 -0
- package/dist/src/__tests__/core/guardrails.test.js.map +1 -0
- package/dist/src/__tests__/core/pipeline.test.d.ts +2 -0
- package/dist/src/__tests__/core/pipeline.test.d.ts.map +1 -0
- package/dist/src/__tests__/core/pipeline.test.js +331 -0
- package/dist/src/__tests__/core/pipeline.test.js.map +1 -0
- package/dist/src/__tests__/core/state.test.d.ts +2 -0
- package/dist/src/__tests__/core/state.test.d.ts.map +1 -0
- package/dist/src/__tests__/core/state.test.js +132 -0
- package/dist/src/__tests__/core/state.test.js.map +1 -0
- package/dist/src/__tests__/core/ws-server.test.d.ts +2 -0
- package/dist/src/__tests__/core/ws-server.test.d.ts.map +1 -0
- package/dist/src/__tests__/core/ws-server.test.js +177 -0
- package/dist/src/__tests__/core/ws-server.test.js.map +1 -0
- package/dist/src/__tests__/helpers/temp-dir.d.ts +8 -0
- package/dist/src/__tests__/helpers/temp-dir.d.ts.map +1 -0
- package/dist/src/__tests__/helpers/temp-dir.js +25 -0
- package/dist/src/__tests__/helpers/temp-dir.js.map +1 -0
- package/dist/src/commands/agent.d.ts +3 -0
- package/dist/src/commands/agent.d.ts.map +1 -0
- package/dist/src/commands/agent.js +103 -0
- package/dist/src/commands/agent.js.map +1 -0
- package/dist/src/commands/allocate.d.ts +3 -0
- package/dist/src/commands/allocate.d.ts.map +1 -0
- package/dist/src/commands/allocate.js +229 -0
- package/dist/src/commands/allocate.js.map +1 -0
- package/dist/src/commands/analyze.d.ts +3 -0
- package/dist/src/commands/analyze.d.ts.map +1 -0
- package/dist/src/commands/analyze.js +63 -0
- package/dist/src/commands/analyze.js.map +1 -0
- package/dist/src/commands/architect-review.d.ts +3 -0
- package/dist/src/commands/architect-review.d.ts.map +1 -0
- package/dist/src/commands/architect-review.js +695 -0
- package/dist/src/commands/architect-review.js.map +1 -0
- package/dist/src/commands/architect.d.ts +3 -0
- package/dist/src/commands/architect.d.ts.map +1 -0
- package/dist/src/commands/architect.js +49 -0
- package/dist/src/commands/architect.js.map +1 -0
- package/dist/src/commands/audit.d.ts +3 -0
- package/dist/src/commands/audit.d.ts.map +1 -0
- package/dist/src/commands/audit.js +55 -0
- package/dist/src/commands/audit.js.map +1 -0
- package/dist/src/commands/autopilot.d.ts +7 -0
- package/dist/src/commands/autopilot.d.ts.map +1 -0
- package/dist/src/commands/autopilot.js +377 -0
- package/dist/src/commands/autopilot.js.map +1 -0
- package/dist/src/commands/babysit-prs.d.ts +13 -0
- package/dist/src/commands/babysit-prs.d.ts.map +1 -0
- package/dist/src/commands/babysit-prs.js +283 -0
- package/dist/src/commands/babysit-prs.js.map +1 -0
- package/dist/src/commands/benchmark.d.ts +34 -0
- package/dist/src/commands/benchmark.d.ts.map +1 -0
- package/dist/src/commands/benchmark.js +534 -0
- package/dist/src/commands/benchmark.js.map +1 -0
- package/dist/src/commands/build.d.ts +3 -0
- package/dist/src/commands/build.d.ts.map +1 -0
- package/dist/src/commands/build.js +63 -0
- package/dist/src/commands/build.js.map +1 -0
- package/dist/src/commands/check.d.ts +3 -0
- package/dist/src/commands/check.d.ts.map +1 -0
- package/dist/src/commands/check.js +102 -0
- package/dist/src/commands/check.js.map +1 -0
- package/dist/src/commands/ci.d.ts +3 -0
- package/dist/src/commands/ci.d.ts.map +1 -0
- package/dist/src/commands/ci.js +124 -0
- package/dist/src/commands/ci.js.map +1 -0
- package/dist/src/commands/compete.d.ts +3 -0
- package/dist/src/commands/compete.d.ts.map +1 -0
- package/dist/src/commands/compete.js +164 -0
- package/dist/src/commands/compete.js.map +1 -0
- package/dist/src/commands/compliance.d.ts +3 -0
- package/dist/src/commands/compliance.d.ts.map +1 -0
- package/dist/src/commands/compliance.js +722 -0
- package/dist/src/commands/compliance.js.map +1 -0
- package/dist/src/commands/context.d.ts +3 -0
- package/dist/src/commands/context.d.ts.map +1 -0
- package/dist/src/commands/context.js +171 -0
- package/dist/src/commands/context.js.map +1 -0
- package/dist/src/commands/contract.d.ts +3 -0
- package/dist/src/commands/contract.d.ts.map +1 -0
- package/dist/src/commands/contract.js +384 -0
- package/dist/src/commands/contract.js.map +1 -0
- package/dist/src/commands/dashboard.d.ts +3 -0
- package/dist/src/commands/dashboard.d.ts.map +1 -0
- package/dist/src/commands/dashboard.js +114 -0
- package/dist/src/commands/dashboard.js.map +1 -0
- package/dist/src/commands/delegate.d.ts +3 -0
- package/dist/src/commands/delegate.d.ts.map +1 -0
- package/dist/src/commands/delegate.js +474 -0
- package/dist/src/commands/delegate.js.map +1 -0
- package/dist/src/commands/deploy.d.ts +17 -0
- package/dist/src/commands/deploy.d.ts.map +1 -0
- package/dist/src/commands/deploy.js +163 -0
- package/dist/src/commands/deploy.js.map +1 -0
- package/dist/src/commands/deps.d.ts +3 -0
- package/dist/src/commands/deps.d.ts.map +1 -0
- package/dist/src/commands/deps.js +548 -0
- package/dist/src/commands/deps.js.map +1 -0
- package/dist/src/commands/doctor.d.ts +3 -0
- package/dist/src/commands/doctor.d.ts.map +1 -0
- package/dist/src/commands/doctor.js +120 -0
- package/dist/src/commands/doctor.js.map +1 -0
- package/dist/src/commands/empathize.d.ts +3 -0
- package/dist/src/commands/empathize.d.ts.map +1 -0
- package/dist/src/commands/empathize.js +253 -0
- package/dist/src/commands/empathize.js.map +1 -0
- package/dist/src/commands/evaluate.d.ts +3 -0
- package/dist/src/commands/evaluate.d.ts.map +1 -0
- package/dist/src/commands/evaluate.js +49 -0
- package/dist/src/commands/evaluate.js.map +1 -0
- package/dist/src/commands/evolve.d.ts +3 -0
- package/dist/src/commands/evolve.d.ts.map +1 -0
- package/dist/src/commands/evolve.js +841 -0
- package/dist/src/commands/evolve.js.map +1 -0
- package/dist/src/commands/experiment.d.ts +3 -0
- package/dist/src/commands/experiment.d.ts.map +1 -0
- package/dist/src/commands/experiment.js +286 -0
- package/dist/src/commands/experiment.js.map +1 -0
- package/dist/src/commands/explain.d.ts +3 -0
- package/dist/src/commands/explain.d.ts.map +1 -0
- package/dist/src/commands/explain.js +159 -0
- package/dist/src/commands/explain.js.map +1 -0
- package/dist/src/commands/federate.d.ts +3 -0
- package/dist/src/commands/federate.d.ts.map +1 -0
- package/dist/src/commands/federate.js +148 -0
- package/dist/src/commands/federate.js.map +1 -0
- package/dist/src/commands/fingerprint.d.ts +3 -0
- package/dist/src/commands/fingerprint.d.ts.map +1 -0
- package/dist/src/commands/fingerprint.js +65 -0
- package/dist/src/commands/fingerprint.js.map +1 -0
- package/dist/src/commands/fix.d.ts +3 -0
- package/dist/src/commands/fix.d.ts.map +1 -0
- package/dist/src/commands/fix.js +160 -0
- package/dist/src/commands/fix.js.map +1 -0
- package/dist/src/commands/fleet.d.ts +3 -0
- package/dist/src/commands/fleet.d.ts.map +1 -0
- package/dist/src/commands/fleet.js +311 -0
- package/dist/src/commands/fleet.js.map +1 -0
- package/dist/src/commands/forecast.d.ts +3 -0
- package/dist/src/commands/forecast.d.ts.map +1 -0
- package/dist/src/commands/forecast.js +522 -0
- package/dist/src/commands/forecast.js.map +1 -0
- package/dist/src/commands/govern.d.ts +3 -0
- package/dist/src/commands/govern.d.ts.map +1 -0
- package/dist/src/commands/govern.js +280 -0
- package/dist/src/commands/govern.js.map +1 -0
- package/dist/src/commands/health.d.ts +17 -0
- package/dist/src/commands/health.d.ts.map +1 -0
- package/dist/src/commands/health.js +491 -0
- package/dist/src/commands/health.js.map +1 -0
- package/dist/src/commands/impact.d.ts +3 -0
- package/dist/src/commands/impact.d.ts.map +1 -0
- package/dist/src/commands/impact.js +186 -0
- package/dist/src/commands/impact.js.map +1 -0
- package/dist/src/commands/improve.d.ts +3 -0
- package/dist/src/commands/improve.d.ts.map +1 -0
- package/dist/src/commands/improve.js +240 -0
- package/dist/src/commands/improve.js.map +1 -0
- package/dist/src/commands/inbox.d.ts +29 -0
- package/dist/src/commands/inbox.d.ts.map +1 -0
- package/dist/src/commands/inbox.js +538 -0
- package/dist/src/commands/inbox.js.map +1 -0
- package/dist/src/commands/incident.d.ts +15 -0
- package/dist/src/commands/incident.d.ts.map +1 -0
- package/dist/src/commands/incident.js +318 -0
- package/dist/src/commands/incident.js.map +1 -0
- package/dist/src/commands/init.d.ts +3 -0
- package/dist/src/commands/init.d.ts.map +1 -0
- package/dist/src/commands/init.js +97 -0
- package/dist/src/commands/init.js.map +1 -0
- package/dist/src/commands/journal.d.ts +3 -0
- package/dist/src/commands/journal.d.ts.map +1 -0
- package/dist/src/commands/journal.js +146 -0
- package/dist/src/commands/journal.js.map +1 -0
- package/dist/src/commands/learn.d.ts +9 -0
- package/dist/src/commands/learn.d.ts.map +1 -0
- package/dist/src/commands/learn.js +107 -0
- package/dist/src/commands/learn.js.map +1 -0
- package/dist/src/commands/mayday.d.ts +3 -0
- package/dist/src/commands/mayday.d.ts.map +1 -0
- package/dist/src/commands/mayday.js +145 -0
- package/dist/src/commands/mayday.js.map +1 -0
- package/dist/src/commands/memory.d.ts +3 -0
- package/dist/src/commands/memory.d.ts.map +1 -0
- package/dist/src/commands/memory.js +113 -0
- package/dist/src/commands/memory.js.map +1 -0
- package/dist/src/commands/mentor.d.ts +3 -0
- package/dist/src/commands/mentor.d.ts.map +1 -0
- package/dist/src/commands/mentor.js +225 -0
- package/dist/src/commands/mentor.js.map +1 -0
- package/dist/src/commands/migrate.d.ts +3 -0
- package/dist/src/commands/migrate.d.ts.map +1 -0
- package/dist/src/commands/migrate.js +169 -0
- package/dist/src/commands/migrate.js.map +1 -0
- package/dist/src/commands/models.d.ts +3 -0
- package/dist/src/commands/models.d.ts.map +1 -0
- package/dist/src/commands/models.js +396 -0
- package/dist/src/commands/models.js.map +1 -0
- package/dist/src/commands/multi-repo.d.ts +18 -0
- package/dist/src/commands/multi-repo.d.ts.map +1 -0
- package/dist/src/commands/multi-repo.js +423 -0
- package/dist/src/commands/multi-repo.js.map +1 -0
- package/dist/src/commands/negotiate.d.ts +3 -0
- package/dist/src/commands/negotiate.d.ts.map +1 -0
- package/dist/src/commands/negotiate.js +239 -0
- package/dist/src/commands/negotiate.js.map +1 -0
- package/dist/src/commands/observe.d.ts +3 -0
- package/dist/src/commands/observe.d.ts.map +1 -0
- package/dist/src/commands/observe.js +445 -0
- package/dist/src/commands/observe.js.map +1 -0
- package/dist/src/commands/onboard.d.ts +3 -0
- package/dist/src/commands/onboard.d.ts.map +1 -0
- package/dist/src/commands/onboard.js +263 -0
- package/dist/src/commands/onboard.js.map +1 -0
- package/dist/src/commands/optimize.d.ts +3 -0
- package/dist/src/commands/optimize.d.ts.map +1 -0
- package/dist/src/commands/optimize.js +340 -0
- package/dist/src/commands/optimize.js.map +1 -0
- package/dist/src/commands/own.d.ts +3 -0
- package/dist/src/commands/own.d.ts.map +1 -0
- package/dist/src/commands/own.js +499 -0
- package/dist/src/commands/own.js.map +1 -0
- package/dist/src/commands/pair.d.ts +3 -0
- package/dist/src/commands/pair.d.ts.map +1 -0
- package/dist/src/commands/pair.js +206 -0
- package/dist/src/commands/pair.js.map +1 -0
- package/dist/src/commands/pipeline.d.ts +3 -0
- package/dist/src/commands/pipeline.d.ts.map +1 -0
- package/dist/src/commands/pipeline.js +143 -0
- package/dist/src/commands/pipeline.js.map +1 -0
- package/dist/src/commands/plan.d.ts +3 -0
- package/dist/src/commands/plan.d.ts.map +1 -0
- package/dist/src/commands/plan.js +49 -0
- package/dist/src/commands/plan.js.map +1 -0
- package/dist/src/commands/plugin.d.ts +3 -0
- package/dist/src/commands/plugin.d.ts.map +1 -0
- package/dist/src/commands/plugin.js +114 -0
- package/dist/src/commands/plugin.js.map +1 -0
- package/dist/src/commands/pm.d.ts +38 -0
- package/dist/src/commands/pm.d.ts.map +1 -0
- package/dist/src/commands/pm.js +664 -0
- package/dist/src/commands/pm.js.map +1 -0
- package/dist/src/commands/pr.d.ts +3 -0
- package/dist/src/commands/pr.d.ts.map +1 -0
- package/dist/src/commands/pr.js +225 -0
- package/dist/src/commands/pr.js.map +1 -0
- package/dist/src/commands/prompt-guard.d.ts +3 -0
- package/dist/src/commands/prompt-guard.d.ts.map +1 -0
- package/dist/src/commands/prompt-guard.js +54 -0
- package/dist/src/commands/prompt-guard.js.map +1 -0
- package/dist/src/commands/provenance.d.ts +3 -0
- package/dist/src/commands/provenance.d.ts.map +1 -0
- package/dist/src/commands/provenance.js +96 -0
- package/dist/src/commands/provenance.js.map +1 -0
- package/dist/src/commands/recover.d.ts +3 -0
- package/dist/src/commands/recover.d.ts.map +1 -0
- package/dist/src/commands/recover.js +32 -0
- package/dist/src/commands/recover.js.map +1 -0
- package/dist/src/commands/refactor.d.ts +3 -0
- package/dist/src/commands/refactor.d.ts.map +1 -0
- package/dist/src/commands/refactor.js +143 -0
- package/dist/src/commands/refactor.js.map +1 -0
- package/dist/src/commands/report.d.ts +66 -0
- package/dist/src/commands/report.d.ts.map +1 -0
- package/dist/src/commands/report.js +493 -0
- package/dist/src/commands/report.js.map +1 -0
- package/dist/src/commands/retro.d.ts +71 -0
- package/dist/src/commands/retro.d.ts.map +1 -0
- package/dist/src/commands/retro.js +449 -0
- package/dist/src/commands/retro.js.map +1 -0
- package/dist/src/commands/review.d.ts +3 -0
- package/dist/src/commands/review.d.ts.map +1 -0
- package/dist/src/commands/review.js +202 -0
- package/dist/src/commands/review.js.map +1 -0
- package/dist/src/commands/risk.d.ts +3 -0
- package/dist/src/commands/risk.d.ts.map +1 -0
- package/dist/src/commands/risk.js +110 -0
- package/dist/src/commands/risk.js.map +1 -0
- package/dist/src/commands/roadmap.d.ts +3 -0
- package/dist/src/commands/roadmap.d.ts.map +1 -0
- package/dist/src/commands/roadmap.js +506 -0
- package/dist/src/commands/roadmap.js.map +1 -0
- package/dist/src/commands/runtime-monitor.d.ts +3 -0
- package/dist/src/commands/runtime-monitor.d.ts.map +1 -0
- package/dist/src/commands/runtime-monitor.js +154 -0
- package/dist/src/commands/runtime-monitor.js.map +1 -0
- package/dist/src/commands/sandbox.d.ts +3 -0
- package/dist/src/commands/sandbox.d.ts.map +1 -0
- package/dist/src/commands/sandbox.js +201 -0
- package/dist/src/commands/sandbox.js.map +1 -0
- package/dist/src/commands/scope.d.ts +3 -0
- package/dist/src/commands/scope.d.ts.map +1 -0
- package/dist/src/commands/scope.js +192 -0
- package/dist/src/commands/scope.js.map +1 -0
- package/dist/src/commands/secrets.d.ts +3 -0
- package/dist/src/commands/secrets.d.ts.map +1 -0
- package/dist/src/commands/secrets.js +99 -0
- package/dist/src/commands/secrets.js.map +1 -0
- package/dist/src/commands/secure.d.ts +3 -0
- package/dist/src/commands/secure.d.ts.map +1 -0
- package/dist/src/commands/secure.js +215 -0
- package/dist/src/commands/secure.js.map +1 -0
- package/dist/src/commands/server.d.ts +3 -0
- package/dist/src/commands/server.d.ts.map +1 -0
- package/dist/src/commands/server.js +228 -0
- package/dist/src/commands/server.js.map +1 -0
- package/dist/src/commands/shared.d.ts +18 -0
- package/dist/src/commands/shared.d.ts.map +1 -0
- package/dist/src/commands/shared.js +61 -0
- package/dist/src/commands/shared.js.map +1 -0
- package/dist/src/commands/simplify.d.ts +3 -0
- package/dist/src/commands/simplify.d.ts.map +1 -0
- package/dist/src/commands/simplify.js +194 -0
- package/dist/src/commands/simplify.js.map +1 -0
- package/dist/src/commands/simulate.d.ts +3 -0
- package/dist/src/commands/simulate.d.ts.map +1 -0
- package/dist/src/commands/simulate.js +275 -0
- package/dist/src/commands/simulate.js.map +1 -0
- package/dist/src/commands/slo.d.ts +3 -0
- package/dist/src/commands/slo.d.ts.map +1 -0
- package/dist/src/commands/slo.js +341 -0
- package/dist/src/commands/slo.js.map +1 -0
- package/dist/src/commands/spawn-capability.d.ts +3 -0
- package/dist/src/commands/spawn-capability.d.ts.map +1 -0
- package/dist/src/commands/spawn-capability.js +153 -0
- package/dist/src/commands/spawn-capability.js.map +1 -0
- package/dist/src/commands/specialize.d.ts +3 -0
- package/dist/src/commands/specialize.d.ts.map +1 -0
- package/dist/src/commands/specialize.js +266 -0
- package/dist/src/commands/specialize.js.map +1 -0
- package/dist/src/commands/spike.d.ts +3 -0
- package/dist/src/commands/spike.d.ts.map +1 -0
- package/dist/src/commands/spike.js +109 -0
- package/dist/src/commands/spike.js.map +1 -0
- package/dist/src/commands/standup.d.ts +3 -0
- package/dist/src/commands/standup.d.ts.map +1 -0
- package/dist/src/commands/standup.js +76 -0
- package/dist/src/commands/standup.js.map +1 -0
- package/dist/src/commands/stats.d.ts +39 -0
- package/dist/src/commands/stats.d.ts.map +1 -0
- package/dist/src/commands/stats.js +185 -0
- package/dist/src/commands/stats.js.map +1 -0
- package/dist/src/commands/status.d.ts +3 -0
- package/dist/src/commands/status.d.ts.map +1 -0
- package/dist/src/commands/status.js +65 -0
- package/dist/src/commands/status.js.map +1 -0
- package/dist/src/commands/supply-chain.d.ts +3 -0
- package/dist/src/commands/supply-chain.d.ts.map +1 -0
- package/dist/src/commands/supply-chain.js +110 -0
- package/dist/src/commands/supply-chain.js.map +1 -0
- package/dist/src/commands/system.d.ts +3 -0
- package/dist/src/commands/system.d.ts.map +1 -0
- package/dist/src/commands/system.js +582 -0
- package/dist/src/commands/system.js.map +1 -0
- package/dist/src/commands/teach.d.ts +3 -0
- package/dist/src/commands/teach.d.ts.map +1 -0
- package/dist/src/commands/teach.js +420 -0
- package/dist/src/commands/teach.js.map +1 -0
- package/dist/src/commands/team.d.ts +44 -0
- package/dist/src/commands/team.d.ts.map +1 -0
- package/dist/src/commands/team.js +355 -0
- package/dist/src/commands/team.js.map +1 -0
- package/dist/src/commands/telemetry.d.ts +3 -0
- package/dist/src/commands/telemetry.d.ts.map +1 -0
- package/dist/src/commands/telemetry.js +87 -0
- package/dist/src/commands/telemetry.js.map +1 -0
- package/dist/src/commands/test-gen.d.ts +3 -0
- package/dist/src/commands/test-gen.d.ts.map +1 -0
- package/dist/src/commands/test-gen.js +541 -0
- package/dist/src/commands/test-gen.js.map +1 -0
- package/dist/src/commands/test.d.ts +3 -0
- package/dist/src/commands/test.d.ts.map +1 -0
- package/dist/src/commands/test.js +84 -0
- package/dist/src/commands/test.js.map +1 -0
- package/dist/src/commands/watch.d.ts +11 -0
- package/dist/src/commands/watch.d.ts.map +1 -0
- package/dist/src/commands/watch.js +317 -0
- package/dist/src/commands/watch.js.map +1 -0
- package/dist/src/core/activity-tracker.d.ts +70 -0
- package/dist/src/core/activity-tracker.d.ts.map +1 -0
- package/dist/src/core/activity-tracker.js +294 -0
- package/dist/src/core/activity-tracker.js.map +1 -0
- package/dist/src/core/agent-bus.d.ts +38 -0
- package/dist/src/core/agent-bus.d.ts.map +1 -0
- package/dist/src/core/agent-bus.js +128 -0
- package/dist/src/core/agent-bus.js.map +1 -0
- package/dist/src/core/agent-loop.d.ts +79 -0
- package/dist/src/core/agent-loop.d.ts.map +1 -0
- package/dist/src/core/agent-loop.js +225 -0
- package/dist/src/core/agent-loop.js.map +1 -0
- package/dist/src/core/agent-manager.d.ts +90 -0
- package/dist/src/core/agent-manager.d.ts.map +1 -0
- package/dist/src/core/agent-manager.js +549 -0
- package/dist/src/core/agent-manager.js.map +1 -0
- package/dist/src/core/agent-process.d.ts +95 -0
- package/dist/src/core/agent-process.d.ts.map +1 -0
- package/dist/src/core/agent-process.js +428 -0
- package/dist/src/core/agent-process.js.map +1 -0
- package/dist/src/core/ambiguity-detector.d.ts +31 -0
- package/dist/src/core/ambiguity-detector.d.ts.map +1 -0
- package/dist/src/core/ambiguity-detector.js +286 -0
- package/dist/src/core/ambiguity-detector.js.map +1 -0
- package/dist/src/core/anomaly-detector.d.ts +30 -0
- package/dist/src/core/anomaly-detector.d.ts.map +1 -0
- package/dist/src/core/anomaly-detector.js +300 -0
- package/dist/src/core/anomaly-detector.js.map +1 -0
- package/dist/src/core/api-lifecycle.d.ts +11 -0
- package/dist/src/core/api-lifecycle.d.ts.map +1 -0
- package/dist/src/core/api-lifecycle.js +178 -0
- package/dist/src/core/api-lifecycle.js.map +1 -0
- package/dist/src/core/audit.d.ts +36 -0
- package/dist/src/core/audit.d.ts.map +1 -0
- package/dist/src/core/audit.js +88 -0
- package/dist/src/core/audit.js.map +1 -0
- package/dist/src/core/capability-spawner.d.ts +17 -0
- package/dist/src/core/capability-spawner.d.ts.map +1 -0
- package/dist/src/core/capability-spawner.js +170 -0
- package/dist/src/core/capability-spawner.js.map +1 -0
- package/dist/src/core/codebase-index.d.ts +53 -0
- package/dist/src/core/codebase-index.d.ts.map +1 -0
- package/dist/src/core/codebase-index.js +540 -0
- package/dist/src/core/codebase-index.js.map +1 -0
- package/dist/src/core/codebase-scanner.d.ts +3 -0
- package/dist/src/core/codebase-scanner.d.ts.map +1 -0
- package/dist/src/core/codebase-scanner.js +179 -0
- package/dist/src/core/codebase-scanner.js.map +1 -0
- package/dist/src/core/competitive-intel.d.ts +18 -0
- package/dist/src/core/competitive-intel.d.ts.map +1 -0
- package/dist/src/core/competitive-intel.js +167 -0
- package/dist/src/core/competitive-intel.js.map +1 -0
- package/dist/src/core/config.d.ts +14 -0
- package/dist/src/core/config.d.ts.map +1 -0
- package/dist/src/core/config.js +116 -0
- package/dist/src/core/config.js.map +1 -0
- package/dist/src/core/convention-extractor.d.ts +8 -0
- package/dist/src/core/convention-extractor.d.ts.map +1 -0
- package/dist/src/core/convention-extractor.js +382 -0
- package/dist/src/core/convention-extractor.js.map +1 -0
- package/dist/src/core/cost-tracker.d.ts +23 -0
- package/dist/src/core/cost-tracker.d.ts.map +1 -0
- package/dist/src/core/cost-tracker.js +83 -0
- package/dist/src/core/cost-tracker.js.map +1 -0
- package/dist/src/core/decision-journal.d.ts +41 -0
- package/dist/src/core/decision-journal.d.ts.map +1 -0
- package/dist/src/core/decision-journal.js +204 -0
- package/dist/src/core/decision-journal.js.map +1 -0
- package/dist/src/core/experiment-engine.d.ts +31 -0
- package/dist/src/core/experiment-engine.d.ts.map +1 -0
- package/dist/src/core/experiment-engine.js +248 -0
- package/dist/src/core/experiment-engine.js.map +1 -0
- package/dist/src/core/federation.d.ts +18 -0
- package/dist/src/core/federation.d.ts.map +1 -0
- package/dist/src/core/federation.js +202 -0
- package/dist/src/core/federation.js.map +1 -0
- package/dist/src/core/fingerprint.d.ts +42 -0
- package/dist/src/core/fingerprint.d.ts.map +1 -0
- package/dist/src/core/fingerprint.js +316 -0
- package/dist/src/core/fingerprint.js.map +1 -0
- package/dist/src/core/git.d.ts +50 -0
- package/dist/src/core/git.d.ts.map +1 -0
- package/dist/src/core/git.js +342 -0
- package/dist/src/core/git.js.map +1 -0
- package/dist/src/core/governance.d.ts +53 -0
- package/dist/src/core/governance.d.ts.map +1 -0
- package/dist/src/core/governance.js +276 -0
- package/dist/src/core/governance.js.map +1 -0
- package/dist/src/core/guardrails.d.ts +34 -0
- package/dist/src/core/guardrails.d.ts.map +1 -0
- package/dist/src/core/guardrails.js +575 -0
- package/dist/src/core/guardrails.js.map +1 -0
- package/dist/src/core/impact-analyzer.d.ts +56 -0
- package/dist/src/core/impact-analyzer.d.ts.map +1 -0
- package/dist/src/core/impact-analyzer.js +309 -0
- package/dist/src/core/impact-analyzer.js.map +1 -0
- package/dist/src/core/input-listener.d.ts +45 -0
- package/dist/src/core/input-listener.d.ts.map +1 -0
- package/dist/src/core/input-listener.js +116 -0
- package/dist/src/core/input-listener.js.map +1 -0
- package/dist/src/core/memory-store.d.ts +61 -0
- package/dist/src/core/memory-store.d.ts.map +1 -0
- package/dist/src/core/memory-store.js +195 -0
- package/dist/src/core/memory-store.js.map +1 -0
- package/dist/src/core/observability.d.ts +56 -0
- package/dist/src/core/observability.d.ts.map +1 -0
- package/dist/src/core/observability.js +305 -0
- package/dist/src/core/observability.js.map +1 -0
- package/dist/src/core/pair-engine.d.ts +47 -0
- package/dist/src/core/pair-engine.d.ts.map +1 -0
- package/dist/src/core/pair-engine.js +355 -0
- package/dist/src/core/pair-engine.js.map +1 -0
- package/dist/src/core/perf-analyzer.d.ts +35 -0
- package/dist/src/core/perf-analyzer.d.ts.map +1 -0
- package/dist/src/core/perf-analyzer.js +598 -0
- package/dist/src/core/perf-analyzer.js.map +1 -0
- package/dist/src/core/pipeline-loader.d.ts +46 -0
- package/dist/src/core/pipeline-loader.d.ts.map +1 -0
- package/dist/src/core/pipeline-loader.js +182 -0
- package/dist/src/core/pipeline-loader.js.map +1 -0
- package/dist/src/core/pipeline.d.ts +183 -0
- package/dist/src/core/pipeline.d.ts.map +1 -0
- package/dist/src/core/pipeline.js +2264 -0
- package/dist/src/core/pipeline.js.map +1 -0
- package/dist/src/core/plugins.d.ts +61 -0
- package/dist/src/core/plugins.d.ts.map +1 -0
- package/dist/src/core/plugins.js +114 -0
- package/dist/src/core/plugins.js.map +1 -0
- package/dist/src/core/preflight.d.ts +7 -0
- package/dist/src/core/preflight.d.ts.map +1 -0
- package/dist/src/core/preflight.js +35 -0
- package/dist/src/core/preflight.js.map +1 -0
- package/dist/src/core/prompt-guard.d.ts +44 -0
- package/dist/src/core/prompt-guard.d.ts.map +1 -0
- package/dist/src/core/prompt-guard.js +274 -0
- package/dist/src/core/prompt-guard.js.map +1 -0
- package/dist/src/core/provenance.d.ts +39 -0
- package/dist/src/core/provenance.d.ts.map +1 -0
- package/dist/src/core/provenance.js +115 -0
- package/dist/src/core/provenance.js.map +1 -0
- package/dist/src/core/providers/anthropic-api.d.ts +34 -0
- package/dist/src/core/providers/anthropic-api.d.ts.map +1 -0
- package/dist/src/core/providers/anthropic-api.js +522 -0
- package/dist/src/core/providers/anthropic-api.js.map +1 -0
- package/dist/src/core/providers/api-agent-backend.d.ts +31 -0
- package/dist/src/core/providers/api-agent-backend.d.ts.map +1 -0
- package/dist/src/core/providers/api-agent-backend.js +127 -0
- package/dist/src/core/providers/api-agent-backend.js.map +1 -0
- package/dist/src/core/providers/api-text-backend.d.ts +35 -0
- package/dist/src/core/providers/api-text-backend.d.ts.map +1 -0
- package/dist/src/core/providers/api-text-backend.js +145 -0
- package/dist/src/core/providers/api-text-backend.js.map +1 -0
- package/dist/src/core/providers/claude-cli.d.ts +80 -0
- package/dist/src/core/providers/claude-cli.d.ts.map +1 -0
- package/dist/src/core/providers/claude-cli.js +489 -0
- package/dist/src/core/providers/claude-cli.js.map +1 -0
- package/dist/src/core/providers/cost-table.d.ts +46 -0
- package/dist/src/core/providers/cost-table.d.ts.map +1 -0
- package/dist/src/core/providers/cost-table.js +136 -0
- package/dist/src/core/providers/cost-table.js.map +1 -0
- package/dist/src/core/providers/google.d.ts +26 -0
- package/dist/src/core/providers/google.d.ts.map +1 -0
- package/dist/src/core/providers/google.js +165 -0
- package/dist/src/core/providers/google.js.map +1 -0
- package/dist/src/core/providers/model-catalog.d.ts +72 -0
- package/dist/src/core/providers/model-catalog.d.ts.map +1 -0
- package/dist/src/core/providers/model-catalog.js +290 -0
- package/dist/src/core/providers/model-catalog.js.map +1 -0
- package/dist/src/core/providers/openai-compat.d.ts +35 -0
- package/dist/src/core/providers/openai-compat.d.ts.map +1 -0
- package/dist/src/core/providers/openai-compat.js +479 -0
- package/dist/src/core/providers/openai-compat.js.map +1 -0
- package/dist/src/core/providers/prompt-adapter.d.ts +42 -0
- package/dist/src/core/providers/prompt-adapter.d.ts.map +1 -0
- package/dist/src/core/providers/prompt-adapter.js +282 -0
- package/dist/src/core/providers/prompt-adapter.js.map +1 -0
- package/dist/src/core/providers/registry.d.ts +93 -0
- package/dist/src/core/providers/registry.d.ts.map +1 -0
- package/dist/src/core/providers/registry.js +191 -0
- package/dist/src/core/providers/registry.js.map +1 -0
- package/dist/src/core/providers/types.d.ts +165 -0
- package/dist/src/core/providers/types.d.ts.map +1 -0
- package/dist/src/core/providers/types.js +13 -0
- package/dist/src/core/providers/types.js.map +1 -0
- package/dist/src/core/quality.d.ts +22 -0
- package/dist/src/core/quality.d.ts.map +1 -0
- package/dist/src/core/quality.js +209 -0
- package/dist/src/core/quality.js.map +1 -0
- package/dist/src/core/resource-allocator.d.ts +37 -0
- package/dist/src/core/resource-allocator.d.ts.map +1 -0
- package/dist/src/core/resource-allocator.js +480 -0
- package/dist/src/core/resource-allocator.js.map +1 -0
- package/dist/src/core/risk-scorer.d.ts +35 -0
- package/dist/src/core/risk-scorer.d.ts.map +1 -0
- package/dist/src/core/risk-scorer.js +226 -0
- package/dist/src/core/risk-scorer.js.map +1 -0
- package/dist/src/core/runtime-monitor.d.ts +49 -0
- package/dist/src/core/runtime-monitor.d.ts.map +1 -0
- package/dist/src/core/runtime-monitor.js +235 -0
- package/dist/src/core/runtime-monitor.js.map +1 -0
- package/dist/src/core/sandbox.d.ts +47 -0
- package/dist/src/core/sandbox.d.ts.map +1 -0
- package/dist/src/core/sandbox.js +277 -0
- package/dist/src/core/sandbox.js.map +1 -0
- package/dist/src/core/secret-detector.d.ts +25 -0
- package/dist/src/core/secret-detector.d.ts.map +1 -0
- package/dist/src/core/secret-detector.js +307 -0
- package/dist/src/core/secret-detector.js.map +1 -0
- package/dist/src/core/security-scanner.d.ts +36 -0
- package/dist/src/core/security-scanner.d.ts.map +1 -0
- package/dist/src/core/security-scanner.js +366 -0
- package/dist/src/core/security-scanner.js.map +1 -0
- package/dist/src/core/self-improvement.d.ts +26 -0
- package/dist/src/core/self-improvement.d.ts.map +1 -0
- package/dist/src/core/self-improvement.js +356 -0
- package/dist/src/core/self-improvement.js.map +1 -0
- package/dist/src/core/simulator.d.ts +28 -0
- package/dist/src/core/simulator.d.ts.map +1 -0
- package/dist/src/core/simulator.js +334 -0
- package/dist/src/core/simulator.js.map +1 -0
- package/dist/src/core/specialization.d.ts +47 -0
- package/dist/src/core/specialization.d.ts.map +1 -0
- package/dist/src/core/specialization.js +239 -0
- package/dist/src/core/specialization.js.map +1 -0
- package/dist/src/core/stakeholder-engine.d.ts +47 -0
- package/dist/src/core/stakeholder-engine.d.ts.map +1 -0
- package/dist/src/core/stakeholder-engine.js +380 -0
- package/dist/src/core/stakeholder-engine.js.map +1 -0
- package/dist/src/core/state.d.ts +99 -0
- package/dist/src/core/state.d.ts.map +1 -0
- package/dist/src/core/state.js +545 -0
- package/dist/src/core/state.js.map +1 -0
- package/dist/src/core/supply-chain.d.ts +26 -0
- package/dist/src/core/supply-chain.d.ts.map +1 -0
- package/dist/src/core/supply-chain.js +332 -0
- package/dist/src/core/supply-chain.js.map +1 -0
- package/dist/src/core/telemetry.d.ts +110 -0
- package/dist/src/core/telemetry.d.ts.map +1 -0
- package/dist/src/core/telemetry.js +276 -0
- package/dist/src/core/telemetry.js.map +1 -0
- package/dist/src/core/tools/definitions.d.ts +10 -0
- package/dist/src/core/tools/definitions.d.ts.map +1 -0
- package/dist/src/core/tools/definitions.js +165 -0
- package/dist/src/core/tools/definitions.js.map +1 -0
- package/dist/src/core/tools/executor.d.ts +27 -0
- package/dist/src/core/tools/executor.d.ts.map +1 -0
- package/dist/src/core/tools/executor.js +306 -0
- package/dist/src/core/tools/executor.js.map +1 -0
- package/dist/src/core/tools/sandbox.d.ts +41 -0
- package/dist/src/core/tools/sandbox.d.ts.map +1 -0
- package/dist/src/core/tools/sandbox.js +106 -0
- package/dist/src/core/tools/sandbox.js.map +1 -0
- package/dist/src/core/training-pipeline.d.ts +66 -0
- package/dist/src/core/training-pipeline.d.ts.map +1 -0
- package/dist/src/core/training-pipeline.js +267 -0
- package/dist/src/core/training-pipeline.js.map +1 -0
- package/dist/src/core/triage.d.ts +56 -0
- package/dist/src/core/triage.d.ts.map +1 -0
- package/dist/src/core/triage.js +227 -0
- package/dist/src/core/triage.js.map +1 -0
- package/dist/src/core/user-intelligence.d.ts +29 -0
- package/dist/src/core/user-intelligence.d.ts.map +1 -0
- package/dist/src/core/user-intelligence.js +172 -0
- package/dist/src/core/user-intelligence.js.map +1 -0
- package/dist/src/core/webhooks.d.ts +32 -0
- package/dist/src/core/webhooks.d.ts.map +1 -0
- package/dist/src/core/webhooks.js +126 -0
- package/dist/src/core/webhooks.js.map +1 -0
- package/dist/src/core/ws-server.d.ts +43 -0
- package/dist/src/core/ws-server.d.ts.map +1 -0
- package/dist/src/core/ws-server.js +3278 -0
- package/dist/src/core/ws-server.js.map +1 -0
- package/dist/src/prompts/loader.d.ts +36 -0
- package/dist/src/prompts/loader.d.ts.map +1 -0
- package/dist/src/prompts/loader.js +156 -0
- package/dist/src/prompts/loader.js.map +1 -0
- package/dist/src/types.d.ts +2539 -0
- package/dist/src/types.d.ts.map +1 -0
- package/dist/src/types.js +62 -0
- package/dist/src/types.js.map +1 -0
- package/package.json +66 -0
|
@@ -0,0 +1,226 @@
|
|
|
1
|
+
import { readFileSync, existsSync } from 'node:fs';
|
|
2
|
+
import { join, dirname, basename, extname } from 'node:path';
|
|
3
|
+
import { execSync } from 'node:child_process';
|
|
4
|
+
/** Patterns indicating core/critical files */
|
|
5
|
+
const CRITICAL_PATTERNS = [
|
|
6
|
+
/auth/i, /login/i, /session/i, /token/i, /jwt/i, /oauth/i,
|
|
7
|
+
/payment/i, /billing/i, /stripe/i, /checkout/i, /invoice/i,
|
|
8
|
+
/database/i, /migration/i, /schema/i, /model/i,
|
|
9
|
+
/security/i, /encrypt/i, /decrypt/i, /secret/i, /credential/i,
|
|
10
|
+
/middleware/i, /guard/i, /permission/i, /rbac/i, /acl/i,
|
|
11
|
+
];
|
|
12
|
+
/** Patterns indicating high-risk infrastructure files */
|
|
13
|
+
const INFRA_PATTERNS = [
|
|
14
|
+
/config/i, /env/i, /docker/i, /ci/i, /deploy/i, /pipeline/i,
|
|
15
|
+
/webpack/i, /vite\.config/i, /tsconfig/i, /package\.json$/,
|
|
16
|
+
];
|
|
17
|
+
/** Common test file patterns */
|
|
18
|
+
const TEST_PATTERNS = [
|
|
19
|
+
'.test.', '.spec.', '__tests__', '__test__',
|
|
20
|
+
'.test.ts', '.test.tsx', '.test.js', '.test.jsx',
|
|
21
|
+
'.spec.ts', '.spec.tsx', '.spec.js', '.spec.jsx',
|
|
22
|
+
];
|
|
23
|
+
export class RiskScorer {
|
|
24
|
+
cwd;
|
|
25
|
+
constructor(cwd) {
|
|
26
|
+
this.cwd = cwd;
|
|
27
|
+
}
|
|
28
|
+
/** Score a set of changed files */
|
|
29
|
+
scoreFiles(files) {
|
|
30
|
+
return files.map(f => this.scoreFile(f)).sort((a, b) => b.overall - a.overall);
|
|
31
|
+
}
|
|
32
|
+
/** Score a single file */
|
|
33
|
+
scoreFile(file) {
|
|
34
|
+
const dimensions = [
|
|
35
|
+
{ name: 'File Risk', score: this.fileRiskScore(file), weight: 0.25, detail: '' },
|
|
36
|
+
{ name: 'Coverage', score: this.coverageScore(file), weight: 0.20, detail: '' },
|
|
37
|
+
{ name: 'Blast Radius', score: this.blastRadiusScore(file), weight: 0.20, detail: '' },
|
|
38
|
+
{ name: 'Change History', score: this.changeHistoryScore(file), weight: 0.15, detail: '' },
|
|
39
|
+
{ name: 'Complexity', score: this.complexityScore(file), weight: 0.10, detail: '' },
|
|
40
|
+
{ name: 'Novelty', score: this.noveltyScore(file), weight: 0.10, detail: '' },
|
|
41
|
+
];
|
|
42
|
+
const overall = Math.round(dimensions.reduce((sum, d) => sum + d.score * d.weight, 0));
|
|
43
|
+
const level = this.scoreToLevel(overall);
|
|
44
|
+
return { file, overall, level, dimensions };
|
|
45
|
+
}
|
|
46
|
+
/** Detect core/critical files by path patterns */
|
|
47
|
+
fileRiskScore(file) {
|
|
48
|
+
const lower = file.toLowerCase();
|
|
49
|
+
// Skip test files — they are low risk
|
|
50
|
+
if (TEST_PATTERNS.some(p => lower.includes(p))) {
|
|
51
|
+
return 5;
|
|
52
|
+
}
|
|
53
|
+
// Critical domain files
|
|
54
|
+
const criticalMatches = CRITICAL_PATTERNS.filter(p => p.test(file));
|
|
55
|
+
if (criticalMatches.length >= 2)
|
|
56
|
+
return 95;
|
|
57
|
+
if (criticalMatches.length === 1)
|
|
58
|
+
return 75;
|
|
59
|
+
// Infrastructure files
|
|
60
|
+
const infraMatches = INFRA_PATTERNS.filter(p => p.test(file));
|
|
61
|
+
if (infraMatches.length > 0)
|
|
62
|
+
return 60;
|
|
63
|
+
// Entry points
|
|
64
|
+
if (/index\.[jt]sx?$/.test(file) || /main\.[jt]sx?$/.test(file) || /app\.[jt]sx?$/.test(file)) {
|
|
65
|
+
return 50;
|
|
66
|
+
}
|
|
67
|
+
// Default: moderate risk
|
|
68
|
+
return 25;
|
|
69
|
+
}
|
|
70
|
+
/** Check if test file exists — no test = higher risk */
|
|
71
|
+
coverageScore(file) {
|
|
72
|
+
const ext = extname(file);
|
|
73
|
+
const base = basename(file, ext);
|
|
74
|
+
const dir = dirname(file);
|
|
75
|
+
const fullDir = join(this.cwd, dir);
|
|
76
|
+
// Test files themselves have zero coverage risk
|
|
77
|
+
if (TEST_PATTERNS.some(p => file.includes(p))) {
|
|
78
|
+
return 0;
|
|
79
|
+
}
|
|
80
|
+
// Check common test file locations
|
|
81
|
+
const testVariants = [
|
|
82
|
+
join(fullDir, `${base}.test${ext}`),
|
|
83
|
+
join(fullDir, `${base}.spec${ext}`),
|
|
84
|
+
join(fullDir, '__tests__', `${base}${ext}`),
|
|
85
|
+
join(fullDir, '__tests__', `${base}.test${ext}`),
|
|
86
|
+
join(this.cwd, 'tests', dir, `${base}.test${ext}`),
|
|
87
|
+
join(this.cwd, 'test', dir, `${base}.test${ext}`),
|
|
88
|
+
];
|
|
89
|
+
for (const testPath of testVariants) {
|
|
90
|
+
if (existsSync(testPath)) {
|
|
91
|
+
return 15; // Has a test file — low risk
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
return 85; // No test file found — high risk
|
|
95
|
+
}
|
|
96
|
+
/** Count importers of this file via grep */
|
|
97
|
+
blastRadiusScore(file) {
|
|
98
|
+
try {
|
|
99
|
+
const relPath = file.replace(/\.[jt]sx?$/, '');
|
|
100
|
+
const fileName = basename(relPath);
|
|
101
|
+
// Search for imports of this file
|
|
102
|
+
const result = execSync(`git grep -l --no-color -E "(import|require).*['\"].*${fileName}['\"]" -- "*.ts" "*.tsx" "*.js" "*.jsx" 2>/dev/null || true`, { cwd: this.cwd, encoding: 'utf-8', timeout: 10000 }).trim();
|
|
103
|
+
const importers = result ? result.split('\n').filter(l => l.trim().length > 0).length : 0;
|
|
104
|
+
// Scale: 0 importers = 0, 1-2 = 20, 3-5 = 40, 6-10 = 60, 11-20 = 80, 20+ = 100
|
|
105
|
+
if (importers === 0)
|
|
106
|
+
return 0;
|
|
107
|
+
if (importers <= 2)
|
|
108
|
+
return 20;
|
|
109
|
+
if (importers <= 5)
|
|
110
|
+
return 40;
|
|
111
|
+
if (importers <= 10)
|
|
112
|
+
return 60;
|
|
113
|
+
if (importers <= 20)
|
|
114
|
+
return 80;
|
|
115
|
+
return 100;
|
|
116
|
+
}
|
|
117
|
+
catch {
|
|
118
|
+
return 30; // Default moderate if git grep fails
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
/** Count recent commits touching this file (last 90 days) */
|
|
122
|
+
changeHistoryScore(file) {
|
|
123
|
+
try {
|
|
124
|
+
const result = execSync(`git log --oneline --since="90 days ago" -- "${file}" 2>/dev/null | wc -l`, { cwd: this.cwd, encoding: 'utf-8', timeout: 10000 }).trim();
|
|
125
|
+
const commits = parseInt(result, 10) || 0;
|
|
126
|
+
// Scale: 0-1 = 10, 2-5 = 30, 6-10 = 50, 11-20 = 70, 21-50 = 85, 50+ = 100
|
|
127
|
+
if (commits <= 1)
|
|
128
|
+
return 10;
|
|
129
|
+
if (commits <= 5)
|
|
130
|
+
return 30;
|
|
131
|
+
if (commits <= 10)
|
|
132
|
+
return 50;
|
|
133
|
+
if (commits <= 20)
|
|
134
|
+
return 70;
|
|
135
|
+
if (commits <= 50)
|
|
136
|
+
return 85;
|
|
137
|
+
return 100;
|
|
138
|
+
}
|
|
139
|
+
catch {
|
|
140
|
+
return 30; // Default moderate if git fails
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
/** File size / line count as complexity proxy */
|
|
144
|
+
complexityScore(file) {
|
|
145
|
+
const fullPath = join(this.cwd, file);
|
|
146
|
+
if (!existsSync(fullPath))
|
|
147
|
+
return 50; // Can't assess — moderate default
|
|
148
|
+
try {
|
|
149
|
+
const content = readFileSync(fullPath, 'utf-8');
|
|
150
|
+
const lines = content.split('\n').length;
|
|
151
|
+
// Count nesting depth (braces, brackets for complexity)
|
|
152
|
+
let maxDepth = 0;
|
|
153
|
+
let currentDepth = 0;
|
|
154
|
+
for (const char of content) {
|
|
155
|
+
if (char === '{') {
|
|
156
|
+
currentDepth++;
|
|
157
|
+
if (currentDepth > maxDepth)
|
|
158
|
+
maxDepth = currentDepth;
|
|
159
|
+
}
|
|
160
|
+
else if (char === '}') {
|
|
161
|
+
currentDepth--;
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
// Combine line count and nesting
|
|
165
|
+
let lineScore;
|
|
166
|
+
if (lines <= 50)
|
|
167
|
+
lineScore = 10;
|
|
168
|
+
else if (lines <= 150)
|
|
169
|
+
lineScore = 25;
|
|
170
|
+
else if (lines <= 300)
|
|
171
|
+
lineScore = 45;
|
|
172
|
+
else if (lines <= 500)
|
|
173
|
+
lineScore = 65;
|
|
174
|
+
else if (lines <= 1000)
|
|
175
|
+
lineScore = 80;
|
|
176
|
+
else
|
|
177
|
+
lineScore = 95;
|
|
178
|
+
let depthScore;
|
|
179
|
+
if (maxDepth <= 3)
|
|
180
|
+
depthScore = 10;
|
|
181
|
+
else if (maxDepth <= 5)
|
|
182
|
+
depthScore = 30;
|
|
183
|
+
else if (maxDepth <= 8)
|
|
184
|
+
depthScore = 55;
|
|
185
|
+
else if (maxDepth <= 12)
|
|
186
|
+
depthScore = 75;
|
|
187
|
+
else
|
|
188
|
+
depthScore = 95;
|
|
189
|
+
return Math.round(lineScore * 0.6 + depthScore * 0.4);
|
|
190
|
+
}
|
|
191
|
+
catch {
|
|
192
|
+
return 50;
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
/** Is this a new file (no git history)? */
|
|
196
|
+
noveltyScore(file) {
|
|
197
|
+
try {
|
|
198
|
+
const result = execSync(`git log --oneline -- "${file}" 2>/dev/null | wc -l`, { cwd: this.cwd, encoding: 'utf-8', timeout: 10000 }).trim();
|
|
199
|
+
const totalCommits = parseInt(result, 10) || 0;
|
|
200
|
+
// Brand new (0-1 commits) = high risk, battle-tested = low
|
|
201
|
+
if (totalCommits === 0)
|
|
202
|
+
return 100; // Untracked / brand new
|
|
203
|
+
if (totalCommits === 1)
|
|
204
|
+
return 80; // Just added
|
|
205
|
+
if (totalCommits <= 3)
|
|
206
|
+
return 55; // Young
|
|
207
|
+
if (totalCommits <= 10)
|
|
208
|
+
return 30; // Moderate history
|
|
209
|
+
return 10; // Well-established
|
|
210
|
+
}
|
|
211
|
+
catch {
|
|
212
|
+
return 70; // If we can't check, assume fairly new
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
/** Map overall score to risk level */
|
|
216
|
+
scoreToLevel(score) {
|
|
217
|
+
if (score <= 25)
|
|
218
|
+
return 'low';
|
|
219
|
+
if (score <= 50)
|
|
220
|
+
return 'medium';
|
|
221
|
+
if (score <= 75)
|
|
222
|
+
return 'high';
|
|
223
|
+
return 'critical';
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
//# sourceMappingURL=risk-scorer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"risk-scorer.js","sourceRoot":"","sources":["../../../src/core/risk-scorer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
export interface RuntimeEvent {
|
|
2
|
+
type: 'filesystem' | 'network' | 'env-access' | 'subprocess' | 'install-script';
|
|
3
|
+
detail: string;
|
|
4
|
+
timestamp: number;
|
|
5
|
+
severity: 'info' | 'warning' | 'critical';
|
|
6
|
+
source: string;
|
|
7
|
+
}
|
|
8
|
+
export interface RuntimeBaseline {
|
|
9
|
+
expectedFilesystem: string[];
|
|
10
|
+
expectedNetwork: string[];
|
|
11
|
+
expectedSubprocesses: string[];
|
|
12
|
+
createdAt: number;
|
|
13
|
+
}
|
|
14
|
+
export declare class RuntimeMonitor {
|
|
15
|
+
private swarmDir;
|
|
16
|
+
private events;
|
|
17
|
+
private baseline;
|
|
18
|
+
private eventsFile;
|
|
19
|
+
private baselineFile;
|
|
20
|
+
constructor(swarmDir: string);
|
|
21
|
+
/** Record a runtime event */
|
|
22
|
+
recordEvent(event: Omit<RuntimeEvent, 'timestamp'>): void;
|
|
23
|
+
/** Check event against baseline — returns true if anomalous */
|
|
24
|
+
checkAnomaly(event: RuntimeEvent): boolean;
|
|
25
|
+
/** Save current events as baseline */
|
|
26
|
+
saveBaseline(): void;
|
|
27
|
+
/** Load baseline from disk */
|
|
28
|
+
private loadBaseline;
|
|
29
|
+
/** Load existing events from disk */
|
|
30
|
+
private loadEvents;
|
|
31
|
+
/** Get all events, optionally filtered by time */
|
|
32
|
+
getEvents(since?: number): RuntimeEvent[];
|
|
33
|
+
/** Get anomalies (events not in baseline) */
|
|
34
|
+
getAnomalies(): RuntimeEvent[];
|
|
35
|
+
/** Monitor npm install for suspicious behavior */
|
|
36
|
+
monitorInstall(packageName: string): RuntimeEvent[];
|
|
37
|
+
/** Clear events */
|
|
38
|
+
clearEvents(): void;
|
|
39
|
+
/** Generate summary report */
|
|
40
|
+
getSummary(): {
|
|
41
|
+
totalEvents: number;
|
|
42
|
+
anomalies: number;
|
|
43
|
+
byType: Record<string, number>;
|
|
44
|
+
bySeverity: Record<string, number>;
|
|
45
|
+
};
|
|
46
|
+
/** Simple glob-like matching (supports * wildcards) */
|
|
47
|
+
private matchGlob;
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=runtime-monitor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtime-monitor.d.ts","sourceRoot":"","sources":["../../../src/core/runtime-monitor.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,YAAY,GAAG,SAAS,GAAG,YAAY,GAAG,YAAY,GAAG,gBAAgB,CAAC;IAChF,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,GAAG,SAAS,GAAG,UAAU,CAAC;IAC1C,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,eAAe;IAC9B,kBAAkB,EAAE,MAAM,EAAE,CAAC;IAC7B,eAAe,EAAE,MAAM,EAAE,CAAC;IAC1B,oBAAoB,EAAE,MAAM,EAAE,CAAC;IAC/B,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,qBAAa,cAAc;IAMb,OAAO,CAAC,QAAQ;IAL5B,OAAO,CAAC,MAAM,CAAsB;IACpC,OAAO,CAAC,QAAQ,CAAgC;IAChD,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,YAAY,CAAS;gBAET,QAAQ,EAAE,MAAM;IAUpC,6BAA6B;IAC7B,WAAW,CAAC,KAAK,EAAE,IAAI,CAAC,YAAY,EAAE,WAAW,CAAC,GAAG,IAAI;IAWzD,+DAA+D;IAC/D,YAAY,CAAC,KAAK,EAAE,YAAY,GAAG,OAAO;IA6B1C,sCAAsC;IACtC,YAAY,IAAI,IAAI;IA8BpB,8BAA8B;IAC9B,OAAO,CAAC,YAAY;IAWpB,qCAAqC;IACrC,OAAO,CAAC,UAAU;IAalB,kDAAkD;IAClD,SAAS,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,YAAY,EAAE;IAOzC,6CAA6C;IAC7C,YAAY,IAAI,YAAY,EAAE;IAK9B,kDAAkD;IAClD,cAAc,CAAC,WAAW,EAAE,MAAM,GAAG,YAAY,EAAE;IA0FnD,mBAAmB;IACnB,WAAW,IAAI,IAAI;IASnB,8BAA8B;IAC9B,UAAU,IAAI;QACZ,WAAW,EAAE,MAAM,CAAC;QACpB,SAAS,EAAE,MAAM,CAAC;QAClB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QAC/B,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;KACpC;IAiBD,uDAAuD;IACvD,OAAO,CAAC,SAAS;CAIlB"}
|
|
@@ -0,0 +1,235 @@
|
|
|
1
|
+
import { readFileSync, writeFileSync, appendFileSync, existsSync, mkdirSync } from 'node:fs';
|
|
2
|
+
import { join } from 'node:path';
|
|
3
|
+
import { execSync } from 'node:child_process';
|
|
4
|
+
export class RuntimeMonitor {
|
|
5
|
+
swarmDir;
|
|
6
|
+
events = [];
|
|
7
|
+
baseline = null;
|
|
8
|
+
eventsFile;
|
|
9
|
+
baselineFile;
|
|
10
|
+
constructor(swarmDir) {
|
|
11
|
+
this.swarmDir = swarmDir;
|
|
12
|
+
this.eventsFile = join(swarmDir, 'runtime-events.jsonl');
|
|
13
|
+
this.baselineFile = join(swarmDir, 'runtime-baseline.json');
|
|
14
|
+
if (!existsSync(swarmDir)) {
|
|
15
|
+
mkdirSync(swarmDir, { recursive: true });
|
|
16
|
+
}
|
|
17
|
+
this.loadBaseline();
|
|
18
|
+
this.loadEvents();
|
|
19
|
+
}
|
|
20
|
+
/** Record a runtime event */
|
|
21
|
+
recordEvent(event) {
|
|
22
|
+
const fullEvent = { ...event, timestamp: Date.now() };
|
|
23
|
+
this.events.push(fullEvent);
|
|
24
|
+
// Append to JSONL log
|
|
25
|
+
try {
|
|
26
|
+
appendFileSync(this.eventsFile, JSON.stringify(fullEvent) + '\n', 'utf-8');
|
|
27
|
+
}
|
|
28
|
+
catch {
|
|
29
|
+
// If we can't write, just keep in-memory
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
/** Check event against baseline — returns true if anomalous */
|
|
33
|
+
checkAnomaly(event) {
|
|
34
|
+
if (!this.baseline)
|
|
35
|
+
return false;
|
|
36
|
+
switch (event.type) {
|
|
37
|
+
case 'filesystem':
|
|
38
|
+
return !this.baseline.expectedFilesystem.some((pattern) => event.detail.includes(pattern) || this.matchGlob(event.detail, pattern));
|
|
39
|
+
case 'network':
|
|
40
|
+
return !this.baseline.expectedNetwork.some((host) => event.detail.includes(host));
|
|
41
|
+
case 'subprocess':
|
|
42
|
+
return !this.baseline.expectedSubprocesses.some((cmd) => event.detail.includes(cmd));
|
|
43
|
+
case 'install-script':
|
|
44
|
+
// Install scripts are always flagged as anomalous unless in baseline
|
|
45
|
+
return !this.baseline.expectedSubprocesses.some((cmd) => event.detail.includes(cmd));
|
|
46
|
+
case 'env-access':
|
|
47
|
+
// Environment access is always potentially anomalous
|
|
48
|
+
return true;
|
|
49
|
+
default:
|
|
50
|
+
return false;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
/** Save current events as baseline */
|
|
54
|
+
saveBaseline() {
|
|
55
|
+
const filesystem = new Set();
|
|
56
|
+
const network = new Set();
|
|
57
|
+
const subprocesses = new Set();
|
|
58
|
+
for (const event of this.events) {
|
|
59
|
+
switch (event.type) {
|
|
60
|
+
case 'filesystem':
|
|
61
|
+
filesystem.add(event.detail);
|
|
62
|
+
break;
|
|
63
|
+
case 'network':
|
|
64
|
+
network.add(event.detail);
|
|
65
|
+
break;
|
|
66
|
+
case 'subprocess':
|
|
67
|
+
case 'install-script':
|
|
68
|
+
subprocesses.add(event.detail);
|
|
69
|
+
break;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
this.baseline = {
|
|
73
|
+
expectedFilesystem: [...filesystem],
|
|
74
|
+
expectedNetwork: [...network],
|
|
75
|
+
expectedSubprocesses: [...subprocesses],
|
|
76
|
+
createdAt: Date.now(),
|
|
77
|
+
};
|
|
78
|
+
writeFileSync(this.baselineFile, JSON.stringify(this.baseline, null, 2), 'utf-8');
|
|
79
|
+
}
|
|
80
|
+
/** Load baseline from disk */
|
|
81
|
+
loadBaseline() {
|
|
82
|
+
try {
|
|
83
|
+
if (existsSync(this.baselineFile)) {
|
|
84
|
+
const raw = readFileSync(this.baselineFile, 'utf-8');
|
|
85
|
+
this.baseline = JSON.parse(raw);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
catch {
|
|
89
|
+
this.baseline = null;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
/** Load existing events from disk */
|
|
93
|
+
loadEvents() {
|
|
94
|
+
try {
|
|
95
|
+
if (existsSync(this.eventsFile)) {
|
|
96
|
+
const raw = readFileSync(this.eventsFile, 'utf-8').trim();
|
|
97
|
+
if (raw) {
|
|
98
|
+
this.events = raw.split('\n').map((line) => JSON.parse(line));
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
catch {
|
|
103
|
+
this.events = [];
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
/** Get all events, optionally filtered by time */
|
|
107
|
+
getEvents(since) {
|
|
108
|
+
if (since !== undefined) {
|
|
109
|
+
return this.events.filter((e) => e.timestamp >= since);
|
|
110
|
+
}
|
|
111
|
+
return [...this.events];
|
|
112
|
+
}
|
|
113
|
+
/** Get anomalies (events not in baseline) */
|
|
114
|
+
getAnomalies() {
|
|
115
|
+
if (!this.baseline)
|
|
116
|
+
return [];
|
|
117
|
+
return this.events.filter((e) => this.checkAnomaly(e));
|
|
118
|
+
}
|
|
119
|
+
/** Monitor npm install for suspicious behavior */
|
|
120
|
+
monitorInstall(packageName) {
|
|
121
|
+
const installEvents = [];
|
|
122
|
+
try {
|
|
123
|
+
// Run npm install --dry-run --json to inspect what would happen
|
|
124
|
+
const result = execSync(`npm install ${packageName} --dry-run --json 2>&1`, {
|
|
125
|
+
encoding: 'utf-8',
|
|
126
|
+
timeout: 30000,
|
|
127
|
+
cwd: process.cwd(),
|
|
128
|
+
});
|
|
129
|
+
let parsed = null;
|
|
130
|
+
try {
|
|
131
|
+
parsed = JSON.parse(result);
|
|
132
|
+
}
|
|
133
|
+
catch {
|
|
134
|
+
// Non-JSON output, still record
|
|
135
|
+
}
|
|
136
|
+
if (parsed) {
|
|
137
|
+
// Check for install scripts
|
|
138
|
+
const added = parsed.added || [];
|
|
139
|
+
for (const pkg of added) {
|
|
140
|
+
const scripts = pkg.scripts;
|
|
141
|
+
if (scripts) {
|
|
142
|
+
for (const [hook, cmd] of Object.entries(scripts)) {
|
|
143
|
+
if (['preinstall', 'postinstall', 'install', 'prepare'].includes(hook)) {
|
|
144
|
+
const event = {
|
|
145
|
+
type: 'install-script',
|
|
146
|
+
detail: `${pkg.name}@${pkg.version}: ${hook} → ${cmd}`,
|
|
147
|
+
severity: 'warning',
|
|
148
|
+
source: `npm-install:${packageName}`,
|
|
149
|
+
};
|
|
150
|
+
this.recordEvent(event);
|
|
151
|
+
installEvents.push({ ...event, timestamp: Date.now() });
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
// Also check for known suspicious patterns
|
|
158
|
+
const suspiciousPatterns = [
|
|
159
|
+
/curl\s+/i,
|
|
160
|
+
/wget\s+/i,
|
|
161
|
+
/eval\s*\(/,
|
|
162
|
+
/child_process/,
|
|
163
|
+
/exec\s*\(/,
|
|
164
|
+
/\.env/,
|
|
165
|
+
/process\.env/,
|
|
166
|
+
/base64/i,
|
|
167
|
+
];
|
|
168
|
+
for (const pattern of suspiciousPatterns) {
|
|
169
|
+
if (pattern.test(result)) {
|
|
170
|
+
const event = {
|
|
171
|
+
type: 'install-script',
|
|
172
|
+
detail: `Suspicious pattern detected in ${packageName}: ${pattern.source}`,
|
|
173
|
+
severity: 'critical',
|
|
174
|
+
source: `npm-install:${packageName}`,
|
|
175
|
+
};
|
|
176
|
+
this.recordEvent(event);
|
|
177
|
+
installEvents.push({ ...event, timestamp: Date.now() });
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
// Record successful dry-run as info
|
|
181
|
+
if (installEvents.length === 0) {
|
|
182
|
+
const event = {
|
|
183
|
+
type: 'subprocess',
|
|
184
|
+
detail: `npm install ${packageName} --dry-run completed (clean)`,
|
|
185
|
+
severity: 'info',
|
|
186
|
+
source: `npm-install:${packageName}`,
|
|
187
|
+
};
|
|
188
|
+
this.recordEvent(event);
|
|
189
|
+
installEvents.push({ ...event, timestamp: Date.now() });
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
catch (err) {
|
|
193
|
+
const event = {
|
|
194
|
+
type: 'subprocess',
|
|
195
|
+
detail: `npm install ${packageName} --dry-run failed: ${err instanceof Error ? err.message : String(err)}`,
|
|
196
|
+
severity: 'warning',
|
|
197
|
+
source: `npm-install:${packageName}`,
|
|
198
|
+
};
|
|
199
|
+
this.recordEvent(event);
|
|
200
|
+
installEvents.push({ ...event, timestamp: Date.now() });
|
|
201
|
+
}
|
|
202
|
+
return installEvents;
|
|
203
|
+
}
|
|
204
|
+
/** Clear events */
|
|
205
|
+
clearEvents() {
|
|
206
|
+
this.events = [];
|
|
207
|
+
try {
|
|
208
|
+
writeFileSync(this.eventsFile, '', 'utf-8');
|
|
209
|
+
}
|
|
210
|
+
catch {
|
|
211
|
+
// Ignore write errors
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
/** Generate summary report */
|
|
215
|
+
getSummary() {
|
|
216
|
+
const byType = {};
|
|
217
|
+
const bySeverity = {};
|
|
218
|
+
for (const event of this.events) {
|
|
219
|
+
byType[event.type] = (byType[event.type] || 0) + 1;
|
|
220
|
+
bySeverity[event.severity] = (bySeverity[event.severity] || 0) + 1;
|
|
221
|
+
}
|
|
222
|
+
return {
|
|
223
|
+
totalEvents: this.events.length,
|
|
224
|
+
anomalies: this.getAnomalies().length,
|
|
225
|
+
byType,
|
|
226
|
+
bySeverity,
|
|
227
|
+
};
|
|
228
|
+
}
|
|
229
|
+
/** Simple glob-like matching (supports * wildcards) */
|
|
230
|
+
matchGlob(value, pattern) {
|
|
231
|
+
const escaped = pattern.replace(/[.+^${}()|[\]\\]/g, '\\$&').replace(/\*/g, '.*');
|
|
232
|
+
return new RegExp(`^${escaped}$`).test(value);
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
//# sourceMappingURL=runtime-monitor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtime-monitor.js","sourceRoot":"","sources":["../../../src/core/runtime-monitor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
export type SandboxMode = 'strict' | 'moderate' | 'off';
|
|
2
|
+
export interface SandboxViolation {
|
|
3
|
+
type: 'filesystem' | 'network' | 'command' | 'process';
|
|
4
|
+
detail: string;
|
|
5
|
+
severity: 'blocked' | 'warning';
|
|
6
|
+
timestamp: number;
|
|
7
|
+
}
|
|
8
|
+
export interface SandboxConfig {
|
|
9
|
+
mode: SandboxMode;
|
|
10
|
+
/** Allowed filesystem paths (project dir always allowed) */
|
|
11
|
+
allowedPaths?: string[];
|
|
12
|
+
/** Blocked filesystem paths */
|
|
13
|
+
blockedPaths?: string[];
|
|
14
|
+
/** Allowed network hosts (package registries always allowed) */
|
|
15
|
+
allowedHosts?: string[];
|
|
16
|
+
/** Blocked commands */
|
|
17
|
+
blockedCommands?: string[];
|
|
18
|
+
}
|
|
19
|
+
export declare class Sandbox {
|
|
20
|
+
private projectDir;
|
|
21
|
+
private config;
|
|
22
|
+
private violations;
|
|
23
|
+
private auditFilePath;
|
|
24
|
+
constructor(projectDir: string, config?: SandboxConfig);
|
|
25
|
+
/** Get the current sandbox mode */
|
|
26
|
+
getMode(): SandboxMode;
|
|
27
|
+
/** Get the current config */
|
|
28
|
+
getConfig(): SandboxConfig;
|
|
29
|
+
/** Validate a filesystem operation */
|
|
30
|
+
checkFilesystem(path: string, operation: 'read' | 'write' | 'delete'): boolean;
|
|
31
|
+
/** Validate a network request */
|
|
32
|
+
checkNetwork(host: string): boolean;
|
|
33
|
+
/** Validate a command execution */
|
|
34
|
+
checkCommand(cmd: string): boolean;
|
|
35
|
+
/** Get violation log */
|
|
36
|
+
getViolations(): SandboxViolation[];
|
|
37
|
+
/** Get violations from the persisted security audit log */
|
|
38
|
+
getPersistedViolations(limit?: number): SandboxViolation[];
|
|
39
|
+
/** Build --disallowed-tools and --append-system-prompt for sandbox mode */
|
|
40
|
+
getAgentConstraints(): {
|
|
41
|
+
disallowedTools?: string[];
|
|
42
|
+
appendSystemPrompt?: string;
|
|
43
|
+
};
|
|
44
|
+
/** Log violation to .swarm/security-audit.jsonl */
|
|
45
|
+
private logViolation;
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=sandbox.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sandbox.d.ts","sourceRoot":"","sources":["../../../src/core/sandbox.ts"],"names":[],"mappings":"AAIA,MAAM,MAAM,WAAW,GAAG,QAAQ,GAAG,UAAU,GAAG,KAAK,CAAC;AAExD,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,YAAY,GAAG,SAAS,GAAG,SAAS,GAAG,SAAS,CAAC;IACvD,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,SAAS,GAAG,SAAS,CAAC;IAChC,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,WAAW,CAAC;IAClB,4DAA4D;IAC5D,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,+BAA+B;IAC/B,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,gEAAgE;IAChE,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,uBAAuB;IACvB,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;CAC5B;AAwCD,qBAAa,OAAO;IAKhB,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,MAAM;IALhB,OAAO,CAAC,UAAU,CAA0B;IAC5C,OAAO,CAAC,aAAa,CAAS;gBAGpB,UAAU,EAAE,MAAM,EAClB,MAAM,GAAE,aAAoC;IAStD,mCAAmC;IACnC,OAAO,IAAI,WAAW;IAItB,6BAA6B;IAC7B,SAAS,IAAI,aAAa;IAI1B,sCAAsC;IACtC,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,GAAG,QAAQ,GAAG,OAAO;IAyE9E,iCAAiC;IACjC,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IA2CnC,mCAAmC;IACnC,YAAY,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAmDlC,wBAAwB;IACxB,aAAa,IAAI,gBAAgB,EAAE;IAInC,2DAA2D;IAC3D,sBAAsB,CAAC,KAAK,SAAM,GAAG,gBAAgB,EAAE;IAmBvD,2EAA2E;IAC3E,mBAAmB,IAAI;QAAE,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;QAAC,kBAAkB,CAAC,EAAE,MAAM,CAAA;KAAE;IAyClF,mDAAmD;IACnD,OAAO,CAAC,YAAY;CAQrB"}
|