@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.
- package/bin/bolloon-cli.cjs +157 -0
- package/bin/bolloon-daemon.sh +207 -0
- package/bin/bolloon.cmd +11 -0
- package/dist/agents/constraint-layer.js +10 -15
- package/dist/agents/pi-sdk.js +433 -106
- package/dist/agents/protocol.js +82 -1
- package/dist/agents/subagent-manager.js +2 -2
- package/dist/agents/workflow-engine.js +15 -20
- package/dist/agents/workflow-pivot-loop.js +541 -0
- package/dist/bollharness/src/index.js +5 -0
- package/dist/bollharness/src/scripts/checks/check_adr_plan_numbering.js +6 -0
- package/dist/bollharness/src/scripts/checks/check_api_types.js +45 -0
- package/dist/bollharness/src/scripts/checks/check_artifact_link.js +146 -0
- package/dist/bollharness/src/scripts/checks/check_bridge_deps.js +6 -0
- package/dist/bollharness/src/scripts/checks/check_bugfix_binding.js +6 -0
- package/dist/bollharness/src/scripts/checks/check_bugfix_binding_ci.js +6 -0
- package/dist/bollharness/src/scripts/checks/check_doc_file_references.js +6 -0
- package/dist/bollharness/src/scripts/checks/check_doc_freshness.js +135 -0
- package/dist/bollharness/src/scripts/checks/check_doc_links.js +31 -0
- package/dist/bollharness/src/scripts/checks/check_file_existence_claims.js +6 -0
- package/dist/bollharness/src/scripts/checks/check_fragment_integrity.js +34 -0
- package/dist/bollharness/src/scripts/checks/check_hook_installed.js +63 -0
- package/dist/bollharness/src/scripts/checks/check_issue_closure.js +41 -0
- package/dist/bollharness/src/scripts/checks/check_mcp_parity.js +6 -0
- package/dist/bollharness/src/scripts/checks/check_security.js +48 -0
- package/dist/bollharness/src/scripts/checks/check_skill_parity.js +6 -0
- package/dist/bollharness/src/scripts/checks/check_versions.js +6 -0
- package/dist/bollharness/src/scripts/checks/finding.js +13 -0
- package/dist/bollharness/src/scripts/checks/next_decision_number.js +20 -0
- package/dist/bollharness/src/scripts/checks/regenerate_magic_docs.js +6 -0
- package/dist/bollharness/src/scripts/ci/detect_rebaseline_triggers.js +8 -0
- package/dist/bollharness/src/scripts/ci/scan_subprocess_cfg.js +8 -0
- package/dist/bollharness/src/scripts/ci/scan_verify_artifacts.js +8 -0
- package/dist/bollharness/src/scripts/ci/scan_yaml_schema.js +8 -0
- package/dist/bollharness/src/scripts/context_router.js +67 -0
- package/dist/bollharness/src/scripts/deploy-guard.js +157 -0
- package/dist/bollharness/src/scripts/guard-feedback.js +192 -0
- package/dist/bollharness/src/scripts/guard_router.js +158 -0
- package/dist/bollharness/src/scripts/hooks/_hook_output.js +6 -0
- package/dist/bollharness/src/scripts/hooks/auto-python3.js +6 -0
- package/dist/bollharness/src/scripts/hooks/deploy-progress-on-session-end.js +6 -0
- package/dist/bollharness/src/scripts/hooks/failure-analyzer.js +6 -0
- package/dist/bollharness/src/scripts/hooks/gate-judgment-inject.js +92 -0
- package/dist/bollharness/src/scripts/hooks/gate-transition-judgment.js +63 -0
- package/dist/bollharness/src/scripts/hooks/inbox-ack.js +6 -0
- package/dist/bollharness/src/scripts/hooks/inbox-inject-on-start.js +6 -0
- package/dist/bollharness/src/scripts/hooks/inbox-validate.js +6 -0
- package/dist/bollharness/src/scripts/hooks/inbox-write-ledger.js +6 -0
- package/dist/bollharness/src/scripts/hooks/initializer-agent.js +6 -0
- package/dist/bollharness/src/scripts/hooks/loop-detection.js +73 -0
- package/dist/bollharness/src/scripts/hooks/owner-guard.js +6 -0
- package/dist/bollharness/src/scripts/hooks/precompact.js +6 -0
- package/dist/bollharness/src/scripts/hooks/review-agent-gatekeeper.js +6 -0
- package/dist/bollharness/src/scripts/hooks/risk-tracker.js +108 -0
- package/dist/bollharness/src/scripts/hooks/sanitize-on-read.js +6 -0
- package/dist/bollharness/src/scripts/hooks/session-reflection.js +7 -0
- package/dist/bollharness/src/scripts/hooks/session-start-magic-docs.js +7 -0
- package/dist/bollharness/src/scripts/hooks/session-start-reset-risk.js +7 -0
- package/dist/bollharness/src/scripts/hooks/session-start-toolkit-reminder.js +7 -0
- package/dist/bollharness/src/scripts/hooks/stop-evaluator.js +157 -0
- package/dist/bollharness/src/scripts/hooks/tool-call-counter.js +6 -0
- package/dist/bollharness/src/scripts/hooks/trace-analyzer.js +10 -0
- package/dist/bollharness/src/scripts/install/install-trust-token.js +7 -0
- package/dist/bollharness/src/scripts/install/multi_project_registry.js +9 -0
- package/dist/bollharness/src/scripts/install/phase2_auto.js +21 -0
- package/dist/bollharness/src/scripts/install/pre_commit_installer.js +6 -0
- package/dist/bollharness/src/scripts/install/tier_selector.js +7 -0
- package/dist/bollharness/src/scripts/install/transcript_miner.js +7 -0
- package/dist/bollharness/src/scripts/lib/claim_patterns.js +10 -0
- package/dist/bollharness/src/scripts/lib/sanitize_patterns.js +12 -0
- package/dist/bollharness/src/scripts/sanitize.js +6 -0
- package/dist/bollharness-integration/channel-judgment-engine.js +530 -0
- package/dist/bollharness-integration/context-chain-router.js +383 -0
- package/dist/bollharness-integration/context-router-judgment.js +13 -21
- package/dist/bollharness-integration/context-router.js +22 -64
- package/dist/bollharness-integration/gate-state-machine.js +14 -19
- package/dist/bollharness-integration/gate-transition-hooks.js +16 -61
- package/dist/bollharness-integration/guard-checker.js +21 -68
- package/dist/bollharness-integration/index.js +14 -124
- package/dist/bollharness-integration/integration.js +13 -20
- package/dist/bollharness-integration/llm-judgment-engine.js +569 -0
- package/dist/bollharness-integration/skill-adapter.js +18 -64
- package/dist/cli-entry.js +261 -0
- package/dist/constraint-runtime/src/commands.js +17 -7
- package/dist/constraint-runtime/src/constraint/budget.js +1 -6
- package/dist/constraint-runtime/src/constraint/permission.js +1 -6
- package/dist/constraint-runtime/src/models.js +1 -3
- package/dist/constraint-runtime/src/tools.js +17 -7
- package/dist/constraints/index.js +1 -7
- package/dist/documents/reader.js +8 -49
- package/dist/heartbeat/DaemonManager.js +242 -0
- package/dist/heartbeat/HealthMonitor.js +285 -0
- package/dist/heartbeat/StartupVerifier.js +205 -0
- package/dist/heartbeat/Watchdog.js +168 -0
- package/dist/heartbeat/index.js +84 -0
- package/dist/heartbeat/types.js +5 -0
- package/dist/index.js +381 -28
- package/dist/llm/config-store.js +31 -57
- package/dist/llm/llm-judgment-client.js +389 -0
- package/dist/llm/pi-ai.js +9 -52
- package/dist/network/agent-network.js +46 -90
- package/dist/network/hybrid-messenger.js +125 -0
- package/dist/network/iroh-bootstrap.js +38 -0
- package/dist/network/iroh-discovery.js +145 -0
- package/dist/network/iroh-integration.js +9 -16
- package/dist/network/iroh-transport.js +10 -48
- package/dist/network/p2p.js +23 -62
- package/dist/network/storage/adapters/json-adapter.js +4 -42
- package/dist/network/storage/index.js +147 -0
- package/dist/network/storage/types.js +14 -0
- package/dist/pi-ecosystem/index.js +233 -0
- package/dist/pi-ecosystem-colony/index.js +29 -90
- package/dist/pi-ecosystem-goals/index.js +20 -74
- package/dist/pi-ecosystem-judgment/decision.js +29 -47
- package/dist/pi-ecosystem-judgment/distillation.js +16 -29
- package/dist/pi-ecosystem-judgment/human-value-store.js +13 -60
- package/dist/pi-ecosystem-judgment/index.js +21 -74
- package/dist/pi-ecosystem-judgment/value-injection.js +26 -72
- package/dist/pi-ecosystem-mcp/index.js +24 -78
- package/dist/pi-ecosystem-subagents/index.js +20 -69
- package/dist/social/ant-colony/AdaptiveHeartbeat.js +3 -8
- package/dist/social/ant-colony/PheromoneEngine.js +11 -49
- package/dist/social/ant-colony/index.js +6 -0
- package/dist/social/ant-colony/types.js +4 -8
- package/dist/social/channels/ChannelManager.js +8 -46
- package/dist/social/channels/DiapChannelBridge.js +9 -47
- package/dist/social/channels/InterestMatcher.js +2 -7
- package/dist/social/channels/channel-agent-session.js +309 -0
- package/dist/social/channels/channel-heartbeat-agent.js +494 -0
- package/dist/social/channels/diap-doc-parser.js +204 -0
- package/dist/social/channels/harness-workflow-integrator.js +446 -0
- package/dist/social/channels/index.js +9 -0
- package/dist/social/channels/types.js +3 -7
- package/dist/social/global-shared-context.js +6 -47
- package/dist/social/heartbeat.js +29 -72
- package/dist/social/persona/enhanced-persona.js +299 -0
- package/dist/web/client.js +302 -136
- package/dist/web/components/p2p/index.js +159 -9
- package/dist/web/components/p2p/p2p-connection.js +136 -0
- package/dist/web/components/p2p/p2p-manager.js +24 -0
- package/dist/web/components/p2p/p2p-store-memory.js +1 -1
- package/dist/web/components/p2p/types.js +7 -0
- package/dist/web/index.html +5 -0
- package/dist/web/style.css +118 -0
- package/package.json +12 -6
- package/scripts/build-cli.js +206 -0
- package/scripts/postinstall.js +153 -0
- package/src/agents/pi-sdk.ts +347 -28
- package/src/agents/protocol.ts +95 -1
- package/src/agents/workflow-pivot-loop.ts +674 -0
- package/src/bollharness/scripts/context-fragments/pi-agent-operations.md +34 -0
- package/src/cli-entry.ts +304 -0
- package/src/heartbeat/DaemonManager.ts +283 -0
- package/src/heartbeat/HealthMonitor.ts +316 -0
- package/src/heartbeat/StartupVerifier.ts +223 -0
- package/src/heartbeat/Watchdog.ts +198 -0
- package/src/heartbeat/index.ts +108 -0
- package/src/heartbeat/types.ts +82 -0
- package/src/llm/config-store.ts +23 -5
- package/src/network/iroh-transport.ts +3 -3
- package/src/web/client.js +302 -136
- package/src/web/components/p2p/P2PModal.tsx +91 -3
- package/src/web/components/p2p/index.ts +171 -9
- package/src/web/components/p2p/p2p-connection.ts +153 -1
- package/src/web/components/p2p/p2p-manager.ts +39 -1
- package/src/web/components/p2p/p2p-store-memory.ts +1 -1
- package/src/web/components/p2p/p2p-tools.ts +315 -0
- package/src/web/components/p2p/types.ts +58 -0
- package/src/web/index.html +5 -0
- package/src/web/server.ts +353 -36
- package/src/web/style.css +118 -0
- package/tsconfig.cli.json +16 -0
- package/tsconfig.electron.json +1 -1
- package/tsconfig.json +1 -2
- package/dist/constraint-runtime/tests/agent.test.js +0 -16
- package/dist/constraint-runtime/tests/constraint.test.js +0 -41
- package/dist/constraint-runtime/tests/skill.test.js +0 -19
- package/dist/constraint-runtime/tests/thinking.test.js +0 -22
- package/dist/electron-preload.js +0 -15
- package/dist/electron-preload.js.map +0 -1
- package/dist/electron.js +0 -206
- package/dist/electron.js.map +0 -1
- package/dist/test/constraint-layer.test.js +0 -164
- package/dist/test/global-shared-context.test.js +0 -315
- package/dist/test/pi-sdk.test.js +0 -47
- package/dist/test/set-persona.test.js +0 -38
- package/dist/test/subagent-manager.test.js +0 -276
- package/dist/test/workflow-engine.test.js +0 -87
- package/dist/web/server.js +0 -1647
- package/dist/web/server.js.map +0 -1
- package/dist/workflows/collaboration.js +0 -374
- package/dist/workflows/index.js +0 -54
- package/docs/agent-communication.md +0 -333
- package/docs/plans/2026-05-15-document-agent-design.md +0 -479
- package/docs/plans/2026-05-15-document-agent-implementation-plan.md +0 -792
- package/docs/plans/2026-05-16-chat-ui-design.md +0 -86
- package/docs/plans/2026-05-16-constraint-runtime-design.md +0 -106
- package/docs/plans/2026-05-16-constraint-runtime-implementation.md +0 -441
- 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
- package/src/bollharness/.boll/CLAUDE.md.template +0 -34
- package/src/bollharness/.boll/MANIFEST.yaml +0 -213
- package/src/bollharness/.boll/active-review-agents/.gitkeep +0 -0
- package/src/bollharness/.boll/agents/review-base.yaml +0 -108
- package/src/bollharness/.boll/deploy-allowlist.yaml +0 -38
- package/src/bollharness/.boll/inbox/schema/message-v1.json +0 -99
- package/src/bollharness/.boll/install-staging/.gitkeep +0 -0
- package/src/bollharness/.boll/issue-adapter.yaml +0 -31
- package/src/bollharness/.boll/plugins/boll-mode-toolkit/contracts/mode-contract.md +0 -85
- package/src/bollharness/.boll/plugins/boll-review-toolkit/contracts/evidence-packet-schema.json +0 -102
- package/src/bollharness/.boll/plugins/boll-review-toolkit/contracts/review-contract.yaml +0 -247
- package/src/bollharness/.boll/rules/backend-routes.md +0 -31
- package/src/bollharness/.boll/rules/closure-semantics.md +0 -30
- package/src/bollharness/.boll/rules/env-vars.md +0 -32
- package/src/bollharness/.boll/rules/hanis-protocol.md +0 -145
- package/src/bollharness/.boll/rules/repo-structure.md +0 -42
- package/src/bollharness/.boll/rules/review-agent-isolation.md +0 -73
- package/src/bollharness/.boll/rules/source-of-truth.md +0 -33
- package/src/bollharness/.boll/settings.json +0 -180
- package/src/bollharness/.boll/settings.json.template +0 -31
- package/src/bollharness/.boll/skills/arch/SKILL.md +0 -372
- package/src/bollharness/.boll/skills/bug-pipeline/SKILL.md +0 -168
- package/src/bollharness/.boll/skills/bug-triage/SKILL.md +0 -161
- package/src/bollharness/.boll/skills/context-chains/SKILL.md +0 -250
- package/src/bollharness/.boll/skills/context-chains/context-chain-index.md +0 -48
- package/src/bollharness/.boll/skills/context-chains/work-type-extractors/code_change_extractor.ts +0 -142
- package/src/bollharness/.boll/skills/context-chains/work-type-extractors/debugging_extractor.ts +0 -126
- package/src/bollharness/.boll/skills/context-chains/work-type-extractors/design_extractor.ts +0 -148
- package/src/bollharness/.boll/skills/context-chains/work-type-extractors/planning_extractor.ts +0 -162
- package/src/bollharness/.boll/skills/context-chains/work-type-extractors/question_extractor.ts +0 -116
- package/src/bollharness/.boll/skills/context-chains/work-type-extractors/review_extractor.ts +0 -136
- package/src/bollharness/.boll/skills/crystal-learn/SKILL.md +0 -93
- package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-0.md +0 -34
- package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-1.md +0 -34
- package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-2.md +0 -35
- package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-3.md +0 -34
- package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-4.md +0 -43
- package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-5.md +0 -34
- package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-6.md +0 -37
- package/src/bollharness/.boll/skills/crystal-learn/invariants/INV-7.md +0 -46
- package/src/bollharness/.boll/skills/guardian-fixer/PROMPT.md +0 -415
- package/src/bollharness/.boll/skills/guardian-fixer/SKILL.md +0 -320
- package/src/bollharness/.boll/skills/harness-dev/SKILL.md +0 -93
- package/src/bollharness/.boll/skills/harness-dev/examples/README.md +0 -227
- package/src/bollharness/.boll/skills/harness-dev-handoff/SKILL.md +0 -165
- package/src/bollharness/.boll/skills/harness-eng/SKILL.md +0 -110
- package/src/bollharness/.boll/skills/harness-eng-test/SKILL.md +0 -79
- package/src/bollharness/.boll/skills/harness-lab/SKILL.md +0 -170
- package/src/bollharness/.boll/skills/harness-ops/SKILL.md +0 -57
- package/src/bollharness/.boll/skills/harness-voice/SKILL.md +0 -183
- package/src/bollharness/.boll/skills/judgment/SKILL.md +0 -115
- package/src/bollharness/.boll/skills/lead/SKILL.md +0 -245
- package/src/bollharness/.boll/skills/lead/install-wow-harness.md +0 -77
- package/src/bollharness/.boll/skills/lead/ref-review-sop.md +0 -91
- package/src/bollharness/.boll/skills/lead/ref-stages.md +0 -129
- package/src/bollharness/.boll/skills/skill-discovery/SKILL.md +0 -169
- package/src/bollharness/.boll/skills/task-arch/SKILL.md +0 -106
- package/src/bollharness/.boll/skills/toolkit/SKILL.md +0 -57
- package/src/bollharness/.boll/tasks/.gitkeep +0 -0
- package/src/bollharness/.boll/toolkit-index.yaml +0 -112
- package/src/bollharness/.claude/agents/review-base.yaml +0 -108
- package/src/bollharness/.claude/plugins/boll-mode-toolkit/.claude-plugin/plugin.json +0 -44
- package/src/bollharness/.claude/plugins/boll-review-toolkit/.claude-plugin/plugin.json +0 -24
- package/src/bollharness/.claude/plugins/boll-review-toolkit/contracts/evidence-packet-schema.json +0 -102
- package/src/bollharness/.claude/plugins/boll-review-toolkit/contracts/review-contract.yaml +0 -247
- package/src/bollharness/.claude/settings.json +0 -157
- package/src/bollharness/.claude/skills/arch/SKILL.md +0 -64
- package/src/bollharness/.claude/skills/crystal-learn/SKILL.md +0 -93
- package/src/bollharness/.claude/skills/guardian-fixer/PROMPT.md +0 -44
- package/src/bollharness/.claude/skills/guardian-fixer/SKILL.md +0 -324
- package/src/bollharness/.claude/skills/harness-dev/SKILL.md +0 -93
- package/src/bollharness/.claude/skills/harness-dev/examples/README.md +0 -17
- package/src/bollharness/.claude/skills/harness-dev-handoff/SKILL.md +0 -165
- package/src/bollharness/.claude/skills/harness-eng/SKILL.md +0 -183
- package/src/bollharness/.claude/skills/harness-eng-test/SKILL.md +0 -57
- package/src/bollharness/.claude/skills/harness-ops/SKILL.md +0 -57
- package/src/bollharness/.claude/skills/harness-voice/SKILL.md +0 -84
- package/src/bollharness/.claude/skills/lead/INDEX.md +0 -28
- package/src/bollharness/.claude/skills/lead/SKILL.md +0 -24
- package/src/bollharness/.claude/skills/lead/install-wow-harness.md +0 -77
- package/src/bollharness/.claude/skills/lead/ref-review-sop.md +0 -48
- package/src/bollharness/.claude/skills/lead/ref-stages.md +0 -58
- package/src/bollharness/.claude/skills/plan-lock/SKILL.md +0 -74
- package/src/bollharness/.claude/skills/skill-discovery/SKILL.md +0 -120
- package/src/bollharness/.claude/skills/task-arch/SKILL.md +0 -106
- package/src/bollharness/.claude/skills/toolkit/SKILL.md +0 -57
- package/src/bollharness/.claude/skills/toolkit/list.sh +0 -92
- package/src/bollharness/.githooks/pre-commit +0 -21
- package/src/bollharness/.github/workflows/ci.yml +0 -88
- package/src/bollharness/docs/decisions/ADR-030-guard-signal-protocol-and-governance-reload.md +0 -1076
- package/src/bollharness/docs/decisions/ADR-038-harness-optimization-strategy.md +0 -2039
- package/src/bollharness/docs/decisions/ADR-041-codex-claude-code-division-of-labor.md +0 -128
- package/src/bollharness/docs/decisions/ADR-H1-crystal-learn-revival.md +0 -188
- package/src/bollharness/docs/decisions/ADR-H2-identity-isolation.md +0 -183
- package/src/bollharness/docs/decisions/ADR-H3-memory-scope.md +0 -133
- package/src/bollharness/docs/decisions/ADR-H4-prompt-governance.md +0 -146
- package/src/bollharness/docs/decisions/ADR-H5-gate-quantization.md +0 -212
- package/src/bollharness/docs/decisions/ADR-H6-state-file-health.md +0 -211
- package/src/bollharness/docs/decisions/ADR-H8-issue-and-doc-compliance.md +0 -202
- package/src/bollharness/docs/decisions/ADR-H9-mailbox.md +0 -231
- package/src/bollharness/docs/decisions/PLAN-H1-crystal-learn-revival.md +0 -270
- package/src/bollharness/docs/decisions/PLAN-H2-identity-isolation.md +0 -291
- package/src/bollharness/docs/decisions/PLAN-H3-memory-scope.md +0 -228
- package/src/bollharness/docs/decisions/PLAN-H4-prompt-governance.md +0 -227
- package/src/bollharness/docs/decisions/PLAN-H5-gate-quantization.md +0 -239
- package/src/bollharness/docs/decisions/PLAN-H6-state-file-health.md +0 -325
- package/src/bollharness/docs/decisions/PLAN-H8-issue-and-doc-compliance.md +0 -242
- package/src/bollharness/docs/decisions/PLAN-H9-mailbox.md +0 -378
- package/src/bollharness/docs/launch-article-en.md +0 -276
- package/src/bollharness/docs/launch-article-zh.md +0 -305
- package/src/bollharness/docs/practice.html +0 -356
- package/src/bollharness/docs/practice.md +0 -82
- package/src/bollharness/docs/research/round-1/README.md +0 -11
- package/src/bollharness/docs/research/round-2/README.md +0 -11
- package/src/bollharness/docs/research/round-3/README.md +0 -11
- package/src/bollharness/docs/research/round-4/README.md +0 -11
- package/src/bollharness/docs/research/round-5/README.md +0 -11
- package/src/bollharness/docs/research/round-6/README.md +0 -11
- package/src/bollharness/package-lock.json +0 -48
- package/src/bollharness/reference/boll-reference/.claude/rules/backend-routes.md +0 -268
- package/src/bollharness/reference/boll-reference/.claude/rules/bridge.md +0 -20
- package/src/bollharness/reference/boll-reference/.claude/rules/closure-semantics.md +0 -30
- package/src/bollharness/reference/boll-reference/.claude/rules/coaching.md +0 -13
- package/src/bollharness/reference/boll-reference/.claude/rules/env-vars.md +0 -50
- package/src/bollharness/reference/boll-reference/.claude/rules/hackathon.md +0 -12
- package/src/bollharness/reference/boll-reference/.claude/rules/repo-structure.md +0 -184
- package/src/bollharness/reference/boll-reference/.claude/rules/review-agent-isolation.md +0 -112
- package/src/bollharness/reference/boll-reference/.claude/rules/scenes.md +0 -12
- package/src/bollharness/reference/boll-reference/.claude/skills/arch/SKILL.md +0 -551
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-animation/SKILL.md +0 -26
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-bridge/SKILL.md +0 -227
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-bridge/agents/openai.yaml +0 -4
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-bridge/references/bridge-failure-taxonomy.md +0 -142
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-bridge/references/bridge-validation-ladder.md +0 -107
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-crystal/SKILL.md +0 -893
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-crystal-learn/SKILL.md +0 -89
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-dev/SKILL.md +0 -93
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-dev/examples/README.md +0 -209
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-dev-handoff/SKILL.md +0 -165
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng/SKILL.md +0 -110
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng-frontend/SKILL.md +0 -203
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng-hdc/SKILL.md +0 -27
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng-orchestrator/SKILL.md +0 -28
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng-prompt/SKILL.md +0 -27
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-eng-test/SKILL.md +0 -79
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-lab/SKILL.md +0 -372
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-run/SKILL.md +0 -437
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-ux-appstore/SKILL.md +0 -27
- package/src/bollharness/reference/boll-reference/.claude/skills/boll-voice/SKILL.md +0 -442
- package/src/bollharness/reference/boll-reference/.claude/skills/guardian-fixer/PROMPT.md +0 -421
- package/src/bollharness/reference/boll-reference/.claude/skills/guardian-fixer/SKILL.md +0 -326
- package/src/bollharness/reference/boll-reference/.claude/skills/lead/SKILL.md +0 -155
- package/src/bollharness/reference/boll-reference/.claude/skills/lead/ref-review-sop.md +0 -91
- package/src/bollharness/reference/boll-reference/.claude/skills/lead/ref-stages.md +0 -129
- package/src/bollharness/reference/boll-reference/.claude/skills/nature-designer/output/skill-map-preview.png +0 -0
- package/src/bollharness/reference/boll-reference/.claude/skills/nature-designer/output/skill-map-v2.png +0 -0
- package/src/bollharness/reference/boll-reference/.claude/skills/nature-designer/output/skill-map-v3.png +0 -0
- package/src/bollharness/reference/boll-reference/.claude/skills/nature-designer/output/skill-map-v4.png +0 -0
- package/src/bollharness/reference/boll-reference/.claude/skills/plan-lock/SKILL.md +0 -425
- package/src/bollharness/reference/boll-reference/.claude/skills/plan-lock/ref-three-checks.md +0 -62
- package/src/bollharness/reference/boll-reference/.claude/skills/plan-lock/ref-wp-templates.md +0 -78
- package/src/bollharness/reference/boll-reference/.claude/skills/task-arch/SKILL.md +0 -76
- package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-graph/SKILL.md +0 -57
- package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-graph/beads-graph.sh +0 -153
- package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-init/SKILL.md +0 -52
- package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-init/beads-auto-link.sh +0 -76
- package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-sync/SKILL.md +0 -50
- package/src/bollharness/reference/boll-reference/.claude/skills/vibedevteam-sync/beads-sync-proj.sh +0 -108
- package/src/bollharness/reference/boll-reference/docs/architecture/AGENT-PROFILE.md +0 -151
- package/src/bollharness/reference/boll-reference/docs/architecture/COST-STRUCTURE.md +0 -56
- package/src/bollharness/reference/boll-reference/docs/architecture/INDEX.md +0 -76
- package/src/bollharness/reference/boll-reference/docs/architecture/MODULE1-INTENT-FIELD.md +0 -116
- package/src/bollharness/reference/boll-reference/docs/architecture/MODULE2-CRYSTALLIZATION.md +0 -200
- package/src/bollharness/reference/boll-reference/docs/architecture/PRINCIPLES.md +0 -84
- package/src/bollharness/reference/boll-reference/docs/architecture/PROTOCOL-CORE.md +0 -209
- package/src/bollharness/reference/boll-reference/docs/architecture/VISION.md +0 -181
- package/src/bollharness/reference/boll-reference/docs/architecture/discussions/D-01-MARKET-SCENE-PROTOCOL.md +0 -754
- package/src/bollharness/templates/scaffold/.boll/guard/.gitkeep +0 -0
- package/src/bollharness/templates/scaffold/.boll/metrics/.gitkeep +0 -0
- package/src/bollharness/templates/scaffold/.boll/state/.gitkeep +0 -0
- package/src/bollharness/templates/scaffold/docs/INDEX.md +0 -3
- package/src/bollharness/templates/scaffold/docs/decisions/ADR_TEMPLATE.md +0 -38
- package/src/bollharness/templates/scaffold/docs/decisions/PLAN_TEMPLATE.md +0 -45
- package/src/bollharness/templates/scaffold/docs/decisions/tasks/.gitkeep +0 -2
- package/src/bollharness/templates/scaffold/docs/issues/.gitkeep +0 -0
- package/src/bollharness/templates/scaffold/docs/issues/GUARD_ISSUE_TEMPLATE.md +0 -35
- package/src/bollharness/templates/scaffold/docs/issues/ISSUE_TEMPLATE.md +0 -51
- package/src/bollharness/tsconfig.json +0 -26
- package/src/constraint-runtime/package-lock.json +0 -48
- package/src/constraint-runtime/package.json +0 -34
- package/src/constraint-runtime/src/_archive_helper.ts +0 -16
- package/src/constraint-runtime/src/agent/coordinator.ts +0 -71
- package/src/constraint-runtime/src/agent/index.ts +0 -1
- package/src/constraint-runtime/src/assistant/index.ts +0 -15
- package/src/constraint-runtime/src/bootstrap/index.ts +0 -15
- package/src/constraint-runtime/src/bootstrap_graph.ts +0 -17
- package/src/constraint-runtime/src/bridge/index.ts +0 -15
- package/src/constraint-runtime/src/buddy/index.ts +0 -15
- package/src/constraint-runtime/src/cli/index.ts +0 -15
- package/src/constraint-runtime/src/command_graph.ts +0 -20
- package/src/constraint-runtime/src/commands.ts +0 -83
- package/src/constraint-runtime/src/components/index.ts +0 -15
- package/src/constraint-runtime/src/constants/index.ts +0 -15
- package/src/constraint-runtime/src/constraint/budget.ts +0 -25
- package/src/constraint-runtime/src/constraint/index.ts +0 -3
- package/src/constraint-runtime/src/constraint/permission.ts +0 -28
- package/src/constraint-runtime/src/context.ts +0 -45
- package/src/constraint-runtime/src/coordinator/index.ts +0 -15
- package/src/constraint-runtime/src/cost_hook.ts +0 -6
- package/src/constraint-runtime/src/cost_tracker.ts +0 -9
- package/src/constraint-runtime/src/deferred_init.ts +0 -18
- package/src/constraint-runtime/src/direct_modes.ts +0 -13
- package/src/constraint-runtime/src/dynamic-tool-loader.ts +0 -115
- package/src/constraint-runtime/src/entrypoints/index.ts +0 -15
- package/src/constraint-runtime/src/execution_registry.ts +0 -41
- package/src/constraint-runtime/src/history.ts +0 -16
- package/src/constraint-runtime/src/hooks/index.ts +0 -15
- package/src/constraint-runtime/src/index.ts +0 -28
- package/src/constraint-runtime/src/ink.ts +0 -4
- package/src/constraint-runtime/src/keybindings/index.ts +0 -15
- package/src/constraint-runtime/src/memdir/index.ts +0 -15
- package/src/constraint-runtime/src/migrations/index.ts +0 -15
- package/src/constraint-runtime/src/models.ts +0 -49
- package/src/constraint-runtime/src/moreright/index.ts +0 -15
- package/src/constraint-runtime/src/native_ts/index.ts +0 -15
- package/src/constraint-runtime/src/output_styles/index.ts +0 -15
- package/src/constraint-runtime/src/parity_audit.ts +0 -23
- package/src/constraint-runtime/src/plugins/index.ts +0 -15
- package/src/constraint-runtime/src/port_manifest.ts +0 -20
- package/src/constraint-runtime/src/prefetch.ts +0 -17
- package/src/constraint-runtime/src/query.ts +0 -7
- package/src/constraint-runtime/src/reference_data/archive_surface_snapshot.json +0 -63
- package/src/constraint-runtime/src/reference_data/commands_snapshot.json +0 -1037
- package/src/constraint-runtime/src/reference_data/subsystems/OpenCLI.json +0 -10
- package/src/constraint-runtime/src/reference_data/subsystems/PolymarketSDK.json +0 -12
- package/src/constraint-runtime/src/reference_data/subsystems/SafeSDK.json +0 -14
- package/src/constraint-runtime/src/reference_data/subsystems/assistant.json +0 -8
- package/src/constraint-runtime/src/reference_data/subsystems/bootstrap.json +0 -8
- package/src/constraint-runtime/src/reference_data/subsystems/bridge.json +0 -32
- package/src/constraint-runtime/src/reference_data/subsystems/buddy.json +0 -13
- package/src/constraint-runtime/src/reference_data/subsystems/cli.json +0 -26
- package/src/constraint-runtime/src/reference_data/subsystems/components.json +0 -32
- package/src/constraint-runtime/src/reference_data/subsystems/constants.json +0 -28
- package/src/constraint-runtime/src/reference_data/subsystems/coordinator.json +0 -8
- package/src/constraint-runtime/src/reference_data/subsystems/entrypoints.json +0 -15
- package/src/constraint-runtime/src/reference_data/subsystems/hooks.json +0 -32
- package/src/constraint-runtime/src/reference_data/subsystems/keybindings.json +0 -21
- package/src/constraint-runtime/src/reference_data/subsystems/memdir.json +0 -15
- package/src/constraint-runtime/src/reference_data/subsystems/migrations.json +0 -18
- package/src/constraint-runtime/src/reference_data/subsystems/moreright.json +0 -8
- package/src/constraint-runtime/src/reference_data/subsystems/native_ts.json +0 -11
- package/src/constraint-runtime/src/reference_data/subsystems/outputStyles.json +0 -8
- package/src/constraint-runtime/src/reference_data/subsystems/plugins.json +0 -9
- package/src/constraint-runtime/src/reference_data/subsystems/remote.json +0 -11
- package/src/constraint-runtime/src/reference_data/subsystems/schemas.json +0 -8
- package/src/constraint-runtime/src/reference_data/subsystems/screens.json +0 -10
- package/src/constraint-runtime/src/reference_data/subsystems/server.json +0 -10
- package/src/constraint-runtime/src/reference_data/subsystems/services.json +0 -32
- package/src/constraint-runtime/src/reference_data/subsystems/skills.json +0 -27
- package/src/constraint-runtime/src/reference_data/subsystems/state.json +0 -13
- package/src/constraint-runtime/src/reference_data/subsystems/types.json +0 -18
- package/src/constraint-runtime/src/reference_data/subsystems/upstreamproxy.json +0 -9
- package/src/constraint-runtime/src/reference_data/subsystems/utils.json +0 -32
- package/src/constraint-runtime/src/reference_data/subsystems/vim.json +0 -12
- package/src/constraint-runtime/src/reference_data/subsystems/voice.json +0 -8
- package/src/constraint-runtime/src/reference_data/tools_snapshot.json +0 -1042
- package/src/constraint-runtime/src/remote/index.ts +0 -15
- package/src/constraint-runtime/src/remote_runtime.ts +0 -17
- package/src/constraint-runtime/src/runtime/index.ts +0 -1
- package/src/constraint-runtime/src/runtime/session.ts +0 -42
- package/src/constraint-runtime/src/schemas/index.ts +0 -15
- package/src/constraint-runtime/src/screens/index.ts +0 -15
- package/src/constraint-runtime/src/server/index.ts +0 -15
- package/src/constraint-runtime/src/services/index.ts +0 -15
- package/src/constraint-runtime/src/session_store.ts +0 -32
- package/src/constraint-runtime/src/setup.ts +0 -50
- package/src/constraint-runtime/src/skills/index.ts +0 -1
- package/src/constraint-runtime/src/skills/skill-registry.ts +0 -40
- package/src/constraint-runtime/src/state/index.ts +0 -15
- package/src/constraint-runtime/src/system_init.ts +0 -21
- package/src/constraint-runtime/src/thinking/engine.ts +0 -61
- package/src/constraint-runtime/src/thinking/index.ts +0 -1
- package/src/constraint-runtime/src/tool_pool.ts +0 -20
- package/src/constraint-runtime/src/tools/OpenCLI/execAdapter.ts +0 -12
- package/src/constraint-runtime/src/tools/OpenCLI/listAdapters.ts +0 -12
- package/src/constraint-runtime/src/tools/OpenCLI/runCommand.ts +0 -13
- package/src/constraint-runtime/src/tools/PolymarketSDK/cancelOrder.ts +0 -10
- package/src/constraint-runtime/src/tools/PolymarketSDK/createOrder.ts +0 -13
- package/src/constraint-runtime/src/tools/PolymarketSDK/getMarket.ts +0 -14
- package/src/constraint-runtime/src/tools/PolymarketSDK/getOrders.ts +0 -10
- package/src/constraint-runtime/src/tools/PolymarketSDK/listMarkets.ts +0 -24
- package/src/constraint-runtime/src/tools/SafeSDK/confirmTransaction.ts +0 -13
- package/src/constraint-runtime/src/tools/SafeSDK/createTransaction.ts +0 -23
- package/src/constraint-runtime/src/tools/SafeSDK/deploySafe.ts +0 -12
- package/src/constraint-runtime/src/tools/SafeSDK/executeTransaction.ts +0 -12
- package/src/constraint-runtime/src/tools/SafeSDK/getBalance.ts +0 -10
- package/src/constraint-runtime/src/tools/SafeSDK/getPendingTransactions.ts +0 -10
- package/src/constraint-runtime/src/tools/SafeSDK/proposeTransaction.ts +0 -14
- package/src/constraint-runtime/src/tools/WalletTools/autoPay.ts +0 -58
- package/src/constraint-runtime/src/tools/WalletTools/createWallet.ts +0 -19
- package/src/constraint-runtime/src/tools/WalletTools/getBalance.ts +0 -28
- package/src/constraint-runtime/src/tools/WalletTools/importWallet.ts +0 -34
- package/src/constraint-runtime/src/tools/WalletTools/sendTransaction.ts +0 -50
- package/src/constraint-runtime/src/tools/WalletTools/signMessage.ts +0 -23
- package/src/constraint-runtime/src/tools/WalletTools/transferToken.ts +0 -49
- package/src/constraint-runtime/src/tools.ts +0 -100
- package/src/constraint-runtime/src/transcript.ts +0 -23
- package/src/constraint-runtime/src/types/index.ts +0 -15
- package/src/constraint-runtime/src/upstream_proxy/index.ts +0 -15
- package/src/constraint-runtime/src/utils/index.ts +0 -15
- package/src/constraint-runtime/src/vim/index.ts +0 -15
- package/src/constraint-runtime/src/voice/index.ts +0 -15
- package/src/constraint-runtime/tests/agent.test.ts +0 -20
- package/src/constraint-runtime/tests/constraint.test.ts +0 -47
- package/src/constraint-runtime/tests/skill.test.ts +0 -23
- package/src/constraint-runtime/tests/thinking.test.ts +0 -28
- package/src/constraint-runtime/tsconfig.json +0 -13
- package/src/pi-ecosystem/index.ts +0 -453
- package/src/pi-ecosystem-colony/index.ts +0 -482
- package/src/pi-ecosystem-goals/index.ts +0 -585
- package/src/pi-ecosystem-judgment/decision.ts +0 -431
- package/src/pi-ecosystem-judgment/distillation.ts +0 -398
- package/src/pi-ecosystem-judgment/human-value-store.ts +0 -580
- package/src/pi-ecosystem-judgment/index.ts +0 -678
- package/src/pi-ecosystem-judgment/value-injection.ts +0 -744
- package/src/pi-ecosystem-mcp/index.ts +0 -427
- package/src/pi-ecosystem-subagents/index.ts +0 -408
- package/src/test/ai-judgment-test.ts +0 -92
- package/src/test/bollharness-integration.test.ts +0 -398
- package/src/test/channel-agent-multi-dialogue.ts +0 -265
- package/src/test/channel-heartbeat-agent-test.ts +0 -244
- package/src/test/constraint-layer.test.ts +0 -191
- package/src/test/diap-identity-test.ts +0 -222
- package/src/test/diap-quick-test.ts +0 -73
- package/src/test/global-shared-context.test.ts +0 -393
- package/src/test/harness-judgment-injection.test.ts +0 -353
- package/src/test/harness-workflow-integrator-test.ts +0 -285
- package/src/test/human-value-store.test.ts +0 -316
- package/src/test/hybrid-integration-test.ts +0 -126
- package/src/test/hybrid-messenger-verify.ts +0 -68
- package/src/test/iroh-bistream-debug.ts +0 -50
- package/src/test/iroh-communication.test.ts +0 -81
- package/src/test/iroh-debug-test.ts +0 -69
- package/src/test/iroh-diap-test.ts +0 -90
- package/src/test/iroh-direct-connect.ts +0 -65
- package/src/test/iroh-e2e-fixed.ts +0 -106
- package/src/test/iroh-e2e-same-process.ts +0 -83
- package/src/test/iroh-e2e.ts +0 -83
- package/src/test/iroh-final-e2e.ts +0 -84
- package/src/test/iroh-relay-test.ts +0 -46
- package/src/test/iroh-simple-test.ts +0 -49
- package/src/test/iroh-transport-verify.ts +0 -60
- package/src/test/iroh-transport.test.ts +0 -47
- package/src/test/iroh-two-nodes.ts +0 -87
- package/src/test/iroh-verify.ts +0 -55
- package/src/test/judgment-decision.test.ts +0 -373
- package/src/test/llm-judgment-integration.test.ts +0 -257
- package/src/test/p2p-agent-complex-dialogue.ts +0 -490
- package/src/test/p2p-agent-dialogue.ts +0 -423
- package/src/test/p2p-agent-full-bidirectional.ts +0 -686
- package/src/test/p2p-agent-harness-flow.ts +0 -562
- package/src/test/p2p-agent-harness-single.ts +0 -175
- package/src/test/p2p-ai-dialogue-test.ts +0 -374
- package/src/test/p2p-cid-connect-test.ts +0 -245
- package/src/test/p2p-connect-receiver.ts +0 -85
- package/src/test/p2p-iroh-test.ts +0 -214
- package/src/test/p2p-minimal-test.ts +0 -264
- package/src/test/p2p-node-1.ts +0 -172
- package/src/test/p2p-node-2.ts +0 -172
- package/src/test/p2p-server.ts +0 -335
- package/src/test/p2p-two-nodes-test.ts +0 -542
- package/src/test/pi-sdk.test.ts +0 -47
- package/src/test/set-persona.ts +0 -56
- package/src/test/simple.test.ts +0 -11
- package/src/test/storage-integration.test.ts +0 -191
- package/src/test/subagent-manager.test.ts +0 -392
- package/src/test/test-gate-flow.test.ts +0 -92
- package/src/test/workflow-engine.test.ts +0 -101
- package/src/workflows/collaboration.ts +0 -455
- package/src/workflows/index.ts +0 -64
- package/vitest.config.ts +0 -12
- package//346/203/263/346/263/225.md +0 -79
|
@@ -1,268 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
paths:
|
|
3
|
-
- "backend/product/routes/**"
|
|
4
|
-
- "backend/server.py"
|
|
5
|
-
- "backend/product/protocol/**"
|
|
6
|
-
- "backend/product/auth/**"
|
|
7
|
-
- "backend/product/coaching/**"
|
|
8
|
-
- "backend/product/hackathon/**"
|
|
9
|
-
- "backend/product/bridge/**"
|
|
10
|
-
- "backend/product/a2a/**"
|
|
11
|
-
- "backend/product/matching/**"
|
|
12
|
-
- "backend/product/messaging/**"
|
|
13
|
-
- "backend/product/public_profiles/**"
|
|
14
|
-
- "backend/product/inbox/**"
|
|
15
|
-
- "mcp-server/boll_mcp/**"
|
|
16
|
-
- "mcp-server-node/src/**"
|
|
17
|
-
---
|
|
18
|
-
|
|
19
|
-
# Runtime Routes
|
|
20
|
-
|
|
21
|
-
## Core
|
|
22
|
-
- `GET /health`
|
|
23
|
-
|
|
24
|
-
## Field API (`/field/api`)
|
|
25
|
-
- `GET /field/api/stats`
|
|
26
|
-
- `POST /field/api/deposit` (**admin-only**)
|
|
27
|
-
- `POST /field/api/load-profiles` (**admin-only**)
|
|
28
|
-
- `POST /field/api/match-perspectives` (**admin-only**)
|
|
29
|
-
- `POST /field/api/match`
|
|
30
|
-
- `POST /field/api/match-owners`
|
|
31
|
-
|
|
32
|
-
## Product API (`/api`)
|
|
33
|
-
- `POST /api/register` — invite-code + email registration
|
|
34
|
-
- `POST /api/login` — email + password login
|
|
35
|
-
- `POST /api/logout` — session logout
|
|
36
|
-
- `PUT /api/change-password` — change password (session auth)
|
|
37
|
-
- `GET /api/profile` — get current user profile
|
|
38
|
-
- `PUT /api/profile` — update profile
|
|
39
|
-
- `PATCH /api/profile/visibility` — toggle profile visibility
|
|
40
|
-
- `GET /api/ws-ticket` — WebSocket auth ticket
|
|
41
|
-
- `POST /api/demands` — create demand (clarification-session)
|
|
42
|
-
- `PUT /api/demands/{demand_id}/confirm` — confirm demand
|
|
43
|
-
- `POST /api/demands/{demand_id}/start` — start convergence run
|
|
44
|
-
- `GET /api/demands` — list user demands
|
|
45
|
-
- `GET /api/demands/{demand_id}` — demand detail
|
|
46
|
-
- `GET /api/runs/{run_id}` — run status (+ participant_names)
|
|
47
|
-
- `GET /api/runs/{run_id}/result` — run result (+ participant_names)
|
|
48
|
-
- `WS /ws/runs/{run_id}` — run progress WebSocket
|
|
49
|
-
- `POST /api/admin/invite-codes` (**admin-only**)
|
|
50
|
-
- `POST /api/admin/stream-token` (**admin-only**) — SSE auth token
|
|
51
|
-
- `GET /api/admin/stream` (**admin-only**) — SSE event stream
|
|
52
|
-
- `GET /api/admin/bridges` (**admin-only**) — bridge instance status
|
|
53
|
-
- `GET /api/admin/runs` (**admin-only**) — runs list with filters
|
|
54
|
-
- `GET /api/admin/runs/{run_id}/events` (**admin-only**) — run event log
|
|
55
|
-
- `GET /api/admin/invite-chain` (**admin-only**) — invite tree tracing (PLAN-064)
|
|
56
|
-
- `GET /api/admin/usage/overview` (**admin-only**) — usage analytics overview
|
|
57
|
-
- `GET /api/admin/usage/events` (**admin-only**) — usage event log
|
|
58
|
-
- `GET /api/admin/usage/report` (**admin-only**) — usage report
|
|
59
|
-
- `GET /api/admin/users-overview` (**admin-only**) — all users overview
|
|
60
|
-
- `GET /api/admin/users/{user_id}/sessions` (**admin-only**) — user session history
|
|
61
|
-
- `GET /api/admin/sessions/turns` (**admin-only**) — session turns across users
|
|
62
|
-
- `GET /api/admin/config/status` (**admin-only**) — server config status
|
|
63
|
-
- `GET /api/dashboard` — user dashboard data
|
|
64
|
-
- `GET /api/metrics/platform` — platform-wide metrics
|
|
65
|
-
|
|
66
|
-
## Coaching API (`/api/coaching`)
|
|
67
|
-
- `POST /api/coaching/chat` — create a coaching session and stream first reply
|
|
68
|
-
- `POST /api/coaching/chat/{session_id}` — continue an existing coaching session
|
|
69
|
-
- `POST /api/coaching/report/{session_id}` — stream report generation for a session
|
|
70
|
-
- `GET /api/coaching/sessions` — list coaching sessions for current account
|
|
71
|
-
- `GET /api/coaching/sessions/{session_id}` — get coaching session detail
|
|
72
|
-
- `GET /api/coaching/sessions/{session_id}/report` — fetch persisted coaching report
|
|
73
|
-
- `POST /api/coaching/sync-profile` — sync user coaching profile to protocol layer
|
|
74
|
-
- `PUT /api/coaching/profile` — update user coaching profile
|
|
75
|
-
- `PATCH /api/coaching/sessions/{session_id}/title` — rename a coaching session
|
|
76
|
-
- `DELETE /api/coaching/sessions/{session_id}` — delete a coaching session
|
|
77
|
-
- `GET /api/coaching/profile` — get user coaching profile (profile_fields + coaching_fields + insight_overrides)
|
|
78
|
-
- `POST /api/coaching/profile-chat` — AI profile assistant SSE chat (no session creation)
|
|
79
|
-
- `PATCH /api/coaching/insight-overrides` — confirm/reject/edit AI-extracted insights
|
|
80
|
-
- `GET /api/coaching/operations` — list async operations (find_people/daily_surprise)
|
|
81
|
-
- `POST /api/coaching/behavior` — record share/download/copy behavior metrics
|
|
82
|
-
- `GET /api/coaching/settings/dream-consent` — get dream opt-in status
|
|
83
|
-
- `PUT /api/coaching/settings/dream-consent` — toggle dream opt-in
|
|
84
|
-
- `POST /api/coaching/dream-now` — manually trigger dream consolidation for today
|
|
85
|
-
- `GET /api/coaching/growth-logs` — list growth log entries
|
|
86
|
-
- `PATCH /api/coaching/growth-logs/{log_id}/share` — share growth log to plaza (anonymized)
|
|
87
|
-
- `DELETE /api/coaching/growth-logs/{log_id}/share` — revoke sharing (72h window)
|
|
88
|
-
- `GET /api/coaching/plaza` — **unauthenticated** browse anonymized growth logs (rate-limited: 60/min/IP)
|
|
89
|
-
|
|
90
|
-
## Coaching Admin API (`/api/coaching/admin`, **admin-only**)
|
|
91
|
-
- `GET /api/coaching/admin/users` — list coaching users with session counts
|
|
92
|
-
- `GET /api/coaching/admin/users/{account_id}` — get coaching panorama for one user
|
|
93
|
-
- `GET /api/coaching/admin/users/{account_id}/export` — export one user's coaching data
|
|
94
|
-
- `GET /api/coaching/admin/prompts` — list prompt versions for coaching prompts
|
|
95
|
-
- `PUT /api/coaching/admin/prompts/{prompt_name}` — create and activate a prompt version
|
|
96
|
-
- `POST /api/coaching/admin/prompts/{prompt_name}/preview` — render a prompt template without persisting
|
|
97
|
-
- `GET /api/coaching/admin/export` — export all coaching data
|
|
98
|
-
- `GET /api/coaching/admin/strategy` (**admin-only**) — get coaching strategy config (internal)
|
|
99
|
-
- `PUT /api/coaching/admin/strategy/{config_key}` (**admin-only**) — update coaching strategy config (internal)
|
|
100
|
-
- `GET /api/coaching/admin/operations` (**admin-only**) — list async operations (internal)
|
|
101
|
-
- `POST /api/coaching/admin/operations/{operation_id}/retry` (**admin-only**) — retry failed operation (internal)
|
|
102
|
-
- `GET /api/coaching/admin/scheduler-health` (**admin-only**) — coaching scheduler health (internal)
|
|
103
|
-
|
|
104
|
-
## Hackathon API (`/api/hackathon`, **session auth**)
|
|
105
|
-
- `POST /api/hackathon/events` — create hackathon event (**organizer**)
|
|
106
|
-
- `GET /api/hackathon/events` — list events
|
|
107
|
-
- `GET /api/hackathon/events/{event_id}` — event detail
|
|
108
|
-
- `PUT /api/hackathon/events/{event_id}` — update event (**organizer**)
|
|
109
|
-
- `PATCH /api/hackathon/events/{event_id}/status` — transition event status (**organizer**)
|
|
110
|
-
- `POST /api/hackathon/events/{event_id}/invite` — generate invite codes (**organizer**)
|
|
111
|
-
- `POST /api/hackathon/events/{event_id}/enrollments` — enroll in event
|
|
112
|
-
- `GET /api/hackathon/events/{event_id}/enrollments` — list enrollments
|
|
113
|
-
- `GET /api/hackathon/events/{event_id}/enrollments/mine` — my enrollment
|
|
114
|
-
- `PATCH /api/hackathon/enrollments/{enrollment_id}` — update enrollment role (**organizer**)
|
|
115
|
-
- `POST /api/hackathon/events/{event_id}/teams` — create team
|
|
116
|
-
- `GET /api/hackathon/events/{event_id}/teams` — list teams
|
|
117
|
-
- `GET /api/hackathon/teams/{team_id}` — team detail
|
|
118
|
-
- `POST /api/hackathon/teams/{team_id}/members` — add team member
|
|
119
|
-
- `DELETE /api/hackathon/teams/{team_id}/members/{agent_id}` — remove team member
|
|
120
|
-
- `PATCH /api/hackathon/teams/{team_id}/status` — update team status
|
|
121
|
-
- `POST /api/hackathon/teams/{team_id}/claim` — claim challenge
|
|
122
|
-
- `POST /api/hackathon/events/{event_id}/challenges` — create challenge (**organizer**)
|
|
123
|
-
- `GET /api/hackathon/events/{event_id}/challenges` — list challenges
|
|
124
|
-
- `POST /api/hackathon/teams/{team_id}/submit` — submit deliverables
|
|
125
|
-
- `GET /api/hackathon/events/{event_id}/reviews/assignments` — get review assignments (**judge**)
|
|
126
|
-
- `POST /api/hackathon/reviews` — submit review (**judge**)
|
|
127
|
-
- `GET /api/hackathon/events/{event_id}/reviews/summary` — review summary (**organizer**)
|
|
128
|
-
- `GET /api/hackathon/teams/{team_id}/reviews` — team reviews
|
|
129
|
-
- `POST /api/hackathon/upload/sts-token` — get OSS upload token
|
|
130
|
-
- `GET /api/hackathon/events/{event_id}/stats` — event statistics
|
|
131
|
-
- `POST /api/hackathon/events/{event_id}/import` — bulk import participants (**organizer**)
|
|
132
|
-
- `GET /api/hackathon/events/{event_id}/import/{job_id}` — import job status
|
|
133
|
-
|
|
134
|
-
## Public API (`/api/public`, **unauthenticated**, PLAN-064)
|
|
135
|
-
- `POST /api/public/registration-chat` — SSE streaming registration chat (rate-limited: 10 req/min/IP)
|
|
136
|
-
|
|
137
|
-
## Scene API (`/api/scene` + `/api/auth/secondme`)
|
|
138
|
-
- `GET /api/auth/secondme/url` — SecondMe OAuth URL
|
|
139
|
-
- `GET /api/auth/secondme/callback` — SecondMe OAuth callback (browser redirect)
|
|
140
|
-
- `POST /api/auth/secondme/callback` — SecondMe OAuth callback (JSON API)
|
|
141
|
-
- `POST /api/auth/secondme/register` — SecondMe register
|
|
142
|
-
- `POST /api/auth/secondme/bind` — SecondMe bind to existing account
|
|
143
|
-
- `POST /api/scene/chat` — SSE streaming scene chat
|
|
144
|
-
|
|
145
|
-
## A2A Protocol API (`/a2a` + `/.well-known`)
|
|
146
|
-
- `GET /.well-known/agent-card.json` — A2A agent card matching
|
|
147
|
-
- `GET /a2a/extendedAgentCard` — extended agent card
|
|
148
|
-
- `POST /a2a/message:send` — send A2A message
|
|
149
|
-
- `POST /a2a/message:stream` — stream A2A message
|
|
150
|
-
- `GET /a2a/tasks/{task_id}` — get A2A task
|
|
151
|
-
- `GET /a2a/tasks` — list A2A tasks
|
|
152
|
-
|
|
153
|
-
## Discovery Agent API (`/api/matching`)
|
|
154
|
-
- `GET /api/matching/agents/{agent_id}/recommendations` — list recommendations for agent
|
|
155
|
-
- `POST /api/matching/agents/{agent_id}/feedback` — submit matching feedback
|
|
156
|
-
- `GET /api/matching/agents/{agent_id}/status` — get agent matching status
|
|
157
|
-
|
|
158
|
-
## Plaza API (`/api/plaza`, **unauthenticated**)
|
|
159
|
-
- `GET /api/plaza/profiles` — list community profiles
|
|
160
|
-
- `GET /api/plaza/profiles/{user_id}` — get community profile detail
|
|
161
|
-
- `GET /api/plaza/projects` — list community projects
|
|
162
|
-
- `GET /api/plaza/demands` — list community demands
|
|
163
|
-
|
|
164
|
-
## Public Profiles API (`/api/public-profiles`)
|
|
165
|
-
- `PUT /api/public-profiles/{agent_id}` — update public profile
|
|
166
|
-
- `GET /api/public-profiles` — list public directory
|
|
167
|
-
- `GET /api/public-profiles/lookup` — lookup public profiles
|
|
168
|
-
- `GET /api/public-profiles/{agent_id}` — get public profile
|
|
169
|
-
|
|
170
|
-
## DID API
|
|
171
|
-
- `GET /user/{account_id}/did.json` — account-level DID document
|
|
172
|
-
|
|
173
|
-
## Bridge API (`/api/bridge`, **bridge-key auth**)
|
|
174
|
-
- `GET /api/bridge/pending` — poll pending runs
|
|
175
|
-
- `POST /api/bridge/accept` — accept a run
|
|
176
|
-
- `POST /api/bridge/heartbeat` — heartbeat
|
|
177
|
-
- `POST /api/bridge/events` — push progress events
|
|
178
|
-
- `POST /api/bridge/complete` — complete a run
|
|
179
|
-
|
|
180
|
-
## Protocol API (`/protocol`, **session-token auth**, MCP Server target)
|
|
181
|
-
- `GET /protocol` — protocol metadata + encoding package summary
|
|
182
|
-
- `GET /protocol/encoding-package` — full encoding package
|
|
183
|
-
- `GET /protocol/agents/{agent_id}/federation` — federation metadata
|
|
184
|
-
- `GET /protocol/agents/{agent_id}/did.json` — DID document
|
|
185
|
-
- `POST /protocol/auth/register` — register account + default agent
|
|
186
|
-
- `POST /protocol/auth/login` — login
|
|
187
|
-
- `POST /protocol/auth/consumer-sessions` — create consumer auth session (PLAN-064)
|
|
188
|
-
- `GET /protocol/auth/consumer-sessions/{auth_session_id}` — get consumer session state (PLAN-064)
|
|
189
|
-
- `POST /protocol/auth/consumer-sessions/{auth_session_id}/exchange` — exchange challenge for token (PLAN-064)
|
|
190
|
-
- `POST /protocol/auth/anp/challenge` — ANP DID challenge generation (PLAN-064)
|
|
191
|
-
- `POST /protocol/auth/anp/verify` — ANP DID signature verification (PLAN-064)
|
|
192
|
-
- `POST /protocol/auth/token` — refresh session token
|
|
193
|
-
- `POST /protocol/auth/logout` — logout
|
|
194
|
-
- `POST /protocol/auth/change-password` — change password
|
|
195
|
-
- `POST /protocol/auth/forgot-password` — request password reset (PLAN-064)
|
|
196
|
-
- `POST /protocol/auth/reset-password` — reset password with token (PLAN-064)
|
|
197
|
-
- `DELETE /protocol/auth/account` — delete account (PLAN-064)
|
|
198
|
-
- `POST /protocol/auth/byok-session` — bind BYOK API key (supports Anthropic + compatible providers: minimax; optional `base_url` for relay)
|
|
199
|
-
- `GET /protocol/auth/byok-session` — check BYOK status
|
|
200
|
-
- `DELETE /protocol/auth/byok-session` — clear BYOK binding
|
|
201
|
-
- `POST /protocol/auth/redeem-code` — redeem invite code → +30 quota bonus (PLAN-085 WP-03)
|
|
202
|
-
- `GET /protocol/account` — get current account metadata (PLAN-064)
|
|
203
|
-
- `POST /protocol/account/email/verification` — request email verification (PLAN-064)
|
|
204
|
-
- `GET /protocol/account/email/verify` — email verification callback (PLAN-064)
|
|
205
|
-
- `GET /protocol/inbox` — list inbox items (PLAN-064)
|
|
206
|
-
- `GET /protocol/inbox/{item_id}` — get inbox item detail (PLAN-064)
|
|
207
|
-
- `POST /protocol/inbox/{item_id}/read` — mark inbox item as read (PLAN-064)
|
|
208
|
-
- `POST /protocol/agents` — create agent
|
|
209
|
-
- `GET /protocol/agents` — list agents
|
|
210
|
-
- `GET /protocol/agents/public` — list public agents directory (PLAN-064)
|
|
211
|
-
- `GET /protocol/agents/public/{agent_id}` — get public agent detail (PLAN-064)
|
|
212
|
-
- `GET /protocol/agents/{agent_id}` — get agent detail
|
|
213
|
-
- `GET /protocol/agents/{agent_id}/quality` — get agent profile quality score (PLAN-064)
|
|
214
|
-
- `PUT /protocol/agents/{agent_id}` — update agent
|
|
215
|
-
- `PATCH /protocol/agents/{agent_id}/visibility` — set visibility
|
|
216
|
-
- `DELETE /protocol/agents/{agent_id}` — delete agent
|
|
217
|
-
- `GET /protocol/invite-codes` — list user's own invite codes (PLAN-064)
|
|
218
|
-
- `GET /protocol/demands/public` — list public demands (PLAN-064)
|
|
219
|
-
- `GET /protocol/demands/public/{demand_id}` — get public demand detail (PLAN-064)
|
|
220
|
-
- `PATCH /protocol/demands/{demand_id}/visibility` — toggle demand visibility (PLAN-064)
|
|
221
|
-
- `GET /protocol/talent-pool` — list talent pool (PLAN-064)
|
|
222
|
-
- `POST /protocol/talent-pool` — add agent to talent pool (PLAN-064)
|
|
223
|
-
- `PUT /protocol/talent-pool/{agent_id}` — update talent pool entry (PLAN-064)
|
|
224
|
-
- `DELETE /protocol/talent-pool/{agent_id}` — remove from talent pool (PLAN-064)
|
|
225
|
-
- `GET /protocol/notifications/stream` — SSE notifications stream (PLAN-064)
|
|
226
|
-
- `POST /protocol/clarification-sessions` — start clarification-session session
|
|
227
|
-
- `GET /protocol/clarification-sessions/{session_id}` — get clarification-session state
|
|
228
|
-
- `POST /protocol/clarification-sessions/{session_id}/reply` — continue clarification-session (SSE)
|
|
229
|
-
- `POST /protocol/clarification-sessions/{session_id}/confirm` — confirm + trigger matching; when `start_negotiation=true`, also starts hosted negotiation
|
|
230
|
-
- `POST /protocol/discover` — ad-hoc matching query; when `start_negotiation=true`, also starts hosted negotiation
|
|
231
|
-
- `GET /protocol/discover/{query_id}` — get matching results
|
|
232
|
-
- `POST /protocol/discover/{query_id}/rerun` — re-run existing matching (PLAN-064)
|
|
233
|
-
- `GET /protocol/recommendations/{recommendation_id}` — get recommendation detail
|
|
234
|
-
- `POST /protocol/invitations` — create invitation
|
|
235
|
-
- `GET /protocol/invitations` — list invitations
|
|
236
|
-
- `GET /protocol/invitations/{invitation_id}` — get invitation
|
|
237
|
-
- `PATCH /protocol/invitations/{invitation_id}` — accept/decline invitation
|
|
238
|
-
- `GET /protocol/runs/public` — list public runs (PLAN-064)
|
|
239
|
-
- `GET /protocol/runs/public/{run_id}` — get public run detail (PLAN-064)
|
|
240
|
-
- `GET /protocol/runs/public/{run_id}/result` — get public run result (PLAN-064)
|
|
241
|
-
- `PATCH /protocol/runs/{run_id}/visibility` — toggle run visibility (PLAN-064)
|
|
242
|
-
- `POST /protocol/runs` — legacy invitation-based run creation
|
|
243
|
-
- `GET /protocol/runs/{run_id}` — run status
|
|
244
|
-
- `GET /protocol/runs/{run_id}/prompt` — get current round prompt
|
|
245
|
-
- `POST /protocol/runs/{run_id}/respond` — submit participant response
|
|
246
|
-
- `GET /protocol/runs/{run_id}/result` — get run result
|
|
247
|
-
- `WS /protocol/runs/{run_id}/stream` — run progress WebSocket
|
|
248
|
-
- `POST /protocol/feedback` — submit feedback
|
|
249
|
-
- `GET /protocol/usage` — usage stats
|
|
250
|
-
- `GET /protocol/scenes` — list available scenes (PLAN-064)
|
|
251
|
-
- `GET /protocol/scenes/{scene_id}` — get scene configuration (PLAN-064)
|
|
252
|
-
- `POST /protocol/conversations` — send message (inter-agent messaging)
|
|
253
|
-
- `GET /protocol/conversations` — list conversations
|
|
254
|
-
- `GET /protocol/conversations/{conversation_id}/messages` — get conversation messages
|
|
255
|
-
- `POST /protocol/conversations/{conversation_id}/read` — mark conversation as read
|
|
256
|
-
|
|
257
|
-
## Auth Lanes
|
|
258
|
-
- `GET /api/lanes/secondme_ai/callback` — SecondMe AI lane OAuth callback (HTML)
|
|
259
|
-
|
|
260
|
-
## Auth Headers
|
|
261
|
-
|
|
262
|
-
Admin-only routes require `boll_ADMIN_KEY` via either:
|
|
263
|
-
- `X-Admin-Key: <key>`
|
|
264
|
-
- `Authorization: Bearer <key>`
|
|
265
|
-
|
|
266
|
-
Bridge routes require `BRIDGE_API_KEY` via `Authorization: Bearer <key>`.
|
|
267
|
-
|
|
268
|
-
Protocol routes require session token via `Authorization: Bearer <session_token>` and accept `application/vnd.boll.v1+json`.
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
paths:
|
|
3
|
-
- "bridge_agent/**"
|
|
4
|
-
- "backend/product/bridge/**"
|
|
5
|
-
- "bridge_contract/**"
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
# Bridge 宪法 (ADR-026)
|
|
9
|
-
|
|
10
|
-
Bridge 是薄中继,不是本地 orchestrator。以下 5 条规则约束所有 bridge 改动:
|
|
11
|
-
|
|
12
|
-
1. **Worker 不拥有业务解释权,只上报执行事实。** 如果一段 worker 代码需要理解输出内容的含义,它就写错了地方。
|
|
13
|
-
2. **同一个语义只允许有一个定义。** 不管是文件名模式、artifact 类型、还是 event 含义,只能在一个地方定义。
|
|
14
|
-
3. **跑通了就发结果,没跑通就报 failed。** 不做 partial_success 抢救、不生成 placeholder、不从失败 stdout 里猜内容。这些如果需要,由 server 决定。
|
|
15
|
-
4. **生产不能是第一个集成环境。** 本地必须能用 fake CLI + 真实 HTTP backend 跑完整链。
|
|
16
|
-
5. **新增观测维度或 event 类型,只改 server,不改 worker。** 这是开闭原则的具体体现。
|
|
17
|
-
|
|
18
|
-
三层职责:`boll-run` 定义成功产物契约 → `worker` 执行和上报事实 → `server` 解释事实并生成产品语义。
|
|
19
|
-
|
|
20
|
-
详见: `docs/decisions/ADR-026-bridge-thin-relay-architecture.md`
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
paths:
|
|
3
|
-
- "docs/issues/**"
|
|
4
|
-
- "docs/decisions/ADR-030*"
|
|
5
|
-
- "scripts/hooks/**"
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
# Closure Semantics (ADR-030)
|
|
9
|
-
|
|
10
|
-
## Fixed 三层定义
|
|
11
|
-
|
|
12
|
-
Issue 标记 "Fixed" 不等于"症状消失"。三个层级:
|
|
13
|
-
|
|
14
|
-
| 层级 | 含义 | 标准 | 标记 |
|
|
15
|
-
|------|------|------|------|
|
|
16
|
-
| Level 1 | 症状消失 | 生产不报错了,但没有分析复发路径 | Runtime Fixed |
|
|
17
|
-
| Level 2 | 复发路径关闭 | 修了根因,分析了复发路径,写了 prevention_status | **Fixed** |
|
|
18
|
-
| Level 3 | 机制消灭 | Fixed + 有机械化 guard 自动检测防止复发 | Fixed + Guarded |
|
|
19
|
-
|
|
20
|
-
## Issue Doc YAML Frontmatter 规范
|
|
21
|
-
|
|
22
|
-
所有 `docs/issues/` 下的 issue 文档必须包含以下 frontmatter 字段:
|
|
23
|
-
|
|
24
|
-
```yaml
|
|
25
|
-
status: fixed|open|wont_fix # 当前状态
|
|
26
|
-
prevention_status: open|closed # 复发预防是否闭环
|
|
27
|
-
mechanism_layer: guard|test|type|convention # 防护机制层级
|
|
28
|
-
```
|
|
29
|
-
|
|
30
|
-
详见: `docs/decisions/ADR-030-guard-signal-protocol-and-governance-reload.md`
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
paths:
|
|
3
|
-
- "scenes/example-coach/**"
|
|
4
|
-
- "backend/product/coaching/**"
|
|
5
|
-
- "backend/product/routes/coaching*.py"
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
# example-coach(kunzhi-coach)开发规则
|
|
9
|
-
|
|
10
|
-
- 独立上下文:`scenes/example-coach/CLAUDE.md` 是专属开发指南
|
|
11
|
-
- 协议接口契约:`scenes/example-coach/docs/PROTOCOL-CONTRACT.md` 定义与协议的精确依赖
|
|
12
|
-
- 高危模式:`scenes/example-coach/docs/ERROR-PATTERNS.md` 列出 6 个 coaching 专属错误模式
|
|
13
|
-
- 两套语言:协议术语和用户语言严格分离,场景用户永远不接触协议内部概念
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
paths:
|
|
3
|
-
- "backend/product/config.py"
|
|
4
|
-
- "backend/server.py"
|
|
5
|
-
- "scripts/deploy*.sh"
|
|
6
|
-
- "scripts/deploy*.py"
|
|
7
|
-
- ".env*"
|
|
8
|
-
---
|
|
9
|
-
|
|
10
|
-
# Important Environment Variables
|
|
11
|
-
|
|
12
|
-
## Required
|
|
13
|
-
- `DATABASE_URL` — PostgreSQL connection string
|
|
14
|
-
- `BRIDGE_API_KEY` — bridge agent authentication
|
|
15
|
-
- `boll_ADMIN_KEY` — admin route authentication
|
|
16
|
-
|
|
17
|
-
## Optional
|
|
18
|
-
- `ALLOWED_ORIGINS` — CORS origins (default includes localhost + <NETWORK_REDACTED> + <NETWORK_REDACTED> + auth.<NETWORK_REDACTED> + hackathon domains; see `backend/product/config.py`)
|
|
19
|
-
- `boll_ANTHROPIC_API_KEY` — single API key (enables MPG)
|
|
20
|
-
- `boll_ANTHROPIC_API_KEYS` — comma-separated API keys (rotation)
|
|
21
|
-
- `boll_ANTHROPIC_BASE_URL` — custom API base URL
|
|
22
|
-
- `SESSION_TTL_DAYS` — session expiry (default: 30)
|
|
23
|
-
- `BCRYPT_ROUNDS` — password hash rounds (default: 12)
|
|
24
|
-
- `LOGIN_MAX_ATTEMPTS_PER_MINUTE` — rate limit (default: 5)
|
|
25
|
-
- `LOGIN_FREEZE_AFTER_FAILURES` — lockout threshold (default: 10)
|
|
26
|
-
- `LOGIN_FREEZE_MINUTES` — lockout duration (default: 15)
|
|
27
|
-
|
|
28
|
-
## Secrets (production-only)
|
|
29
|
-
- `boll_KEY_ENCRYPTION_SECRET` — BYOK key encryption
|
|
30
|
-
- `boll_PROTOCOL_ENCODING_PACKAGE_SECRET` — encoding package signing
|
|
31
|
-
- `boll_PROTOCOL_FEDERATION_SECRET` — federation auth
|
|
32
|
-
- `boll_OSS_ACCESS_KEY_ID` / `boll_OSS_ACCESS_KEY_SECRET` / `boll_OSS_ROLE_ARN` — Alibaba Cloud OSS
|
|
33
|
-
- `boll_SMTP_HOST` / `boll_SMTP_PORT` / `boll_SMTP_USERNAME` / `boll_SMTP_PASSWORD` / `boll_SMTP_SENDER` / `boll_SMTP_USE_TLS` — email delivery
|
|
34
|
-
- `SECONDME_CLIENT_ID` / `SECONDME_CLIENT_SECRET` / `SECONDME_REDIRECT_URI` — SecondMe OAuth
|
|
35
|
-
|
|
36
|
-
## LLM Configuration
|
|
37
|
-
- `boll_DEFAULT_MODEL` — default LLM model
|
|
38
|
-
- `boll_COACHING_ANTHROPIC_API_KEY` / `boll_COACHING_ANTHROPIC_BASE_URL` / `boll_COACHING_ANTHROPIC_MODEL` — coaching-specific LLM
|
|
39
|
-
- `boll_OPENROUTER_API_KEY` / `boll_OPENROUTER_BASE_URL` / `boll_OPENROUTER_MODEL` — OpenRouter fallback
|
|
40
|
-
|
|
41
|
-
## Operational
|
|
42
|
-
- `boll_SECURE_COOKIES` — cookie security flag (default: true in prod)
|
|
43
|
-
- `boll_PROTOCOL_BYOK_SESSION_TTL_MINUTES` — BYOK session TTL
|
|
44
|
-
- `boll_PROTOCOL_PUBLIC_ORIGIN` / `boll_PUBLIC_BASE_URL` / `boll_APP_PUBLIC_BASE_URL` — public URLs (note: `_build_public_run_url` only reads `app_public_base_url || public_base_url`; `protocol_public_origin` is reserved/unused as of 2026-04-07)
|
|
45
|
-
- `RATE_LIMIT_OVERRIDES` — per-email rate limit overrides (`email:endpoint:max:window,...`); only effective for endpoints that pass `account_email` (not register/login)
|
|
46
|
-
- `RATE_LIMIT_BYPASS_IPS` — comma-separated IP allowlist that skips ALL rate limiting; for internal E2E scripts and health checks running from localhost / known internal subnets so they don't burn the public per-IP register quota. Prod default: `127.0.0.1`
|
|
47
|
-
- `boll_QUALITY_GATE_C_THRESHOLD` / `boll_QUALITY_GATE_A_THRESHOLD` — quality gate thresholds
|
|
48
|
-
- `FIELD_SNAPSHOT_PATH` — field cache path
|
|
49
|
-
- `RUN_TTL_ASSIGNED_MINUTES` / `RUN_TTL_RUNNING_MINUTES` / `RUN_TTL_DELIVERING_MINUTES` — run lifecycle TTLs
|
|
50
|
-
- `RUN_MAX_RETRY_ATTEMPTS` / `RUN_RECOVERY_INTERVAL_SECONDS` — run recovery
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
paths:
|
|
3
|
-
- "scenes/epic-hackathon/**"
|
|
4
|
-
- "backend/product/hackathon/**"
|
|
5
|
-
- "backend/product/routes/hackathon*.py"
|
|
6
|
-
---
|
|
7
|
-
|
|
8
|
-
# Hackathon 开发规则
|
|
9
|
-
|
|
10
|
-
- 双字段模式:`_xxx_to_dict` 必须同时返回 `id` 和 `xxx_id`
|
|
11
|
-
- ADR-037 场景适配器:协议概念不得泄露到场景 API,用 SceneAdapter 做翻译+编排+角色路由
|
|
12
|
-
- 状态机:`backend/product/hackathon/state_machine.py` 是事件状态转换的单一真相源
|
|
@@ -1,184 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
paths:
|
|
3
|
-
- "backend/**"
|
|
4
|
-
- "scenes/**"
|
|
5
|
-
- "website/**"
|
|
6
|
-
- "mcp-server/**"
|
|
7
|
-
- "mcp-server-node/**"
|
|
8
|
-
- "bridge_agent/**"
|
|
9
|
-
- "bridge_contract/**"
|
|
10
|
-
- "tests/**"
|
|
11
|
-
- "experiments/**"
|
|
12
|
-
---
|
|
13
|
-
|
|
14
|
-
# Repository Structure & Development Commands
|
|
15
|
-
|
|
16
|
-
## Repository Structure
|
|
17
|
-
|
|
18
|
-
```
|
|
19
|
-
boll/
|
|
20
|
-
├── CHANGELOG.md # Platform-level changelog (v0.1.0 ~ v0.4.1)
|
|
21
|
-
├── backend/
|
|
22
|
-
│ ├── server.py # V2-only FastAPI entry (port 8080)
|
|
23
|
-
│ ├── boll/
|
|
24
|
-
│ │ ├── __init__.py # V2 field-only exports
|
|
25
|
-
│ │ ├── field/ # Intent Field module (12 files)
|
|
26
|
-
│ │ └── matching/ # Discovery engine core (operators, recommendation, encoding, evaluation, logging)
|
|
27
|
-
│ ├── product/ # V2 productization layer
|
|
28
|
-
│ │ ├── config.py # Pydantic env-backed config
|
|
29
|
-
│ │ ├── field_sync.py # DB → MemoryField reload
|
|
30
|
-
│ │ ├── llm.py # LLM client factory
|
|
31
|
-
│ │ ├── quota.py # Commercial quota management
|
|
32
|
-
│ │ ├── scheduler.py # Run recovery scheduler
|
|
33
|
-
│ │ ├── scene_chat_runtime.py # SSE scene chat runtime
|
|
34
|
-
│ │ ├── a2a/ # A2A protocol adapter
|
|
35
|
-
│ │ ├── auth/ # Auth service + middleware + passwords + SecondMe OAuth
|
|
36
|
-
│ │ ├── bridge/ # Bridge protocol (local Mac ↔ cloud); event_translator.py: bridge→protocol 事件翻译层
|
|
37
|
-
│ │ ├── catalyst/ # Cloud-side catalyst (coordinator, deadline scheduler, prompt loader); convergence.py: 收敛标记解析单一真相源
|
|
38
|
-
│ │ ├── db/ # SQLAlchemy engine + CRUD (users/demands/runs/events/artifacts)
|
|
39
|
-
│ │ ├── demands/ # Demand clarification-session + matching service
|
|
40
|
-
│ │ ├── matching/ # Discovery pipeline (scanner, nominator, store)
|
|
41
|
-
│ │ ├── inbox/ # Inbox service
|
|
42
|
-
│ │ ├── lanes/ # Auth lanes (SecondMe AI etc.)
|
|
43
|
-
│ │ ├── messaging/ # Inter-agent messaging
|
|
44
|
-
│ │ ├── metrics/ # Platform metrics calculator
|
|
45
|
-
│ │ ├── notifications/ # SSE notification stream
|
|
46
|
-
│ │ ├── coaching/ # Coaching service (kunzhi-coach prompts, export, constants)
|
|
47
|
-
│ │ ├── hackathon/ # Hackathon service (state_machine, service layer)
|
|
48
|
-
│ │ ├── openagents/ # OpenAgents runtime carrier + session manager
|
|
49
|
-
│ │ ├── protocol/ # Canonical protocol API (bootstrap, deps, encoding, federation, service)
|
|
50
|
-
│ │ ├── public_profiles/ # Public profile service
|
|
51
|
-
│ │ ├── routes/ # API routes (auth/profile/admin/demands/bridge/runs/dashboard/scene_auth/scene_chat/coaching/coaching_admin/hackathon/protocol/matching/a2a/plaza/public/public_profiles/did/messaging)
|
|
52
|
-
│ │ ├── security/ # Security utilities (URL fetcher, sanitization)
|
|
53
|
-
│ │ └── ws/ # WebSocket hub + ticket auth
|
|
54
|
-
│ ├── models/ # ML model artifacts (bge-m3 embeddings)
|
|
55
|
-
│ ├── tests/
|
|
56
|
-
│ │ ├── field/ # V2 field unit tests (89)
|
|
57
|
-
│ │ ├── product/ # Product unit tests (545, needs Docker)
|
|
58
|
-
│ │ ├── unit/ # Pure in-memory unit tests (60, no Docker)
|
|
59
|
-
│ │ ├── matching/ # Discovery engine tests (21)
|
|
60
|
-
│ │ └── test_phase0_surface.py # Phase-0 surface gate tests (8)
|
|
61
|
-
│ └── venv/
|
|
62
|
-
├── bridge_contract/ # Pure-Python bridge contract helpers (artifacts, events, finalization, runtime_profile)
|
|
63
|
-
├── bridge_agent/ # Local bridge agent (polls cloud → runs convergence)
|
|
64
|
-
│ ├── agent.py # Bridge agent entry
|
|
65
|
-
│ ├── bridge_listen.py # HTTP helper (await-task, monitor, complete)
|
|
66
|
-
│ ├── test_progress.py # Progress detection tests (31)
|
|
67
|
-
│ ├── config.yaml # Bridge config
|
|
68
|
-
│ └── run_e2e.py # E2E test runner
|
|
69
|
-
├── mcp-server/ # MCP server — Python (boll-mcp, version see pyproject.toml)
|
|
70
|
-
│ ├── boll_mcp/ # 74 active tools (version see pyproject.toml)
|
|
71
|
-
│ ├── CHANGELOG.md # MCP-specific changelog (0.3.0 ~ 0.4.0)
|
|
72
|
-
│ └── pyproject.toml
|
|
73
|
-
├── mcp-server-node/ # MCP server — TypeScript/Node (boll-mcp, version see package.json)
|
|
74
|
-
│ ├── src/ # 74 active tools (mirror of Python version)
|
|
75
|
-
│ └── package.json
|
|
76
|
-
├── tests/
|
|
77
|
-
│ ├── convergence_poc/ # Crystallization protocol experiments + tests (9)
|
|
78
|
-
│ │ ├── prompts/ # Prompt version chain
|
|
79
|
-
│ │ └── simulations/real/ # RUN-001 ~ RUN-006
|
|
80
|
-
│ └── field_poc/ # Field experiment archive (EXP-005~008)
|
|
81
|
-
├── website/
|
|
82
|
-
│ ├── app/
|
|
83
|
-
│ │ ├── page.tsx # Home
|
|
84
|
-
│ │ ├── (auth)/ # Login + Register pages
|
|
85
|
-
│ │ ├── dashboard/ # User dashboard
|
|
86
|
-
│ │ ├── demand/ # New demand + match result
|
|
87
|
-
│ │ ├── field/ # Field experience page
|
|
88
|
-
│ │ ├── profile/ # User profile
|
|
89
|
-
│ │ ├── run/ # Run progress + result
|
|
90
|
-
│ │ └── workspace/ # Startup Hub workspace
|
|
91
|
-
│ └── package.json
|
|
92
|
-
├── docs/
|
|
93
|
-
│ ├── ARCHITECTURE_DESIGN.md # V1 architecture (archived reference)
|
|
94
|
-
│ ├── archive/ENGINEERING_REFERENCE.md # Engineering standards (archived)
|
|
95
|
-
│ ├── INDEX.md # Documentation navigation index
|
|
96
|
-
│ ├── ROADMAP.md # Milestones + current direction + planned
|
|
97
|
-
│ ├── architecture/ # Modular arch docs (principles, modules, vision)
|
|
98
|
-
│ ├── community/ # Profile contribution guide
|
|
99
|
-
│ ├── decisions/ # ADR + TECH + TEST + PLAN + REVIEW + EVAL
|
|
100
|
-
│ │ ├── ADR-001~034 # Architecture Decision Records
|
|
101
|
-
│ │ ├── TECH-015/TECH-018/TECH-SPEC-008 # Engineering designs
|
|
102
|
-
│ │ ├── TEST-015/TEST-019 # Test designs
|
|
103
|
-
│ │ ├── PLAN-001~080 # Implementation plans
|
|
104
|
-
│ │ ├── REVIEW-015~057 # Audits
|
|
105
|
-
│ │ └── tasks/ # Task documents (use `find docs/decisions/tasks -name '*.md' | wc -l` to count)
|
|
106
|
-
│ ├── issues/ # Guardian/red-team issue documents (guard-YYYYMMDD-HHMM-*.md)
|
|
107
|
-
│ ├── design-logs/ # Design evolution logs (001~008)
|
|
108
|
-
│ ├── research/ # Research reports (000~015)
|
|
109
|
-
│ ├── reviews/ # Review artifacts (review-015, review-015-2)
|
|
110
|
-
│ ├── guides/ # Developer guides
|
|
111
|
-
│ ├── archive/ # Legacy V1 docs
|
|
112
|
-
│ └── prompts/ # V1 skill prompts (archived)
|
|
113
|
-
├── scenes/ # Scene demo apps
|
|
114
|
-
│ ├── admin-dashboard/ # 管理后台 demo (Vite + React)
|
|
115
|
-
│ ├── ai-gig-market/ # AI Agent 零工平台 demo (Vite + React)
|
|
116
|
-
│ ├── craw-opc/ # Craw OPC (placeholder)
|
|
117
|
-
│ ├── epic-hackathon/ # Epic Hackathon demo (Vite + React)
|
|
118
|
-
│ ├── hackathon-observer/ # Hackathon 观察者 (archive)
|
|
119
|
-
│ ├── kunzhi-coach/ # example-coach scene app + prompts
|
|
120
|
-
│ ├── kunzhi-coach-admin/ # example-coach后台管理 (Vite + React)
|
|
121
|
-
│ ├── lobster-office/ # 龙虾办公 demo (Vite + React)
|
|
122
|
-
│ ├── shrimp-hackathon/ # Shrimp Hackathon (placeholder)
|
|
123
|
-
│ ├── smart-home-butler/ # 智能家居管家 (placeholder)
|
|
124
|
-
│ └── startup-hub/ # Startup Hub workspace
|
|
125
|
-
├── experiments/
|
|
126
|
-
│ └── real_data/ # Discovery GT Recall experiments (WP-015)
|
|
127
|
-
├── scripts/ # Utility scripts
|
|
128
|
-
├── data/
|
|
129
|
-
│ └── profiles/ # Community profiles
|
|
130
|
-
└── .claude/skills/ # Repo-local Codex skills(见 docs/skills/REGISTRY.md)
|
|
131
|
-
```
|
|
132
|
-
|
|
133
|
-
## Development Commands
|
|
134
|
-
|
|
135
|
-
```bash
|
|
136
|
-
# Backend
|
|
137
|
-
cd backend
|
|
138
|
-
source venv/bin/activate
|
|
139
|
-
uvicorn server:app --reload --port 8080
|
|
140
|
-
|
|
141
|
-
# Deployment (MUST use this, never manual scp — hook enforced)
|
|
142
|
-
bash scripts/deploy.sh --yes # Full deploy: coherence check → sync → restart → verify
|
|
143
|
-
bash scripts/deploy.sh --dry-run # Preview only, no changes
|
|
144
|
-
bash scripts/deploy-edge.sh --yes # Sync repo-managed nginx edge config + verify public routes
|
|
145
|
-
bash scripts/deploy-edge.sh --dry-run
|
|
146
|
-
# Note: --yes skips interactive confirmation (required for AI execution)
|
|
147
|
-
# Manual scp/rsync to production server is blocked by PreToolUse hook
|
|
148
|
-
|
|
149
|
-
# Demo frontend deployment (static files, no backend restart)
|
|
150
|
-
bash scripts/deploy-demo.sh ai-gig-market --channel prod --yes # Build + deploy public demo
|
|
151
|
-
bash scripts/deploy-demo.sh ai-gig-market --channel preview --yes # Build + deploy internal preview
|
|
152
|
-
bash scripts/deploy-demo.sh ai-gig-market --dry-run # Preview only
|
|
153
|
-
bash scripts/deploy-demo.sh ai-gig-market --skip-build --yes # Deploy existing dist
|
|
154
|
-
|
|
155
|
-
# Frontend
|
|
156
|
-
cd website
|
|
157
|
-
npm run dev
|
|
158
|
-
|
|
159
|
-
# Tests (1992 collectable as of 2026-04-06)
|
|
160
|
-
cd /Users/nature/个人项目/boll
|
|
161
|
-
backend/venv/bin/pytest -q backend/tests/test_phase0_surface.py # Phase-0 gate (8)
|
|
162
|
-
backend/venv/bin/pytest -q backend/tests/field # Field unit (89)
|
|
163
|
-
backend/venv/bin/pytest -q backend/tests/unit # Pure in-memory unit (462, no Docker)
|
|
164
|
-
backend/venv/bin/pytest -q backend/tests/product # Product unit (750, needs Docker)
|
|
165
|
-
backend/venv/bin/pytest -q backend/tests/matching # Discovery engine (21)
|
|
166
|
-
backend/venv/bin/pytest -q tests/convergence_poc/simulations/real # Crystallization (9)
|
|
167
|
-
backend/venv/bin/pytest -q bridge_agent/test_progress.py # Bridge progress (31)
|
|
168
|
-
|
|
169
|
-
# MCP Server (Python)
|
|
170
|
-
pip install -e ./mcp-server
|
|
171
|
-
boll-mcp --help
|
|
172
|
-
|
|
173
|
-
# MCP Server (Node/TypeScript)
|
|
174
|
-
cd mcp-server-node
|
|
175
|
-
npm install && npm run build
|
|
176
|
-
npx boll-mcp
|
|
177
|
-
|
|
178
|
-
# Official install entry
|
|
179
|
-
/mcp
|
|
180
|
-
|
|
181
|
-
# Frontend build
|
|
182
|
-
cd website
|
|
183
|
-
npm run build
|
|
184
|
-
```
|