bonecode 1.0.0 → 1.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +64 -50
- package/bin/bonecode +47 -42
- package/bone/output/agent/.dockerignore +7 -7
- package/bone/output/agent/.env.example +36 -36
- package/bone/output/agent/.github/workflows/ci.yaml +58 -58
- package/bone/output/agent/AgentDomain.bone.map +349 -349
- package/bone/output/agent/AgentDomain.postman_collection.json +957 -957
- package/bone/output/agent/Dockerfile +22 -22
- package/bone/output/agent/README.md +47 -47
- package/bone/output/agent/admin/index.html +739 -739
- package/bone/output/agent/docker-compose.yaml +22 -22
- package/bone/output/agent/k8s/deployment.yaml +75 -75
- package/bone/output/agent/migrations/agent.sql +36 -36
- package/bone/output/agent/migrations/agent_instance.sql +36 -36
- package/bone/output/agent/migrations/audit_log.sql +18 -18
- package/bone/output/agent/migrations/build_step.sql +34 -34
- package/bone/output/agent/migrations/event_outbox.sql +31 -31
- package/bone/output/agent/migrations/plan.sql +30 -30
- package/bone/output/agent/migrations/task.sql +30 -30
- package/bone/output/agent/migrations/tool_call.sql +33 -33
- package/bone/output/agent/openapi.yaml +1116 -1116
- package/bone/output/agent/package.json +35 -35
- package/bone/output/agent/schema.graphql +233 -233
- package/bone/output/agent/sdk/client.ts +231 -231
- package/bone/output/agent/src/algorithms.ts +2 -2
- package/bone/output/agent/src/audit.ts +44 -44
- package/bone/output/agent/src/auth.ts +57 -57
- package/bone/output/agent/src/cron.ts +12 -12
- package/bone/output/agent/src/db.ts +31 -31
- package/bone/output/agent/src/debug.ts +66 -66
- package/bone/output/agent/src/events.ts +243 -243
- package/bone/output/agent/src/extensions.ts +54 -54
- package/bone/output/agent/src/failure_rules.ts +322 -322
- package/bone/output/agent/src/flows.ts +168 -168
- package/bone/output/agent/src/health.ts +43 -43
- package/bone/output/agent/src/index.ts +99 -99
- package/bone/output/agent/src/logger.ts +69 -66
- package/bone/output/agent/src/metrics.ts +75 -75
- package/bone/output/agent/src/migrate.ts +351 -351
- package/bone/output/agent/src/migration_diff.ts +108 -108
- package/bone/output/agent/src/notify.ts +125 -125
- package/bone/output/agent/src/routes/plan.ts +91 -91
- package/bone/output/agent/src/routes/task.ts +105 -105
- package/bone/output/agent/src/routes/tool_call.ts +166 -166
- package/bone/output/agent/src/schemas.ts +384 -384
- package/bone/output/agent/src/state_machines/agent_instance.ts +24 -24
- package/bone/output/agent/src/state_machines/build_step.ts +22 -22
- package/bone/output/agent/src/state_machines/plan.ts +22 -22
- package/bone/output/agent/src/state_machines/task.ts +22 -22
- package/bone/output/agent/src/state_machines/tool_call.ts +22 -22
- package/bone/output/agent/src/tests.ts +361 -361
- package/bone/output/agent/src/websocket.ts +200 -200
- package/bone/output/agent/tsconfig.json +24 -24
- package/bone/output/rag/.dockerignore +7 -7
- package/bone/output/rag/.env.example +36 -36
- package/bone/output/rag/.github/workflows/ci.yaml +58 -58
- package/bone/output/rag/Dockerfile +22 -22
- package/bone/output/rag/RAGDomain.bone.map +286 -286
- package/bone/output/rag/RAGDomain.postman_collection.json +922 -922
- package/bone/output/rag/README.md +47 -47
- package/bone/output/rag/admin/index.html +817 -817
- package/bone/output/rag/docker-compose.yaml +22 -22
- package/bone/output/rag/k8s/deployment.yaml +75 -75
- package/bone/output/rag/migrations/audit_log.sql +18 -18
- package/bone/output/rag/migrations/code_chunk.sql +34 -34
- package/bone/output/rag/migrations/code_file.sql +33 -33
- package/bone/output/rag/migrations/event_outbox.sql +31 -31
- package/bone/output/rag/migrations/indexing_job.sql +33 -33
- package/bone/output/rag/migrations/knowledge_base.sql +35 -35
- package/bone/output/rag/migrations/memory_entry.sql +34 -34
- package/bone/output/rag/openapi.yaml +1097 -1097
- package/bone/output/rag/package.json +35 -35
- package/bone/output/rag/schema.graphql +245 -245
- package/bone/output/rag/sdk/client.ts +234 -234
- package/bone/output/rag/src/algorithms.ts +2 -2
- package/bone/output/rag/src/audit.ts +37 -37
- package/bone/output/rag/src/auth.ts +57 -57
- package/bone/output/rag/src/cron.ts +12 -12
- package/bone/output/rag/src/db.ts +31 -31
- package/bone/output/rag/src/debug.ts +66 -66
- package/bone/output/rag/src/events.ts +243 -243
- package/bone/output/rag/src/extensions.ts +350 -350
- package/bone/output/rag/src/failure_rules.ts +314 -314
- package/bone/output/rag/src/flows.ts +239 -239
- package/bone/output/rag/src/health.ts +43 -43
- package/bone/output/rag/src/index.ts +94 -94
- package/bone/output/rag/src/logger.ts +69 -66
- package/bone/output/rag/src/metrics.ts +75 -75
- package/bone/output/rag/src/migrate.ts +363 -363
- package/bone/output/rag/src/migration_diff.ts +108 -108
- package/bone/output/rag/src/notify.ts +99 -99
- package/bone/output/rag/src/routes/code_chunk.ts +75 -75
- package/bone/output/rag/src/routes/code_file.ts +101 -101
- package/bone/output/rag/src/routes/indexing_job.ts +87 -87
- package/bone/output/rag/src/routes/knowledge_base.ts +230 -230
- package/bone/output/rag/src/routes/memory_entry.ts +87 -87
- package/bone/output/rag/src/schemas.ts +394 -394
- package/bone/output/rag/src/state_machines/code_file.ts +23 -23
- package/bone/output/rag/src/state_machines/indexing_job.ts +22 -22
- package/bone/output/rag/src/state_machines/knowledge_base.ts +23 -23
- package/bone/output/rag/src/state_machines/memory_entry.ts +20 -20
- package/bone/output/rag/src/tests.ts +339 -339
- package/bone/output/rag/tsconfig.json +24 -24
- package/bone/output/session/.dockerignore +7 -7
- package/bone/output/session/.env.example +36 -36
- package/bone/output/session/.github/workflows/ci.yaml +58 -58
- package/bone/output/session/Dockerfile +22 -22
- package/bone/output/session/README.md +47 -47
- package/bone/output/session/SessionDomain.bone.map +349 -349
- package/bone/output/session/SessionDomain.postman_collection.json +957 -957
- package/bone/output/session/admin/index.html +666 -666
- package/bone/output/session/docker-compose.yaml +22 -22
- package/bone/output/session/k8s/deployment.yaml +75 -75
- package/bone/output/session/migrations/audit_log.sql +18 -18
- package/bone/output/session/migrations/event_outbox.sql +31 -31
- package/bone/output/session/migrations/message.sql +31 -31
- package/bone/output/session/migrations/part.sql +28 -28
- package/bone/output/session/migrations/permission.sql +28 -28
- package/bone/output/session/migrations/project.sql +28 -28
- package/bone/output/session/migrations/session.sql +38 -38
- package/bone/output/session/openapi.yaml +1101 -1101
- package/bone/output/session/package.json +35 -35
- package/bone/output/session/schema.graphql +222 -222
- package/bone/output/session/sdk/client.ts +225 -225
- package/bone/output/session/src/algorithms.ts +2 -2
- package/bone/output/session/src/audit.ts +44 -44
- package/bone/output/session/src/auth.ts +57 -57
- package/bone/output/session/src/cron.ts +12 -12
- package/bone/output/session/src/db.ts +31 -31
- package/bone/output/session/src/debug.ts +66 -66
- package/bone/output/session/src/events.ts +270 -270
- package/bone/output/session/src/extensions.ts +215 -215
- package/bone/output/session/src/failure_rules.ts +283 -283
- package/bone/output/session/src/flows.ts +168 -168
- package/bone/output/session/src/health.ts +43 -43
- package/bone/output/session/src/index.ts +99 -99
- package/bone/output/session/src/logger.ts +67 -66
- package/bone/output/session/src/metrics.ts +75 -75
- package/bone/output/session/src/migrate.ts +331 -331
- package/bone/output/session/src/migration_diff.ts +108 -108
- package/bone/output/session/src/notify.ts +112 -112
- package/bone/output/session/src/routes/message.ts +93 -93
- package/bone/output/session/src/routes/part.ts +79 -79
- package/bone/output/session/src/routes/permission.ts +79 -79
- package/bone/output/session/src/routes/project.ts +79 -79
- package/bone/output/session/src/routes/session.ts +294 -294
- package/bone/output/session/src/schemas.ts +357 -357
- package/bone/output/session/src/state_machines/session.ts +23 -23
- package/bone/output/session/src/tests.ts +325 -325
- package/bone/output/session/src/websocket.ts +223 -200
- package/bone/output/session/tsconfig.json +24 -24
- package/bone/output/workspace/.dockerignore +7 -7
- package/bone/output/workspace/.env.example +36 -36
- package/bone/output/workspace/.github/workflows/ci.yaml +58 -58
- package/bone/output/workspace/Dockerfile +22 -22
- package/bone/output/workspace/README.md +45 -45
- package/bone/output/workspace/WorkspaceDomain.bone.map +188 -188
- package/bone/output/workspace/WorkspaceDomain.postman_collection.json +620 -620
- package/bone/output/workspace/admin/index.html +484 -484
- package/bone/output/workspace/docker-compose.yaml +22 -22
- package/bone/output/workspace/k8s/deployment.yaml +75 -75
- package/bone/output/workspace/migrations/audit_log.sql +18 -18
- package/bone/output/workspace/migrations/codebase.sql +34 -34
- package/bone/output/workspace/migrations/event_outbox.sql +31 -31
- package/bone/output/workspace/migrations/snapshot.sql +32 -32
- package/bone/output/workspace/migrations/workspace.sql +33 -33
- package/bone/output/workspace/openapi.yaml +721 -721
- package/bone/output/workspace/package.json +35 -35
- package/bone/output/workspace/schema.graphql +153 -153
- package/bone/output/workspace/sdk/client.ts +155 -155
- package/bone/output/workspace/src/algorithms.ts +2 -2
- package/bone/output/workspace/src/audit.ts +37 -37
- package/bone/output/workspace/src/auth.ts +57 -57
- package/bone/output/workspace/src/cron.ts +12 -12
- package/bone/output/workspace/src/db.ts +31 -31
- package/bone/output/workspace/src/debug.ts +66 -66
- package/bone/output/workspace/src/events.ts +243 -243
- package/bone/output/workspace/src/extensions.ts +44 -44
- package/bone/output/workspace/src/failure_rules.ts +152 -152
- package/bone/output/workspace/src/health.ts +43 -43
- package/bone/output/workspace/src/index.ts +88 -88
- package/bone/output/workspace/src/logger.ts +69 -66
- package/bone/output/workspace/src/metrics.ts +75 -75
- package/bone/output/workspace/src/migrate.ts +219 -219
- package/bone/output/workspace/src/migration_diff.ts +108 -108
- package/bone/output/workspace/src/notify.ts +73 -73
- package/bone/output/workspace/src/routes/codebase.ts +87 -87
- package/bone/output/workspace/src/routes/snapshot.ts +127 -127
- package/bone/output/workspace/src/routes/workspace.ts +190 -190
- package/bone/output/workspace/src/schemas.ts +231 -231
- package/bone/output/workspace/src/state_machines/codebase.ts +21 -21
- package/bone/output/workspace/src/state_machines/snapshot.ts +20 -20
- package/bone/output/workspace/src/state_machines/workspace.ts +21 -21
- package/bone/output/workspace/src/tests.ts +248 -248
- package/bone/output/workspace/tsconfig.json +24 -24
- package/compat/opencode_adapter.ts +282 -34
- package/dist/bone/output/agent/src/algorithms.d.ts +1 -0
- package/dist/bone/output/agent/src/algorithms.js +3 -0
- package/dist/bone/output/agent/src/algorithms.js.map +1 -0
- package/dist/bone/output/agent/src/audit.d.ts +3 -0
- package/dist/bone/output/agent/src/audit.js +40 -0
- package/dist/bone/output/agent/src/audit.js.map +1 -0
- package/dist/bone/output/agent/src/auth.d.ts +8 -0
- package/dist/bone/output/agent/src/auth.js +56 -0
- package/dist/bone/output/agent/src/auth.js.map +1 -0
- package/dist/bone/output/agent/src/db.d.ts +6 -0
- package/dist/bone/output/agent/src/db.js +63 -0
- package/dist/bone/output/agent/src/db.js.map +1 -0
- package/dist/bone/output/agent/src/events.d.ts +25 -0
- package/dist/bone/output/agent/src/events.js +184 -0
- package/dist/bone/output/agent/src/events.js.map +1 -0
- package/dist/bone/output/agent/src/logger.d.ts +28 -0
- package/dist/bone/output/agent/src/logger.js +45 -0
- package/dist/bone/output/agent/src/logger.js.map +1 -0
- package/dist/bone/output/agent/src/metrics.d.ts +5 -0
- package/dist/bone/output/agent/src/metrics.js +60 -0
- package/dist/bone/output/agent/src/metrics.js.map +1 -0
- package/dist/bone/output/agent/src/routes/agent_instance.d.ts +1 -0
- package/dist/bone/output/agent/src/routes/agent_instance.js +253 -0
- package/dist/bone/output/agent/src/routes/agent_instance.js.map +1 -0
- package/dist/bone/output/agent/src/routes/build_step.d.ts +1 -0
- package/dist/bone/output/agent/src/routes/build_step.js +133 -0
- package/dist/bone/output/agent/src/routes/build_step.js.map +1 -0
- package/dist/bone/output/agent/src/routes/plan.d.ts +1 -0
- package/dist/bone/output/agent/src/routes/plan.js +119 -0
- package/dist/bone/output/agent/src/routes/plan.js.map +1 -0
- package/dist/bone/output/agent/src/routes/task.d.ts +1 -0
- package/dist/bone/output/agent/src/routes/task.js +133 -0
- package/dist/bone/output/agent/src/routes/task.js.map +1 -0
- package/dist/bone/output/agent/src/routes/tool_call.d.ts +1 -0
- package/dist/bone/output/agent/src/routes/tool_call.js +190 -0
- package/dist/bone/output/agent/src/routes/tool_call.js.map +1 -0
- package/dist/bone/output/agent/src/state_machines/agent_instance.d.ts +9 -0
- package/dist/bone/output/agent/src/state_machines/agent_instance.js +22 -0
- package/dist/bone/output/agent/src/state_machines/agent_instance.js.map +1 -0
- package/dist/bone/output/agent/src/state_machines/build_step.d.ts +9 -0
- package/dist/bone/output/agent/src/state_machines/build_step.js +20 -0
- package/dist/bone/output/agent/src/state_machines/build_step.js.map +1 -0
- package/dist/bone/output/agent/src/state_machines/plan.d.ts +9 -0
- package/dist/bone/output/agent/src/state_machines/plan.js +20 -0
- package/dist/bone/output/agent/src/state_machines/plan.js.map +1 -0
- package/dist/bone/output/agent/src/state_machines/task.d.ts +9 -0
- package/dist/bone/output/agent/src/state_machines/task.js +20 -0
- package/dist/bone/output/agent/src/state_machines/task.js.map +1 -0
- package/dist/bone/output/agent/src/state_machines/tool_call.d.ts +9 -0
- package/dist/bone/output/agent/src/state_machines/tool_call.js +20 -0
- package/dist/bone/output/agent/src/state_machines/tool_call.js.map +1 -0
- package/dist/bone/output/rag/src/algorithms.d.ts +1 -0
- package/dist/bone/output/rag/src/algorithms.js +3 -0
- package/dist/bone/output/rag/src/algorithms.js.map +1 -0
- package/dist/bone/output/rag/src/auth.d.ts +8 -0
- package/dist/bone/output/rag/src/auth.js +56 -0
- package/dist/bone/output/rag/src/auth.js.map +1 -0
- package/dist/bone/output/rag/src/db.d.ts +6 -0
- package/dist/bone/output/rag/src/db.js +63 -0
- package/dist/bone/output/rag/src/db.js.map +1 -0
- package/dist/bone/output/rag/src/events.d.ts +25 -0
- package/dist/bone/output/rag/src/events.js +184 -0
- package/dist/bone/output/rag/src/events.js.map +1 -0
- package/dist/bone/output/rag/src/extensions.d.ts +83 -0
- package/dist/bone/output/rag/src/extensions.js +329 -0
- package/dist/bone/output/rag/src/extensions.js.map +1 -0
- package/dist/bone/output/rag/src/flows.d.ts +24 -0
- package/dist/bone/output/rag/src/flows.js +236 -0
- package/dist/bone/output/rag/src/flows.js.map +1 -0
- package/dist/bone/output/rag/src/logger.d.ts +28 -0
- package/dist/bone/output/rag/src/logger.js +45 -0
- package/dist/bone/output/rag/src/logger.js.map +1 -0
- package/dist/bone/output/rag/src/metrics.d.ts +5 -0
- package/dist/bone/output/rag/src/metrics.js +60 -0
- package/dist/bone/output/rag/src/metrics.js.map +1 -0
- package/dist/bone/output/rag/src/routes/code_chunk.d.ts +1 -0
- package/dist/bone/output/rag/src/routes/code_chunk.js +100 -0
- package/dist/bone/output/rag/src/routes/code_chunk.js.map +1 -0
- package/dist/bone/output/rag/src/routes/code_file.d.ts +1 -0
- package/dist/bone/output/rag/src/routes/code_file.js +127 -0
- package/dist/bone/output/rag/src/routes/code_file.js.map +1 -0
- package/dist/bone/output/rag/src/routes/indexing_job.d.ts +1 -0
- package/dist/bone/output/rag/src/routes/indexing_job.js +113 -0
- package/dist/bone/output/rag/src/routes/indexing_job.js.map +1 -0
- package/dist/bone/output/rag/src/routes/knowledge_base.d.ts +1 -0
- package/dist/bone/output/rag/src/routes/knowledge_base.js +242 -0
- package/dist/bone/output/rag/src/routes/knowledge_base.js.map +1 -0
- package/dist/bone/output/rag/src/routes/memory_entry.d.ts +1 -0
- package/dist/bone/output/rag/src/routes/memory_entry.js +113 -0
- package/dist/bone/output/rag/src/routes/memory_entry.js.map +1 -0
- package/dist/bone/output/rag/src/state_machines/code_file.d.ts +9 -0
- package/dist/bone/output/rag/src/state_machines/code_file.js +21 -0
- package/dist/bone/output/rag/src/state_machines/code_file.js.map +1 -0
- package/dist/bone/output/rag/src/state_machines/indexing_job.d.ts +9 -0
- package/dist/bone/output/rag/src/state_machines/indexing_job.js +20 -0
- package/dist/bone/output/rag/src/state_machines/indexing_job.js.map +1 -0
- package/dist/bone/output/rag/src/state_machines/knowledge_base.d.ts +9 -0
- package/dist/bone/output/rag/src/state_machines/knowledge_base.js +21 -0
- package/dist/bone/output/rag/src/state_machines/knowledge_base.js.map +1 -0
- package/dist/bone/output/rag/src/state_machines/memory_entry.d.ts +9 -0
- package/dist/bone/output/rag/src/state_machines/memory_entry.js +18 -0
- package/dist/bone/output/rag/src/state_machines/memory_entry.js.map +1 -0
- package/dist/bone/output/session/src/algorithms.d.ts +1 -0
- package/dist/bone/output/session/src/algorithms.js +3 -0
- package/dist/bone/output/session/src/algorithms.js.map +1 -0
- package/dist/bone/output/session/src/audit.d.ts +3 -0
- package/dist/bone/output/session/src/audit.js +40 -0
- package/dist/bone/output/session/src/audit.js.map +1 -0
- package/dist/bone/output/session/src/auth.d.ts +8 -0
- package/dist/bone/output/session/src/auth.js +56 -0
- package/dist/bone/output/session/src/auth.js.map +1 -0
- package/dist/bone/output/session/src/db.d.ts +6 -0
- package/dist/bone/output/session/src/db.js +63 -0
- package/dist/bone/output/session/src/db.js.map +1 -0
- package/dist/bone/output/session/src/events.d.ts +26 -0
- package/dist/bone/output/session/src/events.js +212 -0
- package/dist/bone/output/session/src/events.js.map +1 -0
- package/dist/bone/output/session/src/extensions.d.ts +41 -0
- package/dist/bone/output/session/src/extensions.js +217 -0
- package/dist/bone/output/session/src/extensions.js.map +1 -0
- package/dist/bone/output/session/src/logger.d.ts +28 -0
- package/dist/bone/output/session/src/logger.js +44 -0
- package/dist/bone/output/session/src/logger.js.map +1 -0
- package/dist/bone/output/session/src/metrics.d.ts +5 -0
- package/dist/bone/output/session/src/metrics.js +60 -0
- package/dist/bone/output/session/src/metrics.js.map +1 -0
- package/dist/bone/output/session/src/routes/message.d.ts +1 -0
- package/dist/bone/output/session/src/routes/message.js +120 -0
- package/dist/bone/output/session/src/routes/message.js.map +1 -0
- package/dist/bone/output/session/src/routes/part.d.ts +1 -0
- package/dist/bone/output/session/src/routes/part.js +106 -0
- package/dist/bone/output/session/src/routes/part.js.map +1 -0
- package/dist/bone/output/session/src/routes/permission.d.ts +1 -0
- package/dist/bone/output/session/src/routes/permission.js +106 -0
- package/dist/bone/output/session/src/routes/permission.js.map +1 -0
- package/dist/bone/output/session/src/routes/project.d.ts +1 -0
- package/dist/bone/output/session/src/routes/project.js +106 -0
- package/dist/bone/output/session/src/routes/project.js.map +1 -0
- package/dist/bone/output/session/src/routes/session.d.ts +1 -0
- package/dist/bone/output/session/src/routes/session.js +308 -0
- package/dist/bone/output/session/src/routes/session.js.map +1 -0
- package/dist/bone/output/session/src/state_machines/session.d.ts +9 -0
- package/dist/bone/output/session/src/state_machines/session.js +21 -0
- package/dist/bone/output/session/src/state_machines/session.js.map +1 -0
- package/dist/bone/output/session/src/websocket.d.ts +15 -0
- package/dist/bone/output/session/src/websocket.js +215 -0
- package/dist/bone/output/session/src/websocket.js.map +1 -0
- package/dist/bone/output/workspace/src/algorithms.d.ts +1 -0
- package/dist/bone/output/workspace/src/algorithms.js +3 -0
- package/dist/bone/output/workspace/src/algorithms.js.map +1 -0
- package/dist/bone/output/workspace/src/auth.d.ts +8 -0
- package/dist/bone/output/workspace/src/auth.js +56 -0
- package/dist/bone/output/workspace/src/auth.js.map +1 -0
- package/dist/bone/output/workspace/src/db.d.ts +6 -0
- package/dist/bone/output/workspace/src/db.js +63 -0
- package/dist/bone/output/workspace/src/db.js.map +1 -0
- package/dist/bone/output/workspace/src/events.d.ts +25 -0
- package/dist/bone/output/workspace/src/events.js +184 -0
- package/dist/bone/output/workspace/src/events.js.map +1 -0
- package/dist/bone/output/workspace/src/logger.d.ts +28 -0
- package/dist/bone/output/workspace/src/logger.js +45 -0
- package/dist/bone/output/workspace/src/logger.js.map +1 -0
- package/dist/bone/output/workspace/src/metrics.d.ts +5 -0
- package/dist/bone/output/workspace/src/metrics.js +60 -0
- package/dist/bone/output/workspace/src/metrics.js.map +1 -0
- package/dist/bone/output/workspace/src/routes/codebase.d.ts +1 -0
- package/dist/bone/output/workspace/src/routes/codebase.js +113 -0
- package/dist/bone/output/workspace/src/routes/codebase.js.map +1 -0
- package/dist/bone/output/workspace/src/routes/snapshot.d.ts +1 -0
- package/dist/bone/output/workspace/src/routes/snapshot.js +151 -0
- package/dist/bone/output/workspace/src/routes/snapshot.js.map +1 -0
- package/dist/bone/output/workspace/src/routes/workspace.d.ts +1 -0
- package/dist/bone/output/workspace/src/routes/workspace.js +209 -0
- package/dist/bone/output/workspace/src/routes/workspace.js.map +1 -0
- package/dist/bone/output/workspace/src/state_machines/codebase.d.ts +9 -0
- package/dist/bone/output/workspace/src/state_machines/codebase.js +19 -0
- package/dist/bone/output/workspace/src/state_machines/codebase.js.map +1 -0
- package/dist/bone/output/workspace/src/state_machines/snapshot.d.ts +9 -0
- package/dist/bone/output/workspace/src/state_machines/snapshot.js +18 -0
- package/dist/bone/output/workspace/src/state_machines/snapshot.js.map +1 -0
- package/dist/bone/output/workspace/src/state_machines/workspace.d.ts +9 -0
- package/dist/bone/output/workspace/src/state_machines/workspace.js +19 -0
- package/dist/bone/output/workspace/src/state_machines/workspace.js.map +1 -0
- package/dist/compat/opencode_adapter.d.ts +25 -0
- package/dist/compat/opencode_adapter.js +599 -0
- package/dist/compat/opencode_adapter.js.map +1 -0
- package/dist/extensions/chunker.d.ts +24 -0
- package/dist/extensions/chunker.js +360 -0
- package/dist/extensions/chunker.js.map +1 -0
- package/dist/extensions/embedding_provider.d.ts +18 -0
- package/dist/extensions/embedding_provider.js +150 -0
- package/dist/extensions/embedding_provider.js.map +1 -0
- package/dist/extensions/llm_provider.d.ts +33 -0
- package/dist/extensions/llm_provider.js +338 -0
- package/dist/extensions/llm_provider.js.map +1 -0
- package/dist/extensions/mcp_bridge.d.ts +44 -0
- package/dist/extensions/mcp_bridge.js +151 -0
- package/dist/extensions/mcp_bridge.js.map +1 -0
- package/dist/extensions/rag_search.d.ts +38 -0
- package/dist/extensions/rag_search.js +242 -0
- package/dist/extensions/rag_search.js.map +1 -0
- package/dist/extensions/snapshot.d.ts +14 -0
- package/dist/extensions/snapshot.js +158 -0
- package/dist/extensions/snapshot.js.map +1 -0
- package/dist/extensions/tool_executor.d.ts +28 -0
- package/dist/extensions/tool_executor.js +268 -0
- package/dist/extensions/tool_executor.js.map +1 -0
- package/dist/src/cli.d.ts +15 -0
- package/dist/src/cli.js +687 -0
- package/dist/src/cli.js.map +1 -0
- package/dist/src/config.d.ts +44 -0
- package/dist/src/config.js +165 -0
- package/dist/src/config.js.map +1 -0
- package/dist/src/context_builder.d.ts +51 -0
- package/dist/src/context_builder.js +558 -0
- package/dist/src/context_builder.js.map +1 -0
- package/dist/src/db_adapter.d.ts +24 -0
- package/dist/src/db_adapter.js +341 -0
- package/dist/src/db_adapter.js.map +1 -0
- package/dist/src/engine/session/compaction_logic.d.ts +11 -0
- package/dist/src/engine/session/compaction_logic.js +113 -0
- package/dist/src/engine/session/compaction_logic.js.map +1 -0
- package/dist/src/engine/session/instruction_loader.d.ts +5 -0
- package/dist/src/engine/session/instruction_loader.js +78 -0
- package/dist/src/engine/session/instruction_loader.js.map +1 -0
- package/dist/src/engine/session/overflow_check.d.ts +14 -0
- package/dist/src/engine/session/overflow_check.js +45 -0
- package/dist/src/engine/session/overflow_check.js.map +1 -0
- package/dist/src/engine/session/prompt.d.ts +45 -0
- package/dist/src/engine/session/prompt.js +584 -0
- package/dist/src/engine/session/prompt.js.map +1 -0
- package/dist/src/engine/session/provider_transform.d.ts +59 -0
- package/dist/src/engine/session/provider_transform.js +193 -0
- package/dist/src/engine/session/provider_transform.js.map +1 -0
- package/dist/src/engine/session/retry_logic.d.ts +12 -0
- package/dist/src/engine/session/retry_logic.js +72 -0
- package/dist/src/engine/session/retry_logic.js.map +1 -0
- package/dist/src/engine/session/system_prompt.d.ts +9 -0
- package/dist/src/engine/session/system_prompt.js +96 -0
- package/dist/src/engine/session/system_prompt.js.map +1 -0
- package/dist/src/engine/session/tool_registry.d.ts +5 -0
- package/dist/src/engine/session/tool_registry.js +117 -0
- package/dist/src/engine/session/tool_registry.js.map +1 -0
- package/dist/src/export.d.ts +13 -0
- package/dist/src/export.js +103 -0
- package/dist/src/export.js.map +1 -0
- package/dist/src/mdns.d.ts +7 -0
- package/dist/src/mdns.js +60 -0
- package/dist/src/mdns.js.map +1 -0
- package/dist/src/rag_worker.d.ts +38 -0
- package/dist/src/rag_worker.js +435 -0
- package/dist/src/rag_worker.js.map +1 -0
- package/dist/src/server.d.ts +11 -0
- package/dist/src/server.js +214 -0
- package/dist/src/server.js.map +1 -0
- package/dist/src/stats.d.ts +45 -0
- package/dist/src/stats.js +233 -0
- package/dist/src/stats.js.map +1 -0
- package/dist/src/tui.d.ts +29 -0
- package/dist/src/tui.js +1053 -0
- package/dist/src/tui.js.map +1 -0
- package/package.json +21 -5
- package/src/cli.ts +314 -113
- package/src/db_adapter.ts +354 -0
- package/src/engine/account/account.sql.ts +39 -39
- package/src/engine/account/account.ts +456 -456
- package/src/engine/account/repo.ts +166 -166
- package/src/engine/account/schema.ts +99 -99
- package/src/engine/account/url.ts +8 -8
- package/src/engine/acp/README.md +174 -174
- package/src/engine/acp/agent.ts +1968 -1968
- package/src/engine/acp/runtime.ts +22 -22
- package/src/engine/acp/session.ts +122 -122
- package/src/engine/acp/types.ts +24 -24
- package/src/engine/agent/agent.ts +463 -463
- package/src/engine/agent/generate.txt +75 -75
- package/src/engine/agent/prompt/compaction.txt +9 -9
- package/src/engine/agent/prompt/explore.txt +18 -18
- package/src/engine/agent/prompt/scout.txt +36 -36
- package/src/engine/agent/prompt/summary.txt +11 -11
- package/src/engine/agent/prompt/title.txt +44 -44
- package/src/engine/agent/subagent-permissions.ts +34 -34
- package/src/engine/auth/index.ts +96 -96
- package/src/engine/background/background/job.ts +200 -200
- package/src/engine/background/job.ts +200 -200
- package/src/engine/bus/bus-event.ts +45 -45
- package/src/engine/bus/global.ts +22 -22
- package/src/engine/bus/index.ts +203 -203
- package/src/engine/command/command/index.ts +181 -181
- package/src/engine/command/command/template/initialize.txt +66 -66
- package/src/engine/command/command/template/review.txt +101 -101
- package/src/engine/command/index.ts +181 -181
- package/src/engine/command/template/initialize.txt +66 -66
- package/src/engine/command/template/review.txt +101 -101
- package/src/engine/config/agent.ts +172 -172
- package/src/engine/config/attachment.ts +25 -25
- package/src/engine/config/command.ts +62 -62
- package/src/engine/config/config.ts +833 -833
- package/src/engine/config/console-state.ts +14 -14
- package/src/engine/config/entry-name.ts +16 -16
- package/src/engine/config/error.ts +23 -23
- package/src/engine/config/formatter.ts +13 -13
- package/src/engine/config/layout.ts +6 -6
- package/src/engine/config/lsp.ts +43 -43
- package/src/engine/config/managed.ts +71 -71
- package/src/engine/config/markdown.ts +96 -96
- package/src/engine/config/mcp.ts +56 -56
- package/src/engine/config/model-id.ts +5 -5
- package/src/engine/config/parse.ts +79 -79
- package/src/engine/config/paths.ts +45 -45
- package/src/engine/config/permission.ts +58 -58
- package/src/engine/config/plugin.ts +84 -84
- package/src/engine/config/provider.ts +111 -111
- package/src/engine/config/reference.ts +23 -23
- package/src/engine/config/server.ts +19 -19
- package/src/engine/config/skills.ts +14 -14
- package/src/engine/config/variable.ts +90 -90
- package/src/engine/control-plane/adapters/index.ts +41 -41
- package/src/engine/control-plane/adapters/worktree.ts +96 -96
- package/src/engine/control-plane/dev/README.md +19 -19
- package/src/engine/control-plane/dev/debug-workspace-plugin.ts +73 -73
- package/src/engine/control-plane/schema.ts +14 -14
- package/src/engine/control-plane/types.ts +59 -59
- package/src/engine/control-plane/util.ts +39 -39
- package/src/engine/control-plane/workspace-adapter-runtime.ts +51 -51
- package/src/engine/control-plane/workspace-context.ts +26 -26
- package/src/engine/control-plane/workspace.sql.ts +20 -20
- package/src/engine/control-plane/workspace.ts +1072 -1072
- package/src/engine/data-migration.ts +161 -161
- package/src/engine/effect/app-runtime.ts +143 -143
- package/src/engine/effect/bootstrap-runtime.ts +29 -29
- package/src/engine/effect/bridge.ts +84 -84
- package/src/engine/effect/config-service.ts +67 -67
- package/src/engine/effect/instance-ref.ts +11 -11
- package/src/engine/effect/instance-registry.ts +12 -12
- package/src/engine/effect/instance-state.ts +72 -72
- package/src/engine/effect/promise.ts +17 -17
- package/src/engine/effect/run-service.ts +47 -47
- package/src/engine/effect/runner.ts +217 -217
- package/src/engine/effect/runtime-flags.ts +74 -74
- package/src/engine/effect/service-use.ts +38 -38
- package/src/engine/env/index.ts +37 -37
- package/src/engine/event-v2-bridge.ts +89 -89
- package/src/engine/file/file/ignore.ts +81 -81
- package/src/engine/file/file/index.ts +651 -651
- package/src/engine/file/file/protected.ts +59 -59
- package/src/engine/file/file/ripgrep.ts +481 -481
- package/src/engine/file/file/watcher.ts +167 -167
- package/src/engine/file/ignore.ts +81 -81
- package/src/engine/file/index.ts +651 -651
- package/src/engine/file/protected.ts +59 -59
- package/src/engine/file/ripgrep.ts +481 -481
- package/src/engine/file/watcher.ts +167 -167
- package/src/engine/format/format/formatter.ts +404 -404
- package/src/engine/format/format/index.ts +209 -209
- package/src/engine/format/formatter.ts +404 -404
- package/src/engine/format/index.ts +209 -209
- package/src/engine/git/git/index.ts +347 -347
- package/src/engine/git/index.ts +347 -347
- package/src/engine/id/id.ts +80 -80
- package/src/engine/ide/index.ts +70 -70
- package/src/engine/image/image/image.ts +176 -176
- package/src/engine/image/image.ts +176 -176
- package/src/engine/index.ts +251 -251
- package/src/engine/installation/index.ts +327 -327
- package/src/engine/lsp/client.ts +707 -707
- package/src/engine/lsp/diagnostic.ts +29 -29
- package/src/engine/lsp/language.ts +121 -121
- package/src/engine/lsp/launch.ts +21 -21
- package/src/engine/lsp/lsp/client.ts +707 -707
- package/src/engine/lsp/lsp/diagnostic.ts +29 -29
- package/src/engine/lsp/lsp/language.ts +121 -121
- package/src/engine/lsp/lsp/launch.ts +21 -21
- package/src/engine/lsp/lsp/lsp.ts +507 -507
- package/src/engine/lsp/lsp/server.ts +2064 -2064
- package/src/engine/lsp/lsp.ts +507 -507
- package/src/engine/lsp/server.ts +2064 -2064
- package/src/engine/mcp/auth.ts +146 -146
- package/src/engine/mcp/index.ts +958 -958
- package/src/engine/mcp/mcp/auth.ts +146 -146
- package/src/engine/mcp/mcp/index.ts +958 -958
- package/src/engine/mcp/mcp/oauth-callback.ts +232 -232
- package/src/engine/mcp/mcp/oauth-provider.ts +214 -214
- package/src/engine/mcp/oauth-callback.ts +232 -232
- package/src/engine/mcp/oauth-provider.ts +214 -214
- package/src/engine/node.ts +6 -6
- package/src/engine/patch/index.ts +689 -689
- package/src/engine/patch/patch/index.ts +689 -689
- package/src/engine/permission/arity.ts +163 -163
- package/src/engine/permission/evaluate.ts +15 -15
- package/src/engine/permission/index.ts +306 -306
- package/src/engine/permission/permission/arity.ts +163 -163
- package/src/engine/permission/permission/evaluate.ts +15 -15
- package/src/engine/permission/permission/index.ts +306 -306
- package/src/engine/permission/permission/schema.ts +13 -13
- package/src/engine/permission/schema.ts +13 -13
- package/src/engine/plugin/azure.ts +26 -26
- package/src/engine/plugin/cloudflare.ts +76 -76
- package/src/engine/plugin/codex.ts +622 -622
- package/src/engine/plugin/digitalocean.ts +411 -411
- package/src/engine/plugin/github-copilot/copilot.ts +394 -394
- package/src/engine/plugin/github-copilot/models.ts +196 -196
- package/src/engine/plugin/index.ts +295 -295
- package/src/engine/plugin/install.ts +439 -439
- package/src/engine/plugin/loader.ts +216 -216
- package/src/engine/plugin/meta.ts +188 -188
- package/src/engine/plugin/shared.ts +323 -323
- package/src/engine/project/bootstrap-service.ts +9 -9
- package/src/engine/project/bootstrap.ts +75 -75
- package/src/engine/project/instance-context.ts +24 -24
- package/src/engine/project/instance-layer.ts +11 -11
- package/src/engine/project/instance-runtime.ts +16 -16
- package/src/engine/project/instance-store.ts +193 -193
- package/src/engine/project/project.sql.ts +17 -17
- package/src/engine/project/project.ts +537 -537
- package/src/engine/project/schema.ts +13 -13
- package/src/engine/project/vcs.ts +405 -405
- package/src/engine/provider/auth.ts +225 -225
- package/src/engine/provider/error.ts +204 -204
- package/src/engine/provider/model-status.ts +8 -8
- package/src/engine/provider/provider.ts +1843 -1843
- package/src/engine/provider/schema.ts +30 -30
- package/src/engine/provider/transform.ts +1376 -1376
- package/src/engine/pty/index.ts +365 -365
- package/src/engine/pty/input.ts +24 -24
- package/src/engine/pty/pty/index.ts +365 -365
- package/src/engine/pty/pty/input.ts +24 -24
- package/src/engine/pty/pty/pty.bun.ts +26 -26
- package/src/engine/pty/pty/pty.node.ts +27 -27
- package/src/engine/pty/pty/pty.ts +25 -25
- package/src/engine/pty/pty/schema.ts +14 -14
- package/src/engine/pty/pty/ticket.ts +68 -68
- package/src/engine/pty/pty.bun.ts +26 -26
- package/src/engine/pty/pty.node.ts +27 -27
- package/src/engine/pty/pty.ts +25 -25
- package/src/engine/pty/schema.ts +14 -14
- package/src/engine/pty/ticket.ts +68 -68
- package/src/engine/question/index.ts +213 -213
- package/src/engine/question/question/index.ts +213 -213
- package/src/engine/question/question/schema.ts +10 -10
- package/src/engine/question/schema.ts +10 -10
- package/src/engine/reference/reference/reference.ts +241 -241
- package/src/engine/reference/reference/repository-cache.ts +147 -147
- package/src/engine/reference/reference.ts +241 -241
- package/src/engine/reference/repository-cache.ts +147 -147
- package/src/engine/session/compaction.ts +651 -651
- package/src/engine/session/instruction.ts +238 -238
- package/src/engine/session/llm.ts +459 -459
- package/src/engine/session/message-error.ts +14 -14
- package/src/engine/session/message-v2.ts +1202 -1202
- package/src/engine/session/message.ts +146 -146
- package/src/engine/session/overflow.ts +32 -32
- package/src/engine/session/processor.ts +823 -823
- package/src/engine/session/prompt/anthropic.txt +105 -105
- package/src/engine/session/prompt/beast.txt +147 -147
- package/src/engine/session/prompt/build-switch.txt +5 -5
- package/src/engine/session/prompt/codex.txt +79 -79
- package/src/engine/session/prompt/copilot-gpt-5.txt +143 -143
- package/src/engine/session/prompt/default.txt +105 -105
- package/src/engine/session/prompt/gemini.txt +155 -155
- package/src/engine/session/prompt/gpt.txt +107 -107
- package/src/engine/session/prompt/kimi.txt +95 -95
- package/src/engine/session/prompt/max-steps.txt +15 -15
- package/src/engine/session/prompt/plan-reminder-anthropic.txt +67 -67
- package/src/engine/session/prompt/plan.txt +26 -26
- package/src/engine/session/prompt/trinity.txt +97 -97
- package/src/engine/session/prompt.ts +66 -9
- package/src/engine/session/retry.ts +200 -200
- package/src/engine/session/revert.ts +162 -162
- package/src/engine/session/run-state.ts +153 -153
- package/src/engine/session/schema.ts +26 -26
- package/src/engine/session/session.sql.ts +137 -137
- package/src/engine/session/session.ts +1011 -1011
- package/src/engine/session/status.ts +94 -94
- package/src/engine/session/summary.ts +164 -164
- package/src/engine/session/system.ts +84 -84
- package/src/engine/session/todo.ts +81 -81
- package/src/engine/share/session.ts +61 -61
- package/src/engine/share/share-next.ts +376 -376
- package/src/engine/share/share.sql.ts +13 -13
- package/src/engine/shell/shell/shell.ts +215 -215
- package/src/engine/shell/shell.ts +215 -215
- package/src/engine/skill/discovery.ts +116 -116
- package/src/engine/skill/index.ts +336 -336
- package/src/engine/skill/prompt/customize-opencode.md +377 -377
- package/src/engine/skill/skill/discovery.ts +116 -116
- package/src/engine/skill/skill/index.ts +336 -336
- package/src/engine/skill/skill/prompt/customize-opencode.md +377 -377
- package/src/engine/snapshot/index.ts +762 -762
- package/src/engine/snapshot/snapshot/index.ts +762 -762
- package/src/engine/sync/README.md +179 -179
- package/src/engine/sync/event.sql.ts +17 -17
- package/src/engine/sync/index.ts +410 -410
- package/src/engine/sync/schema.ts +11 -11
- package/src/engine/temporary.ts +33 -33
- package/src/engine/tool/apply_patch.ts +313 -313
- package/src/engine/tool/apply_patch.txt +33 -33
- package/src/engine/tool/edit.ts +711 -711
- package/src/engine/tool/edit.txt +10 -10
- package/src/engine/tool/external-directory.ts +49 -49
- package/src/engine/tool/glob.ts +103 -103
- package/src/engine/tool/glob.txt +6 -6
- package/src/engine/tool/grep.ts +156 -156
- package/src/engine/tool/grep.txt +8 -8
- package/src/engine/tool/invalid.ts +21 -21
- package/src/engine/tool/json-schema.ts +164 -164
- package/src/engine/tool/lsp.ts +113 -113
- package/src/engine/tool/lsp.txt +24 -24
- package/src/engine/tool/mcp-websearch.ts +96 -96
- package/src/engine/tool/plan-enter.txt +14 -14
- package/src/engine/tool/plan-exit.txt +13 -13
- package/src/engine/tool/plan.ts +78 -78
- package/src/engine/tool/question.ts +44 -44
- package/src/engine/tool/question.txt +10 -10
- package/src/engine/tool/read.ts +337 -337
- package/src/engine/tool/read.txt +14 -14
- package/src/engine/tool/registry.ts +472 -472
- package/src/engine/tool/repo_clone.ts +80 -80
- package/src/engine/tool/repo_clone.txt +5 -5
- package/src/engine/tool/repo_overview.ts +279 -279
- package/src/engine/tool/repo_overview.txt +4 -4
- package/src/engine/tool/schema.ts +14 -14
- package/src/engine/tool/shell/id.ts +19 -19
- package/src/engine/tool/shell/prompt.ts +295 -295
- package/src/engine/tool/shell/shell.txt +77 -77
- package/src/engine/tool/shell.ts +647 -647
- package/src/engine/tool/skill.ts +75 -75
- package/src/engine/tool/skill.txt +5 -5
- package/src/engine/tool/task.ts +337 -337
- package/src/engine/tool/task.txt +58 -58
- package/src/engine/tool/task_status.ts +179 -179
- package/src/engine/tool/task_status.txt +13 -13
- package/src/engine/tool/todo.ts +57 -57
- package/src/engine/tool/todowrite.txt +167 -167
- package/src/engine/tool/tool/apply_patch.ts +313 -313
- package/src/engine/tool/tool/apply_patch.txt +33 -33
- package/src/engine/tool/tool/edit.ts +711 -711
- package/src/engine/tool/tool/edit.txt +10 -10
- package/src/engine/tool/tool/external-directory.ts +49 -49
- package/src/engine/tool/tool/glob.ts +103 -103
- package/src/engine/tool/tool/glob.txt +6 -6
- package/src/engine/tool/tool/grep.ts +156 -156
- package/src/engine/tool/tool/grep.txt +8 -8
- package/src/engine/tool/tool/invalid.ts +21 -21
- package/src/engine/tool/tool/json-schema.ts +164 -164
- package/src/engine/tool/tool/lsp.ts +113 -113
- package/src/engine/tool/tool/lsp.txt +24 -24
- package/src/engine/tool/tool/mcp-websearch.ts +96 -96
- package/src/engine/tool/tool/plan-enter.txt +14 -14
- package/src/engine/tool/tool/plan-exit.txt +13 -13
- package/src/engine/tool/tool/plan.ts +78 -78
- package/src/engine/tool/tool/question.ts +44 -44
- package/src/engine/tool/tool/question.txt +10 -10
- package/src/engine/tool/tool/read.ts +337 -337
- package/src/engine/tool/tool/read.txt +14 -14
- package/src/engine/tool/tool/registry.ts +472 -472
- package/src/engine/tool/tool/repo_clone.ts +80 -80
- package/src/engine/tool/tool/repo_clone.txt +5 -5
- package/src/engine/tool/tool/repo_overview.ts +279 -279
- package/src/engine/tool/tool/repo_overview.txt +4 -4
- package/src/engine/tool/tool/schema.ts +14 -14
- package/src/engine/tool/tool/shell/id.ts +19 -19
- package/src/engine/tool/tool/shell/prompt.ts +295 -295
- package/src/engine/tool/tool/shell/shell.txt +77 -77
- package/src/engine/tool/tool/shell.ts +647 -647
- package/src/engine/tool/tool/skill.ts +75 -75
- package/src/engine/tool/tool/skill.txt +5 -5
- package/src/engine/tool/tool/task.ts +337 -337
- package/src/engine/tool/tool/task.txt +58 -58
- package/src/engine/tool/tool/task_status.ts +179 -179
- package/src/engine/tool/tool/task_status.txt +13 -13
- package/src/engine/tool/tool/todo.ts +57 -57
- package/src/engine/tool/tool/todowrite.txt +167 -167
- package/src/engine/tool/tool/tool.ts +164 -164
- package/src/engine/tool/tool/truncate.ts +160 -160
- package/src/engine/tool/tool/truncation-dir.ts +4 -4
- package/src/engine/tool/tool/webfetch.ts +192 -192
- package/src/engine/tool/tool/webfetch.txt +13 -13
- package/src/engine/tool/tool/websearch.ts +143 -143
- package/src/engine/tool/tool/websearch.txt +14 -14
- package/src/engine/tool/tool/write.ts +104 -104
- package/src/engine/tool/tool/write.txt +8 -8
- package/src/engine/tool/tool.ts +164 -164
- package/src/engine/tool/truncate.ts +160 -160
- package/src/engine/tool/truncation-dir.ts +4 -4
- package/src/engine/tool/webfetch.ts +192 -192
- package/src/engine/tool/webfetch.txt +13 -13
- package/src/engine/tool/websearch.ts +143 -143
- package/src/engine/tool/websearch.txt +14 -14
- package/src/engine/tool/write.ts +104 -104
- package/src/engine/tool/write.txt +8 -8
- package/src/engine/util/archive.ts +17 -17
- package/src/engine/util/bom.ts +31 -31
- package/src/engine/util/data-url.ts +9 -9
- package/src/engine/util/defer.ts +10 -10
- package/src/engine/util/effect-http-client.ts +11 -11
- package/src/engine/util/error.ts +88 -88
- package/src/engine/util/filesystem.ts +252 -252
- package/src/engine/util/format.ts +20 -20
- package/src/engine/util/iife.ts +3 -3
- package/src/engine/util/lazy.ts +20 -20
- package/src/engine/util/local-context.ts +25 -25
- package/src/engine/util/locale.ts +86 -86
- package/src/engine/util/media.ts +26 -26
- package/src/engine/util/process.ts +176 -176
- package/src/engine/util/queue.ts +32 -32
- package/src/engine/util/record.ts +3 -3
- package/src/engine/util/repository.ts +158 -158
- package/src/engine/util/rpc.ts +66 -66
- package/src/engine/util/signal.ts +12 -12
- package/src/engine/util/timeout.ts +13 -13
- package/src/engine/util/token.ts +7 -7
- package/src/engine/util/util/archive.ts +17 -17
- package/src/engine/util/util/bom.ts +31 -31
- package/src/engine/util/util/data-url.ts +9 -9
- package/src/engine/util/util/defer.ts +10 -10
- package/src/engine/util/util/effect-http-client.ts +11 -11
- package/src/engine/util/util/error.ts +88 -88
- package/src/engine/util/util/filesystem.ts +252 -252
- package/src/engine/util/util/format.ts +20 -20
- package/src/engine/util/util/iife.ts +3 -3
- package/src/engine/util/util/lazy.ts +20 -20
- package/src/engine/util/util/local-context.ts +25 -25
- package/src/engine/util/util/locale.ts +86 -86
- package/src/engine/util/util/media.ts +26 -26
- package/src/engine/util/util/process.ts +176 -176
- package/src/engine/util/util/queue.ts +32 -32
- package/src/engine/util/util/record.ts +3 -3
- package/src/engine/util/util/repository.ts +158 -158
- package/src/engine/util/util/rpc.ts +66 -66
- package/src/engine/util/util/signal.ts +12 -12
- package/src/engine/util/util/timeout.ts +13 -13
- package/src/engine/util/util/token.ts +7 -7
- package/src/engine/util/util/which.ts +14 -14
- package/src/engine/util/util/wildcard.ts +59 -59
- package/src/engine/util/which.ts +14 -14
- package/src/engine/util/wildcard.ts +59 -59
- package/src/engine/worktree/index.ts +621 -621
- package/src/export.ts +122 -0
- package/src/mdns.ts +53 -0
- package/src/server.ts +151 -156
- package/src/stats.ts +290 -0
- package/src/tui.ts +964 -480
|
@@ -1,326 +1,326 @@
|
|
|
1
|
-
// Generated by BoneScript compiler. DO NOT EDIT.
|
|
2
|
-
// Regression tests derived from capability declarations.
|
|
3
|
-
// Run: npx ts-node src/tests.ts
|
|
4
|
-
|
|
5
|
-
import * as http from "http";
|
|
6
|
-
|
|
7
|
-
const BASE_URL = process.env.TEST_BASE_URL || "http://localhost:3000";
|
|
8
|
-
const AUTH_TOKEN = process.env.TEST_AUTH_TOKEN || "";
|
|
9
|
-
|
|
10
|
-
let passed = 0;
|
|
11
|
-
let failed = 0;
|
|
12
|
-
|
|
13
|
-
async function request(method: string, path: string, body?: any): Promise<{ status: number; data: any }> {
|
|
14
|
-
const url = new URL(path, BASE_URL);
|
|
15
|
-
const res = await fetch(url.toString(), {
|
|
16
|
-
method,
|
|
17
|
-
headers: {
|
|
18
|
-
"Content-Type": "application/json",
|
|
19
|
-
...(AUTH_TOKEN ? { "Authorization": `Bearer ${AUTH_TOKEN}` } : {}),
|
|
20
|
-
},
|
|
21
|
-
body: body ? JSON.stringify(body) : undefined,
|
|
22
|
-
});
|
|
23
|
-
const data = await res.json().catch(() => ({}));
|
|
24
|
-
return { status: res.status, data };
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
async function test(name: string, fn: () => Promise<void>): Promise<void> {
|
|
28
|
-
try {
|
|
29
|
-
await fn();
|
|
30
|
-
console.log(` ✓ ${name}`);
|
|
31
|
-
passed++;
|
|
32
|
-
} catch (e: any) {
|
|
33
|
-
console.log(` ✗ ${name}: ${e.message}`);
|
|
34
|
-
failed++;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
function assert(condition: boolean, message: string): void {
|
|
39
|
-
if (!condition) throw new Error(message);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
(async () => {
|
|
43
|
-
// ─── ProjectService Tests ─────────────────────────────────────────────────────
|
|
44
|
-
|
|
45
|
-
console.log("\nProjectService — CRUD");
|
|
46
|
-
|
|
47
|
-
let __project_id: string;
|
|
48
|
-
|
|
49
|
-
await test("POST /projects — creates entity", async () => {
|
|
50
|
-
const { status, data } = await request("POST", "/projects", {"root_commit_hash":"test_value","worktree":"test_value","vcs":"test_value","name":"test_value","sandboxes":{}});
|
|
51
|
-
assert(status === 201, `Expected 201, got ${status}: ${JSON.stringify(data)}`);
|
|
52
|
-
assert(data.id, "Response must have id");
|
|
53
|
-
__project_id = data.id;
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
await test("GET /projects/:id — reads entity", async () => {
|
|
57
|
-
const { status, data } = await request("GET", `/projects/${__project_id}`);
|
|
58
|
-
assert(status === 200, `Expected 200, got ${status}`);
|
|
59
|
-
assert(data.id === __project_id, "ID must match");
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
await test("GET /projects — lists entities", async () => {
|
|
63
|
-
const { status, data } = await request("GET", "/projects");
|
|
64
|
-
assert(status === 200, `Expected 200, got ${status}`);
|
|
65
|
-
assert(Array.isArray(data.items), "Response must have items array");
|
|
66
|
-
assert(typeof data.total === "number", "Response must have total");
|
|
67
|
-
});
|
|
68
|
-
|
|
69
|
-
await test("GET /projects — rejects unauthenticated", async () => {
|
|
70
|
-
const res = await fetch(`${BASE_URL}/projects`);
|
|
71
|
-
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
await test("DELETE /projects/:id — deletes entity", async () => {
|
|
75
|
-
const { status } = await request("DELETE", `/projects/${__project_id}`);
|
|
76
|
-
assert(status === 204, `Expected 204, got ${status}`);
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
await test("GET /projects/:id — returns 404 after delete", async () => {
|
|
80
|
-
const { status } = await request("GET", `/projects/${__project_id}`);
|
|
81
|
-
assert(status === 404, `Expected 404, got ${status}`);
|
|
82
|
-
});
|
|
83
|
-
|
|
84
|
-
// ─── SessionService Tests ─────────────────────────────────────────────────────
|
|
85
|
-
|
|
86
|
-
console.log("\nSessionService — CRUD");
|
|
87
|
-
|
|
88
|
-
let __session_id: string;
|
|
89
|
-
|
|
90
|
-
await test("POST /sessions — creates entity", async () => {
|
|
91
|
-
const { status, data } = await request("POST", "/sessions", {"slug":"test_value","project_id":"00000000-0000-0000-0000-000000000001","workspace_id":null,"parent_id":null,"directory":"test_value","title":"test_value","version":"test_value","share_url":null,"summary_additions":null,"summary_deletions":null,"summary_files":null,"summary_diffs":null,"revert_data":null,"permission_ruleset":null});
|
|
92
|
-
assert(status === 201, `Expected 201, got ${status}: ${JSON.stringify(data)}`);
|
|
93
|
-
assert(data.id, "Response must have id");
|
|
94
|
-
__session_id = data.id;
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
await test("GET /sessions/:id — reads entity", async () => {
|
|
98
|
-
const { status, data } = await request("GET", `/sessions/${__session_id}`);
|
|
99
|
-
assert(status === 200, `Expected 200, got ${status}`);
|
|
100
|
-
assert(data.id === __session_id, "ID must match");
|
|
101
|
-
});
|
|
102
|
-
|
|
103
|
-
await test("GET /sessions — lists entities", async () => {
|
|
104
|
-
const { status, data } = await request("GET", "/sessions");
|
|
105
|
-
assert(status === 200, `Expected 200, got ${status}`);
|
|
106
|
-
assert(Array.isArray(data.items), "Response must have items array");
|
|
107
|
-
assert(typeof data.total === "number", "Response must have total");
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
await test("GET /sessions — rejects unauthenticated", async () => {
|
|
111
|
-
const res = await fetch(`${BASE_URL}/sessions`);
|
|
112
|
-
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
113
|
-
});
|
|
114
|
-
|
|
115
|
-
await test("POST /sessions/archive-session — capability executes", async () => {
|
|
116
|
-
const { status, data } = await request("POST", "/sessions/archive-session", {
|
|
117
|
-
session_id: __session_id,
|
|
118
|
-
});
|
|
119
|
-
// Capability may return 200 (success) or 422 (precondition failed) — both are valid
|
|
120
|
-
assert([200, 422].includes(status), `Expected 200 or 422, got ${status}: ${JSON.stringify(data)}`);
|
|
121
|
-
});
|
|
122
|
-
|
|
123
|
-
await test("POST /sessions/archive-session — returns 401 without auth", async () => {
|
|
124
|
-
const res = await fetch(`${BASE_URL}/sessions/archive-session`, { method: "POST" });
|
|
125
|
-
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
126
|
-
});
|
|
127
|
-
|
|
128
|
-
await test("POST /sessions/delete-session — capability executes", async () => {
|
|
129
|
-
const { status, data } = await request("POST", "/sessions/delete-session", {
|
|
130
|
-
session_id: __session_id,
|
|
131
|
-
});
|
|
132
|
-
// Capability may return 200 (success) or 422 (precondition failed) — both are valid
|
|
133
|
-
assert([200, 422].includes(status), `Expected 200 or 422, got ${status}: ${JSON.stringify(data)}`);
|
|
134
|
-
});
|
|
135
|
-
|
|
136
|
-
await test("POST /sessions/delete-session — returns 401 without auth", async () => {
|
|
137
|
-
const res = await fetch(`${BASE_URL}/sessions/delete-session`, { method: "POST" });
|
|
138
|
-
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
139
|
-
});
|
|
140
|
-
|
|
141
|
-
await test("POST /sessions/add-message — capability executes", async () => {
|
|
142
|
-
const { status, data } = await request("POST", "/sessions/add-message", {
|
|
143
|
-
session_id: __session_id,
|
|
144
|
-
});
|
|
145
|
-
// Capability may return 200 (success) or 422 (precondition failed) — both are valid
|
|
146
|
-
assert([200, 422].includes(status), `Expected 200 or 422, got ${status}: ${JSON.stringify(data)}`);
|
|
147
|
-
});
|
|
148
|
-
|
|
149
|
-
await test("POST /sessions/add-message — returns 401 without auth", async () => {
|
|
150
|
-
const res = await fetch(`${BASE_URL}/sessions/add-message`, { method: "POST" });
|
|
151
|
-
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
152
|
-
});
|
|
153
|
-
|
|
154
|
-
await test("POST /sessions/update-part — capability executes", async () => {
|
|
155
|
-
const { status, data } = await request("POST", "/sessions/update-part", {
|
|
156
|
-
session_id: __session_id,
|
|
157
|
-
});
|
|
158
|
-
// Capability may return 200 (success) or 422 (precondition failed) — both are valid
|
|
159
|
-
assert([200, 422].includes(status), `Expected 200 or 422, got ${status}: ${JSON.stringify(data)}`);
|
|
160
|
-
});
|
|
161
|
-
|
|
162
|
-
await test("POST /sessions/update-part — returns 401 without auth", async () => {
|
|
163
|
-
const res = await fetch(`${BASE_URL}/sessions/update-part`, { method: "POST" });
|
|
164
|
-
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
165
|
-
});
|
|
166
|
-
|
|
167
|
-
await test("POST /sessions/compact-session — capability executes", async () => {
|
|
168
|
-
const { status, data } = await request("POST", "/sessions/compact-session", {
|
|
169
|
-
session_id: __session_id,
|
|
170
|
-
});
|
|
171
|
-
// Capability may return 200 (success) or 422 (precondition failed) — both are valid
|
|
172
|
-
assert([200, 422].includes(status), `Expected 200 or 422, got ${status}: ${JSON.stringify(data)}`);
|
|
173
|
-
});
|
|
174
|
-
|
|
175
|
-
await test("POST /sessions/compact-session — returns 401 without auth", async () => {
|
|
176
|
-
const res = await fetch(`${BASE_URL}/sessions/compact-session`, { method: "POST" });
|
|
177
|
-
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
178
|
-
});
|
|
179
|
-
|
|
180
|
-
// State machine: Session
|
|
181
|
-
await test("PUT /sessions/:id — rejects invalid state transition", async () => {
|
|
182
|
-
const { status, data } = await request("PUT", `/sessions/${__session_id}`, {
|
|
183
|
-
state: "__invalid_state__",
|
|
184
|
-
});
|
|
185
|
-
assert(status === 422, `Expected 422 for invalid transition, got ${status}`);
|
|
186
|
-
assert(data.error?.code === "INVALID_TRANSITION", "Error code must be INVALID_TRANSITION");
|
|
187
|
-
});
|
|
188
|
-
|
|
189
|
-
await test("DELETE /sessions/:id — deletes entity", async () => {
|
|
190
|
-
const { status } = await request("DELETE", `/sessions/${__session_id}`);
|
|
191
|
-
assert(status === 204, `Expected 204, got ${status}`);
|
|
192
|
-
});
|
|
193
|
-
|
|
194
|
-
await test("GET /sessions/:id — returns 404 after delete", async () => {
|
|
195
|
-
const { status } = await request("GET", `/sessions/${__session_id}`);
|
|
196
|
-
assert(status === 404, `Expected 404, got ${status}`);
|
|
197
|
-
});
|
|
198
|
-
|
|
199
|
-
// ─── MessageService Tests ─────────────────────────────────────────────────────
|
|
200
|
-
|
|
201
|
-
console.log("\nMessageService — CRUD");
|
|
202
|
-
|
|
203
|
-
let __message_id: string;
|
|
204
|
-
|
|
205
|
-
await test("POST /messages — creates entity", async () => {
|
|
206
|
-
const { status, data } = await request("POST", "/messages", {"session_id":"00000000-0000-0000-0000-000000000001","role":"test_value","model_id":null,"provider_id":null,"tokens_input":null,"tokens_output":null,"cost_usd":null,"error":null});
|
|
207
|
-
assert(status === 201, `Expected 201, got ${status}: ${JSON.stringify(data)}`);
|
|
208
|
-
assert(data.id, "Response must have id");
|
|
209
|
-
__message_id = data.id;
|
|
210
|
-
});
|
|
211
|
-
|
|
212
|
-
await test("GET /messages/:id — reads entity", async () => {
|
|
213
|
-
const { status, data } = await request("GET", `/messages/${__message_id}`);
|
|
214
|
-
assert(status === 200, `Expected 200, got ${status}`);
|
|
215
|
-
assert(data.id === __message_id, "ID must match");
|
|
216
|
-
});
|
|
217
|
-
|
|
218
|
-
await test("GET /messages — lists entities", async () => {
|
|
219
|
-
const { status, data } = await request("GET", "/messages");
|
|
220
|
-
assert(status === 200, `Expected 200, got ${status}`);
|
|
221
|
-
assert(Array.isArray(data.items), "Response must have items array");
|
|
222
|
-
assert(typeof data.total === "number", "Response must have total");
|
|
223
|
-
});
|
|
224
|
-
|
|
225
|
-
await test("GET /messages — rejects unauthenticated", async () => {
|
|
226
|
-
const res = await fetch(`${BASE_URL}/messages`);
|
|
227
|
-
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
228
|
-
});
|
|
229
|
-
|
|
230
|
-
await test("DELETE /messages/:id — deletes entity", async () => {
|
|
231
|
-
const { status } = await request("DELETE", `/messages/${__message_id}`);
|
|
232
|
-
assert(status === 204, `Expected 204, got ${status}`);
|
|
233
|
-
});
|
|
234
|
-
|
|
235
|
-
await test("GET /messages/:id — returns 404 after delete", async () => {
|
|
236
|
-
const { status } = await request("GET", `/messages/${__message_id}`);
|
|
237
|
-
assert(status === 404, `Expected 404, got ${status}`);
|
|
238
|
-
});
|
|
239
|
-
|
|
240
|
-
// ─── PartService Tests ─────────────────────────────────────────────────────
|
|
241
|
-
|
|
242
|
-
console.log("\nPartService — CRUD");
|
|
243
|
-
|
|
244
|
-
let __part_id: string;
|
|
245
|
-
|
|
246
|
-
await test("POST /parts — creates entity", async () => {
|
|
247
|
-
const { status, data } = await request("POST", "/parts", {"message_id":"00000000-0000-0000-0000-000000000001","session_id":"00000000-0000-0000-0000-000000000001","part_type":"test_value","data":{},"order_index":1});
|
|
248
|
-
assert(status === 201, `Expected 201, got ${status}: ${JSON.stringify(data)}`);
|
|
249
|
-
assert(data.id, "Response must have id");
|
|
250
|
-
__part_id = data.id;
|
|
251
|
-
});
|
|
252
|
-
|
|
253
|
-
await test("GET /parts/:id — reads entity", async () => {
|
|
254
|
-
const { status, data } = await request("GET", `/parts/${__part_id}`);
|
|
255
|
-
assert(status === 200, `Expected 200, got ${status}`);
|
|
256
|
-
assert(data.id === __part_id, "ID must match");
|
|
257
|
-
});
|
|
258
|
-
|
|
259
|
-
await test("GET /parts — lists entities", async () => {
|
|
260
|
-
const { status, data } = await request("GET", "/parts");
|
|
261
|
-
assert(status === 200, `Expected 200, got ${status}`);
|
|
262
|
-
assert(Array.isArray(data.items), "Response must have items array");
|
|
263
|
-
assert(typeof data.total === "number", "Response must have total");
|
|
264
|
-
});
|
|
265
|
-
|
|
266
|
-
await test("GET /parts — rejects unauthenticated", async () => {
|
|
267
|
-
const res = await fetch(`${BASE_URL}/parts`);
|
|
268
|
-
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
269
|
-
});
|
|
270
|
-
|
|
271
|
-
await test("DELETE /parts/:id — deletes entity", async () => {
|
|
272
|
-
const { status } = await request("DELETE", `/parts/${__part_id}`);
|
|
273
|
-
assert(status === 204, `Expected 204, got ${status}`);
|
|
274
|
-
});
|
|
275
|
-
|
|
276
|
-
await test("GET /parts/:id — returns 404 after delete", async () => {
|
|
277
|
-
const { status } = await request("GET", `/parts/${__part_id}`);
|
|
278
|
-
assert(status === 404, `Expected 404, got ${status}`);
|
|
279
|
-
});
|
|
280
|
-
|
|
281
|
-
// ─── PermissionService Tests ─────────────────────────────────────────────────────
|
|
282
|
-
|
|
283
|
-
console.log("\nPermissionService — CRUD");
|
|
284
|
-
|
|
285
|
-
let __permission_id: string;
|
|
286
|
-
|
|
287
|
-
await test("POST /permissions — creates entity", async () => {
|
|
288
|
-
const { status, data } = await request("POST", "/permissions", {"session_id":"00000000-0000-0000-0000-000000000001","tool_name":"test_value","pattern":null,"decision":"test_value","expires_at":null});
|
|
289
|
-
assert(status === 201, `Expected 201, got ${status}: ${JSON.stringify(data)}`);
|
|
290
|
-
assert(data.id, "Response must have id");
|
|
291
|
-
__permission_id = data.id;
|
|
292
|
-
});
|
|
293
|
-
|
|
294
|
-
await test("GET /permissions/:id — reads entity", async () => {
|
|
295
|
-
const { status, data } = await request("GET", `/permissions/${__permission_id}`);
|
|
296
|
-
assert(status === 200, `Expected 200, got ${status}`);
|
|
297
|
-
assert(data.id === __permission_id, "ID must match");
|
|
298
|
-
});
|
|
299
|
-
|
|
300
|
-
await test("GET /permissions — lists entities", async () => {
|
|
301
|
-
const { status, data } = await request("GET", "/permissions");
|
|
302
|
-
assert(status === 200, `Expected 200, got ${status}`);
|
|
303
|
-
assert(Array.isArray(data.items), "Response must have items array");
|
|
304
|
-
assert(typeof data.total === "number", "Response must have total");
|
|
305
|
-
});
|
|
306
|
-
|
|
307
|
-
await test("GET /permissions — rejects unauthenticated", async () => {
|
|
308
|
-
const res = await fetch(`${BASE_URL}/permissions`);
|
|
309
|
-
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
310
|
-
});
|
|
311
|
-
|
|
312
|
-
await test("DELETE /permissions/:id — deletes entity", async () => {
|
|
313
|
-
const { status } = await request("DELETE", `/permissions/${__permission_id}`);
|
|
314
|
-
assert(status === 204, `Expected 204, got ${status}`);
|
|
315
|
-
});
|
|
316
|
-
|
|
317
|
-
await test("GET /permissions/:id — returns 404 after delete", async () => {
|
|
318
|
-
const { status } = await request("GET", `/permissions/${__permission_id}`);
|
|
319
|
-
assert(status === 404, `Expected 404, got ${status}`);
|
|
320
|
-
});
|
|
321
|
-
|
|
322
|
-
console.log(`\n════════════════════════════════════════`);
|
|
323
|
-
console.log(`Results: ${passed} passed, ${failed} failed`);
|
|
324
|
-
console.log("═".repeat(40));
|
|
325
|
-
if (failed > 0) process.exit(1);
|
|
1
|
+
// Generated by BoneScript compiler. DO NOT EDIT.
|
|
2
|
+
// Regression tests derived from capability declarations.
|
|
3
|
+
// Run: npx ts-node src/tests.ts
|
|
4
|
+
|
|
5
|
+
import * as http from "http";
|
|
6
|
+
|
|
7
|
+
const BASE_URL = process.env.TEST_BASE_URL || "http://localhost:3000";
|
|
8
|
+
const AUTH_TOKEN = process.env.TEST_AUTH_TOKEN || "";
|
|
9
|
+
|
|
10
|
+
let passed = 0;
|
|
11
|
+
let failed = 0;
|
|
12
|
+
|
|
13
|
+
async function request(method: string, path: string, body?: any): Promise<{ status: number; data: any }> {
|
|
14
|
+
const url = new URL(path, BASE_URL);
|
|
15
|
+
const res = await fetch(url.toString(), {
|
|
16
|
+
method,
|
|
17
|
+
headers: {
|
|
18
|
+
"Content-Type": "application/json",
|
|
19
|
+
...(AUTH_TOKEN ? { "Authorization": `Bearer ${AUTH_TOKEN}` } : {}),
|
|
20
|
+
},
|
|
21
|
+
body: body ? JSON.stringify(body) : undefined,
|
|
22
|
+
});
|
|
23
|
+
const data = await res.json().catch(() => ({}));
|
|
24
|
+
return { status: res.status, data };
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
async function test(name: string, fn: () => Promise<void>): Promise<void> {
|
|
28
|
+
try {
|
|
29
|
+
await fn();
|
|
30
|
+
console.log(` ✓ ${name}`);
|
|
31
|
+
passed++;
|
|
32
|
+
} catch (e: any) {
|
|
33
|
+
console.log(` ✗ ${name}: ${e.message}`);
|
|
34
|
+
failed++;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
function assert(condition: boolean, message: string): void {
|
|
39
|
+
if (!condition) throw new Error(message);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
(async () => {
|
|
43
|
+
// ─── ProjectService Tests ─────────────────────────────────────────────────────
|
|
44
|
+
|
|
45
|
+
console.log("\nProjectService — CRUD");
|
|
46
|
+
|
|
47
|
+
let __project_id: string;
|
|
48
|
+
|
|
49
|
+
await test("POST /projects — creates entity", async () => {
|
|
50
|
+
const { status, data } = await request("POST", "/projects", {"root_commit_hash":"test_value","worktree":"test_value","vcs":"test_value","name":"test_value","sandboxes":{}});
|
|
51
|
+
assert(status === 201, `Expected 201, got ${status}: ${JSON.stringify(data)}`);
|
|
52
|
+
assert(data.id, "Response must have id");
|
|
53
|
+
__project_id = data.id;
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
await test("GET /projects/:id — reads entity", async () => {
|
|
57
|
+
const { status, data } = await request("GET", `/projects/${__project_id}`);
|
|
58
|
+
assert(status === 200, `Expected 200, got ${status}`);
|
|
59
|
+
assert(data.id === __project_id, "ID must match");
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
await test("GET /projects — lists entities", async () => {
|
|
63
|
+
const { status, data } = await request("GET", "/projects");
|
|
64
|
+
assert(status === 200, `Expected 200, got ${status}`);
|
|
65
|
+
assert(Array.isArray(data.items), "Response must have items array");
|
|
66
|
+
assert(typeof data.total === "number", "Response must have total");
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
await test("GET /projects — rejects unauthenticated", async () => {
|
|
70
|
+
const res = await fetch(`${BASE_URL}/projects`);
|
|
71
|
+
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
await test("DELETE /projects/:id — deletes entity", async () => {
|
|
75
|
+
const { status } = await request("DELETE", `/projects/${__project_id}`);
|
|
76
|
+
assert(status === 204, `Expected 204, got ${status}`);
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
await test("GET /projects/:id — returns 404 after delete", async () => {
|
|
80
|
+
const { status } = await request("GET", `/projects/${__project_id}`);
|
|
81
|
+
assert(status === 404, `Expected 404, got ${status}`);
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
// ─── SessionService Tests ─────────────────────────────────────────────────────
|
|
85
|
+
|
|
86
|
+
console.log("\nSessionService — CRUD");
|
|
87
|
+
|
|
88
|
+
let __session_id: string;
|
|
89
|
+
|
|
90
|
+
await test("POST /sessions — creates entity", async () => {
|
|
91
|
+
const { status, data } = await request("POST", "/sessions", {"slug":"test_value","project_id":"00000000-0000-0000-0000-000000000001","workspace_id":null,"parent_id":null,"directory":"test_value","title":"test_value","version":"test_value","share_url":null,"summary_additions":null,"summary_deletions":null,"summary_files":null,"summary_diffs":null,"revert_data":null,"permission_ruleset":null});
|
|
92
|
+
assert(status === 201, `Expected 201, got ${status}: ${JSON.stringify(data)}`);
|
|
93
|
+
assert(data.id, "Response must have id");
|
|
94
|
+
__session_id = data.id;
|
|
95
|
+
});
|
|
96
|
+
|
|
97
|
+
await test("GET /sessions/:id — reads entity", async () => {
|
|
98
|
+
const { status, data } = await request("GET", `/sessions/${__session_id}`);
|
|
99
|
+
assert(status === 200, `Expected 200, got ${status}`);
|
|
100
|
+
assert(data.id === __session_id, "ID must match");
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
await test("GET /sessions — lists entities", async () => {
|
|
104
|
+
const { status, data } = await request("GET", "/sessions");
|
|
105
|
+
assert(status === 200, `Expected 200, got ${status}`);
|
|
106
|
+
assert(Array.isArray(data.items), "Response must have items array");
|
|
107
|
+
assert(typeof data.total === "number", "Response must have total");
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
await test("GET /sessions — rejects unauthenticated", async () => {
|
|
111
|
+
const res = await fetch(`${BASE_URL}/sessions`);
|
|
112
|
+
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
113
|
+
});
|
|
114
|
+
|
|
115
|
+
await test("POST /sessions/archive-session — capability executes", async () => {
|
|
116
|
+
const { status, data } = await request("POST", "/sessions/archive-session", {
|
|
117
|
+
session_id: __session_id,
|
|
118
|
+
});
|
|
119
|
+
// Capability may return 200 (success) or 422 (precondition failed) — both are valid
|
|
120
|
+
assert([200, 422].includes(status), `Expected 200 or 422, got ${status}: ${JSON.stringify(data)}`);
|
|
121
|
+
});
|
|
122
|
+
|
|
123
|
+
await test("POST /sessions/archive-session — returns 401 without auth", async () => {
|
|
124
|
+
const res = await fetch(`${BASE_URL}/sessions/archive-session`, { method: "POST" });
|
|
125
|
+
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
await test("POST /sessions/delete-session — capability executes", async () => {
|
|
129
|
+
const { status, data } = await request("POST", "/sessions/delete-session", {
|
|
130
|
+
session_id: __session_id,
|
|
131
|
+
});
|
|
132
|
+
// Capability may return 200 (success) or 422 (precondition failed) — both are valid
|
|
133
|
+
assert([200, 422].includes(status), `Expected 200 or 422, got ${status}: ${JSON.stringify(data)}`);
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
await test("POST /sessions/delete-session — returns 401 without auth", async () => {
|
|
137
|
+
const res = await fetch(`${BASE_URL}/sessions/delete-session`, { method: "POST" });
|
|
138
|
+
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
139
|
+
});
|
|
140
|
+
|
|
141
|
+
await test("POST /sessions/add-message — capability executes", async () => {
|
|
142
|
+
const { status, data } = await request("POST", "/sessions/add-message", {
|
|
143
|
+
session_id: __session_id,
|
|
144
|
+
});
|
|
145
|
+
// Capability may return 200 (success) or 422 (precondition failed) — both are valid
|
|
146
|
+
assert([200, 422].includes(status), `Expected 200 or 422, got ${status}: ${JSON.stringify(data)}`);
|
|
147
|
+
});
|
|
148
|
+
|
|
149
|
+
await test("POST /sessions/add-message — returns 401 without auth", async () => {
|
|
150
|
+
const res = await fetch(`${BASE_URL}/sessions/add-message`, { method: "POST" });
|
|
151
|
+
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
152
|
+
});
|
|
153
|
+
|
|
154
|
+
await test("POST /sessions/update-part — capability executes", async () => {
|
|
155
|
+
const { status, data } = await request("POST", "/sessions/update-part", {
|
|
156
|
+
session_id: __session_id,
|
|
157
|
+
});
|
|
158
|
+
// Capability may return 200 (success) or 422 (precondition failed) — both are valid
|
|
159
|
+
assert([200, 422].includes(status), `Expected 200 or 422, got ${status}: ${JSON.stringify(data)}`);
|
|
160
|
+
});
|
|
161
|
+
|
|
162
|
+
await test("POST /sessions/update-part — returns 401 without auth", async () => {
|
|
163
|
+
const res = await fetch(`${BASE_URL}/sessions/update-part`, { method: "POST" });
|
|
164
|
+
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
165
|
+
});
|
|
166
|
+
|
|
167
|
+
await test("POST /sessions/compact-session — capability executes", async () => {
|
|
168
|
+
const { status, data } = await request("POST", "/sessions/compact-session", {
|
|
169
|
+
session_id: __session_id,
|
|
170
|
+
});
|
|
171
|
+
// Capability may return 200 (success) or 422 (precondition failed) — both are valid
|
|
172
|
+
assert([200, 422].includes(status), `Expected 200 or 422, got ${status}: ${JSON.stringify(data)}`);
|
|
173
|
+
});
|
|
174
|
+
|
|
175
|
+
await test("POST /sessions/compact-session — returns 401 without auth", async () => {
|
|
176
|
+
const res = await fetch(`${BASE_URL}/sessions/compact-session`, { method: "POST" });
|
|
177
|
+
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
178
|
+
});
|
|
179
|
+
|
|
180
|
+
// State machine: Session
|
|
181
|
+
await test("PUT /sessions/:id — rejects invalid state transition", async () => {
|
|
182
|
+
const { status, data } = await request("PUT", `/sessions/${__session_id}`, {
|
|
183
|
+
state: "__invalid_state__",
|
|
184
|
+
});
|
|
185
|
+
assert(status === 422, `Expected 422 for invalid transition, got ${status}`);
|
|
186
|
+
assert(data.error?.code === "INVALID_TRANSITION", "Error code must be INVALID_TRANSITION");
|
|
187
|
+
});
|
|
188
|
+
|
|
189
|
+
await test("DELETE /sessions/:id — deletes entity", async () => {
|
|
190
|
+
const { status } = await request("DELETE", `/sessions/${__session_id}`);
|
|
191
|
+
assert(status === 204, `Expected 204, got ${status}`);
|
|
192
|
+
});
|
|
193
|
+
|
|
194
|
+
await test("GET /sessions/:id — returns 404 after delete", async () => {
|
|
195
|
+
const { status } = await request("GET", `/sessions/${__session_id}`);
|
|
196
|
+
assert(status === 404, `Expected 404, got ${status}`);
|
|
197
|
+
});
|
|
198
|
+
|
|
199
|
+
// ─── MessageService Tests ─────────────────────────────────────────────────────
|
|
200
|
+
|
|
201
|
+
console.log("\nMessageService — CRUD");
|
|
202
|
+
|
|
203
|
+
let __message_id: string;
|
|
204
|
+
|
|
205
|
+
await test("POST /messages — creates entity", async () => {
|
|
206
|
+
const { status, data } = await request("POST", "/messages", {"session_id":"00000000-0000-0000-0000-000000000001","role":"test_value","model_id":null,"provider_id":null,"tokens_input":null,"tokens_output":null,"cost_usd":null,"error":null});
|
|
207
|
+
assert(status === 201, `Expected 201, got ${status}: ${JSON.stringify(data)}`);
|
|
208
|
+
assert(data.id, "Response must have id");
|
|
209
|
+
__message_id = data.id;
|
|
210
|
+
});
|
|
211
|
+
|
|
212
|
+
await test("GET /messages/:id — reads entity", async () => {
|
|
213
|
+
const { status, data } = await request("GET", `/messages/${__message_id}`);
|
|
214
|
+
assert(status === 200, `Expected 200, got ${status}`);
|
|
215
|
+
assert(data.id === __message_id, "ID must match");
|
|
216
|
+
});
|
|
217
|
+
|
|
218
|
+
await test("GET /messages — lists entities", async () => {
|
|
219
|
+
const { status, data } = await request("GET", "/messages");
|
|
220
|
+
assert(status === 200, `Expected 200, got ${status}`);
|
|
221
|
+
assert(Array.isArray(data.items), "Response must have items array");
|
|
222
|
+
assert(typeof data.total === "number", "Response must have total");
|
|
223
|
+
});
|
|
224
|
+
|
|
225
|
+
await test("GET /messages — rejects unauthenticated", async () => {
|
|
226
|
+
const res = await fetch(`${BASE_URL}/messages`);
|
|
227
|
+
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
228
|
+
});
|
|
229
|
+
|
|
230
|
+
await test("DELETE /messages/:id — deletes entity", async () => {
|
|
231
|
+
const { status } = await request("DELETE", `/messages/${__message_id}`);
|
|
232
|
+
assert(status === 204, `Expected 204, got ${status}`);
|
|
233
|
+
});
|
|
234
|
+
|
|
235
|
+
await test("GET /messages/:id — returns 404 after delete", async () => {
|
|
236
|
+
const { status } = await request("GET", `/messages/${__message_id}`);
|
|
237
|
+
assert(status === 404, `Expected 404, got ${status}`);
|
|
238
|
+
});
|
|
239
|
+
|
|
240
|
+
// ─── PartService Tests ─────────────────────────────────────────────────────
|
|
241
|
+
|
|
242
|
+
console.log("\nPartService — CRUD");
|
|
243
|
+
|
|
244
|
+
let __part_id: string;
|
|
245
|
+
|
|
246
|
+
await test("POST /parts — creates entity", async () => {
|
|
247
|
+
const { status, data } = await request("POST", "/parts", {"message_id":"00000000-0000-0000-0000-000000000001","session_id":"00000000-0000-0000-0000-000000000001","part_type":"test_value","data":{},"order_index":1});
|
|
248
|
+
assert(status === 201, `Expected 201, got ${status}: ${JSON.stringify(data)}`);
|
|
249
|
+
assert(data.id, "Response must have id");
|
|
250
|
+
__part_id = data.id;
|
|
251
|
+
});
|
|
252
|
+
|
|
253
|
+
await test("GET /parts/:id — reads entity", async () => {
|
|
254
|
+
const { status, data } = await request("GET", `/parts/${__part_id}`);
|
|
255
|
+
assert(status === 200, `Expected 200, got ${status}`);
|
|
256
|
+
assert(data.id === __part_id, "ID must match");
|
|
257
|
+
});
|
|
258
|
+
|
|
259
|
+
await test("GET /parts — lists entities", async () => {
|
|
260
|
+
const { status, data } = await request("GET", "/parts");
|
|
261
|
+
assert(status === 200, `Expected 200, got ${status}`);
|
|
262
|
+
assert(Array.isArray(data.items), "Response must have items array");
|
|
263
|
+
assert(typeof data.total === "number", "Response must have total");
|
|
264
|
+
});
|
|
265
|
+
|
|
266
|
+
await test("GET /parts — rejects unauthenticated", async () => {
|
|
267
|
+
const res = await fetch(`${BASE_URL}/parts`);
|
|
268
|
+
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
269
|
+
});
|
|
270
|
+
|
|
271
|
+
await test("DELETE /parts/:id — deletes entity", async () => {
|
|
272
|
+
const { status } = await request("DELETE", `/parts/${__part_id}`);
|
|
273
|
+
assert(status === 204, `Expected 204, got ${status}`);
|
|
274
|
+
});
|
|
275
|
+
|
|
276
|
+
await test("GET /parts/:id — returns 404 after delete", async () => {
|
|
277
|
+
const { status } = await request("GET", `/parts/${__part_id}`);
|
|
278
|
+
assert(status === 404, `Expected 404, got ${status}`);
|
|
279
|
+
});
|
|
280
|
+
|
|
281
|
+
// ─── PermissionService Tests ─────────────────────────────────────────────────────
|
|
282
|
+
|
|
283
|
+
console.log("\nPermissionService — CRUD");
|
|
284
|
+
|
|
285
|
+
let __permission_id: string;
|
|
286
|
+
|
|
287
|
+
await test("POST /permissions — creates entity", async () => {
|
|
288
|
+
const { status, data } = await request("POST", "/permissions", {"session_id":"00000000-0000-0000-0000-000000000001","tool_name":"test_value","pattern":null,"decision":"test_value","expires_at":null});
|
|
289
|
+
assert(status === 201, `Expected 201, got ${status}: ${JSON.stringify(data)}`);
|
|
290
|
+
assert(data.id, "Response must have id");
|
|
291
|
+
__permission_id = data.id;
|
|
292
|
+
});
|
|
293
|
+
|
|
294
|
+
await test("GET /permissions/:id — reads entity", async () => {
|
|
295
|
+
const { status, data } = await request("GET", `/permissions/${__permission_id}`);
|
|
296
|
+
assert(status === 200, `Expected 200, got ${status}`);
|
|
297
|
+
assert(data.id === __permission_id, "ID must match");
|
|
298
|
+
});
|
|
299
|
+
|
|
300
|
+
await test("GET /permissions — lists entities", async () => {
|
|
301
|
+
const { status, data } = await request("GET", "/permissions");
|
|
302
|
+
assert(status === 200, `Expected 200, got ${status}`);
|
|
303
|
+
assert(Array.isArray(data.items), "Response must have items array");
|
|
304
|
+
assert(typeof data.total === "number", "Response must have total");
|
|
305
|
+
});
|
|
306
|
+
|
|
307
|
+
await test("GET /permissions — rejects unauthenticated", async () => {
|
|
308
|
+
const res = await fetch(`${BASE_URL}/permissions`);
|
|
309
|
+
assert(res.status === 401, `Expected 401, got ${res.status}`);
|
|
310
|
+
});
|
|
311
|
+
|
|
312
|
+
await test("DELETE /permissions/:id — deletes entity", async () => {
|
|
313
|
+
const { status } = await request("DELETE", `/permissions/${__permission_id}`);
|
|
314
|
+
assert(status === 204, `Expected 204, got ${status}`);
|
|
315
|
+
});
|
|
316
|
+
|
|
317
|
+
await test("GET /permissions/:id — returns 404 after delete", async () => {
|
|
318
|
+
const { status } = await request("GET", `/permissions/${__permission_id}`);
|
|
319
|
+
assert(status === 404, `Expected 404, got ${status}`);
|
|
320
|
+
});
|
|
321
|
+
|
|
322
|
+
console.log(`\n════════════════════════════════════════`);
|
|
323
|
+
console.log(`Results: ${passed} passed, ${failed} failed`);
|
|
324
|
+
console.log("═".repeat(40));
|
|
325
|
+
if (failed > 0) process.exit(1);
|
|
326
326
|
})().catch(e => { console.error(e); process.exit(1); });
|