bonecode 1.0.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/ARCHITECTURE.md +183 -0
- package/README.md +71 -0
- package/bin/bonecode +62 -0
- package/bone/migrations/rag_vectors.sql +258 -0
- package/bone/output/agent/.dockerignore +7 -0
- package/bone/output/agent/.env.example +36 -0
- package/bone/output/agent/.github/workflows/ci.yaml +58 -0
- package/bone/output/agent/AgentDomain.bone.map +350 -0
- package/bone/output/agent/AgentDomain.postman_collection.json +958 -0
- package/bone/output/agent/Dockerfile +22 -0
- package/bone/output/agent/README.md +47 -0
- package/bone/output/agent/admin/index.html +740 -0
- package/bone/output/agent/docker-compose.yaml +22 -0
- package/bone/output/agent/k8s/deployment.yaml +75 -0
- package/bone/output/agent/migrations/agent.sql +36 -0
- package/bone/output/agent/migrations/agent_instance.sql +36 -0
- package/bone/output/agent/migrations/audit_log.sql +18 -0
- package/bone/output/agent/migrations/build_step.sql +34 -0
- package/bone/output/agent/migrations/event_outbox.sql +31 -0
- package/bone/output/agent/migrations/plan.sql +30 -0
- package/bone/output/agent/migrations/task.sql +30 -0
- package/bone/output/agent/migrations/tool_call.sql +33 -0
- package/bone/output/agent/openapi.yaml +1116 -0
- package/bone/output/agent/package.json +36 -0
- package/bone/output/agent/schema.graphql +233 -0
- package/bone/output/agent/sdk/client.ts +231 -0
- package/bone/output/agent/src/algorithms.ts +2 -0
- package/bone/output/agent/src/audit.ts +44 -0
- package/bone/output/agent/src/auth.ts +57 -0
- package/bone/output/agent/src/cron.ts +12 -0
- package/bone/output/agent/src/db.ts +32 -0
- package/bone/output/agent/src/debug.ts +66 -0
- package/bone/output/agent/src/events.ts +243 -0
- package/bone/output/agent/src/extensions.ts +54 -0
- package/bone/output/agent/src/failure_rules.ts +323 -0
- package/bone/output/agent/src/flows.ts +168 -0
- package/bone/output/agent/src/health.ts +43 -0
- package/bone/output/agent/src/index.ts +100 -0
- package/bone/output/agent/src/logger.ts +66 -0
- package/bone/output/agent/src/metrics.ts +75 -0
- package/bone/output/agent/src/migrate.ts +352 -0
- package/bone/output/agent/src/migration_diff.ts +108 -0
- package/bone/output/agent/src/notify.ts +125 -0
- package/bone/output/agent/src/routes/agent_instance.ts +234 -0
- package/bone/output/agent/src/routes/build_step.ts +105 -0
- package/bone/output/agent/src/routes/plan.ts +91 -0
- package/bone/output/agent/src/routes/task.ts +105 -0
- package/bone/output/agent/src/routes/tool_call.ts +166 -0
- package/bone/output/agent/src/schemas.ts +384 -0
- package/bone/output/agent/src/state_machines/agent_instance.ts +24 -0
- package/bone/output/agent/src/state_machines/build_step.ts +22 -0
- package/bone/output/agent/src/state_machines/plan.ts +22 -0
- package/bone/output/agent/src/state_machines/task.ts +22 -0
- package/bone/output/agent/src/state_machines/tool_call.ts +22 -0
- package/bone/output/agent/src/tests.ts +362 -0
- package/bone/output/agent/src/websocket.ts +201 -0
- package/bone/output/agent/tsconfig.json +25 -0
- package/bone/output/rag/.dockerignore +7 -0
- package/bone/output/rag/.env.example +36 -0
- package/bone/output/rag/.github/workflows/ci.yaml +58 -0
- package/bone/output/rag/Dockerfile +22 -0
- package/bone/output/rag/RAGDomain.bone.map +287 -0
- package/bone/output/rag/RAGDomain.postman_collection.json +923 -0
- package/bone/output/rag/README.md +47 -0
- package/bone/output/rag/admin/index.html +818 -0
- package/bone/output/rag/docker-compose.yaml +22 -0
- package/bone/output/rag/k8s/deployment.yaml +75 -0
- package/bone/output/rag/migrations/audit_log.sql +18 -0
- package/bone/output/rag/migrations/code_chunk.sql +34 -0
- package/bone/output/rag/migrations/code_file.sql +33 -0
- package/bone/output/rag/migrations/event_outbox.sql +31 -0
- package/bone/output/rag/migrations/indexing_job.sql +33 -0
- package/bone/output/rag/migrations/knowledge_base.sql +35 -0
- package/bone/output/rag/migrations/memory_entry.sql +34 -0
- package/bone/output/rag/openapi.yaml +1097 -0
- package/bone/output/rag/package.json +36 -0
- package/bone/output/rag/schema.graphql +245 -0
- package/bone/output/rag/sdk/client.ts +234 -0
- package/bone/output/rag/src/algorithms.ts +2 -0
- package/bone/output/rag/src/audit.ts +37 -0
- package/bone/output/rag/src/auth.ts +57 -0
- package/bone/output/rag/src/cron.ts +12 -0
- package/bone/output/rag/src/db.ts +32 -0
- package/bone/output/rag/src/debug.ts +66 -0
- package/bone/output/rag/src/events.ts +243 -0
- package/bone/output/rag/src/extensions.ts +350 -0
- package/bone/output/rag/src/failure_rules.ts +315 -0
- package/bone/output/rag/src/flows.ts +239 -0
- package/bone/output/rag/src/health.ts +43 -0
- package/bone/output/rag/src/index.ts +95 -0
- package/bone/output/rag/src/logger.ts +66 -0
- package/bone/output/rag/src/metrics.ts +75 -0
- package/bone/output/rag/src/migrate.ts +364 -0
- package/bone/output/rag/src/migration_diff.ts +108 -0
- package/bone/output/rag/src/notify.ts +99 -0
- package/bone/output/rag/src/routes/code_chunk.ts +75 -0
- package/bone/output/rag/src/routes/code_file.ts +101 -0
- package/bone/output/rag/src/routes/indexing_job.ts +87 -0
- package/bone/output/rag/src/routes/knowledge_base.ts +230 -0
- package/bone/output/rag/src/routes/memory_entry.ts +87 -0
- package/bone/output/rag/src/schemas.ts +394 -0
- package/bone/output/rag/src/state_machines/code_file.ts +23 -0
- package/bone/output/rag/src/state_machines/indexing_job.ts +22 -0
- package/bone/output/rag/src/state_machines/knowledge_base.ts +23 -0
- package/bone/output/rag/src/state_machines/memory_entry.ts +20 -0
- package/bone/output/rag/src/tests.ts +340 -0
- package/bone/output/rag/tsconfig.json +25 -0
- package/bone/output/session/.dockerignore +7 -0
- package/bone/output/session/.env.example +36 -0
- package/bone/output/session/.github/workflows/ci.yaml +58 -0
- package/bone/output/session/Dockerfile +22 -0
- package/bone/output/session/README.md +47 -0
- package/bone/output/session/SessionDomain.bone.map +350 -0
- package/bone/output/session/SessionDomain.postman_collection.json +958 -0
- package/bone/output/session/admin/index.html +667 -0
- package/bone/output/session/docker-compose.yaml +22 -0
- package/bone/output/session/k8s/deployment.yaml +75 -0
- package/bone/output/session/migrations/audit_log.sql +18 -0
- package/bone/output/session/migrations/event_outbox.sql +31 -0
- package/bone/output/session/migrations/message.sql +31 -0
- package/bone/output/session/migrations/part.sql +28 -0
- package/bone/output/session/migrations/permission.sql +28 -0
- package/bone/output/session/migrations/project.sql +28 -0
- package/bone/output/session/migrations/session.sql +38 -0
- package/bone/output/session/openapi.yaml +1101 -0
- package/bone/output/session/package.json +36 -0
- package/bone/output/session/schema.graphql +222 -0
- package/bone/output/session/sdk/client.ts +225 -0
- package/bone/output/session/src/algorithms.ts +2 -0
- package/bone/output/session/src/audit.ts +44 -0
- package/bone/output/session/src/auth.ts +57 -0
- package/bone/output/session/src/cron.ts +12 -0
- package/bone/output/session/src/db.ts +32 -0
- package/bone/output/session/src/debug.ts +66 -0
- package/bone/output/session/src/events.ts +270 -0
- package/bone/output/session/src/extensions.ts +215 -0
- package/bone/output/session/src/failure_rules.ts +284 -0
- package/bone/output/session/src/flows.ts +168 -0
- package/bone/output/session/src/health.ts +43 -0
- package/bone/output/session/src/index.ts +100 -0
- package/bone/output/session/src/logger.ts +66 -0
- package/bone/output/session/src/metrics.ts +75 -0
- package/bone/output/session/src/migrate.ts +332 -0
- package/bone/output/session/src/migration_diff.ts +108 -0
- package/bone/output/session/src/notify.ts +112 -0
- package/bone/output/session/src/routes/message.ts +93 -0
- package/bone/output/session/src/routes/part.ts +79 -0
- package/bone/output/session/src/routes/permission.ts +79 -0
- package/bone/output/session/src/routes/project.ts +79 -0
- package/bone/output/session/src/routes/session.ts +294 -0
- package/bone/output/session/src/schemas.ts +357 -0
- package/bone/output/session/src/state_machines/session.ts +23 -0
- package/bone/output/session/src/tests.ts +326 -0
- package/bone/output/session/src/websocket.ts +201 -0
- package/bone/output/session/tsconfig.json +25 -0
- package/bone/output/workspace/.dockerignore +7 -0
- package/bone/output/workspace/.env.example +36 -0
- package/bone/output/workspace/.github/workflows/ci.yaml +58 -0
- package/bone/output/workspace/Dockerfile +22 -0
- package/bone/output/workspace/README.md +45 -0
- package/bone/output/workspace/WorkspaceDomain.bone.map +189 -0
- package/bone/output/workspace/WorkspaceDomain.postman_collection.json +621 -0
- package/bone/output/workspace/admin/index.html +485 -0
- package/bone/output/workspace/docker-compose.yaml +22 -0
- package/bone/output/workspace/k8s/deployment.yaml +75 -0
- package/bone/output/workspace/migrations/audit_log.sql +18 -0
- package/bone/output/workspace/migrations/codebase.sql +34 -0
- package/bone/output/workspace/migrations/event_outbox.sql +31 -0
- package/bone/output/workspace/migrations/snapshot.sql +32 -0
- package/bone/output/workspace/migrations/workspace.sql +33 -0
- package/bone/output/workspace/openapi.yaml +721 -0
- package/bone/output/workspace/package.json +36 -0
- package/bone/output/workspace/schema.graphql +153 -0
- package/bone/output/workspace/sdk/client.ts +155 -0
- package/bone/output/workspace/src/algorithms.ts +2 -0
- package/bone/output/workspace/src/audit.ts +37 -0
- package/bone/output/workspace/src/auth.ts +57 -0
- package/bone/output/workspace/src/cron.ts +12 -0
- package/bone/output/workspace/src/db.ts +32 -0
- package/bone/output/workspace/src/debug.ts +66 -0
- package/bone/output/workspace/src/events.ts +243 -0
- package/bone/output/workspace/src/extensions.ts +44 -0
- package/bone/output/workspace/src/failure_rules.ts +153 -0
- package/bone/output/workspace/src/health.ts +43 -0
- package/bone/output/workspace/src/index.ts +89 -0
- package/bone/output/workspace/src/logger.ts +66 -0
- package/bone/output/workspace/src/metrics.ts +75 -0
- package/bone/output/workspace/src/migrate.ts +220 -0
- package/bone/output/workspace/src/migration_diff.ts +108 -0
- package/bone/output/workspace/src/notify.ts +73 -0
- package/bone/output/workspace/src/routes/codebase.ts +87 -0
- package/bone/output/workspace/src/routes/snapshot.ts +127 -0
- package/bone/output/workspace/src/routes/workspace.ts +190 -0
- package/bone/output/workspace/src/schemas.ts +231 -0
- package/bone/output/workspace/src/state_machines/codebase.ts +21 -0
- package/bone/output/workspace/src/state_machines/snapshot.ts +20 -0
- package/bone/output/workspace/src/state_machines/workspace.ts +21 -0
- package/bone/output/workspace/src/tests.ts +249 -0
- package/bone/output/workspace/tsconfig.json +25 -0
- package/compat/opencode_adapter.ts +410 -0
- package/package.json +69 -0
- package/scripts/check_benchmark_session.js +34 -0
- package/scripts/check_finish_event.js +24 -0
- package/scripts/check_parts.js +15 -0
- package/scripts/compile.js +79 -0
- package/scripts/copy_opencode.ps1 +53 -0
- package/scripts/create_functions.sql +129 -0
- package/scripts/migrate.js +85 -0
- package/scripts/migrate_from_opencode.ts +218 -0
- package/scripts/test_agent_loop.js +101 -0
- package/scripts/test_api.ps1 +116 -0
- package/scripts/test_context_builder.js +136 -0
- package/scripts/test_context_builder.ts +97 -0
- package/scripts/test_rag.js +189 -0
- package/scripts/test_stream_events.js +36 -0
- package/scripts/test_websocket_and_saga.js +216 -0
- package/src/cli.ts +475 -0
- package/src/config.ts +162 -0
- package/src/context_builder.ts +598 -0
- package/src/engine/account/account.sql.ts +39 -0
- package/src/engine/account/account.ts +456 -0
- package/src/engine/account/repo.ts +166 -0
- package/src/engine/account/schema.ts +99 -0
- package/src/engine/account/url.ts +8 -0
- package/src/engine/acp/README.md +174 -0
- package/src/engine/acp/agent.ts +1968 -0
- package/src/engine/acp/runtime.ts +22 -0
- package/src/engine/acp/session.ts +122 -0
- package/src/engine/acp/types.ts +24 -0
- package/src/engine/agent/agent.ts +463 -0
- package/src/engine/agent/generate.txt +75 -0
- package/src/engine/agent/prompt/compaction.txt +9 -0
- package/src/engine/agent/prompt/explore.txt +18 -0
- package/src/engine/agent/prompt/scout.txt +36 -0
- package/src/engine/agent/prompt/summary.txt +11 -0
- package/src/engine/agent/prompt/title.txt +44 -0
- package/src/engine/agent/subagent-permissions.ts +34 -0
- package/src/engine/auth/index.ts +96 -0
- package/src/engine/background/background/job.ts +200 -0
- package/src/engine/background/job.ts +200 -0
- package/src/engine/bus/bus-event.ts +45 -0
- package/src/engine/bus/global.ts +22 -0
- package/src/engine/bus/index.ts +203 -0
- package/src/engine/command/command/index.ts +181 -0
- package/src/engine/command/command/template/initialize.txt +66 -0
- package/src/engine/command/command/template/review.txt +101 -0
- package/src/engine/command/index.ts +181 -0
- package/src/engine/command/template/initialize.txt +66 -0
- package/src/engine/command/template/review.txt +101 -0
- package/src/engine/config/agent.ts +172 -0
- package/src/engine/config/attachment.ts +25 -0
- package/src/engine/config/command.ts +62 -0
- package/src/engine/config/config.ts +833 -0
- package/src/engine/config/console-state.ts +14 -0
- package/src/engine/config/entry-name.ts +16 -0
- package/src/engine/config/error.ts +23 -0
- package/src/engine/config/formatter.ts +13 -0
- package/src/engine/config/layout.ts +6 -0
- package/src/engine/config/lsp.ts +43 -0
- package/src/engine/config/managed.ts +71 -0
- package/src/engine/config/markdown.ts +96 -0
- package/src/engine/config/mcp.ts +56 -0
- package/src/engine/config/model-id.ts +5 -0
- package/src/engine/config/parse.ts +79 -0
- package/src/engine/config/paths.ts +45 -0
- package/src/engine/config/permission.ts +58 -0
- package/src/engine/config/plugin.ts +84 -0
- package/src/engine/config/provider.ts +111 -0
- package/src/engine/config/reference.ts +23 -0
- package/src/engine/config/server.ts +19 -0
- package/src/engine/config/skills.ts +14 -0
- package/src/engine/config/variable.ts +90 -0
- package/src/engine/control-plane/adapters/index.ts +41 -0
- package/src/engine/control-plane/adapters/worktree.ts +96 -0
- package/src/engine/control-plane/dev/README.md +19 -0
- package/src/engine/control-plane/dev/debug-workspace-plugin.ts +73 -0
- package/src/engine/control-plane/schema.ts +14 -0
- package/src/engine/control-plane/types.ts +59 -0
- package/src/engine/control-plane/util.ts +39 -0
- package/src/engine/control-plane/workspace-adapter-runtime.ts +51 -0
- package/src/engine/control-plane/workspace-context.ts +26 -0
- package/src/engine/control-plane/workspace.sql.ts +20 -0
- package/src/engine/control-plane/workspace.ts +1072 -0
- package/src/engine/data-migration.ts +161 -0
- package/src/engine/effect/app-runtime.ts +143 -0
- package/src/engine/effect/bootstrap-runtime.ts +29 -0
- package/src/engine/effect/bridge.ts +84 -0
- package/src/engine/effect/config-service.ts +67 -0
- package/src/engine/effect/instance-ref.ts +11 -0
- package/src/engine/effect/instance-registry.ts +12 -0
- package/src/engine/effect/instance-state.ts +72 -0
- package/src/engine/effect/promise.ts +17 -0
- package/src/engine/effect/run-service.ts +47 -0
- package/src/engine/effect/runner.ts +217 -0
- package/src/engine/effect/runtime-flags.ts +74 -0
- package/src/engine/effect/service-use.ts +38 -0
- package/src/engine/env/index.ts +37 -0
- package/src/engine/event-v2-bridge.ts +89 -0
- package/src/engine/file/file/ignore.ts +81 -0
- package/src/engine/file/file/index.ts +651 -0
- package/src/engine/file/file/protected.ts +59 -0
- package/src/engine/file/file/ripgrep.ts +481 -0
- package/src/engine/file/file/watcher.ts +167 -0
- package/src/engine/file/ignore.ts +81 -0
- package/src/engine/file/index.ts +651 -0
- package/src/engine/file/protected.ts +59 -0
- package/src/engine/file/ripgrep.ts +481 -0
- package/src/engine/file/watcher.ts +167 -0
- package/src/engine/format/format/formatter.ts +404 -0
- package/src/engine/format/format/index.ts +209 -0
- package/src/engine/format/formatter.ts +404 -0
- package/src/engine/format/index.ts +209 -0
- package/src/engine/git/git/index.ts +347 -0
- package/src/engine/git/index.ts +347 -0
- package/src/engine/id/id.ts +80 -0
- package/src/engine/ide/index.ts +70 -0
- package/src/engine/image/image/image.ts +176 -0
- package/src/engine/image/image.ts +176 -0
- package/src/engine/index.ts +251 -0
- package/src/engine/installation/index.ts +327 -0
- package/src/engine/lsp/client.ts +707 -0
- package/src/engine/lsp/diagnostic.ts +29 -0
- package/src/engine/lsp/language.ts +121 -0
- package/src/engine/lsp/launch.ts +21 -0
- package/src/engine/lsp/lsp/client.ts +707 -0
- package/src/engine/lsp/lsp/diagnostic.ts +29 -0
- package/src/engine/lsp/lsp/language.ts +121 -0
- package/src/engine/lsp/lsp/launch.ts +21 -0
- package/src/engine/lsp/lsp/lsp.ts +507 -0
- package/src/engine/lsp/lsp/server.ts +2064 -0
- package/src/engine/lsp/lsp.ts +507 -0
- package/src/engine/lsp/server.ts +2064 -0
- package/src/engine/mcp/auth.ts +146 -0
- package/src/engine/mcp/index.ts +958 -0
- package/src/engine/mcp/mcp/auth.ts +146 -0
- package/src/engine/mcp/mcp/index.ts +958 -0
- package/src/engine/mcp/mcp/oauth-callback.ts +232 -0
- package/src/engine/mcp/mcp/oauth-provider.ts +214 -0
- package/src/engine/mcp/oauth-callback.ts +232 -0
- package/src/engine/mcp/oauth-provider.ts +214 -0
- package/src/engine/node.ts +6 -0
- package/src/engine/patch/index.ts +689 -0
- package/src/engine/patch/patch/index.ts +689 -0
- package/src/engine/permission/arity.ts +163 -0
- package/src/engine/permission/evaluate.ts +15 -0
- package/src/engine/permission/index.ts +306 -0
- package/src/engine/permission/permission/arity.ts +163 -0
- package/src/engine/permission/permission/evaluate.ts +15 -0
- package/src/engine/permission/permission/index.ts +306 -0
- package/src/engine/permission/permission/schema.ts +13 -0
- package/src/engine/permission/schema.ts +13 -0
- package/src/engine/plugin/azure.ts +26 -0
- package/src/engine/plugin/cloudflare.ts +76 -0
- package/src/engine/plugin/codex.ts +622 -0
- package/src/engine/plugin/digitalocean.ts +411 -0
- package/src/engine/plugin/github-copilot/copilot.ts +394 -0
- package/src/engine/plugin/github-copilot/models.ts +196 -0
- package/src/engine/plugin/index.ts +295 -0
- package/src/engine/plugin/install.ts +439 -0
- package/src/engine/plugin/loader.ts +216 -0
- package/src/engine/plugin/meta.ts +188 -0
- package/src/engine/plugin/shared.ts +323 -0
- package/src/engine/project/bootstrap-service.ts +9 -0
- package/src/engine/project/bootstrap.ts +75 -0
- package/src/engine/project/instance-context.ts +24 -0
- package/src/engine/project/instance-layer.ts +11 -0
- package/src/engine/project/instance-runtime.ts +16 -0
- package/src/engine/project/instance-store.ts +193 -0
- package/src/engine/project/project.sql.ts +17 -0
- package/src/engine/project/project.ts +537 -0
- package/src/engine/project/schema.ts +13 -0
- package/src/engine/project/vcs.ts +405 -0
- package/src/engine/provider/auth.ts +225 -0
- package/src/engine/provider/error.ts +204 -0
- package/src/engine/provider/model-status.ts +8 -0
- package/src/engine/provider/provider.ts +1843 -0
- package/src/engine/provider/schema.ts +30 -0
- package/src/engine/provider/sdk/copilot/AGENTS.md +1 -0
- package/src/engine/provider/transform.ts +1376 -0
- package/src/engine/pty/index.ts +365 -0
- package/src/engine/pty/input.ts +24 -0
- package/src/engine/pty/pty/index.ts +365 -0
- package/src/engine/pty/pty/input.ts +24 -0
- package/src/engine/pty/pty/pty.bun.ts +26 -0
- package/src/engine/pty/pty/pty.node.ts +27 -0
- package/src/engine/pty/pty/pty.ts +25 -0
- package/src/engine/pty/pty/schema.ts +14 -0
- package/src/engine/pty/pty/ticket.ts +68 -0
- package/src/engine/pty/pty.bun.ts +26 -0
- package/src/engine/pty/pty.node.ts +27 -0
- package/src/engine/pty/pty.ts +25 -0
- package/src/engine/pty/schema.ts +14 -0
- package/src/engine/pty/ticket.ts +68 -0
- package/src/engine/question/index.ts +213 -0
- package/src/engine/question/question/index.ts +213 -0
- package/src/engine/question/question/schema.ts +10 -0
- package/src/engine/question/schema.ts +10 -0
- package/src/engine/reference/reference/reference.ts +241 -0
- package/src/engine/reference/reference/repository-cache.ts +147 -0
- package/src/engine/reference/reference.ts +241 -0
- package/src/engine/reference/repository-cache.ts +147 -0
- package/src/engine/session/compaction.ts +651 -0
- package/src/engine/session/compaction_logic.ts +120 -0
- package/src/engine/session/instruction.ts +238 -0
- package/src/engine/session/instruction_loader.ts +54 -0
- package/src/engine/session/llm.ts +459 -0
- package/src/engine/session/message-error.ts +14 -0
- package/src/engine/session/message-v2.ts +1202 -0
- package/src/engine/session/message.ts +146 -0
- package/src/engine/session/overflow.ts +32 -0
- package/src/engine/session/overflow_check.ts +46 -0
- package/src/engine/session/processor.ts +823 -0
- package/src/engine/session/prompt/anthropic.txt +105 -0
- package/src/engine/session/prompt/beast.txt +147 -0
- package/src/engine/session/prompt/build-switch.txt +5 -0
- package/src/engine/session/prompt/codex.txt +79 -0
- package/src/engine/session/prompt/copilot-gpt-5.txt +143 -0
- package/src/engine/session/prompt/default.txt +105 -0
- package/src/engine/session/prompt/gemini.txt +155 -0
- package/src/engine/session/prompt/gpt.txt +107 -0
- package/src/engine/session/prompt/kimi.txt +95 -0
- package/src/engine/session/prompt/max-steps.txt +16 -0
- package/src/engine/session/prompt/plan-reminder-anthropic.txt +67 -0
- package/src/engine/session/prompt/plan.txt +26 -0
- package/src/engine/session/prompt/trinity.txt +97 -0
- package/src/engine/session/prompt.ts +671 -0
- package/src/engine/session/provider_transform.ts +187 -0
- package/src/engine/session/retry.ts +200 -0
- package/src/engine/session/retry_logic.ts +65 -0
- package/src/engine/session/revert.ts +162 -0
- package/src/engine/session/run-state.ts +153 -0
- package/src/engine/session/schema.ts +26 -0
- package/src/engine/session/session.sql.ts +137 -0
- package/src/engine/session/session.ts +1011 -0
- package/src/engine/session/status.ts +94 -0
- package/src/engine/session/summary.ts +164 -0
- package/src/engine/session/system.ts +84 -0
- package/src/engine/session/system_prompt.ts +65 -0
- package/src/engine/session/todo.ts +81 -0
- package/src/engine/session/tool_registry.ts +162 -0
- package/src/engine/share/session.ts +61 -0
- package/src/engine/share/share-next.ts +376 -0
- package/src/engine/share/share.sql.ts +13 -0
- package/src/engine/shell/shell/shell.ts +215 -0
- package/src/engine/shell/shell.ts +215 -0
- package/src/engine/skill/discovery.ts +116 -0
- package/src/engine/skill/index.ts +336 -0
- package/src/engine/skill/prompt/customize-opencode.md +377 -0
- package/src/engine/skill/skill/discovery.ts +116 -0
- package/src/engine/skill/skill/index.ts +336 -0
- package/src/engine/skill/skill/prompt/customize-opencode.md +377 -0
- package/src/engine/snapshot/index.ts +762 -0
- package/src/engine/snapshot/snapshot/index.ts +762 -0
- package/src/engine/sync/README.md +179 -0
- package/src/engine/sync/event.sql.ts +17 -0
- package/src/engine/sync/index.ts +410 -0
- package/src/engine/sync/schema.ts +11 -0
- package/src/engine/temporary.ts +33 -0
- package/src/engine/tool/apply_patch.ts +313 -0
- package/src/engine/tool/apply_patch.txt +33 -0
- package/src/engine/tool/edit.ts +711 -0
- package/src/engine/tool/edit.txt +10 -0
- package/src/engine/tool/external-directory.ts +49 -0
- package/src/engine/tool/glob.ts +103 -0
- package/src/engine/tool/glob.txt +6 -0
- package/src/engine/tool/grep.ts +156 -0
- package/src/engine/tool/grep.txt +8 -0
- package/src/engine/tool/invalid.ts +21 -0
- package/src/engine/tool/json-schema.ts +164 -0
- package/src/engine/tool/lsp.ts +113 -0
- package/src/engine/tool/lsp.txt +24 -0
- package/src/engine/tool/mcp-websearch.ts +96 -0
- package/src/engine/tool/plan-enter.txt +14 -0
- package/src/engine/tool/plan-exit.txt +13 -0
- package/src/engine/tool/plan.ts +78 -0
- package/src/engine/tool/question.ts +44 -0
- package/src/engine/tool/question.txt +10 -0
- package/src/engine/tool/read.ts +337 -0
- package/src/engine/tool/read.txt +14 -0
- package/src/engine/tool/registry.ts +472 -0
- package/src/engine/tool/repo_clone.ts +80 -0
- package/src/engine/tool/repo_clone.txt +5 -0
- package/src/engine/tool/repo_overview.ts +279 -0
- package/src/engine/tool/repo_overview.txt +4 -0
- package/src/engine/tool/schema.ts +14 -0
- package/src/engine/tool/shell/id.ts +19 -0
- package/src/engine/tool/shell/prompt.ts +295 -0
- package/src/engine/tool/shell/shell.txt +77 -0
- package/src/engine/tool/shell.ts +647 -0
- package/src/engine/tool/skill.ts +75 -0
- package/src/engine/tool/skill.txt +5 -0
- package/src/engine/tool/task.ts +337 -0
- package/src/engine/tool/task.txt +58 -0
- package/src/engine/tool/task_status.ts +179 -0
- package/src/engine/tool/task_status.txt +13 -0
- package/src/engine/tool/todo.ts +57 -0
- package/src/engine/tool/todowrite.txt +167 -0
- package/src/engine/tool/tool/apply_patch.ts +313 -0
- package/src/engine/tool/tool/apply_patch.txt +33 -0
- package/src/engine/tool/tool/edit.ts +711 -0
- package/src/engine/tool/tool/edit.txt +10 -0
- package/src/engine/tool/tool/external-directory.ts +49 -0
- package/src/engine/tool/tool/glob.ts +103 -0
- package/src/engine/tool/tool/glob.txt +6 -0
- package/src/engine/tool/tool/grep.ts +156 -0
- package/src/engine/tool/tool/grep.txt +8 -0
- package/src/engine/tool/tool/invalid.ts +21 -0
- package/src/engine/tool/tool/json-schema.ts +164 -0
- package/src/engine/tool/tool/lsp.ts +113 -0
- package/src/engine/tool/tool/lsp.txt +24 -0
- package/src/engine/tool/tool/mcp-websearch.ts +96 -0
- package/src/engine/tool/tool/plan-enter.txt +14 -0
- package/src/engine/tool/tool/plan-exit.txt +13 -0
- package/src/engine/tool/tool/plan.ts +78 -0
- package/src/engine/tool/tool/question.ts +44 -0
- package/src/engine/tool/tool/question.txt +10 -0
- package/src/engine/tool/tool/read.ts +337 -0
- package/src/engine/tool/tool/read.txt +14 -0
- package/src/engine/tool/tool/registry.ts +472 -0
- package/src/engine/tool/tool/repo_clone.ts +80 -0
- package/src/engine/tool/tool/repo_clone.txt +5 -0
- package/src/engine/tool/tool/repo_overview.ts +279 -0
- package/src/engine/tool/tool/repo_overview.txt +4 -0
- package/src/engine/tool/tool/schema.ts +14 -0
- package/src/engine/tool/tool/shell/id.ts +19 -0
- package/src/engine/tool/tool/shell/prompt.ts +295 -0
- package/src/engine/tool/tool/shell/shell.txt +77 -0
- package/src/engine/tool/tool/shell.ts +647 -0
- package/src/engine/tool/tool/skill.ts +75 -0
- package/src/engine/tool/tool/skill.txt +5 -0
- package/src/engine/tool/tool/task.ts +337 -0
- package/src/engine/tool/tool/task.txt +58 -0
- package/src/engine/tool/tool/task_status.ts +179 -0
- package/src/engine/tool/tool/task_status.txt +13 -0
- package/src/engine/tool/tool/todo.ts +57 -0
- package/src/engine/tool/tool/todowrite.txt +167 -0
- package/src/engine/tool/tool/tool.ts +164 -0
- package/src/engine/tool/tool/truncate.ts +160 -0
- package/src/engine/tool/tool/truncation-dir.ts +4 -0
- package/src/engine/tool/tool/webfetch.ts +192 -0
- package/src/engine/tool/tool/webfetch.txt +13 -0
- package/src/engine/tool/tool/websearch.ts +143 -0
- package/src/engine/tool/tool/websearch.txt +14 -0
- package/src/engine/tool/tool/write.ts +104 -0
- package/src/engine/tool/tool/write.txt +8 -0
- package/src/engine/tool/tool.ts +164 -0
- package/src/engine/tool/truncate.ts +160 -0
- package/src/engine/tool/truncation-dir.ts +4 -0
- package/src/engine/tool/webfetch.ts +192 -0
- package/src/engine/tool/webfetch.txt +13 -0
- package/src/engine/tool/websearch.ts +143 -0
- package/src/engine/tool/websearch.txt +14 -0
- package/src/engine/tool/write.ts +104 -0
- package/src/engine/tool/write.txt +8 -0
- package/src/engine/util/archive.ts +17 -0
- package/src/engine/util/bom.ts +31 -0
- package/src/engine/util/data-url.ts +9 -0
- package/src/engine/util/defer.ts +10 -0
- package/src/engine/util/effect-http-client.ts +11 -0
- package/src/engine/util/error.ts +88 -0
- package/src/engine/util/filesystem.ts +252 -0
- package/src/engine/util/format.ts +20 -0
- package/src/engine/util/iife.ts +3 -0
- package/src/engine/util/lazy.ts +20 -0
- package/src/engine/util/local-context.ts +25 -0
- package/src/engine/util/locale.ts +86 -0
- package/src/engine/util/media.ts +26 -0
- package/src/engine/util/process.ts +176 -0
- package/src/engine/util/queue.ts +32 -0
- package/src/engine/util/record.ts +3 -0
- package/src/engine/util/repository.ts +158 -0
- package/src/engine/util/rpc.ts +66 -0
- package/src/engine/util/signal.ts +12 -0
- package/src/engine/util/timeout.ts +13 -0
- package/src/engine/util/token.ts +7 -0
- package/src/engine/util/util/archive.ts +17 -0
- package/src/engine/util/util/bom.ts +31 -0
- package/src/engine/util/util/data-url.ts +9 -0
- package/src/engine/util/util/defer.ts +10 -0
- package/src/engine/util/util/effect-http-client.ts +11 -0
- package/src/engine/util/util/error.ts +88 -0
- package/src/engine/util/util/filesystem.ts +252 -0
- package/src/engine/util/util/format.ts +20 -0
- package/src/engine/util/util/iife.ts +3 -0
- package/src/engine/util/util/lazy.ts +20 -0
- package/src/engine/util/util/local-context.ts +25 -0
- package/src/engine/util/util/locale.ts +86 -0
- package/src/engine/util/util/media.ts +26 -0
- package/src/engine/util/util/process.ts +176 -0
- package/src/engine/util/util/queue.ts +32 -0
- package/src/engine/util/util/record.ts +3 -0
- package/src/engine/util/util/repository.ts +158 -0
- package/src/engine/util/util/rpc.ts +66 -0
- package/src/engine/util/util/signal.ts +12 -0
- package/src/engine/util/util/timeout.ts +13 -0
- package/src/engine/util/util/token.ts +7 -0
- package/src/engine/util/util/which.ts +14 -0
- package/src/engine/util/util/wildcard.ts +59 -0
- package/src/engine/util/which.ts +14 -0
- package/src/engine/util/wildcard.ts +59 -0
- package/src/engine/worktree/index.ts +621 -0
- package/src/rag_worker.ts +519 -0
- package/src/server.ts +201 -0
- package/src/tui.ts +637 -0
- package/tsconfig.json +24 -0
|
@@ -0,0 +1,234 @@
|
|
|
1
|
+
// Generated by BoneScript compiler. DO NOT EDIT.
|
|
2
|
+
// Service: AgentInstanceService
|
|
3
|
+
import { Router, Request, Response } from "express";
|
|
4
|
+
import { v4 as uuid } from "uuid";
|
|
5
|
+
import { query, queryOne, execute, pool } from "../db";
|
|
6
|
+
import { eventBus } from "../events";
|
|
7
|
+
import { requireAuth, AuthContext } from "../auth";
|
|
8
|
+
import rateLimit from "express-rate-limit";
|
|
9
|
+
import { auditLog } from "../audit";
|
|
10
|
+
import { logger } from "../logger";
|
|
11
|
+
import { counter } from "../metrics";
|
|
12
|
+
import * as __algorithms from "../algorithms";
|
|
13
|
+
const { shortestPath, topologicalSort, binarySearch, bipartiteMatching, roundRobin, weightedAverage, percentile, rankBy, consistentHash } = __algorithms as any;
|
|
14
|
+
|
|
15
|
+
import { transitionAgentInstance, AGENTINSTANCE_INITIAL } from "../state_machines/agent_instance";
|
|
16
|
+
|
|
17
|
+
export const agentInstancesRouter = Router();
|
|
18
|
+
|
|
19
|
+
// Rate limiter from policy declaration
|
|
20
|
+
const __routeRateLimit = rateLimit({ windowMs: 60000, max: 200, standardHeaders: true, legacyHeaders: false });
|
|
21
|
+
|
|
22
|
+
// CREATE
|
|
23
|
+
agentInstancesRouter.post("/", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
24
|
+
try {
|
|
25
|
+
const id = uuid();
|
|
26
|
+
const { session_id, model_id, provider_id, system_prompt, temperature, max_tokens, context_window_used, context_window_max, total_cost_usd, total_tokens_in, total_tokens_out, config } = req.body;
|
|
27
|
+
const state = AGENTINSTANCE_INITIAL;
|
|
28
|
+
const sql = `INSERT INTO agent_instances (id, session_id, model_id, provider_id, system_prompt, temperature, max_tokens, context_window_used, context_window_max, total_cost_usd, total_tokens_in, total_tokens_out, config, state) VALUES ($1, $2, $3, $4, $5, $6, $7, $8, $9, $10, $11, $12, $13, $14) RETURNING *`;
|
|
29
|
+
const rows = await query(sql, [id, session_id, model_id, provider_id, system_prompt, temperature, max_tokens, context_window_used, context_window_max, total_cost_usd, total_tokens_in, total_tokens_out, config, state]);
|
|
30
|
+
counter("entity.created", { entity: "AgentInstance" });
|
|
31
|
+
res.status(201).json(rows[0]);
|
|
32
|
+
} catch (e: any) {
|
|
33
|
+
res.status(400).json({ error: { code: "CREATE_FAILED", message: e.message } });
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
// READ
|
|
38
|
+
agentInstancesRouter.get("/:id", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
39
|
+
try {
|
|
40
|
+
const row = await queryOne(`SELECT * FROM agent_instances WHERE id = $1`, [req.params.id]);
|
|
41
|
+
if (!row) return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
42
|
+
res.json(row);
|
|
43
|
+
} catch (e: any) {
|
|
44
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
// LIST
|
|
49
|
+
agentInstancesRouter.get("/", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
50
|
+
try {
|
|
51
|
+
const page = parseInt(req.query.page as string) || 1;
|
|
52
|
+
const pageSize = Math.min(parseInt(req.query.page_size as string) || 50, 100);
|
|
53
|
+
const offset = (page - 1) * pageSize;
|
|
54
|
+
const rows = await query(`SELECT * FROM agent_instances ORDER BY created_at DESC LIMIT $1 OFFSET $2`, [pageSize, offset]);
|
|
55
|
+
const [{ count }] = await query(`SELECT COUNT(*) as count FROM agent_instances`);
|
|
56
|
+
res.json({ items: rows, total: parseInt(count), page, page_size: pageSize });
|
|
57
|
+
} catch (e: any) {
|
|
58
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
// UPDATE
|
|
63
|
+
agentInstancesRouter.put("/:id", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
64
|
+
const fields = { ...req.body };
|
|
65
|
+
// State machine enforcement
|
|
66
|
+
if (fields.state !== undefined) {
|
|
67
|
+
const current = await queryOne<{ state: string }>(`SELECT state FROM agent_instances WHERE id = $1`, [req.params.id]);
|
|
68
|
+
if (!current) return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
69
|
+
// Find the trigger for this state transition
|
|
70
|
+
const trigger = `${current.state}_to_${fields.state}`;
|
|
71
|
+
const tr = transitionAgentInstance(current.state as any, trigger);
|
|
72
|
+
if (!tr.ok) return res.status(422).json({ error: { code: "INVALID_TRANSITION", message: `Cannot transition from ${current.state} to ${fields.state}` } });
|
|
73
|
+
}
|
|
74
|
+
const sets = Object.keys(fields).map((k, i) => `${k} = $${i + 2}`).join(", ");
|
|
75
|
+
const values = Object.values(fields);
|
|
76
|
+
const sql = `UPDATE agent_instances SET ${sets}, updated_at = NOW() WHERE id = $1 RETURNING *`;
|
|
77
|
+
const rows = await query(sql, [req.params.id, ...values]);
|
|
78
|
+
if (rows.length === 0) return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
79
|
+
res.json(rows[0]);
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
// DELETE
|
|
83
|
+
agentInstancesRouter.delete("/:id", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
84
|
+
try {
|
|
85
|
+
const count = await execute(`DELETE FROM agent_instances WHERE id = $1`, [req.params.id]);
|
|
86
|
+
if (count === 0) return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
87
|
+
res.status(204).send();
|
|
88
|
+
} catch (e: any) {
|
|
89
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
90
|
+
}
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
// CAPABILITY: complete_agent [transactional]
|
|
94
|
+
agentInstancesRouter.post("/complete-agent", __routeRateLimit, requireAuth, auditLog("complete_agent", "AgentInstance"), async (req: Request, res: Response) => {
|
|
95
|
+
const auth: AuthContext = (req as any).auth;
|
|
96
|
+
const __client = await pool.connect();
|
|
97
|
+
try {
|
|
98
|
+
await __client.query("BEGIN");
|
|
99
|
+
// Fetch entities
|
|
100
|
+
const agent = await queryOne(`SELECT * FROM agent_instances WHERE id = $1`, [req.body.agent_id || req.params.id]);
|
|
101
|
+
if (!agent) {
|
|
102
|
+
return res.status(404).json({ error: { code: "NOT_FOUND", message: "agent not found" } });
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
// Preconditions
|
|
106
|
+
if (!([["running", "waiting_for_tool"]].flat().includes(agent?.state))) {
|
|
107
|
+
return res.status(422).json({ error: { code: "PRECONDITION_FAILED", message: "agent.state in [\\\"running\\\", \\\"waiting_for_tool\\\"]" } });
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
// Effects (applied in declaration order)
|
|
111
|
+
const __effect_0 = await query(`UPDATE agents SET state = $1, updated_at = NOW() WHERE id = $2 RETURNING *`, ["done", req.body.agent_id || req.params.id]);
|
|
112
|
+
if (!__effect_0 || __effect_0.length === 0) {
|
|
113
|
+
throw new Error("Effect failed: agent.state = \"done\"");
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
// Emit events
|
|
117
|
+
await eventBus.publish("AgentCompleted", { agent_id: agent?.id, timestamp: new Date().toISOString(), actor_id: auth.actor_id }, "AgentInstanceService", auth.trace_id, __client);
|
|
118
|
+
|
|
119
|
+
res.json({ ok: true, action: "complete_agent", entity: agent });
|
|
120
|
+
await __client.query("COMMIT");
|
|
121
|
+
} catch (e: any) {
|
|
122
|
+
await __client.query("ROLLBACK");
|
|
123
|
+
res.status(400).json({ error: { code: "CAPABILITY_FAILED", message: e.message } });
|
|
124
|
+
} finally {
|
|
125
|
+
__client.release();
|
|
126
|
+
}
|
|
127
|
+
});
|
|
128
|
+
|
|
129
|
+
// CAPABILITY: fail_agent [transactional]
|
|
130
|
+
agentInstancesRouter.post("/fail-agent", __routeRateLimit, requireAuth, auditLog("fail_agent", "AgentInstance"), async (req: Request, res: Response) => {
|
|
131
|
+
const auth: AuthContext = (req as any).auth;
|
|
132
|
+
const __client = await pool.connect();
|
|
133
|
+
try {
|
|
134
|
+
await __client.query("BEGIN");
|
|
135
|
+
const { error } = req.body;
|
|
136
|
+
|
|
137
|
+
// Fetch entities
|
|
138
|
+
const agent = await queryOne(`SELECT * FROM agent_instances WHERE id = $1`, [req.body.agent_id || req.params.id]);
|
|
139
|
+
if (!agent) {
|
|
140
|
+
return res.status(404).json({ error: { code: "NOT_FOUND", message: "agent not found" } });
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
// Preconditions
|
|
144
|
+
if (!([["running", "waiting_for_tool", "compacting"]].flat().includes(agent?.state))) {
|
|
145
|
+
return res.status(422).json({ error: { code: "PRECONDITION_FAILED", message: "agent.state in [\\\"running\\\", \\\"waiting_for_tool\\\", \\\"compacting\\\"]" } });
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
// Effects (applied in declaration order)
|
|
149
|
+
const __effect_0 = await query(`UPDATE agents SET state = $1, updated_at = NOW() WHERE id = $2 RETURNING *`, ["failed", req.body.agent_id || req.params.id]);
|
|
150
|
+
if (!__effect_0 || __effect_0.length === 0) {
|
|
151
|
+
throw new Error("Effect failed: agent.state = \"failed\"");
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
// Emit events
|
|
155
|
+
await eventBus.publish("AgentFailed", { agent_id: agent?.id, timestamp: new Date().toISOString(), actor_id: auth.actor_id }, "AgentInstanceService", auth.trace_id, __client);
|
|
156
|
+
|
|
157
|
+
res.json({ ok: true, action: "fail_agent", entity: agent });
|
|
158
|
+
await __client.query("COMMIT");
|
|
159
|
+
} catch (e: any) {
|
|
160
|
+
await __client.query("ROLLBACK");
|
|
161
|
+
res.status(400).json({ error: { code: "CAPABILITY_FAILED", message: e.message } });
|
|
162
|
+
} finally {
|
|
163
|
+
__client.release();
|
|
164
|
+
}
|
|
165
|
+
});
|
|
166
|
+
|
|
167
|
+
// CAPABILITY: request_tool_call [transactional]
|
|
168
|
+
agentInstancesRouter.post("/request-tool-call", __routeRateLimit, requireAuth, auditLog("request_tool_call", "AgentInstance"), async (req: Request, res: Response) => {
|
|
169
|
+
const auth: AuthContext = (req as any).auth;
|
|
170
|
+
const __client = await pool.connect();
|
|
171
|
+
try {
|
|
172
|
+
await __client.query("BEGIN");
|
|
173
|
+
const { tool_name, tool_input } = req.body;
|
|
174
|
+
|
|
175
|
+
// Fetch entities
|
|
176
|
+
const agent = await queryOne(`SELECT * FROM agent_instances WHERE id = $1`, [req.body.agent_id || req.params.id]);
|
|
177
|
+
if (!agent) {
|
|
178
|
+
return res.status(404).json({ error: { code: "NOT_FOUND", message: "agent not found" } });
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
// Preconditions
|
|
182
|
+
if (!(agent?.state === "running")) {
|
|
183
|
+
return res.status(422).json({ error: { code: "PRECONDITION_FAILED", message: "agent.state == \\\"running\\\"" } });
|
|
184
|
+
}
|
|
185
|
+
if (!(tool_name?.length >= 1)) {
|
|
186
|
+
return res.status(422).json({ error: { code: "PRECONDITION_FAILED", message: "tool_name.length >= 1" } });
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
// Effects (applied in declaration order)
|
|
190
|
+
const __effect_0 = await query(`UPDATE agents SET state = $1, updated_at = NOW() WHERE id = $2 RETURNING *`, ["waiting_for_tool", req.body.agent_id || req.params.id]);
|
|
191
|
+
if (!__effect_0 || __effect_0.length === 0) {
|
|
192
|
+
throw new Error("Effect failed: agent.state = \"waiting_for_tool\"");
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
// Emit events
|
|
196
|
+
await eventBus.publish("ToolCallRequested", { agent_id: agent?.id, timestamp: new Date().toISOString(), actor_id: auth.actor_id }, "AgentInstanceService", auth.trace_id, __client);
|
|
197
|
+
|
|
198
|
+
res.json({ ok: true, action: "request_tool_call", entity: agent });
|
|
199
|
+
await __client.query("COMMIT");
|
|
200
|
+
} catch (e: any) {
|
|
201
|
+
await __client.query("ROLLBACK");
|
|
202
|
+
res.status(400).json({ error: { code: "CAPABILITY_FAILED", message: e.message } });
|
|
203
|
+
} finally {
|
|
204
|
+
__client.release();
|
|
205
|
+
}
|
|
206
|
+
});
|
|
207
|
+
|
|
208
|
+
// RELATION: tasks (has_many Task)
|
|
209
|
+
agentInstancesRouter.get("/:id/tasks", requireAuth, async (req: Request, res: Response) => {
|
|
210
|
+
try {
|
|
211
|
+
const page = parseInt(req.query.page as string) || 1;
|
|
212
|
+
const pageSize = Math.min(parseInt(req.query.page_size as string) || 50, 100);
|
|
213
|
+
const offset = (page - 1) * pageSize;
|
|
214
|
+
const rows = await query(`SELECT * FROM tasks WHERE agent_id = $1 ORDER BY created_at DESC LIMIT $2 OFFSET $3`, [req.params.id, pageSize, offset]);
|
|
215
|
+
const [{ count }] = await query(`SELECT COUNT(*) as count FROM tasks WHERE agent_id = $1`, [req.params.id]);
|
|
216
|
+
res.json({ items: rows, total: parseInt(count), page, page_size: pageSize });
|
|
217
|
+
} catch (e: any) {
|
|
218
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
219
|
+
}
|
|
220
|
+
});
|
|
221
|
+
|
|
222
|
+
// RELATION: tool_calls (has_many ToolCall)
|
|
223
|
+
agentInstancesRouter.get("/:id/tool_calls", requireAuth, async (req: Request, res: Response) => {
|
|
224
|
+
try {
|
|
225
|
+
const page = parseInt(req.query.page as string) || 1;
|
|
226
|
+
const pageSize = Math.min(parseInt(req.query.page_size as string) || 50, 100);
|
|
227
|
+
const offset = (page - 1) * pageSize;
|
|
228
|
+
const rows = await query(`SELECT * FROM tool_calls WHERE agent_id = $1 ORDER BY created_at DESC LIMIT $2 OFFSET $3`, [req.params.id, pageSize, offset]);
|
|
229
|
+
const [{ count }] = await query(`SELECT COUNT(*) as count FROM tool_calls WHERE agent_id = $1`, [req.params.id]);
|
|
230
|
+
res.json({ items: rows, total: parseInt(count), page, page_size: pageSize });
|
|
231
|
+
} catch (e: any) {
|
|
232
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
233
|
+
}
|
|
234
|
+
});
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
// Generated by BoneScript compiler. DO NOT EDIT.
|
|
2
|
+
// Service: BuildStepService
|
|
3
|
+
import { Router, Request, Response } from "express";
|
|
4
|
+
import { v4 as uuid } from "uuid";
|
|
5
|
+
import { query, queryOne, execute, pool } from "../db";
|
|
6
|
+
import { eventBus } from "../events";
|
|
7
|
+
import { requireAuth, AuthContext } from "../auth";
|
|
8
|
+
import rateLimit from "express-rate-limit";
|
|
9
|
+
import { auditLog } from "../audit";
|
|
10
|
+
import { logger } from "../logger";
|
|
11
|
+
import { counter } from "../metrics";
|
|
12
|
+
import * as __algorithms from "../algorithms";
|
|
13
|
+
const { shortestPath, topologicalSort, binarySearch, bipartiteMatching, roundRobin, weightedAverage, percentile, rankBy, consistentHash } = __algorithms as any;
|
|
14
|
+
|
|
15
|
+
import { transitionBuildStep, BUILDSTEP_INITIAL } from "../state_machines/build_step";
|
|
16
|
+
|
|
17
|
+
export const buildStepsRouter = Router();
|
|
18
|
+
|
|
19
|
+
// Rate limiter from policy declaration
|
|
20
|
+
const __routeRateLimit = rateLimit({ windowMs: 60000, max: 200, standardHeaders: true, legacyHeaders: false });
|
|
21
|
+
|
|
22
|
+
// CREATE
|
|
23
|
+
buildStepsRouter.post("/", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
24
|
+
try {
|
|
25
|
+
const id = uuid();
|
|
26
|
+
const { task_id, agent_id, session_id, step_type, description, file_path, diff, result, error, order_index } = req.body;
|
|
27
|
+
const state = BUILDSTEP_INITIAL;
|
|
28
|
+
const sql = `INSERT INTO build_steps (id, task_id, agent_id, session_id, step_type, description, file_path, diff, result, error, order_index, state) VALUES ($1, $2, $3, $4, $5, $6, $7, $8, $9, $10, $11, $12) RETURNING *`;
|
|
29
|
+
const rows = await query(sql, [id, task_id, agent_id, session_id, step_type, description, file_path, diff, result, error, order_index, state]);
|
|
30
|
+
counter("entity.created", { entity: "BuildStep" });
|
|
31
|
+
res.status(201).json(rows[0]);
|
|
32
|
+
} catch (e: any) {
|
|
33
|
+
res.status(400).json({ error: { code: "CREATE_FAILED", message: e.message } });
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
// READ
|
|
38
|
+
buildStepsRouter.get("/:id", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
39
|
+
try {
|
|
40
|
+
const row = await queryOne(`SELECT * FROM build_steps WHERE id = $1`, [req.params.id]);
|
|
41
|
+
if (!row) return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
42
|
+
res.json(row);
|
|
43
|
+
} catch (e: any) {
|
|
44
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
// LIST
|
|
49
|
+
buildStepsRouter.get("/", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
50
|
+
try {
|
|
51
|
+
const page = parseInt(req.query.page as string) || 1;
|
|
52
|
+
const pageSize = Math.min(parseInt(req.query.page_size as string) || 50, 100);
|
|
53
|
+
const offset = (page - 1) * pageSize;
|
|
54
|
+
const rows = await query(`SELECT build_steps.*, row_to_json(task.*) as task FROM build_steps LEFT JOIN tasks task ON build_steps.task_id = task.id ORDER BY build_steps.created_at DESC LIMIT $1 OFFSET $2`, [pageSize, offset]);
|
|
55
|
+
const [{ count }] = await query(`SELECT COUNT(*) as count FROM build_steps`);
|
|
56
|
+
res.json({ items: rows, total: parseInt(count), page, page_size: pageSize });
|
|
57
|
+
} catch (e: any) {
|
|
58
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
// UPDATE
|
|
63
|
+
buildStepsRouter.put("/:id", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
64
|
+
const fields = { ...req.body };
|
|
65
|
+
// State machine enforcement
|
|
66
|
+
if (fields.state !== undefined) {
|
|
67
|
+
const current = await queryOne<{ state: string }>(`SELECT state FROM build_steps WHERE id = $1`, [req.params.id]);
|
|
68
|
+
if (!current) return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
69
|
+
// Find the trigger for this state transition
|
|
70
|
+
const trigger = `${current.state}_to_${fields.state}`;
|
|
71
|
+
const tr = transitionBuildStep(current.state as any, trigger);
|
|
72
|
+
if (!tr.ok) return res.status(422).json({ error: { code: "INVALID_TRANSITION", message: `Cannot transition from ${current.state} to ${fields.state}` } });
|
|
73
|
+
}
|
|
74
|
+
const sets = Object.keys(fields).map((k, i) => `${k} = $${i + 2}`).join(", ");
|
|
75
|
+
const values = Object.values(fields);
|
|
76
|
+
const sql = `UPDATE build_steps SET ${sets}, updated_at = NOW() WHERE id = $1 RETURNING *`;
|
|
77
|
+
const rows = await query(sql, [req.params.id, ...values]);
|
|
78
|
+
if (rows.length === 0) return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
79
|
+
res.json(rows[0]);
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
// DELETE
|
|
83
|
+
buildStepsRouter.delete("/:id", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
84
|
+
try {
|
|
85
|
+
const count = await execute(`DELETE FROM build_steps WHERE id = $1`, [req.params.id]);
|
|
86
|
+
if (count === 0) return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
87
|
+
res.status(204).send();
|
|
88
|
+
} catch (e: any) {
|
|
89
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
90
|
+
}
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
// RELATION: tool_calls (has_many ToolCall)
|
|
94
|
+
buildStepsRouter.get("/:id/tool_calls", requireAuth, async (req: Request, res: Response) => {
|
|
95
|
+
try {
|
|
96
|
+
const page = parseInt(req.query.page as string) || 1;
|
|
97
|
+
const pageSize = Math.min(parseInt(req.query.page_size as string) || 50, 100);
|
|
98
|
+
const offset = (page - 1) * pageSize;
|
|
99
|
+
const rows = await query(`SELECT * FROM tool_calls WHERE build_step_id = $1 ORDER BY created_at DESC LIMIT $2 OFFSET $3`, [req.params.id, pageSize, offset]);
|
|
100
|
+
const [{ count }] = await query(`SELECT COUNT(*) as count FROM tool_calls WHERE build_step_id = $1`, [req.params.id]);
|
|
101
|
+
res.json({ items: rows, total: parseInt(count), page, page_size: pageSize });
|
|
102
|
+
} catch (e: any) {
|
|
103
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
104
|
+
}
|
|
105
|
+
});
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
// Generated by BoneScript compiler. DO NOT EDIT.
|
|
2
|
+
// Service: PlanService
|
|
3
|
+
import { Router, Request, Response } from "express";
|
|
4
|
+
import { v4 as uuid } from "uuid";
|
|
5
|
+
import { query, queryOne, execute, pool } from "../db";
|
|
6
|
+
import { eventBus } from "../events";
|
|
7
|
+
import { requireAuth, AuthContext } from "../auth";
|
|
8
|
+
import rateLimit from "express-rate-limit";
|
|
9
|
+
import { auditLog } from "../audit";
|
|
10
|
+
import { logger } from "../logger";
|
|
11
|
+
import { counter } from "../metrics";
|
|
12
|
+
import * as __algorithms from "../algorithms";
|
|
13
|
+
const { shortestPath, topologicalSort, binarySearch, bipartiteMatching, roundRobin, weightedAverage, percentile, rankBy, consistentHash } = __algorithms as any;
|
|
14
|
+
|
|
15
|
+
import { transitionPlan, PLAN_INITIAL } from "../state_machines/plan";
|
|
16
|
+
|
|
17
|
+
export const plansRouter = Router();
|
|
18
|
+
|
|
19
|
+
// Rate limiter from policy declaration
|
|
20
|
+
const __routeRateLimit = rateLimit({ windowMs: 60000, max: 200, standardHeaders: true, legacyHeaders: false });
|
|
21
|
+
|
|
22
|
+
// CREATE
|
|
23
|
+
plansRouter.post("/", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
24
|
+
try {
|
|
25
|
+
const id = uuid();
|
|
26
|
+
const { session_id, agent_id, task_id, steps, rationale, estimated_tokens } = req.body;
|
|
27
|
+
const state = PLAN_INITIAL;
|
|
28
|
+
const sql = `INSERT INTO plans (id, session_id, agent_id, task_id, steps, rationale, estimated_tokens, state) VALUES ($1, $2, $3, $4, $5, $6, $7, $8) RETURNING *`;
|
|
29
|
+
const rows = await query(sql, [id, session_id, agent_id, task_id, steps, rationale, estimated_tokens, state]);
|
|
30
|
+
counter("entity.created", { entity: "Plan" });
|
|
31
|
+
res.status(201).json(rows[0]);
|
|
32
|
+
} catch (e: any) {
|
|
33
|
+
res.status(400).json({ error: { code: "CREATE_FAILED", message: e.message } });
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
// READ
|
|
38
|
+
plansRouter.get("/:id", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
39
|
+
try {
|
|
40
|
+
const row = await queryOne(`SELECT * FROM plans WHERE id = $1`, [req.params.id]);
|
|
41
|
+
if (!row) return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
42
|
+
res.json(row);
|
|
43
|
+
} catch (e: any) {
|
|
44
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
// LIST
|
|
49
|
+
plansRouter.get("/", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
50
|
+
try {
|
|
51
|
+
const page = parseInt(req.query.page as string) || 1;
|
|
52
|
+
const pageSize = Math.min(parseInt(req.query.page_size as string) || 50, 100);
|
|
53
|
+
const offset = (page - 1) * pageSize;
|
|
54
|
+
const rows = await query(`SELECT * FROM plans ORDER BY created_at DESC LIMIT $1 OFFSET $2`, [pageSize, offset]);
|
|
55
|
+
const [{ count }] = await query(`SELECT COUNT(*) as count FROM plans`);
|
|
56
|
+
res.json({ items: rows, total: parseInt(count), page, page_size: pageSize });
|
|
57
|
+
} catch (e: any) {
|
|
58
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
// UPDATE
|
|
63
|
+
plansRouter.put("/:id", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
64
|
+
const fields = { ...req.body };
|
|
65
|
+
// State machine enforcement
|
|
66
|
+
if (fields.state !== undefined) {
|
|
67
|
+
const current = await queryOne<{ state: string }>(`SELECT state FROM plans WHERE id = $1`, [req.params.id]);
|
|
68
|
+
if (!current) return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
69
|
+
// Find the trigger for this state transition
|
|
70
|
+
const trigger = `${current.state}_to_${fields.state}`;
|
|
71
|
+
const tr = transitionPlan(current.state as any, trigger);
|
|
72
|
+
if (!tr.ok) return res.status(422).json({ error: { code: "INVALID_TRANSITION", message: `Cannot transition from ${current.state} to ${fields.state}` } });
|
|
73
|
+
}
|
|
74
|
+
const sets = Object.keys(fields).map((k, i) => `${k} = $${i + 2}`).join(", ");
|
|
75
|
+
const values = Object.values(fields);
|
|
76
|
+
const sql = `UPDATE plans SET ${sets}, updated_at = NOW() WHERE id = $1 RETURNING *`;
|
|
77
|
+
const rows = await query(sql, [req.params.id, ...values]);
|
|
78
|
+
if (rows.length === 0) return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
79
|
+
res.json(rows[0]);
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
// DELETE
|
|
83
|
+
plansRouter.delete("/:id", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
84
|
+
try {
|
|
85
|
+
const count = await execute(`DELETE FROM plans WHERE id = $1`, [req.params.id]);
|
|
86
|
+
if (count === 0) return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
87
|
+
res.status(204).send();
|
|
88
|
+
} catch (e: any) {
|
|
89
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
90
|
+
}
|
|
91
|
+
});
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
// Generated by BoneScript compiler. DO NOT EDIT.
|
|
2
|
+
// Service: TaskService
|
|
3
|
+
import { Router, Request, Response } from "express";
|
|
4
|
+
import { v4 as uuid } from "uuid";
|
|
5
|
+
import { query, queryOne, execute, pool } from "../db";
|
|
6
|
+
import { eventBus } from "../events";
|
|
7
|
+
import { requireAuth, AuthContext } from "../auth";
|
|
8
|
+
import rateLimit from "express-rate-limit";
|
|
9
|
+
import { auditLog } from "../audit";
|
|
10
|
+
import { logger } from "../logger";
|
|
11
|
+
import { counter } from "../metrics";
|
|
12
|
+
import * as __algorithms from "../algorithms";
|
|
13
|
+
const { shortestPath, topologicalSort, binarySearch, bipartiteMatching, roundRobin, weightedAverage, percentile, rankBy, consistentHash } = __algorithms as any;
|
|
14
|
+
|
|
15
|
+
import { transitionTask, TASK_INITIAL } from "../state_machines/task";
|
|
16
|
+
|
|
17
|
+
export const tasksRouter = Router();
|
|
18
|
+
|
|
19
|
+
// Rate limiter from policy declaration
|
|
20
|
+
const __routeRateLimit = rateLimit({ windowMs: 60000, max: 200, standardHeaders: true, legacyHeaders: false });
|
|
21
|
+
|
|
22
|
+
// CREATE
|
|
23
|
+
tasksRouter.post("/", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
24
|
+
try {
|
|
25
|
+
const id = uuid();
|
|
26
|
+
const { agent_id, session_id, description, priority, result, error } = req.body;
|
|
27
|
+
const state = TASK_INITIAL;
|
|
28
|
+
const sql = `INSERT INTO tasks (id, agent_id, session_id, description, priority, result, error, state) VALUES ($1, $2, $3, $4, $5, $6, $7, $8) RETURNING *`;
|
|
29
|
+
const rows = await query(sql, [id, agent_id, session_id, description, priority, result, error, state]);
|
|
30
|
+
counter("entity.created", { entity: "Task" });
|
|
31
|
+
res.status(201).json(rows[0]);
|
|
32
|
+
} catch (e: any) {
|
|
33
|
+
res.status(400).json({ error: { code: "CREATE_FAILED", message: e.message } });
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
// READ
|
|
38
|
+
tasksRouter.get("/:id", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
39
|
+
try {
|
|
40
|
+
const row = await queryOne(`SELECT * FROM tasks WHERE id = $1`, [req.params.id]);
|
|
41
|
+
if (!row) return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
42
|
+
res.json(row);
|
|
43
|
+
} catch (e: any) {
|
|
44
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
// LIST
|
|
49
|
+
tasksRouter.get("/", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
50
|
+
try {
|
|
51
|
+
const page = parseInt(req.query.page as string) || 1;
|
|
52
|
+
const pageSize = Math.min(parseInt(req.query.page_size as string) || 50, 100);
|
|
53
|
+
const offset = (page - 1) * pageSize;
|
|
54
|
+
const rows = await query(`SELECT tasks.*, row_to_json(agent_instance.*) as agent FROM tasks LEFT JOIN agent_instances agent_instance ON tasks.agent_id = agent_instance.id ORDER BY tasks.created_at DESC LIMIT $1 OFFSET $2`, [pageSize, offset]);
|
|
55
|
+
const [{ count }] = await query(`SELECT COUNT(*) as count FROM tasks`);
|
|
56
|
+
res.json({ items: rows, total: parseInt(count), page, page_size: pageSize });
|
|
57
|
+
} catch (e: any) {
|
|
58
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
// UPDATE
|
|
63
|
+
tasksRouter.put("/:id", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
64
|
+
const fields = { ...req.body };
|
|
65
|
+
// State machine enforcement
|
|
66
|
+
if (fields.state !== undefined) {
|
|
67
|
+
const current = await queryOne<{ state: string }>(`SELECT state FROM tasks WHERE id = $1`, [req.params.id]);
|
|
68
|
+
if (!current) return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
69
|
+
// Find the trigger for this state transition
|
|
70
|
+
const trigger = `${current.state}_to_${fields.state}`;
|
|
71
|
+
const tr = transitionTask(current.state as any, trigger);
|
|
72
|
+
if (!tr.ok) return res.status(422).json({ error: { code: "INVALID_TRANSITION", message: `Cannot transition from ${current.state} to ${fields.state}` } });
|
|
73
|
+
}
|
|
74
|
+
const sets = Object.keys(fields).map((k, i) => `${k} = $${i + 2}`).join(", ");
|
|
75
|
+
const values = Object.values(fields);
|
|
76
|
+
const sql = `UPDATE tasks SET ${sets}, updated_at = NOW() WHERE id = $1 RETURNING *`;
|
|
77
|
+
const rows = await query(sql, [req.params.id, ...values]);
|
|
78
|
+
if (rows.length === 0) return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
79
|
+
res.json(rows[0]);
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
// DELETE
|
|
83
|
+
tasksRouter.delete("/:id", __routeRateLimit, requireAuth, async (req: Request, res: Response) => {
|
|
84
|
+
try {
|
|
85
|
+
const count = await execute(`DELETE FROM tasks WHERE id = $1`, [req.params.id]);
|
|
86
|
+
if (count === 0) return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
87
|
+
res.status(204).send();
|
|
88
|
+
} catch (e: any) {
|
|
89
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
90
|
+
}
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
// RELATION: steps (has_many BuildStep)
|
|
94
|
+
tasksRouter.get("/:id/steps", requireAuth, async (req: Request, res: Response) => {
|
|
95
|
+
try {
|
|
96
|
+
const page = parseInt(req.query.page as string) || 1;
|
|
97
|
+
const pageSize = Math.min(parseInt(req.query.page_size as string) || 50, 100);
|
|
98
|
+
const offset = (page - 1) * pageSize;
|
|
99
|
+
const rows = await query(`SELECT * FROM build_steps WHERE task_id = $1 ORDER BY created_at DESC LIMIT $2 OFFSET $3`, [req.params.id, pageSize, offset]);
|
|
100
|
+
const [{ count }] = await query(`SELECT COUNT(*) as count FROM build_steps WHERE task_id = $1`, [req.params.id]);
|
|
101
|
+
res.json({ items: rows, total: parseInt(count), page, page_size: pageSize });
|
|
102
|
+
} catch (e: any) {
|
|
103
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
104
|
+
}
|
|
105
|
+
});
|