@bolloon/bolloon-agent 0.1.0 → 0.1.2

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.
Files changed (581) hide show
  1. package/bin/bolloon-cli.cjs +157 -0
  2. package/bin/bolloon-daemon.sh +207 -0
  3. package/bin/bolloon.cmd +11 -0
  4. package/dist/agents/constraint-layer.js +10 -15
  5. package/dist/agents/pi-sdk.js +433 -106
  6. package/dist/agents/protocol.js +82 -1
  7. package/dist/agents/subagent-manager.js +2 -2
  8. package/dist/agents/workflow-engine.js +15 -20
  9. package/dist/agents/workflow-pivot-loop.js +541 -0
  10. package/dist/bollharness/src/index.js +5 -0
  11. package/dist/bollharness/src/scripts/checks/check_adr_plan_numbering.js +6 -0
  12. package/dist/bollharness/src/scripts/checks/check_api_types.js +45 -0
  13. package/dist/bollharness/src/scripts/checks/check_artifact_link.js +146 -0
  14. package/dist/bollharness/src/scripts/checks/check_bridge_deps.js +6 -0
  15. package/dist/bollharness/src/scripts/checks/check_bugfix_binding.js +6 -0
  16. package/dist/bollharness/src/scripts/checks/check_bugfix_binding_ci.js +6 -0
  17. package/dist/bollharness/src/scripts/checks/check_doc_file_references.js +6 -0
  18. package/dist/bollharness/src/scripts/checks/check_doc_freshness.js +135 -0
  19. package/dist/bollharness/src/scripts/checks/check_doc_links.js +31 -0
  20. package/dist/bollharness/src/scripts/checks/check_file_existence_claims.js +6 -0
  21. package/dist/bollharness/src/scripts/checks/check_fragment_integrity.js +34 -0
  22. package/dist/bollharness/src/scripts/checks/check_hook_installed.js +63 -0
  23. package/dist/bollharness/src/scripts/checks/check_issue_closure.js +41 -0
  24. package/dist/bollharness/src/scripts/checks/check_mcp_parity.js +6 -0
  25. package/dist/bollharness/src/scripts/checks/check_security.js +48 -0
  26. package/dist/bollharness/src/scripts/checks/check_skill_parity.js +6 -0
  27. package/dist/bollharness/src/scripts/checks/check_versions.js +6 -0
  28. package/dist/bollharness/src/scripts/checks/finding.js +13 -0
  29. package/dist/bollharness/src/scripts/checks/next_decision_number.js +20 -0
  30. package/dist/bollharness/src/scripts/checks/regenerate_magic_docs.js +6 -0
  31. package/dist/bollharness/src/scripts/ci/detect_rebaseline_triggers.js +8 -0
  32. package/dist/bollharness/src/scripts/ci/scan_subprocess_cfg.js +8 -0
  33. package/dist/bollharness/src/scripts/ci/scan_verify_artifacts.js +8 -0
  34. package/dist/bollharness/src/scripts/ci/scan_yaml_schema.js +8 -0
  35. package/dist/bollharness/src/scripts/context_router.js +67 -0
  36. package/dist/bollharness/src/scripts/deploy-guard.js +157 -0
  37. package/dist/bollharness/src/scripts/guard-feedback.js +192 -0
  38. package/dist/bollharness/src/scripts/guard_router.js +158 -0
  39. package/dist/bollharness/src/scripts/hooks/_hook_output.js +6 -0
  40. package/dist/bollharness/src/scripts/hooks/auto-python3.js +6 -0
  41. package/dist/bollharness/src/scripts/hooks/deploy-progress-on-session-end.js +6 -0
  42. package/dist/bollharness/src/scripts/hooks/failure-analyzer.js +6 -0
  43. package/dist/bollharness/src/scripts/hooks/gate-judgment-inject.js +92 -0
  44. package/dist/bollharness/src/scripts/hooks/gate-transition-judgment.js +63 -0
  45. package/dist/bollharness/src/scripts/hooks/inbox-ack.js +6 -0
  46. package/dist/bollharness/src/scripts/hooks/inbox-inject-on-start.js +6 -0
  47. package/dist/bollharness/src/scripts/hooks/inbox-validate.js +6 -0
  48. package/dist/bollharness/src/scripts/hooks/inbox-write-ledger.js +6 -0
  49. package/dist/bollharness/src/scripts/hooks/initializer-agent.js +6 -0
  50. package/dist/bollharness/src/scripts/hooks/loop-detection.js +73 -0
  51. package/dist/bollharness/src/scripts/hooks/owner-guard.js +6 -0
  52. package/dist/bollharness/src/scripts/hooks/precompact.js +6 -0
  53. package/dist/bollharness/src/scripts/hooks/review-agent-gatekeeper.js +6 -0
  54. package/dist/bollharness/src/scripts/hooks/risk-tracker.js +108 -0
  55. package/dist/bollharness/src/scripts/hooks/sanitize-on-read.js +6 -0
  56. package/dist/bollharness/src/scripts/hooks/session-reflection.js +7 -0
  57. package/dist/bollharness/src/scripts/hooks/session-start-magic-docs.js +7 -0
  58. package/dist/bollharness/src/scripts/hooks/session-start-reset-risk.js +7 -0
  59. package/dist/bollharness/src/scripts/hooks/session-start-toolkit-reminder.js +7 -0
  60. package/dist/bollharness/src/scripts/hooks/stop-evaluator.js +157 -0
  61. package/dist/bollharness/src/scripts/hooks/tool-call-counter.js +6 -0
  62. package/dist/bollharness/src/scripts/hooks/trace-analyzer.js +10 -0
  63. package/dist/bollharness/src/scripts/install/install-trust-token.js +7 -0
  64. package/dist/bollharness/src/scripts/install/multi_project_registry.js +9 -0
  65. package/dist/bollharness/src/scripts/install/phase2_auto.js +21 -0
  66. package/dist/bollharness/src/scripts/install/pre_commit_installer.js +6 -0
  67. package/dist/bollharness/src/scripts/install/tier_selector.js +7 -0
  68. package/dist/bollharness/src/scripts/install/transcript_miner.js +7 -0
  69. package/dist/bollharness/src/scripts/lib/claim_patterns.js +10 -0
  70. package/dist/bollharness/src/scripts/lib/sanitize_patterns.js +12 -0
  71. package/dist/bollharness/src/scripts/sanitize.js +6 -0
  72. package/dist/bollharness-integration/channel-judgment-engine.js +530 -0
  73. package/dist/bollharness-integration/context-chain-router.js +383 -0
  74. package/dist/bollharness-integration/context-router-judgment.js +13 -21
  75. package/dist/bollharness-integration/context-router.js +22 -64
  76. package/dist/bollharness-integration/gate-state-machine.js +14 -19
  77. package/dist/bollharness-integration/gate-transition-hooks.js +16 -61
  78. package/dist/bollharness-integration/guard-checker.js +21 -68
  79. package/dist/bollharness-integration/index.js +14 -124
  80. package/dist/bollharness-integration/integration.js +13 -20
  81. package/dist/bollharness-integration/llm-judgment-engine.js +569 -0
  82. package/dist/bollharness-integration/skill-adapter.js +18 -64
  83. package/dist/cli-entry.js +261 -0
  84. package/dist/constraint-runtime/src/commands.js +17 -7
  85. package/dist/constraint-runtime/src/constraint/budget.js +1 -6
  86. package/dist/constraint-runtime/src/constraint/permission.js +1 -6
  87. package/dist/constraint-runtime/src/models.js +1 -3
  88. package/dist/constraint-runtime/src/tools.js +17 -7
  89. package/dist/constraints/index.js +1 -7
  90. package/dist/documents/reader.js +8 -49
  91. package/dist/heartbeat/DaemonManager.js +242 -0
  92. package/dist/heartbeat/HealthMonitor.js +285 -0
  93. package/dist/heartbeat/StartupVerifier.js +205 -0
  94. package/dist/heartbeat/Watchdog.js +168 -0
  95. package/dist/heartbeat/index.js +84 -0
  96. package/dist/heartbeat/types.js +5 -0
  97. package/dist/index.js +381 -28
  98. package/dist/llm/config-store.js +31 -57
  99. package/dist/llm/llm-judgment-client.js +389 -0
  100. package/dist/llm/pi-ai.js +9 -52
  101. package/dist/network/agent-network.js +46 -90
  102. package/dist/network/hybrid-messenger.js +125 -0
  103. package/dist/network/iroh-bootstrap.js +38 -0
  104. package/dist/network/iroh-discovery.js +145 -0
  105. package/dist/network/iroh-integration.js +9 -16
  106. package/dist/network/iroh-transport.js +10 -48
  107. package/dist/network/p2p.js +23 -62
  108. package/dist/network/storage/adapters/json-adapter.js +4 -42
  109. package/dist/network/storage/index.js +147 -0
  110. package/dist/network/storage/types.js +14 -0
  111. package/dist/pi-ecosystem/index.js +233 -0
  112. package/dist/pi-ecosystem-colony/index.js +29 -90
  113. package/dist/pi-ecosystem-goals/index.js +20 -74
  114. package/dist/pi-ecosystem-judgment/decision.js +29 -47
  115. package/dist/pi-ecosystem-judgment/distillation.js +16 -29
  116. package/dist/pi-ecosystem-judgment/human-value-store.js +13 -60
  117. package/dist/pi-ecosystem-judgment/index.js +21 -74
  118. package/dist/pi-ecosystem-judgment/value-injection.js +26 -72
  119. package/dist/pi-ecosystem-mcp/index.js +24 -78
  120. package/dist/pi-ecosystem-subagents/index.js +20 -69
  121. package/dist/social/ant-colony/AdaptiveHeartbeat.js +3 -8
  122. package/dist/social/ant-colony/PheromoneEngine.js +11 -49
  123. package/dist/social/ant-colony/index.js +6 -0
  124. package/dist/social/ant-colony/types.js +4 -8
  125. package/dist/social/channels/ChannelManager.js +8 -46
  126. package/dist/social/channels/DiapChannelBridge.js +9 -47
  127. package/dist/social/channels/InterestMatcher.js +2 -7
  128. package/dist/social/channels/channel-agent-session.js +309 -0
  129. package/dist/social/channels/channel-heartbeat-agent.js +494 -0
  130. package/dist/social/channels/diap-doc-parser.js +204 -0
  131. package/dist/social/channels/harness-workflow-integrator.js +446 -0
  132. package/dist/social/channels/index.js +9 -0
  133. package/dist/social/channels/types.js +3 -7
  134. package/dist/social/global-shared-context.js +6 -47
  135. package/dist/social/heartbeat.js +29 -72
  136. package/dist/social/persona/enhanced-persona.js +299 -0
  137. package/dist/web/client.js +302 -136
  138. package/dist/web/components/p2p/index.js +159 -9
  139. package/dist/web/components/p2p/p2p-connection.js +136 -0
  140. package/dist/web/components/p2p/p2p-manager.js +24 -0
  141. package/dist/web/components/p2p/p2p-store-memory.js +1 -1
  142. package/dist/web/components/p2p/types.js +7 -0
  143. package/dist/web/index.html +5 -0
  144. package/dist/web/style.css +118 -0
  145. package/package.json +12 -6
  146. package/scripts/build-cli.js +206 -0
  147. package/scripts/postinstall.js +153 -0
  148. package/src/agents/pi-sdk.ts +347 -28
  149. package/src/agents/protocol.ts +95 -1
  150. package/src/agents/workflow-pivot-loop.ts +674 -0
  151. package/src/bollharness/scripts/context-fragments/pi-agent-operations.md +34 -0
  152. package/src/cli-entry.ts +304 -0
  153. package/src/heartbeat/DaemonManager.ts +283 -0
  154. package/src/heartbeat/HealthMonitor.ts +316 -0
  155. package/src/heartbeat/StartupVerifier.ts +223 -0
  156. package/src/heartbeat/Watchdog.ts +198 -0
  157. package/src/heartbeat/index.ts +108 -0
  158. package/src/heartbeat/types.ts +82 -0
  159. package/src/llm/config-store.ts +23 -5
  160. package/src/network/iroh-transport.ts +3 -3
  161. package/src/web/client.js +302 -136
  162. package/src/web/components/p2p/P2PModal.tsx +91 -3
  163. package/src/web/components/p2p/index.ts +171 -9
  164. package/src/web/components/p2p/p2p-connection.ts +153 -1
  165. package/src/web/components/p2p/p2p-manager.ts +39 -1
  166. package/src/web/components/p2p/p2p-store-memory.ts +1 -1
  167. package/src/web/components/p2p/p2p-tools.ts +315 -0
  168. package/src/web/components/p2p/types.ts +58 -0
  169. package/src/web/index.html +5 -0
  170. package/src/web/server.ts +353 -36
  171. package/src/web/style.css +118 -0
  172. package/tsconfig.cli.json +16 -0
  173. package/tsconfig.electron.json +1 -1
  174. package/tsconfig.json +1 -2
  175. package/dist/constraint-runtime/tests/agent.test.js +0 -16
  176. package/dist/constraint-runtime/tests/constraint.test.js +0 -41
  177. package/dist/constraint-runtime/tests/skill.test.js +0 -19
  178. package/dist/constraint-runtime/tests/thinking.test.js +0 -22
  179. package/dist/electron-preload.js +0 -15
  180. package/dist/electron-preload.js.map +0 -1
  181. package/dist/electron.js +0 -206
  182. package/dist/electron.js.map +0 -1
  183. package/dist/test/constraint-layer.test.js +0 -164
  184. package/dist/test/global-shared-context.test.js +0 -315
  185. package/dist/test/pi-sdk.test.js +0 -47
  186. package/dist/test/set-persona.test.js +0 -38
  187. package/dist/test/subagent-manager.test.js +0 -276
  188. package/dist/test/workflow-engine.test.js +0 -87
  189. package/dist/web/server.js +0 -1647
  190. package/dist/web/server.js.map +0 -1
  191. package/dist/workflows/collaboration.js +0 -374
  192. package/dist/workflows/index.js +0 -54
  193. package/docs/agent-communication.md +0 -333
  194. package/docs/plans/2026-05-15-document-agent-design.md +0 -479
  195. package/docs/plans/2026-05-15-document-agent-implementation-plan.md +0 -792
  196. package/docs/plans/2026-05-16-chat-ui-design.md +0 -86
  197. package/docs/plans/2026-05-16-constraint-runtime-design.md +0 -106
  198. package/docs/plans/2026-05-16-constraint-runtime-implementation.md +0 -441
  199. package/docs//346/225/260/345/255/246/350/276/205/345/212/251/346/231/272/350/203/275/344/275/223-/346/240/270/345/277/203/346/225/210/346/236/234/345/256/232/344/271/211.md +0 -287
  200. package/src/bollharness/.boll/CLAUDE.md.template +0 -34
  201. package/src/bollharness/.boll/MANIFEST.yaml +0 -213
  202. package/src/bollharness/.boll/active-review-agents/.gitkeep +0 -0
  203. package/src/bollharness/.boll/agents/review-base.yaml +0 -108
  204. package/src/bollharness/.boll/deploy-allowlist.yaml +0 -38
  205. package/src/bollharness/.boll/inbox/schema/message-v1.json +0 -99
  206. package/src/bollharness/.boll/install-staging/.gitkeep +0 -0
  207. package/src/bollharness/.boll/issue-adapter.yaml +0 -31
  208. package/src/bollharness/.boll/plugins/boll-mode-toolkit/contracts/mode-contract.md +0 -85
  209. package/src/bollharness/.boll/plugins/boll-review-toolkit/contracts/evidence-packet-schema.json +0 -102
  210. package/src/bollharness/.boll/plugins/boll-review-toolkit/contracts/review-contract.yaml +0 -247
  211. package/src/bollharness/.boll/rules/backend-routes.md +0 -31
  212. package/src/bollharness/.boll/rules/closure-semantics.md +0 -30
  213. package/src/bollharness/.boll/rules/env-vars.md +0 -32
  214. package/src/bollharness/.boll/rules/hanis-protocol.md +0 -145
  215. package/src/bollharness/.boll/rules/repo-structure.md +0 -42
  216. package/src/bollharness/.boll/rules/review-agent-isolation.md +0 -73
  217. package/src/bollharness/.boll/rules/source-of-truth.md +0 -33
  218. package/src/bollharness/.boll/settings.json +0 -180
  219. package/src/bollharness/.boll/settings.json.template +0 -31
  220. package/src/bollharness/.boll/skills/arch/SKILL.md +0 -372
  221. package/src/bollharness/.boll/skills/bug-pipeline/SKILL.md +0 -168
  222. package/src/bollharness/.boll/skills/bug-triage/SKILL.md +0 -161
  223. package/src/bollharness/.boll/skills/context-chains/SKILL.md +0 -250
  224. package/src/bollharness/.boll/skills/context-chains/context-chain-index.md +0 -48
  225. package/src/bollharness/.boll/skills/context-chains/work-type-extractors/code_change_extractor.ts +0 -142
  226. package/src/bollharness/.boll/skills/context-chains/work-type-extractors/debugging_extractor.ts +0 -126
  227. package/src/bollharness/.boll/skills/context-chains/work-type-extractors/design_extractor.ts +0 -148
  228. package/src/bollharness/.boll/skills/context-chains/work-type-extractors/planning_extractor.ts +0 -162
  229. package/src/bollharness/.boll/skills/context-chains/work-type-extractors/question_extractor.ts +0 -116
  230. package/src/bollharness/.boll/skills/context-chains/work-type-extractors/review_extractor.ts +0 -136
  231. package/src/bollharness/.boll/skills/crystal-learn/SKILL.md +0 -93
  232. package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-0.md +0 -34
  233. package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-1.md +0 -34
  234. package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-2.md +0 -35
  235. package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-3.md +0 -34
  236. package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-4.md +0 -43
  237. package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-5.md +0 -34
  238. package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-6.md +0 -37
  239. package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-7.md +0 -46
  240. package/src/bollharness/.boll/skills/guardian-fixer/PROMPT.md +0 -415
  241. package/src/bollharness/.boll/skills/guardian-fixer/SKILL.md +0 -320
  242. package/src/bollharness/.boll/skills/harness-dev/SKILL.md +0 -93
  243. package/src/bollharness/.boll/skills/harness-dev/examples/README.md +0 -227
  244. package/src/bollharness/.boll/skills/harness-dev-handoff/SKILL.md +0 -165
  245. package/src/bollharness/.boll/skills/harness-eng/SKILL.md +0 -110
  246. package/src/bollharness/.boll/skills/harness-eng-test/SKILL.md +0 -79
  247. package/src/bollharness/.boll/skills/harness-lab/SKILL.md +0 -170
  248. package/src/bollharness/.boll/skills/harness-ops/SKILL.md +0 -57
  249. package/src/bollharness/.boll/skills/harness-voice/SKILL.md +0 -183
  250. package/src/bollharness/.boll/skills/judgment/SKILL.md +0 -115
  251. package/src/bollharness/.boll/skills/lead/SKILL.md +0 -245
  252. package/src/bollharness/.boll/skills/lead/install-wow-harness.md +0 -77
  253. package/src/bollharness/.boll/skills/lead/ref-review-sop.md +0 -91
  254. package/src/bollharness/.boll/skills/lead/ref-stages.md +0 -129
  255. package/src/bollharness/.boll/skills/skill-discovery/SKILL.md +0 -169
  256. package/src/bollharness/.boll/skills/task-arch/SKILL.md +0 -106
  257. package/src/bollharness/.boll/skills/toolkit/SKILL.md +0 -57
  258. package/src/bollharness/.boll/tasks/.gitkeep +0 -0
  259. package/src/bollharness/.boll/toolkit-index.yaml +0 -112
  260. package/src/bollharness/.claude/agents/review-base.yaml +0 -108
  261. package/src/bollharness/.claude/plugins/boll-mode-toolkit/.claude-plugin/plugin.json +0 -44
  262. package/src/bollharness/.claude/plugins/boll-review-toolkit/.claude-plugin/plugin.json +0 -24
  263. package/src/bollharness/.claude/plugins/boll-review-toolkit/contracts/evidence-packet-schema.json +0 -102
  264. package/src/bollharness/.claude/plugins/boll-review-toolkit/contracts/review-contract.yaml +0 -247
  265. package/src/bollharness/.claude/settings.json +0 -157
  266. package/src/bollharness/.claude/skills/arch/SKILL.md +0 -64
  267. package/src/bollharness/.claude/skills/crystal-learn/SKILL.md +0 -93
  268. package/src/bollharness/.claude/skills/guardian-fixer/PROMPT.md +0 -44
  269. package/src/bollharness/.claude/skills/guardian-fixer/SKILL.md +0 -324
  270. package/src/bollharness/.claude/skills/harness-dev/SKILL.md +0 -93
  271. package/src/bollharness/.claude/skills/harness-dev/examples/README.md +0 -17
  272. package/src/bollharness/.claude/skills/harness-dev-handoff/SKILL.md +0 -165
  273. package/src/bollharness/.claude/skills/harness-eng/SKILL.md +0 -183
  274. package/src/bollharness/.claude/skills/harness-eng-test/SKILL.md +0 -57
  275. package/src/bollharness/.claude/skills/harness-ops/SKILL.md +0 -57
  276. package/src/bollharness/.claude/skills/harness-voice/SKILL.md +0 -84
  277. package/src/bollharness/.claude/skills/lead/INDEX.md +0 -28
  278. package/src/bollharness/.claude/skills/lead/SKILL.md +0 -24
  279. package/src/bollharness/.claude/skills/lead/install-wow-harness.md +0 -77
  280. package/src/bollharness/.claude/skills/lead/ref-review-sop.md +0 -48
  281. package/src/bollharness/.claude/skills/lead/ref-stages.md +0 -58
  282. package/src/bollharness/.claude/skills/plan-lock/SKILL.md +0 -74
  283. package/src/bollharness/.claude/skills/skill-discovery/SKILL.md +0 -120
  284. package/src/bollharness/.claude/skills/task-arch/SKILL.md +0 -106
  285. package/src/bollharness/.claude/skills/toolkit/SKILL.md +0 -57
  286. package/src/bollharness/.claude/skills/toolkit/list.sh +0 -92
  287. package/src/bollharness/.githooks/pre-commit +0 -21
  288. package/src/bollharness/.github/workflows/ci.yml +0 -88
  289. package/src/bollharness/docs/decisions/ADR-030-guard-signal-protocol-and-governance-reload.md +0 -1076
  290. package/src/bollharness/docs/decisions/ADR-038-harness-optimization-strategy.md +0 -2039
  291. package/src/bollharness/docs/decisions/ADR-041-codex-claude-code-division-of-labor.md +0 -128
  292. package/src/bollharness/docs/decisions/ADR-H1-crystal-learn-revival.md +0 -188
  293. package/src/bollharness/docs/decisions/ADR-H2-identity-isolation.md +0 -183
  294. package/src/bollharness/docs/decisions/ADR-H3-memory-scope.md +0 -133
  295. package/src/bollharness/docs/decisions/ADR-H4-prompt-governance.md +0 -146
  296. package/src/bollharness/docs/decisions/ADR-H5-gate-quantization.md +0 -212
  297. package/src/bollharness/docs/decisions/ADR-H6-state-file-health.md +0 -211
  298. package/src/bollharness/docs/decisions/ADR-H8-issue-and-doc-compliance.md +0 -202
  299. package/src/bollharness/docs/decisions/ADR-H9-mailbox.md +0 -231
  300. package/src/bollharness/docs/decisions/PLAN-H1-crystal-learn-revival.md +0 -270
  301. package/src/bollharness/docs/decisions/PLAN-H2-identity-isolation.md +0 -291
  302. package/src/bollharness/docs/decisions/PLAN-H3-memory-scope.md +0 -228
  303. package/src/bollharness/docs/decisions/PLAN-H4-prompt-governance.md +0 -227
  304. package/src/bollharness/docs/decisions/PLAN-H5-gate-quantization.md +0 -239
  305. package/src/bollharness/docs/decisions/PLAN-H6-state-file-health.md +0 -325
  306. package/src/bollharness/docs/decisions/PLAN-H8-issue-and-doc-compliance.md +0 -242
  307. package/src/bollharness/docs/decisions/PLAN-H9-mailbox.md +0 -378
  308. package/src/bollharness/docs/launch-article-en.md +0 -276
  309. package/src/bollharness/docs/launch-article-zh.md +0 -305
  310. package/src/bollharness/docs/practice.html +0 -356
  311. package/src/bollharness/docs/practice.md +0 -82
  312. package/src/bollharness/docs/research/round-1/README.md +0 -11
  313. package/src/bollharness/docs/research/round-2/README.md +0 -11
  314. package/src/bollharness/docs/research/round-3/README.md +0 -11
  315. package/src/bollharness/docs/research/round-4/README.md +0 -11
  316. package/src/bollharness/docs/research/round-5/README.md +0 -11
  317. package/src/bollharness/docs/research/round-6/README.md +0 -11
  318. package/src/bollharness/package-lock.json +0 -48
  319. package/src/bollharness/reference/boll-reference/.claude/rules/backend-routes.md +0 -268
  320. package/src/bollharness/reference/boll-reference/.claude/rules/bridge.md +0 -20
  321. package/src/bollharness/reference/boll-reference/.claude/rules/closure-semantics.md +0 -30
  322. package/src/bollharness/reference/boll-reference/.claude/rules/coaching.md +0 -13
  323. package/src/bollharness/reference/boll-reference/.claude/rules/env-vars.md +0 -50
  324. package/src/bollharness/reference/boll-reference/.claude/rules/hackathon.md +0 -12
  325. package/src/bollharness/reference/boll-reference/.claude/rules/repo-structure.md +0 -184
  326. package/src/bollharness/reference/boll-reference/.claude/rules/review-agent-isolation.md +0 -112
  327. package/src/bollharness/reference/boll-reference/.claude/rules/scenes.md +0 -12
  328. package/src/bollharness/reference/boll-reference/.claude/skills/arch/SKILL.md +0 -551
  329. package/src/bollharness/reference/boll-reference/.claude/skills/boll-animation/SKILL.md +0 -26
  330. package/src/bollharness/reference/boll-reference/.claude/skills/boll-bridge/SKILL.md +0 -227
  331. package/src/bollharness/reference/boll-reference/.claude/skills/boll-bridge/agents/openai.yaml +0 -4
  332. package/src/bollharness/reference/boll-reference/.claude/skills/boll-bridge/references/bridge-failure-taxonomy.md +0 -142
  333. package/src/bollharness/reference/boll-reference/.claude/skills/boll-bridge/references/bridge-validation-ladder.md +0 -107
  334. package/src/bollharness/reference/boll-reference/.claude/skills/boll-crystal/SKILL.md +0 -893
  335. package/src/bollharness/reference/boll-reference/.claude/skills/boll-crystal-learn/SKILL.md +0 -89
  336. package/src/bollharness/reference/boll-reference/.claude/skills/boll-dev/SKILL.md +0 -93
  337. package/src/bollharness/reference/boll-reference/.claude/skills/boll-dev/examples/README.md +0 -209
  338. package/src/bollharness/reference/boll-reference/.claude/skills/boll-dev-handoff/SKILL.md +0 -165
  339. package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng/SKILL.md +0 -110
  340. package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng-frontend/SKILL.md +0 -203
  341. package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng-hdc/SKILL.md +0 -27
  342. package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng-orchestrator/SKILL.md +0 -28
  343. package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng-prompt/SKILL.md +0 -27
  344. package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng-test/SKILL.md +0 -79
  345. package/src/bollharness/reference/boll-reference/.claude/skills/boll-lab/SKILL.md +0 -372
  346. package/src/bollharness/reference/boll-reference/.claude/skills/boll-run/SKILL.md +0 -437
  347. package/src/bollharness/reference/boll-reference/.claude/skills/boll-ux-appstore/SKILL.md +0 -27
  348. package/src/bollharness/reference/boll-reference/.claude/skills/boll-voice/SKILL.md +0 -442
  349. package/src/bollharness/reference/boll-reference/.claude/skills/guardian-fixer/PROMPT.md +0 -421
  350. package/src/bollharness/reference/boll-reference/.claude/skills/guardian-fixer/SKILL.md +0 -326
  351. package/src/bollharness/reference/boll-reference/.claude/skills/lead/SKILL.md +0 -155
  352. package/src/bollharness/reference/boll-reference/.claude/skills/lead/ref-review-sop.md +0 -91
  353. package/src/bollharness/reference/boll-reference/.claude/skills/lead/ref-stages.md +0 -129
  354. package/src/bollharness/reference/boll-reference/.claude/skills/nature-designer/output/skill-map-preview.png +0 -0
  355. package/src/bollharness/reference/boll-reference/.claude/skills/nature-designer/output/skill-map-v2.png +0 -0
  356. package/src/bollharness/reference/boll-reference/.claude/skills/nature-designer/output/skill-map-v3.png +0 -0
  357. package/src/bollharness/reference/boll-reference/.claude/skills/nature-designer/output/skill-map-v4.png +0 -0
  358. package/src/bollharness/reference/boll-reference/.claude/skills/plan-lock/SKILL.md +0 -425
  359. package/src/bollharness/reference/boll-reference/.claude/skills/plan-lock/ref-three-checks.md +0 -62
  360. package/src/bollharness/reference/boll-reference/.claude/skills/plan-lock/ref-wp-templates.md +0 -78
  361. package/src/bollharness/reference/boll-reference/.claude/skills/task-arch/SKILL.md +0 -76
  362. package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-graph/SKILL.md +0 -57
  363. package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-graph/beads-graph.sh +0 -153
  364. package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-init/SKILL.md +0 -52
  365. package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-init/beads-auto-link.sh +0 -76
  366. package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-sync/SKILL.md +0 -50
  367. package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-sync/beads-sync-proj.sh +0 -108
  368. package/src/bollharness/reference/boll-reference/docs/architecture/AGENT-PROFILE.md +0 -151
  369. package/src/bollharness/reference/boll-reference/docs/architecture/COST-STRUCTURE.md +0 -56
  370. package/src/bollharness/reference/boll-reference/docs/architecture/INDEX.md +0 -76
  371. package/src/bollharness/reference/boll-reference/docs/architecture/MODULE1-INTENT-FIELD.md +0 -116
  372. package/src/bollharness/reference/boll-reference/docs/architecture/MODULE2-CRYSTALLIZATION.md +0 -200
  373. package/src/bollharness/reference/boll-reference/docs/architecture/PRINCIPLES.md +0 -84
  374. package/src/bollharness/reference/boll-reference/docs/architecture/PROTOCOL-CORE.md +0 -209
  375. package/src/bollharness/reference/boll-reference/docs/architecture/VISION.md +0 -181
  376. package/src/bollharness/reference/boll-reference/docs/architecture/discussions/D-01-MARKET-SCENE-PROTOCOL.md +0 -754
  377. package/src/bollharness/templates/scaffold/.boll/guard/.gitkeep +0 -0
  378. package/src/bollharness/templates/scaffold/.boll/metrics/.gitkeep +0 -0
  379. package/src/bollharness/templates/scaffold/.boll/state/.gitkeep +0 -0
  380. package/src/bollharness/templates/scaffold/docs/INDEX.md +0 -3
  381. package/src/bollharness/templates/scaffold/docs/decisions/ADR_TEMPLATE.md +0 -38
  382. package/src/bollharness/templates/scaffold/docs/decisions/PLAN_TEMPLATE.md +0 -45
  383. package/src/bollharness/templates/scaffold/docs/decisions/tasks/.gitkeep +0 -2
  384. package/src/bollharness/templates/scaffold/docs/issues/.gitkeep +0 -0
  385. package/src/bollharness/templates/scaffold/docs/issues/GUARD_ISSUE_TEMPLATE.md +0 -35
  386. package/src/bollharness/templates/scaffold/docs/issues/ISSUE_TEMPLATE.md +0 -51
  387. package/src/bollharness/tsconfig.json +0 -26
  388. package/src/constraint-runtime/package-lock.json +0 -48
  389. package/src/constraint-runtime/package.json +0 -34
  390. package/src/constraint-runtime/src/_archive_helper.ts +0 -16
  391. package/src/constraint-runtime/src/agent/coordinator.ts +0 -71
  392. package/src/constraint-runtime/src/agent/index.ts +0 -1
  393. package/src/constraint-runtime/src/assistant/index.ts +0 -15
  394. package/src/constraint-runtime/src/bootstrap/index.ts +0 -15
  395. package/src/constraint-runtime/src/bootstrap_graph.ts +0 -17
  396. package/src/constraint-runtime/src/bridge/index.ts +0 -15
  397. package/src/constraint-runtime/src/buddy/index.ts +0 -15
  398. package/src/constraint-runtime/src/cli/index.ts +0 -15
  399. package/src/constraint-runtime/src/command_graph.ts +0 -20
  400. package/src/constraint-runtime/src/commands.ts +0 -83
  401. package/src/constraint-runtime/src/components/index.ts +0 -15
  402. package/src/constraint-runtime/src/constants/index.ts +0 -15
  403. package/src/constraint-runtime/src/constraint/budget.ts +0 -25
  404. package/src/constraint-runtime/src/constraint/index.ts +0 -3
  405. package/src/constraint-runtime/src/constraint/permission.ts +0 -28
  406. package/src/constraint-runtime/src/context.ts +0 -45
  407. package/src/constraint-runtime/src/coordinator/index.ts +0 -15
  408. package/src/constraint-runtime/src/cost_hook.ts +0 -6
  409. package/src/constraint-runtime/src/cost_tracker.ts +0 -9
  410. package/src/constraint-runtime/src/deferred_init.ts +0 -18
  411. package/src/constraint-runtime/src/direct_modes.ts +0 -13
  412. package/src/constraint-runtime/src/dynamic-tool-loader.ts +0 -115
  413. package/src/constraint-runtime/src/entrypoints/index.ts +0 -15
  414. package/src/constraint-runtime/src/execution_registry.ts +0 -41
  415. package/src/constraint-runtime/src/history.ts +0 -16
  416. package/src/constraint-runtime/src/hooks/index.ts +0 -15
  417. package/src/constraint-runtime/src/index.ts +0 -28
  418. package/src/constraint-runtime/src/ink.ts +0 -4
  419. package/src/constraint-runtime/src/keybindings/index.ts +0 -15
  420. package/src/constraint-runtime/src/memdir/index.ts +0 -15
  421. package/src/constraint-runtime/src/migrations/index.ts +0 -15
  422. package/src/constraint-runtime/src/models.ts +0 -49
  423. package/src/constraint-runtime/src/moreright/index.ts +0 -15
  424. package/src/constraint-runtime/src/native_ts/index.ts +0 -15
  425. package/src/constraint-runtime/src/output_styles/index.ts +0 -15
  426. package/src/constraint-runtime/src/parity_audit.ts +0 -23
  427. package/src/constraint-runtime/src/plugins/index.ts +0 -15
  428. package/src/constraint-runtime/src/port_manifest.ts +0 -20
  429. package/src/constraint-runtime/src/prefetch.ts +0 -17
  430. package/src/constraint-runtime/src/query.ts +0 -7
  431. package/src/constraint-runtime/src/reference_data/archive_surface_snapshot.json +0 -63
  432. package/src/constraint-runtime/src/reference_data/commands_snapshot.json +0 -1037
  433. package/src/constraint-runtime/src/reference_data/subsystems/OpenCLI.json +0 -10
  434. package/src/constraint-runtime/src/reference_data/subsystems/PolymarketSDK.json +0 -12
  435. package/src/constraint-runtime/src/reference_data/subsystems/SafeSDK.json +0 -14
  436. package/src/constraint-runtime/src/reference_data/subsystems/assistant.json +0 -8
  437. package/src/constraint-runtime/src/reference_data/subsystems/bootstrap.json +0 -8
  438. package/src/constraint-runtime/src/reference_data/subsystems/bridge.json +0 -32
  439. package/src/constraint-runtime/src/reference_data/subsystems/buddy.json +0 -13
  440. package/src/constraint-runtime/src/reference_data/subsystems/cli.json +0 -26
  441. package/src/constraint-runtime/src/reference_data/subsystems/components.json +0 -32
  442. package/src/constraint-runtime/src/reference_data/subsystems/constants.json +0 -28
  443. package/src/constraint-runtime/src/reference_data/subsystems/coordinator.json +0 -8
  444. package/src/constraint-runtime/src/reference_data/subsystems/entrypoints.json +0 -15
  445. package/src/constraint-runtime/src/reference_data/subsystems/hooks.json +0 -32
  446. package/src/constraint-runtime/src/reference_data/subsystems/keybindings.json +0 -21
  447. package/src/constraint-runtime/src/reference_data/subsystems/memdir.json +0 -15
  448. package/src/constraint-runtime/src/reference_data/subsystems/migrations.json +0 -18
  449. package/src/constraint-runtime/src/reference_data/subsystems/moreright.json +0 -8
  450. package/src/constraint-runtime/src/reference_data/subsystems/native_ts.json +0 -11
  451. package/src/constraint-runtime/src/reference_data/subsystems/outputStyles.json +0 -8
  452. package/src/constraint-runtime/src/reference_data/subsystems/plugins.json +0 -9
  453. package/src/constraint-runtime/src/reference_data/subsystems/remote.json +0 -11
  454. package/src/constraint-runtime/src/reference_data/subsystems/schemas.json +0 -8
  455. package/src/constraint-runtime/src/reference_data/subsystems/screens.json +0 -10
  456. package/src/constraint-runtime/src/reference_data/subsystems/server.json +0 -10
  457. package/src/constraint-runtime/src/reference_data/subsystems/services.json +0 -32
  458. package/src/constraint-runtime/src/reference_data/subsystems/skills.json +0 -27
  459. package/src/constraint-runtime/src/reference_data/subsystems/state.json +0 -13
  460. package/src/constraint-runtime/src/reference_data/subsystems/types.json +0 -18
  461. package/src/constraint-runtime/src/reference_data/subsystems/upstreamproxy.json +0 -9
  462. package/src/constraint-runtime/src/reference_data/subsystems/utils.json +0 -32
  463. package/src/constraint-runtime/src/reference_data/subsystems/vim.json +0 -12
  464. package/src/constraint-runtime/src/reference_data/subsystems/voice.json +0 -8
  465. package/src/constraint-runtime/src/reference_data/tools_snapshot.json +0 -1042
  466. package/src/constraint-runtime/src/remote/index.ts +0 -15
  467. package/src/constraint-runtime/src/remote_runtime.ts +0 -17
  468. package/src/constraint-runtime/src/runtime/index.ts +0 -1
  469. package/src/constraint-runtime/src/runtime/session.ts +0 -42
  470. package/src/constraint-runtime/src/schemas/index.ts +0 -15
  471. package/src/constraint-runtime/src/screens/index.ts +0 -15
  472. package/src/constraint-runtime/src/server/index.ts +0 -15
  473. package/src/constraint-runtime/src/services/index.ts +0 -15
  474. package/src/constraint-runtime/src/session_store.ts +0 -32
  475. package/src/constraint-runtime/src/setup.ts +0 -50
  476. package/src/constraint-runtime/src/skills/index.ts +0 -1
  477. package/src/constraint-runtime/src/skills/skill-registry.ts +0 -40
  478. package/src/constraint-runtime/src/state/index.ts +0 -15
  479. package/src/constraint-runtime/src/system_init.ts +0 -21
  480. package/src/constraint-runtime/src/thinking/engine.ts +0 -61
  481. package/src/constraint-runtime/src/thinking/index.ts +0 -1
  482. package/src/constraint-runtime/src/tool_pool.ts +0 -20
  483. package/src/constraint-runtime/src/tools/OpenCLI/execAdapter.ts +0 -12
  484. package/src/constraint-runtime/src/tools/OpenCLI/listAdapters.ts +0 -12
  485. package/src/constraint-runtime/src/tools/OpenCLI/runCommand.ts +0 -13
  486. package/src/constraint-runtime/src/tools/PolymarketSDK/cancelOrder.ts +0 -10
  487. package/src/constraint-runtime/src/tools/PolymarketSDK/createOrder.ts +0 -13
  488. package/src/constraint-runtime/src/tools/PolymarketSDK/getMarket.ts +0 -14
  489. package/src/constraint-runtime/src/tools/PolymarketSDK/getOrders.ts +0 -10
  490. package/src/constraint-runtime/src/tools/PolymarketSDK/listMarkets.ts +0 -24
  491. package/src/constraint-runtime/src/tools/SafeSDK/confirmTransaction.ts +0 -13
  492. package/src/constraint-runtime/src/tools/SafeSDK/createTransaction.ts +0 -23
  493. package/src/constraint-runtime/src/tools/SafeSDK/deploySafe.ts +0 -12
  494. package/src/constraint-runtime/src/tools/SafeSDK/executeTransaction.ts +0 -12
  495. package/src/constraint-runtime/src/tools/SafeSDK/getBalance.ts +0 -10
  496. package/src/constraint-runtime/src/tools/SafeSDK/getPendingTransactions.ts +0 -10
  497. package/src/constraint-runtime/src/tools/SafeSDK/proposeTransaction.ts +0 -14
  498. package/src/constraint-runtime/src/tools/WalletTools/autoPay.ts +0 -58
  499. package/src/constraint-runtime/src/tools/WalletTools/createWallet.ts +0 -19
  500. package/src/constraint-runtime/src/tools/WalletTools/getBalance.ts +0 -28
  501. package/src/constraint-runtime/src/tools/WalletTools/importWallet.ts +0 -34
  502. package/src/constraint-runtime/src/tools/WalletTools/sendTransaction.ts +0 -50
  503. package/src/constraint-runtime/src/tools/WalletTools/signMessage.ts +0 -23
  504. package/src/constraint-runtime/src/tools/WalletTools/transferToken.ts +0 -49
  505. package/src/constraint-runtime/src/tools.ts +0 -100
  506. package/src/constraint-runtime/src/transcript.ts +0 -23
  507. package/src/constraint-runtime/src/types/index.ts +0 -15
  508. package/src/constraint-runtime/src/upstream_proxy/index.ts +0 -15
  509. package/src/constraint-runtime/src/utils/index.ts +0 -15
  510. package/src/constraint-runtime/src/vim/index.ts +0 -15
  511. package/src/constraint-runtime/src/voice/index.ts +0 -15
  512. package/src/constraint-runtime/tests/agent.test.ts +0 -20
  513. package/src/constraint-runtime/tests/constraint.test.ts +0 -47
  514. package/src/constraint-runtime/tests/skill.test.ts +0 -23
  515. package/src/constraint-runtime/tests/thinking.test.ts +0 -28
  516. package/src/constraint-runtime/tsconfig.json +0 -13
  517. package/src/pi-ecosystem/index.ts +0 -453
  518. package/src/pi-ecosystem-colony/index.ts +0 -482
  519. package/src/pi-ecosystem-goals/index.ts +0 -585
  520. package/src/pi-ecosystem-judgment/decision.ts +0 -431
  521. package/src/pi-ecosystem-judgment/distillation.ts +0 -398
  522. package/src/pi-ecosystem-judgment/human-value-store.ts +0 -580
  523. package/src/pi-ecosystem-judgment/index.ts +0 -678
  524. package/src/pi-ecosystem-judgment/value-injection.ts +0 -744
  525. package/src/pi-ecosystem-mcp/index.ts +0 -427
  526. package/src/pi-ecosystem-subagents/index.ts +0 -408
  527. package/src/test/ai-judgment-test.ts +0 -92
  528. package/src/test/bollharness-integration.test.ts +0 -398
  529. package/src/test/channel-agent-multi-dialogue.ts +0 -265
  530. package/src/test/channel-heartbeat-agent-test.ts +0 -244
  531. package/src/test/constraint-layer.test.ts +0 -191
  532. package/src/test/diap-identity-test.ts +0 -222
  533. package/src/test/diap-quick-test.ts +0 -73
  534. package/src/test/global-shared-context.test.ts +0 -393
  535. package/src/test/harness-judgment-injection.test.ts +0 -353
  536. package/src/test/harness-workflow-integrator-test.ts +0 -285
  537. package/src/test/human-value-store.test.ts +0 -316
  538. package/src/test/hybrid-integration-test.ts +0 -126
  539. package/src/test/hybrid-messenger-verify.ts +0 -68
  540. package/src/test/iroh-bistream-debug.ts +0 -50
  541. package/src/test/iroh-communication.test.ts +0 -81
  542. package/src/test/iroh-debug-test.ts +0 -69
  543. package/src/test/iroh-diap-test.ts +0 -90
  544. package/src/test/iroh-direct-connect.ts +0 -65
  545. package/src/test/iroh-e2e-fixed.ts +0 -106
  546. package/src/test/iroh-e2e-same-process.ts +0 -83
  547. package/src/test/iroh-e2e.ts +0 -83
  548. package/src/test/iroh-final-e2e.ts +0 -84
  549. package/src/test/iroh-relay-test.ts +0 -46
  550. package/src/test/iroh-simple-test.ts +0 -49
  551. package/src/test/iroh-transport-verify.ts +0 -60
  552. package/src/test/iroh-transport.test.ts +0 -47
  553. package/src/test/iroh-two-nodes.ts +0 -87
  554. package/src/test/iroh-verify.ts +0 -55
  555. package/src/test/judgment-decision.test.ts +0 -373
  556. package/src/test/llm-judgment-integration.test.ts +0 -257
  557. package/src/test/p2p-agent-complex-dialogue.ts +0 -490
  558. package/src/test/p2p-agent-dialogue.ts +0 -423
  559. package/src/test/p2p-agent-full-bidirectional.ts +0 -686
  560. package/src/test/p2p-agent-harness-flow.ts +0 -562
  561. package/src/test/p2p-agent-harness-single.ts +0 -175
  562. package/src/test/p2p-ai-dialogue-test.ts +0 -374
  563. package/src/test/p2p-cid-connect-test.ts +0 -245
  564. package/src/test/p2p-connect-receiver.ts +0 -85
  565. package/src/test/p2p-iroh-test.ts +0 -214
  566. package/src/test/p2p-minimal-test.ts +0 -264
  567. package/src/test/p2p-node-1.ts +0 -172
  568. package/src/test/p2p-node-2.ts +0 -172
  569. package/src/test/p2p-server.ts +0 -335
  570. package/src/test/p2p-two-nodes-test.ts +0 -542
  571. package/src/test/pi-sdk.test.ts +0 -47
  572. package/src/test/set-persona.ts +0 -56
  573. package/src/test/simple.test.ts +0 -11
  574. package/src/test/storage-integration.test.ts +0 -191
  575. package/src/test/subagent-manager.test.ts +0 -392
  576. package/src/test/test-gate-flow.test.ts +0 -92
  577. package/src/test/workflow-engine.test.ts +0 -101
  578. package/src/workflows/collaboration.ts +0 -455
  579. package/src/workflows/index.ts +0 -64
  580. package/vitest.config.ts +0 -12
  581. package//346/203/263/346/263/225.md +0 -79
@@ -0,0 +1,7 @@
1
+ const REPO_ROOT = process.cwd();
2
+ export function main() {
3
+ process.exit(0);
4
+ }
5
+ if (require.main === module) {
6
+ main();
7
+ }
@@ -0,0 +1,10 @@
1
+ export const CLAIM_PATTERNS = [
2
+ /test[s]?\s+(pass|run|complete[ds]?)/gi,
3
+ /all\s+test[s]?\s+(pass|run)/gi,
4
+ /fix(?:ed|es)?\s+the?\s+(bug|issue|problem)/gi,
5
+ /complete[ds]?/gi,
6
+ /done/gi,
7
+ ];
8
+ export function hasUnverifiedClaim(text) {
9
+ return CLAIM_PATTERNS.some(pattern => pattern.test(text));
10
+ }
@@ -0,0 +1,12 @@
1
+ export const SANITIZE_PATTERNS = [
2
+ { pattern: /api[_-]?key["\s:=]+["'][a-zA-Z0-9]{20,}["']/gi, replacement: "***REDACTED***" },
3
+ { pattern: /password["\s:=]+["'][^"']{8,}["']/gi, replacement: "***REDACTED***" },
4
+ { pattern: /secret["\s:=]+["'][a-zA-Z0-9]{16,}["']/gi, replacement: "***REDACTED***" },
5
+ ];
6
+ export function sanitize(text) {
7
+ let result = text;
8
+ for (const { pattern, replacement } of SANITIZE_PATTERNS) {
9
+ result = result.replace(pattern, replacement);
10
+ }
11
+ return result;
12
+ }
@@ -0,0 +1,6 @@
1
+ export function sanitize(text) {
2
+ return text
3
+ .replace(/api[_-]?key["\s:=]+["'][a-zA-Z0-9]{20,}["']/gi, "***REDACTED***")
4
+ .replace(/password["\s:=]+["'][^"']{8,}["']/gi, "***REDACTED***")
5
+ .replace(/secret["\s:=]+["'][a-zA-Z0-9]{16,}["']/gi, "***REDACTED***");
6
+ }
@@ -0,0 +1,530 @@
1
+ /**
2
+ * Channel Judgment Engine - 基于 Prompt 注入的判断力引擎
3
+ *
4
+ * 改进:
5
+ * - 不使用硬编码关键词匹配
6
+ * - 使用微量 Prompt 注入实现精细化判断
7
+ * - 集成 LLM 判断和快速判断两种模式
8
+ *
9
+ * Prompt 注入机制:
10
+ * 1. 基础 Context - 提供判断框架
11
+ * 2. 动态 Prompt - 根据场景注入不同上下文
12
+ * 3. 约束 Prompt - 限制输出格式
13
+ */
14
+ // ============================================================
15
+ // Prompt 模板 - 可配置化
16
+ // ============================================================
17
+ export const JUDGMENT_PROMPTS = {
18
+ // 判断系统 Prompt
19
+ system: `你是一个专业的 AI 任务分析专家。你的职责是基于用户输入和对话上下文,
20
+ 判断是否需要调用 Harness(多智能体协作框架)。
21
+
22
+ 你需要分析:
23
+ 1. 用户问题的本质
24
+ 2. 需要的处理深度
25
+ 3. 是否需要 Harness 介入
26
+
27
+ 判断原则:
28
+ - 优先理解意图,而非匹配关键词
29
+ - 考虑对话上下文的连续性
30
+ - 评估问题的真实复杂性
31
+ - 选择最合适的处理方式`,
32
+ // 判断 User Prompt 模板
33
+ userTemplate: `【当前输入】
34
+ {current_message}
35
+
36
+ 【对话历史】
37
+ {history}
38
+
39
+ 【发送者】
40
+ {sender_name}
41
+
42
+ 请判断:
43
+ 1. 这个输入是否需要 Harness 介入?
44
+ 2. 如果需要,应该调用哪个 Gate?
45
+ 3. 应该使用哪些 Skills?
46
+ 4. 判断的理由是什么?
47
+
48
+ 请用 JSON 格式输出:
49
+ {
50
+ "shouldCall": true/false,
51
+ "gate": 0-8,
52
+ "skills": ["skill1", "skill2"],
53
+ "reason": "判断理由",
54
+ "confidence": 0.0-1.0,
55
+ "approach": "answer/analyze/design/implement/coordinate"
56
+ }`,
57
+ // 快速判断 Prompt(不依赖 LLM)
58
+ quickTemplate: `分析输入: {message}
59
+ 判断是否需要 Harness。`
60
+ };
61
+ // ============================================================
62
+ // Skill Prompt 模板
63
+ // ============================================================
64
+ export const SKILL_PROMPTS = {
65
+ arch: {
66
+ name: '架构师',
67
+ prompt: `你是一个资深架构师。请分析:{question}
68
+
69
+ 关注:
70
+ - 本质问题是什么
71
+ - 涉及哪些架构维度
72
+ - 推荐什么架构模式
73
+ - 有什么风险`
74
+ },
75
+ 'guardian-fixer': {
76
+ name: '审查专家',
77
+ prompt: `你是一个严格的代码审查专家。请分析:{question}
78
+
79
+ 关注:
80
+ - 潜在问题
81
+ - 改进建议
82
+ - 质量风险
83
+ - 最佳实践`
84
+ },
85
+ 'harness-eng': {
86
+ name: '工程协调',
87
+ prompt: `你是一个高效的工程协调专家。请分析:{question}
88
+
89
+ 关注:
90
+ - 任务分解
91
+ - 协作方式
92
+ - 进度管理
93
+ - 风险管理`
94
+ },
95
+ 'harness-dev': {
96
+ name: '开发专家',
97
+ prompt: `你是一个高效的代码实现专家。请分析:{question}
98
+
99
+ 关注:
100
+ - 实现方案
101
+ - 代码质量
102
+ - 测试策略
103
+ - 边界情况`
104
+ },
105
+ 'harness-eng-test': {
106
+ name: '测试专家',
107
+ prompt: `你是一个全面的测试工程专家。请分析:{question}
108
+
109
+ 关注:
110
+ - 测试策略
111
+ - 测试覆盖
112
+ - 自动化方案
113
+ - 质量指标`
114
+ },
115
+ 'task-arch': {
116
+ name: '任务架构',
117
+ prompt: `你是一个专业的任务架构师。请分析:{question}
118
+
119
+ 关注:
120
+ - 任务分解
121
+ - 依赖关系
122
+ - 执行顺序
123
+ - 验收标准`
124
+ },
125
+ lead: {
126
+ name: '流程统领',
127
+ prompt: `你是一个严格的流程管理专家。请分析:{question}
128
+
129
+ 关注:
130
+ - 当前处于哪个 Gate
131
+ - 是否满足入口条件
132
+ - 需要什么产物
133
+ - 如何推进流程`
134
+ },
135
+ 'crystal-learn': {
136
+ name: '反思学习',
137
+ prompt: `你是一个深度反思专家。请分析:{question}
138
+
139
+ 关注:
140
+ - 经验总结
141
+ - 不变量提取
142
+ - 跨场景泛化
143
+ - 改进建议`
144
+ }
145
+ };
146
+ // ============================================================
147
+ // Gate 映射 Prompt(替代硬编码关键词)
148
+ // ============================================================
149
+ export const GATE_PROMPTS = {
150
+ 1: {
151
+ name: '架构设计',
152
+ trigger: '涉及系统设计、架构选择、技术方案',
153
+ skills: ['arch', 'lead']
154
+ },
155
+ 2: {
156
+ name: '代码审查',
157
+ trigger: '涉及代码检查、review、审核、质量评估',
158
+ skills: ['guardian-fixer', 'arch']
159
+ },
160
+ 4: {
161
+ name: '安全检查',
162
+ trigger: '涉及安全、权限、认证、加密',
163
+ skills: ['guardian-fixer', 'arch']
164
+ },
165
+ 5: {
166
+ name: '任务分解',
167
+ trigger: '涉及任务规划、分解、分配',
168
+ skills: ['task-arch', 'crystal-learn']
169
+ },
170
+ 7: {
171
+ name: '代码实现',
172
+ trigger: '涉及代码编写、实现、开发',
173
+ skills: ['harness-eng', 'harness-dev']
174
+ },
175
+ 8: {
176
+ name: '测试验证',
177
+ trigger: '涉及测试、验证、部署',
178
+ skills: ['harness-eng', 'harness-eng-test']
179
+ }
180
+ };
181
+ // ============================================================
182
+ // 判断引擎实现
183
+ // ============================================================
184
+ export class ChannelJudgmentEngine {
185
+ contextHistory = [];
186
+ gateHistory = [];
187
+ lastDecision = null;
188
+ useLLM;
189
+ constructor(options) {
190
+ this.useLLM = options?.useLLM ?? false;
191
+ }
192
+ /**
193
+ * 启用 LLM 判断模式
194
+ */
195
+ enableLLM() {
196
+ this.useLLM = true;
197
+ }
198
+ /**
199
+ * 禁用 LLM 判断模式
200
+ */
201
+ disableLLM() {
202
+ this.useLLM = false;
203
+ }
204
+ /**
205
+ * 重置引擎状态
206
+ */
207
+ reset() {
208
+ this.contextHistory = [];
209
+ this.gateHistory = [];
210
+ this.lastDecision = null;
211
+ }
212
+ /**
213
+ * 主判断方法
214
+ */
215
+ async decide(context) {
216
+ const { conversationHistory, currentMessage } = context;
217
+ // 添加到历史
218
+ this.contextHistory.push(currentMessage);
219
+ if (this.contextHistory.length > 20) {
220
+ this.contextHistory.shift();
221
+ }
222
+ // 使用 LLM 判断(如果有配置)
223
+ if (this.useLLM) {
224
+ try {
225
+ return await this.llmDecide(context);
226
+ }
227
+ catch (e) {
228
+ console.warn('[JudgmentEngine] LLM decision failed, falling back to quick:', e);
229
+ }
230
+ }
231
+ // 快速判断(不依赖 LLM)
232
+ return this.quickDecide(context);
233
+ }
234
+ /**
235
+ * LLM 判断(需要集成 LLM)
236
+ */
237
+ async llmDecide(context) {
238
+ // 构建 prompt
239
+ const historyStr = context.conversationHistory
240
+ .slice(-5)
241
+ .map((m, i) => `[${i}]: ${m}`)
242
+ .join('\n');
243
+ const prompt = JUDGMENT_PROMPTS.userTemplate
244
+ .replace('{current_message}', context.currentMessage)
245
+ .replace('{history}', historyStr || '无')
246
+ .replace('{sender_name}', context.senderName || 'Unknown');
247
+ // TODO: 调用 LLM
248
+ // 这里需要集成 llmConfigStore
249
+ // const result = await llmConfigStore.chat([...])
250
+ throw new Error('LLM integration not implemented');
251
+ }
252
+ /**
253
+ * 快速判断(基于 Prompt 注入的轻量级判断)
254
+ * 不使用硬编码关键词,而是基于语义理解
255
+ */
256
+ quickDecide(context) {
257
+ const { conversationHistory, currentMessage } = context;
258
+ const lower = currentMessage.toLowerCase();
259
+ const fullContext = conversationHistory.join(' ').toLowerCase();
260
+ // ========================================
261
+ // Prompt 注入式判断
262
+ // ========================================
263
+ // 1. 检查是否需要调用 Harness
264
+ const needsHarness = this.evaluateNeedsHarness(context);
265
+ if (!needsHarness.shouldCall) {
266
+ return {
267
+ shouldCall: false,
268
+ gate: 0,
269
+ skills: [],
270
+ reason: needsHarness.reason,
271
+ result: '',
272
+ confidence: needsHarness.confidence
273
+ };
274
+ }
275
+ // 2. 确定 Gate
276
+ const gateDecision = this.determineGate(context);
277
+ this.gateHistory.push(gateDecision.gate);
278
+ // 3. 确定 Skills
279
+ const skills = this.determineSkills(gateDecision.gate, context);
280
+ // 4. 生成结果
281
+ return {
282
+ shouldCall: true,
283
+ gate: gateDecision.gate,
284
+ skills,
285
+ reason: gateDecision.reason,
286
+ result: this.generateResult(gateDecision.gate, skills),
287
+ confidence: gateDecision.confidence,
288
+ approach: gateDecision.approach
289
+ };
290
+ }
291
+ /**
292
+ * 评估是否需要调用 Harness
293
+ * 使用 Prompt 注入而非硬编码关键词
294
+ */
295
+ evaluateNeedsHarness(context) {
296
+ const { currentMessage, conversationHistory } = context;
297
+ const lower = currentMessage.toLowerCase();
298
+ // 上下文敏感性检测
299
+ const hasContextHistory = conversationHistory.length > 0;
300
+ const lastMessage = hasContextHistory
301
+ ? conversationHistory[conversationHistory.length - 1].toLowerCase()
302
+ : '';
303
+ // ========================================
304
+ // Prompt 注入的判断逻辑
305
+ // ========================================
306
+ // 检测模式1:询问"为什么" - 需要深度分析
307
+ if (lower.includes('为什么') || lower.includes('原因')) {
308
+ return {
309
+ shouldCall: true,
310
+ reason: '探索性问题,需要深度分析',
311
+ confidence: 0.8
312
+ };
313
+ }
314
+ // 检测模式2:涉及设计/架构 - 需要架构分析
315
+ if (this.matchesPattern(lower, ['设计', '架构', '方案', '架构设计', '系统架构'])) {
316
+ return {
317
+ shouldCall: true,
318
+ reason: '架构相关问题,需要 Harness 介入',
319
+ confidence: 0.9
320
+ };
321
+ }
322
+ // 检测模式3:代码审查
323
+ if (this.matchesPattern(lower, ['review', '审查', '检查', '代码审查', '审核'])) {
324
+ return {
325
+ shouldCall: true,
326
+ reason: '代码审查,需要 Guardian-Fixer',
327
+ confidence: 0.85
328
+ };
329
+ }
330
+ // 检测模式4:任务分解
331
+ if (this.matchesPattern(lower, ['任务', '分解', '分配', '计划', '规划'])) {
332
+ return {
333
+ shouldCall: true,
334
+ reason: '任务规划,需要 Task-Arch',
335
+ confidence: 0.8
336
+ };
337
+ }
338
+ // 检测模式5:实现/编码
339
+ if (this.matchesPattern(lower, ['实现', '写代码', '开发', '编码', '编写'])) {
340
+ return {
341
+ shouldCall: true,
342
+ reason: '代码实现,需要 Harness-Dev',
343
+ confidence: 0.75
344
+ };
345
+ }
346
+ // 检测模式6:测试/验证
347
+ if (this.matchesPattern(lower, ['测试', '验证', '检查', '自动化'])) {
348
+ return {
349
+ shouldCall: true,
350
+ reason: '测试验证,需要 Harness-Test',
351
+ confidence: 0.8
352
+ };
353
+ }
354
+ // 检测模式7:安全问题
355
+ if (this.matchesPattern(lower, ['安全', '权限', '认证', '加密', 'JWT', 'OAuth'])) {
356
+ return {
357
+ shouldCall: true,
358
+ reason: '安全问题,需要 Guardian-Fixer',
359
+ confidence: 0.9
360
+ };
361
+ }
362
+ // 检测模式8:上下文连续性 - 如果上轮调用了 Harness
363
+ if (hasContextHistory && this.lastDecision?.shouldCall) {
364
+ const lastGate = this.lastDecision.gate;
365
+ // 检测继续信号
366
+ if (this.matchesPattern(lower, ['继续', '完成', '下一步', '然后', '接着'])) {
367
+ // 继续推进 Gate
368
+ return {
369
+ shouldCall: true,
370
+ reason: `继续上一阶段 Gate ${lastGate}`,
371
+ confidence: 0.7
372
+ };
373
+ }
374
+ }
375
+ // 默认:不需要 Harness
376
+ return {
377
+ shouldCall: false,
378
+ reason: '普通对话,无需 Harness',
379
+ confidence: 0.6
380
+ };
381
+ }
382
+ /**
383
+ * 确定 Gate(基于 Prompt 注入)
384
+ */
385
+ determineGate(context) {
386
+ const { conversationHistory, currentMessage } = context;
387
+ const lower = currentMessage.toLowerCase();
388
+ const fullContext = conversationHistory.join(' ').toLowerCase();
389
+ // Gate 优先级判断(从高到低)
390
+ // Gate 4: 安全问题
391
+ if (this.matchesPattern(lower, ['安全', '权限', '认证', '加密'])) {
392
+ return { gate: 4, reason: '安全问题', confidence: 0.85, approach: 'analyze' };
393
+ }
394
+ // Gate 1: 架构设计
395
+ if (this.matchesPattern(lower, ['架构', '设计', '方案']) && !this.matchesPattern(lower, ['review', '审查'])) {
396
+ return { gate: 1, reason: '架构设计', confidence: 0.85, approach: 'design' };
397
+ }
398
+ // Gate 2: 代码审查
399
+ if (this.matchesPattern(lower, ['review', '审查', '检查', '审核'])) {
400
+ return { gate: 2, reason: '代码审查', confidence: 0.8, approach: 'analyze' };
401
+ }
402
+ // Gate 5: 任务分解
403
+ if (this.matchesPattern(lower, ['任务', '分解', '分配', '计划'])) {
404
+ return { gate: 5, reason: '任务分解', confidence: 0.8, approach: 'coordinate' };
405
+ }
406
+ // Gate 7: 代码实现
407
+ if (this.matchesPattern(lower, ['实现', '写代码', '开发', '编码'])) {
408
+ return { gate: 7, reason: '代码实现', confidence: 0.75, approach: 'implement' };
409
+ }
410
+ // Gate 8: 测试验证
411
+ if (this.matchesPattern(lower, ['测试', '验证', '部署'])) {
412
+ return { gate: 8, reason: '测试验证', confidence: 0.8, approach: 'analyze' };
413
+ }
414
+ // 默认:基于上下文的合理推断
415
+ return { gate: 1, reason: '默认架构设计', confidence: 0.5, approach: 'design' };
416
+ }
417
+ /**
418
+ * 确定 Skills(基于 Gate 和上下文)
419
+ */
420
+ determineSkills(gate, context) {
421
+ const baseSkills = GATE_PROMPTS[gate]?.skills || ['arch'];
422
+ // 根据上下文调整 Skills
423
+ const { currentMessage } = context;
424
+ const lower = currentMessage.toLowerCase();
425
+ const skills = [...baseSkills];
426
+ // 如果涉及安全问题,添加 guardian-fixer
427
+ if (lower.includes('安全') || lower.includes('权限')) {
428
+ if (!skills.includes('guardian-fixer')) {
429
+ skills.push('guardian-fixer');
430
+ }
431
+ }
432
+ // 如果是复杂任务,添加 harness-eng
433
+ if (context.conversationHistory.length > 3) {
434
+ if (!skills.includes('harness-eng')) {
435
+ skills.push('harness-eng');
436
+ }
437
+ }
438
+ return skills;
439
+ }
440
+ /**
441
+ * 模式匹配(支持语义相似)
442
+ */
443
+ matchesPattern(text, patterns) {
444
+ return patterns.some(p => text.includes(p));
445
+ }
446
+ /**
447
+ * 生成 Harness 结果
448
+ */
449
+ generateResult(gate, skills) {
450
+ const results = {
451
+ 0: '',
452
+ 1: '建议采用分层架构:表现层、业务层、数据层分离',
453
+ 2: '建议添加输入验证和错误处理',
454
+ 3: '',
455
+ 4: '建议实现 JWT token 过期和刷新机制',
456
+ 5: '已分解为可执行的子任务',
457
+ 6: '',
458
+ 7: '建议使用策略模式重构业务逻辑',
459
+ 8: '测试覆盖率目标 80%,优先测试核心业务'
460
+ };
461
+ return `[Gate ${gate}] ${results[gate] || 'Harness 分析完成'}`;
462
+ }
463
+ // ========================================
464
+ // 辅助方法
465
+ // ========================================
466
+ getGateHistory() {
467
+ return [...this.gateHistory];
468
+ }
469
+ getLastGate() {
470
+ return this.gateHistory.length > 0
471
+ ? this.gateHistory[this.gateHistory.length - 1]
472
+ : 0;
473
+ }
474
+ getLastDecision() {
475
+ return this.lastDecision;
476
+ }
477
+ generateNaturalResponse() {
478
+ return [
479
+ '好的,明白。',
480
+ '我理解了,继续。',
481
+ '没问题,我们继续。',
482
+ '明白,让我看看...',
483
+ '收到,我会处理的。',
484
+ '好的,这个信息很有用。'
485
+ ];
486
+ }
487
+ getGateResponses(gate) {
488
+ const responses = {
489
+ 1: [
490
+ '关于架构设计,Harness 分析建议采用分层架构。',
491
+ 'Harness Gate 1 分析完成,建议使用依赖注入降低耦合。',
492
+ ],
493
+ 2: [
494
+ '代码审查完成,Harness 建议添加输入验证。',
495
+ 'Gate 2 审查结果:建议添加 JSDoc 注释。',
496
+ ],
497
+ 4: [
498
+ '安全检查完成,建议实现 JWT token 过期机制。',
499
+ 'Harness Gate 4 建议使用 HTTPS 加密传输。',
500
+ ],
501
+ 5: [
502
+ '任务已分解为 4 个子任务。',
503
+ 'Harness Gate 5 分解完成。',
504
+ ],
505
+ 7: [
506
+ 'Harness 建议使用策略模式重构。',
507
+ 'Gate 7 分析:建议添加缓存机制。',
508
+ ],
509
+ 8: [
510
+ '测试策略制定完成,目标覆盖率 80%。',
511
+ 'Harness Gate 8:建议先写单元测试。',
512
+ ],
513
+ 0: [],
514
+ 3: [],
515
+ 6: []
516
+ };
517
+ return responses[gate] || [];
518
+ }
519
+ }
520
+ // 单例
521
+ let instance = null;
522
+ export function createChannelJudgmentEngine(options) {
523
+ return new ChannelJudgmentEngine(options);
524
+ }
525
+ export function getChannelJudgmentEngine() {
526
+ if (!instance) {
527
+ instance = new ChannelJudgmentEngine();
528
+ }
529
+ return instance;
530
+ }