@amodalai/runtime 0.1.25 → 0.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/dist/src/__fixtures__/README.md +84 -0
- package/dist/src/__fixtures__/smoke-agent/amodal.json +11 -0
- package/dist/src/__fixtures__/smoke-agent/automations/test-auto.md +5 -0
- package/dist/src/__fixtures__/smoke-agent/connections/mock-api/access.json +11 -0
- package/dist/src/__fixtures__/smoke-agent/connections/mock-api/spec.json +4 -0
- package/dist/src/__fixtures__/smoke-agent/connections/mock-api/surface.md +9 -0
- package/dist/src/__fixtures__/smoke-agent/connections/mock-mcp/access.json +3 -0
- package/dist/src/__fixtures__/smoke-agent/connections/mock-mcp/spec.json +8 -0
- package/dist/src/__fixtures__/smoke-agent/evals/basic-eval.md +12 -0
- package/dist/src/__fixtures__/smoke-agent/knowledge/test-knowledge.md +3 -0
- package/dist/src/__fixtures__/smoke-agent/skills/test-skill/SKILL.md +11 -0
- package/dist/src/__fixtures__/smoke-agent/stores/test-items.json +11 -0
- package/dist/src/__fixtures__/smoke-agent/tools/echo_tool/handler.d.ts +18 -0
- package/dist/src/__fixtures__/smoke-agent/tools/echo_tool/handler.js +22 -0
- package/dist/src/__fixtures__/smoke-agent/tools/echo_tool/handler.js.map +1 -0
- package/dist/src/__fixtures__/smoke-agent/tools/echo_tool/tool.json +17 -0
- package/dist/src/__fixtures__/smoke.test.js +718 -0
- package/dist/src/__fixtures__/smoke.test.js.map +1 -0
- package/dist/src/{agent/stores-e2e.test.d.ts → __tests__/providers.test.d.ts} +1 -1
- package/dist/src/__tests__/providers.test.js +209 -0
- package/dist/src/__tests__/providers.test.js.map +1 -0
- package/dist/src/__tests__/test-providers.d.ts +40 -0
- package/dist/src/__tests__/test-providers.js +61 -0
- package/dist/src/__tests__/test-providers.js.map +1 -0
- package/dist/src/agent/agent-types.d.ts +2 -2
- package/dist/src/agent/config-watcher.test.js +18 -14
- package/dist/src/agent/config-watcher.test.js.map +1 -1
- package/dist/src/agent/local-server.d.ts +3 -3
- package/dist/src/agent/local-server.js +213 -122
- package/dist/src/agent/local-server.js.map +1 -1
- package/dist/src/agent/local-server.test.js +17 -13
- package/dist/src/agent/local-server.test.js.map +1 -1
- package/dist/src/agent/loop-types.d.ts +175 -0
- package/dist/src/agent/loop-types.js +20 -0
- package/dist/src/agent/loop-types.js.map +1 -0
- package/dist/src/agent/loop.d.ts +31 -0
- package/dist/src/agent/loop.js +139 -0
- package/dist/src/agent/loop.js.map +1 -0
- package/dist/src/agent/{tool-context-builder.test.d.ts → loop.test.d.ts} +1 -1
- package/dist/src/agent/loop.test.js +1030 -0
- package/dist/src/agent/loop.test.js.map +1 -0
- package/dist/src/agent/mcp-config.d.ts +28 -0
- package/dist/src/agent/mcp-config.js +57 -0
- package/dist/src/agent/mcp-config.js.map +1 -0
- package/dist/src/agent/page-builder.js +6 -1
- package/dist/src/agent/page-builder.js.map +1 -1
- package/dist/src/agent/proactive/proactive-runner.d.ts +24 -8
- package/dist/src/agent/proactive/proactive-runner.js +36 -33
- package/dist/src/agent/proactive/proactive-runner.js.map +1 -1
- package/dist/src/agent/proactive/proactive-runner.test.d.ts +1 -1
- package/dist/src/agent/proactive/proactive-runner.test.js +75 -87
- package/dist/src/agent/proactive/proactive-runner.test.js.map +1 -1
- package/dist/src/agent/routes/admin-chat.d.ts +15 -3
- package/dist/src/agent/routes/admin-chat.js +63 -17
- package/dist/src/agent/routes/admin-chat.js.map +1 -1
- package/dist/src/agent/routes/automations.js +5 -4
- package/dist/src/agent/routes/automations.js.map +1 -1
- package/dist/src/agent/routes/evals.d.ts +3 -2
- package/dist/src/agent/routes/evals.js +25 -11
- package/dist/src/agent/routes/evals.js.map +1 -1
- package/dist/src/agent/routes/files.js +7 -6
- package/dist/src/agent/routes/files.js.map +1 -1
- package/dist/src/agent/routes/inspect.d.ts +6 -2
- package/dist/src/agent/routes/inspect.js +32 -15
- package/dist/src/agent/routes/inspect.js.map +1 -1
- package/dist/src/agent/routes/inspect.test.js +18 -42
- package/dist/src/agent/routes/inspect.test.js.map +1 -1
- package/dist/src/agent/routes/stores.js +9 -8
- package/dist/src/agent/routes/stores.js.map +1 -1
- package/dist/src/agent/routes/task.d.ts +15 -3
- package/dist/src/agent/routes/task.js +16 -6
- package/dist/src/agent/routes/task.js.map +1 -1
- package/dist/src/agent/routes/task.test.d.ts +1 -1
- package/dist/src/agent/routes/task.test.js +70 -53
- package/dist/src/agent/routes/task.test.js.map +1 -1
- package/dist/src/agent/routes/webhooks.js +12 -2
- package/dist/src/agent/routes/webhooks.js.map +1 -1
- package/dist/src/agent/session-store.d.ts +11 -2
- package/dist/src/agent/session-store.js +1 -1
- package/dist/src/agent/session-store.js.map +1 -1
- package/dist/src/agent/snapshot-server.d.ts +2 -22
- package/dist/src/agent/snapshot-server.js +50 -27
- package/dist/src/agent/snapshot-server.js.map +1 -1
- package/dist/src/agent/states/compacting.d.ts +14 -0
- package/dist/src/agent/states/compacting.js +258 -0
- package/dist/src/agent/states/compacting.js.map +1 -0
- package/dist/src/agent/states/confirming.d.ts +10 -0
- package/dist/src/agent/states/confirming.js +76 -0
- package/dist/src/agent/states/confirming.js.map +1 -0
- package/dist/src/agent/states/dispatching.d.ts +18 -0
- package/dist/src/agent/states/dispatching.js +241 -0
- package/dist/src/agent/states/dispatching.js.map +1 -0
- package/dist/src/agent/states/executing.d.ts +21 -0
- package/dist/src/agent/states/executing.js +308 -0
- package/dist/src/agent/states/executing.js.map +1 -0
- package/dist/src/agent/states/streaming.d.ts +10 -0
- package/dist/src/agent/states/streaming.js +155 -0
- package/dist/src/agent/states/streaming.js.map +1 -0
- package/dist/src/agent/states/thinking.d.ts +13 -0
- package/dist/src/agent/states/thinking.js +233 -0
- package/dist/src/agent/states/thinking.js.map +1 -0
- package/dist/src/agent/token-estimate.d.ts +17 -0
- package/dist/src/agent/token-estimate.js +13 -0
- package/dist/src/agent/token-estimate.js.map +1 -0
- package/dist/src/agent/tool-executor-local.js +9 -18
- package/dist/src/agent/tool-executor-local.js.map +1 -1
- package/dist/src/agent/tool-executor-local.test.js +3 -5
- package/dist/src/agent/tool-executor-local.test.js.map +1 -1
- package/dist/src/api/create-agent.d.ts +15 -0
- package/dist/src/api/create-agent.js +137 -0
- package/dist/src/api/create-agent.js.map +1 -0
- package/dist/src/api/types.d.ts +68 -0
- package/dist/src/api/types.js +7 -0
- package/dist/src/api/types.js.map +1 -0
- package/dist/src/config.d.ts +96 -0
- package/dist/src/config.js +221 -0
- package/dist/src/config.js.map +1 -0
- package/dist/src/{agent/custom-tools-e2e.test.d.ts → config.test.d.ts} +1 -1
- package/dist/src/config.test.js +235 -0
- package/dist/src/config.test.js.map +1 -0
- package/dist/src/context/compiler.d.ts +13 -0
- package/dist/src/context/compiler.js +358 -0
- package/dist/src/context/compiler.js.map +1 -0
- package/dist/src/context/compiler.test.d.ts +6 -0
- package/dist/src/context/compiler.test.js +532 -0
- package/dist/src/context/compiler.test.js.map +1 -0
- package/dist/src/context/types.d.ts +110 -0
- package/dist/src/context/types.js +7 -0
- package/dist/src/context/types.js.map +1 -0
- package/dist/src/errors.d.ts +145 -0
- package/dist/src/errors.js +218 -0
- package/dist/src/errors.js.map +1 -0
- package/dist/src/errors.test.d.ts +6 -0
- package/dist/src/errors.test.js +203 -0
- package/dist/src/errors.test.js.map +1 -0
- package/dist/src/index.d.ts +38 -6
- package/dist/src/index.js +40 -22
- package/dist/src/index.js.map +1 -1
- package/dist/src/logger.d.ts +15 -31
- package/dist/src/logger.js +19 -78
- package/dist/src/logger.js.map +1 -1
- package/dist/src/logger.test.d.ts +6 -0
- package/dist/src/logger.test.js +198 -0
- package/dist/src/logger.test.js.map +1 -0
- package/dist/src/providers/create-provider.d.ts +23 -0
- package/dist/src/providers/create-provider.js +185 -0
- package/dist/src/providers/create-provider.js.map +1 -0
- package/dist/src/providers/create-provider.test.d.ts +6 -0
- package/dist/src/providers/create-provider.test.js +95 -0
- package/dist/src/providers/create-provider.test.js.map +1 -0
- package/dist/src/providers/failover.d.ts +38 -0
- package/dist/src/providers/failover.js +147 -0
- package/dist/src/providers/failover.js.map +1 -0
- package/dist/src/providers/failover.test.d.ts +6 -0
- package/dist/src/providers/failover.test.js +169 -0
- package/dist/src/providers/failover.test.js.map +1 -0
- package/dist/src/providers/types.d.ts +110 -0
- package/dist/src/providers/types.js +7 -0
- package/dist/src/providers/types.js.map +1 -0
- package/dist/src/routes/ai-stream.d.ts +13 -10
- package/dist/src/routes/ai-stream.js +76 -38
- package/dist/src/routes/ai-stream.js.map +1 -1
- package/dist/src/routes/chat-new.test.d.ts +6 -0
- package/dist/src/routes/chat-new.test.js +107 -0
- package/dist/src/routes/chat-new.test.js.map +1 -0
- package/dist/src/routes/chat-stream-new.test.d.ts +6 -0
- package/dist/src/routes/chat-stream-new.test.js +135 -0
- package/dist/src/routes/chat-stream-new.test.js.map +1 -0
- package/dist/src/routes/chat-stream.d.ts +14 -4
- package/dist/src/routes/chat-stream.js +47 -27
- package/dist/src/routes/chat-stream.js.map +1 -1
- package/dist/src/routes/chat.d.ts +13 -4
- package/dist/src/routes/chat.js +60 -22
- package/dist/src/routes/chat.js.map +1 -1
- package/dist/src/routes/health.d.ts +3 -2
- package/dist/src/routes/health.js.map +1 -1
- package/dist/src/routes/route-helpers.d.ts +50 -0
- package/dist/src/routes/route-helpers.js +80 -0
- package/dist/src/routes/route-helpers.js.map +1 -0
- package/dist/src/routes/session-resolver.d.ts +72 -0
- package/dist/src/routes/session-resolver.js +123 -0
- package/dist/src/routes/session-resolver.js.map +1 -0
- package/dist/src/routes/session-resolver.test.d.ts +6 -0
- package/dist/src/routes/session-resolver.test.js +206 -0
- package/dist/src/routes/session-resolver.test.js.map +1 -0
- package/dist/src/routes/webhooks.d.ts +3 -1
- package/dist/src/routes/webhooks.js +12 -2
- package/dist/src/routes/webhooks.js.map +1 -1
- package/dist/src/security/permission-checker.d.ts +80 -0
- package/dist/src/security/permission-checker.js +75 -0
- package/dist/src/security/permission-checker.js.map +1 -0
- package/dist/src/security/permission-checker.test.d.ts +6 -0
- package/dist/src/security/permission-checker.test.js +208 -0
- package/dist/src/security/permission-checker.test.js.map +1 -0
- package/dist/src/server.d.ts +12 -11
- package/dist/src/server.js +44 -46
- package/dist/src/server.js.map +1 -1
- package/dist/src/server.test.d.ts +1 -1
- package/dist/src/server.test.js +6 -140
- package/dist/src/server.test.js.map +1 -1
- package/dist/src/session/manager.d.ts +98 -0
- package/dist/src/session/manager.js +364 -0
- package/dist/src/session/manager.js.map +1 -0
- package/dist/src/session/manager.test.d.ts +6 -0
- package/dist/src/session/manager.test.js +315 -0
- package/dist/src/session/manager.test.js.map +1 -0
- package/dist/src/session/session-builder.d.ts +71 -0
- package/dist/src/session/session-builder.js +364 -0
- package/dist/src/session/session-builder.js.map +1 -0
- package/dist/src/session/session-builder.test.d.ts +6 -0
- package/dist/src/session/session-builder.test.js +352 -0
- package/dist/src/session/session-builder.test.js.map +1 -0
- package/dist/src/session/store.d.ts +57 -0
- package/dist/src/session/store.js +167 -0
- package/dist/src/session/store.js.map +1 -0
- package/dist/src/session/store.test.d.ts +6 -0
- package/dist/src/session/store.test.js +145 -0
- package/dist/src/session/store.test.js.map +1 -0
- package/dist/src/session/stream-hooks.d.ts +39 -0
- package/dist/src/session/stream-hooks.js +7 -0
- package/dist/src/session/stream-hooks.js.map +1 -0
- package/dist/src/session/tool-context-factory.d.ts +60 -0
- package/dist/src/session/tool-context-factory.js +190 -0
- package/dist/src/session/tool-context-factory.js.map +1 -0
- package/dist/src/session/tool-context-factory.test.d.ts +6 -0
- package/dist/src/session/tool-context-factory.test.js +287 -0
- package/dist/src/session/tool-context-factory.test.js.map +1 -0
- package/dist/src/session/types.d.ts +188 -0
- package/dist/src/session/types.js +7 -0
- package/dist/src/session/types.js.map +1 -0
- package/dist/src/stores/drizzle-store-backend.d.ts +49 -0
- package/dist/src/stores/drizzle-store-backend.js +306 -0
- package/dist/src/stores/drizzle-store-backend.js.map +1 -0
- package/dist/src/stores/drizzle-store-backend.test.d.ts +6 -0
- package/dist/src/stores/drizzle-store-backend.test.js +215 -0
- package/dist/src/stores/drizzle-store-backend.test.js.map +1 -0
- package/dist/src/stores/index.d.ts +4 -0
- package/dist/src/stores/index.js +2 -0
- package/dist/src/stores/index.js.map +1 -1
- package/dist/src/stores/pglite-store-backend.d.ts +16 -19
- package/dist/src/stores/pglite-store-backend.js +85 -233
- package/dist/src/stores/pglite-store-backend.js.map +1 -1
- package/dist/src/stores/postgres-store-backend.d.ts +30 -0
- package/dist/src/stores/postgres-store-backend.js +100 -0
- package/dist/src/stores/postgres-store-backend.js.map +1 -0
- package/dist/src/stores/schema.d.ts +491 -0
- package/dist/src/stores/schema.js +57 -0
- package/dist/src/stores/schema.js.map +1 -0
- package/dist/src/tools/admin-file-tools.d.ts +13 -0
- package/dist/src/tools/admin-file-tools.js +200 -0
- package/dist/src/tools/admin-file-tools.js.map +1 -0
- package/dist/src/tools/admin-file-tools.test.d.ts +6 -0
- package/dist/src/tools/admin-file-tools.test.js +152 -0
- package/dist/src/tools/admin-file-tools.test.js.map +1 -0
- package/dist/src/tools/custom-tool-adapter.d.ts +41 -0
- package/dist/src/tools/custom-tool-adapter.js +190 -0
- package/dist/src/tools/custom-tool-adapter.js.map +1 -0
- package/dist/src/tools/custom-tool-adapter.test.d.ts +6 -0
- package/dist/src/tools/custom-tool-adapter.test.js +244 -0
- package/dist/src/tools/custom-tool-adapter.test.js.map +1 -0
- package/dist/src/tools/dispatch-tool.d.ts +52 -0
- package/dist/src/tools/dispatch-tool.js +71 -0
- package/dist/src/tools/dispatch-tool.js.map +1 -0
- package/dist/src/tools/dispatch-tool.test.d.ts +6 -0
- package/dist/src/tools/dispatch-tool.test.js +75 -0
- package/dist/src/tools/dispatch-tool.test.js.map +1 -0
- package/dist/src/tools/mcp-tool-adapter.d.ts +18 -0
- package/dist/src/tools/mcp-tool-adapter.js +135 -0
- package/dist/src/tools/mcp-tool-adapter.js.map +1 -0
- package/dist/src/tools/mcp-tool-adapter.test.d.ts +6 -0
- package/dist/src/tools/mcp-tool-adapter.test.js +227 -0
- package/dist/src/tools/mcp-tool-adapter.test.js.map +1 -0
- package/dist/src/tools/registry.d.ts +25 -0
- package/dist/src/tools/registry.js +72 -0
- package/dist/src/tools/registry.js.map +1 -0
- package/dist/src/tools/registry.test.d.ts +6 -0
- package/dist/src/tools/registry.test.js +121 -0
- package/dist/src/tools/registry.test.js.map +1 -0
- package/dist/src/tools/request-tool.d.ts +42 -0
- package/dist/src/tools/request-tool.js +190 -0
- package/dist/src/tools/request-tool.js.map +1 -0
- package/dist/src/tools/request-tool.test.d.ts +6 -0
- package/dist/src/tools/request-tool.test.js +254 -0
- package/dist/src/tools/request-tool.test.js.map +1 -0
- package/dist/src/tools/store-tools.d.ts +29 -0
- package/dist/src/tools/store-tools.js +224 -0
- package/dist/src/tools/store-tools.js.map +1 -0
- package/dist/src/tools/store-tools.test.d.ts +6 -0
- package/dist/src/tools/store-tools.test.js +216 -0
- package/dist/src/tools/store-tools.test.js.map +1 -0
- package/dist/src/tools/types.d.ts +111 -0
- package/dist/src/tools/types.js +7 -0
- package/dist/src/tools/types.js.map +1 -0
- package/dist/src/types.d.ts +20 -12
- package/dist/src/types.js +3 -2
- package/dist/src/types.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +13 -3
- package/dist/src/agent/agent-runner.d.ts +0 -33
- package/dist/src/agent/agent-runner.js +0 -1040
- package/dist/src/agent/agent-runner.js.map +0 -1
- package/dist/src/agent/custom-tools-e2e.test.js +0 -566
- package/dist/src/agent/custom-tools-e2e.test.js.map +0 -1
- package/dist/src/agent/request-helper.d.ts +0 -16
- package/dist/src/agent/request-helper.js +0 -96
- package/dist/src/agent/request-helper.js.map +0 -1
- package/dist/src/agent/stores-e2e.test.js +0 -433
- package/dist/src/agent/stores-e2e.test.js.map +0 -1
- package/dist/src/agent/tool-context-builder.d.ts +0 -11
- package/dist/src/agent/tool-context-builder.js +0 -102
- package/dist/src/agent/tool-context-builder.js.map +0 -1
- package/dist/src/agent/tool-context-builder.test.js +0 -152
- package/dist/src/agent/tool-context-builder.test.js.map +0 -1
- package/dist/src/agent/write-repo-file.test.js +0 -270
- package/dist/src/agent/write-repo-file.test.js.map +0 -1
- package/dist/src/cron/heartbeat-runner.d.ts +0 -21
- package/dist/src/cron/heartbeat-runner.js +0 -79
- package/dist/src/cron/heartbeat-runner.js.map +0 -1
- package/dist/src/cron/heartbeat-runner.test.d.ts +0 -6
- package/dist/src/cron/heartbeat-runner.test.js +0 -120
- package/dist/src/cron/heartbeat-runner.test.js.map +0 -1
- package/dist/src/cron/heartbeat-scheduler.d.ts +0 -26
- package/dist/src/cron/heartbeat-scheduler.js +0 -55
- package/dist/src/cron/heartbeat-scheduler.js.map +0 -1
- package/dist/src/cron/heartbeat-scheduler.test.d.ts +0 -6
- package/dist/src/cron/heartbeat-scheduler.test.js +0 -61
- package/dist/src/cron/heartbeat-scheduler.test.js.map +0 -1
- package/dist/src/routes/ai-stream.test.d.ts +0 -6
- package/dist/src/routes/ai-stream.test.js +0 -586
- package/dist/src/routes/ai-stream.test.js.map +0 -1
- package/dist/src/routes/ask-user-response.d.ts +0 -30
- package/dist/src/routes/ask-user-response.js +0 -61
- package/dist/src/routes/ask-user-response.js.map +0 -1
- package/dist/src/routes/ask-user-response.test.d.ts +0 -6
- package/dist/src/routes/ask-user-response.test.js +0 -88
- package/dist/src/routes/ask-user-response.test.js.map +0 -1
- package/dist/src/routes/chat-stream.test.d.ts +0 -6
- package/dist/src/routes/chat-stream.test.js +0 -155
- package/dist/src/routes/chat-stream.test.js.map +0 -1
- package/dist/src/routes/chat.test.d.ts +0 -6
- package/dist/src/routes/chat.test.js +0 -99
- package/dist/src/routes/chat.test.js.map +0 -1
- package/dist/src/routes/widget-actions.d.ts +0 -49
- package/dist/src/routes/widget-actions.js +0 -78
- package/dist/src/routes/widget-actions.js.map +0 -1
- package/dist/src/session/custom-tool-adapter.d.ts +0 -74
- package/dist/src/session/custom-tool-adapter.js +0 -180
- package/dist/src/session/custom-tool-adapter.js.map +0 -1
- package/dist/src/session/history-converter.d.ts +0 -21
- package/dist/src/session/history-converter.js +0 -59
- package/dist/src/session/history-converter.js.map +0 -1
- package/dist/src/session/history-converter.test.d.ts +0 -6
- package/dist/src/session/history-converter.test.js +0 -130
- package/dist/src/session/history-converter.test.js.map +0 -1
- package/dist/src/session/session-manager.d.ts +0 -219
- package/dist/src/session/session-manager.js +0 -915
- package/dist/src/session/session-manager.js.map +0 -1
- package/dist/src/session/session-manager.test.d.ts +0 -6
- package/dist/src/session/session-manager.test.js +0 -451
- package/dist/src/session/session-manager.test.js.map +0 -1
- package/dist/src/session/session-runner.d.ts +0 -45
- package/dist/src/session/session-runner.js +0 -719
- package/dist/src/session/session-runner.js.map +0 -1
- package/dist/src/session/session-runner.test.d.ts +0 -6
- package/dist/src/session/session-runner.test.js +0 -830
- package/dist/src/session/session-runner.test.js.map +0 -1
- /package/dist/src/{agent/write-repo-file.test.d.ts → __fixtures__/smoke.test.d.ts} +0 -0
|
@@ -0,0 +1,203 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2026 Amodal Labs, Inc.
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
import { describe, it, expect } from 'vitest';
|
|
7
|
+
import { AmodalError, ProviderError, RateLimitError, ProviderTimeoutError, ToolExecutionError, StoreError, ConnectionError, SessionError, CompactionError, ConfigError, } from './errors.js';
|
|
8
|
+
describe('AmodalError', () => {
|
|
9
|
+
it('carries code, message, and context', () => {
|
|
10
|
+
const err = new AmodalError('TEST_CODE', 'something broke', { foo: 'bar' });
|
|
11
|
+
expect(err.code).toBe('TEST_CODE');
|
|
12
|
+
expect(err.message).toBe('something broke');
|
|
13
|
+
expect(err.context).toEqual({ foo: 'bar' });
|
|
14
|
+
expect(err.name).toBe('AmodalError');
|
|
15
|
+
expect(err).toBeInstanceOf(Error);
|
|
16
|
+
});
|
|
17
|
+
it('defaults context to empty object', () => {
|
|
18
|
+
const err = new AmodalError('X', 'msg');
|
|
19
|
+
expect(err.context).toEqual({});
|
|
20
|
+
});
|
|
21
|
+
it('preserves cause chain', () => {
|
|
22
|
+
const cause = new Error('root cause');
|
|
23
|
+
const err = new AmodalError('X', 'wrapped', {}, cause);
|
|
24
|
+
expect(err.cause).toBe(cause);
|
|
25
|
+
});
|
|
26
|
+
it('serializes to JSON with cause', () => {
|
|
27
|
+
const cause = new Error('root');
|
|
28
|
+
const err = new AmodalError('TEST', 'msg', { k: 1 }, cause);
|
|
29
|
+
const json = err.toJSON();
|
|
30
|
+
expect(json).toEqual({
|
|
31
|
+
name: 'AmodalError',
|
|
32
|
+
code: 'TEST',
|
|
33
|
+
message: 'msg',
|
|
34
|
+
context: { k: 1 },
|
|
35
|
+
cause: { name: 'Error', message: 'root' },
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
it('serializes to JSON without cause', () => {
|
|
39
|
+
const err = new AmodalError('TEST', 'msg');
|
|
40
|
+
const json = err.toJSON();
|
|
41
|
+
expect(json).not.toHaveProperty('cause');
|
|
42
|
+
});
|
|
43
|
+
it('serializes non-Error cause as string', () => {
|
|
44
|
+
const err = new AmodalError('TEST', 'msg', {}, 'string cause');
|
|
45
|
+
expect(err.toJSON()['cause']).toBe('string cause');
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
describe('ProviderError', () => {
|
|
49
|
+
it('has correct code and provider fields', () => {
|
|
50
|
+
const err = new ProviderError('API failed', { provider: 'anthropic', statusCode: 500 });
|
|
51
|
+
expect(err.code).toBe('PROVIDER_ERROR');
|
|
52
|
+
expect(err.provider).toBe('anthropic');
|
|
53
|
+
expect(err.statusCode).toBe(500);
|
|
54
|
+
expect(err.retryable).toBe(false);
|
|
55
|
+
expect(err.name).toBe('ProviderError');
|
|
56
|
+
expect(err).toBeInstanceOf(AmodalError);
|
|
57
|
+
expect(err.context['provider']).toBe('anthropic');
|
|
58
|
+
expect(err.context['statusCode']).toBe(500);
|
|
59
|
+
});
|
|
60
|
+
it('defaults retryable to false', () => {
|
|
61
|
+
const err = new ProviderError('fail', { provider: 'openai' });
|
|
62
|
+
expect(err.retryable).toBe(false);
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
describe('RateLimitError', () => {
|
|
66
|
+
it('is a retryable ProviderError with 429 status', () => {
|
|
67
|
+
const err = new RateLimitError('slow down', { provider: 'anthropic', retryAfterMs: 5000 });
|
|
68
|
+
expect(err.statusCode).toBe(429);
|
|
69
|
+
expect(err.retryable).toBe(true);
|
|
70
|
+
expect(err.retryAfterMs).toBe(5000);
|
|
71
|
+
expect(err.name).toBe('RateLimitError');
|
|
72
|
+
expect(err).toBeInstanceOf(ProviderError);
|
|
73
|
+
expect(err).toBeInstanceOf(AmodalError);
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
describe('ProviderTimeoutError', () => {
|
|
77
|
+
it('is a retryable ProviderError', () => {
|
|
78
|
+
const err = new ProviderTimeoutError('timed out', { provider: 'google' });
|
|
79
|
+
expect(err.retryable).toBe(true);
|
|
80
|
+
expect(err.name).toBe('ProviderTimeoutError');
|
|
81
|
+
expect(err).toBeInstanceOf(ProviderError);
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
describe('ToolExecutionError', () => {
|
|
85
|
+
it('carries tool name and call ID in context', () => {
|
|
86
|
+
const err = new ToolExecutionError('tool crashed', {
|
|
87
|
+
toolName: 'fetch_deals',
|
|
88
|
+
callId: 'call_123',
|
|
89
|
+
context: { args: { limit: 10 } },
|
|
90
|
+
});
|
|
91
|
+
expect(err.code).toBe('TOOL_EXECUTION_ERROR');
|
|
92
|
+
expect(err.toolName).toBe('fetch_deals');
|
|
93
|
+
expect(err.callId).toBe('call_123');
|
|
94
|
+
expect(err.context['toolName']).toBe('fetch_deals');
|
|
95
|
+
expect(err.context['args']).toEqual({ limit: 10 });
|
|
96
|
+
expect(err).toBeInstanceOf(AmodalError);
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
describe('StoreError', () => {
|
|
100
|
+
it('carries store name and operation', () => {
|
|
101
|
+
const cause = new Error('PGLite crash');
|
|
102
|
+
const err = new StoreError('write failed', {
|
|
103
|
+
store: 'alerts',
|
|
104
|
+
operation: 'put',
|
|
105
|
+
cause,
|
|
106
|
+
context: { key: 'alert-1' },
|
|
107
|
+
});
|
|
108
|
+
expect(err.code).toBe('STORE_ERROR');
|
|
109
|
+
expect(err.store).toBe('alerts');
|
|
110
|
+
expect(err.operation).toBe('put');
|
|
111
|
+
expect(err.context['key']).toBe('alert-1');
|
|
112
|
+
expect(err.cause).toBe(cause);
|
|
113
|
+
expect(err).toBeInstanceOf(AmodalError);
|
|
114
|
+
});
|
|
115
|
+
});
|
|
116
|
+
describe('ConnectionError', () => {
|
|
117
|
+
it('carries connection name and action', () => {
|
|
118
|
+
const err = new ConnectionError('auth failed', {
|
|
119
|
+
connection: 'typefully',
|
|
120
|
+
action: 'POST /social-sets',
|
|
121
|
+
});
|
|
122
|
+
expect(err.code).toBe('CONNECTION_ERROR');
|
|
123
|
+
expect(err.connection).toBe('typefully');
|
|
124
|
+
expect(err.action).toBe('POST /social-sets');
|
|
125
|
+
expect(err).toBeInstanceOf(AmodalError);
|
|
126
|
+
});
|
|
127
|
+
});
|
|
128
|
+
describe('SessionError', () => {
|
|
129
|
+
it('carries session ID', () => {
|
|
130
|
+
const err = new SessionError('session expired', {
|
|
131
|
+
sessionId: 'sess_abc',
|
|
132
|
+
context: { tenantId: 'tenant_1' },
|
|
133
|
+
});
|
|
134
|
+
expect(err.code).toBe('SESSION_ERROR');
|
|
135
|
+
expect(err.sessionId).toBe('sess_abc');
|
|
136
|
+
expect(err.context['tenantId']).toBe('tenant_1');
|
|
137
|
+
expect(err).toBeInstanceOf(AmodalError);
|
|
138
|
+
});
|
|
139
|
+
});
|
|
140
|
+
describe('CompactionError', () => {
|
|
141
|
+
it('carries stage', () => {
|
|
142
|
+
const err = new CompactionError('summarization failed', { stage: 'pre_summarize' });
|
|
143
|
+
expect(err.code).toBe('COMPACTION_ERROR');
|
|
144
|
+
expect(err.stage).toBe('pre_summarize');
|
|
145
|
+
expect(err).toBeInstanceOf(AmodalError);
|
|
146
|
+
});
|
|
147
|
+
});
|
|
148
|
+
describe('ConfigError', () => {
|
|
149
|
+
it('carries config key', () => {
|
|
150
|
+
const err = new ConfigError('missing API key', {
|
|
151
|
+
key: 'providers.primary.apiKey',
|
|
152
|
+
context: { checked: ['env:ANTHROPIC_API_KEY', 'amodal.json'] },
|
|
153
|
+
});
|
|
154
|
+
expect(err.code).toBe('CONFIG_ERROR');
|
|
155
|
+
expect(err.key).toBe('providers.primary.apiKey');
|
|
156
|
+
expect(err.context['checked']).toEqual(['env:ANTHROPIC_API_KEY', 'amodal.json']);
|
|
157
|
+
expect(err).toBeInstanceOf(AmodalError);
|
|
158
|
+
});
|
|
159
|
+
it('formats a multi-line error with key and suggestion', () => {
|
|
160
|
+
const err = new ConfigError('API key not found', {
|
|
161
|
+
key: 'models.main.provider',
|
|
162
|
+
suggestion: 'Set ANTHROPIC_API_KEY in your .env file.',
|
|
163
|
+
});
|
|
164
|
+
expect(err.format()).toBe('Config error: API key not found\n' +
|
|
165
|
+
' Key: models.main.provider\n' +
|
|
166
|
+
' Fix: Set ANTHROPIC_API_KEY in your .env file.');
|
|
167
|
+
});
|
|
168
|
+
it('formats without suggestion when omitted', () => {
|
|
169
|
+
const err = new ConfigError('bad value', { key: 'stores.backend' });
|
|
170
|
+
expect(err.suggestion).toBe('');
|
|
171
|
+
expect(err.format()).toBe('Config error: bad value\n Key: stores.backend');
|
|
172
|
+
});
|
|
173
|
+
});
|
|
174
|
+
describe('unique error codes', () => {
|
|
175
|
+
it('each subclass has a distinct code', () => {
|
|
176
|
+
const codes = [
|
|
177
|
+
new ProviderError('', { provider: '' }),
|
|
178
|
+
new ToolExecutionError('', { toolName: '', callId: '' }),
|
|
179
|
+
new StoreError('', { store: '', operation: '' }),
|
|
180
|
+
new ConnectionError('', { connection: '', action: '' }),
|
|
181
|
+
new SessionError('', { sessionId: '' }),
|
|
182
|
+
new CompactionError('', { stage: '' }),
|
|
183
|
+
new ConfigError('', { key: '' }),
|
|
184
|
+
].map(e => e.code);
|
|
185
|
+
expect(new Set(codes).size).toBe(codes.length);
|
|
186
|
+
});
|
|
187
|
+
});
|
|
188
|
+
describe('Result type', () => {
|
|
189
|
+
it('narrows on ok check', () => {
|
|
190
|
+
const success = { ok: true, value: 42 };
|
|
191
|
+
const failure = {
|
|
192
|
+
ok: false,
|
|
193
|
+
error: new StoreError('not found', { store: 'alerts', operation: 'get' }),
|
|
194
|
+
};
|
|
195
|
+
if (success.ok) {
|
|
196
|
+
expect(success.value).toBe(42);
|
|
197
|
+
}
|
|
198
|
+
if (!failure.ok) {
|
|
199
|
+
expect(failure.error.store).toBe('alerts');
|
|
200
|
+
}
|
|
201
|
+
});
|
|
202
|
+
});
|
|
203
|
+
//# sourceMappingURL=errors.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.test.js","sourceRoot":"","sources":["../../src/errors.test.ts"],"names":[],"mappings":"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"}
|
package/dist/src/index.d.ts
CHANGED
|
@@ -4,26 +4,58 @@
|
|
|
4
4
|
* SPDX-License-Identifier: MIT
|
|
5
5
|
*/
|
|
6
6
|
export declare const SERVER_VERSION = "0.1.0";
|
|
7
|
+
export { createAgent } from './api/create-agent.js';
|
|
8
|
+
export type { Agent, AgentConfig, AgentSession } from './api/types.js';
|
|
7
9
|
export { createServer } from './server.js';
|
|
8
10
|
export type { ServerInstance, CreateServerOptions } from './server.js';
|
|
9
11
|
export type { ServerConfig } from './types.js';
|
|
10
12
|
export { createAIStreamRouter, type AIStreamRouterOptions } from './routes/ai-stream.js';
|
|
11
13
|
export { createLocalServer } from './agent/local-server.js';
|
|
12
|
-
export type { LocalServerConfig, AgentChatRequest
|
|
13
|
-
export { SessionManager } from './session/session-manager.js';
|
|
14
|
-
export type { ManagedSession, SessionManagerOptions, SessionStore, StoredSessionRecord } from './session/session-manager.js';
|
|
14
|
+
export type { LocalServerConfig, AgentChatRequest } from './agent/agent-types.js';
|
|
15
15
|
export { ProactiveRunner } from './agent/proactive/proactive-runner.js';
|
|
16
16
|
export type { AutomationInfo, ProactiveRunnerConfig } from './agent/proactive/proactive-runner.js';
|
|
17
17
|
export { createSnapshotServer } from './agent/snapshot-server.js';
|
|
18
18
|
export type { SnapshotServerConfig } from './agent/snapshot-server.js';
|
|
19
19
|
export { createChatStreamRouter } from './routes/chat-stream.js';
|
|
20
20
|
export type { ChatStreamRouterOptions } from './routes/chat-stream.js';
|
|
21
|
+
export { createChatRouter } from './routes/chat.js';
|
|
22
|
+
export type { ChatRouterOptions } from './routes/chat.js';
|
|
21
23
|
export { createTaskRouter } from './agent/routes/task.js';
|
|
22
24
|
export type { TaskRouterOptions } from './agent/routes/task.js';
|
|
23
25
|
export { getAuthContext } from './middleware/auth.js';
|
|
24
26
|
export type { AuthContext } from './middleware/auth.js';
|
|
25
|
-
export type { StreamHooks } from './session/
|
|
26
|
-
export { runMessage } from './session/session-runner.js';
|
|
27
|
+
export type { StreamHooks, TokenCounts } from './session/stream-hooks.js';
|
|
27
28
|
export { routeOutput } from './output/output-router.js';
|
|
28
29
|
export { errorHandler } from './middleware/error-handler.js';
|
|
29
|
-
export {
|
|
30
|
+
export { AmodalError, ProviderError, RateLimitError, ProviderTimeoutError, ToolExecutionError, StoreError, ConnectionError, SessionError, CompactionError, ConfigError, } from './errors.js';
|
|
31
|
+
export type { Result } from './errors.js';
|
|
32
|
+
export { log, setLogLevel, getLogLevel, setLogFormat, getLogFormat, setSanitize, LogLevel, initLogLevel, interceptConsole, verbosityToLogLevel, createLogger } from './logger.js';
|
|
33
|
+
export type { Logger, LoggerConfig, LogFormat } from './logger.js';
|
|
34
|
+
export { loadConfig } from './config.js';
|
|
35
|
+
export type { AgentConfig as LegacyAgentConfig, ConfigOverrides, LoadConfigOptions, McpServerConfig } from './config.js';
|
|
36
|
+
export { createProvider } from './providers/create-provider.js';
|
|
37
|
+
export { createFailoverProvider } from './providers/failover.js';
|
|
38
|
+
export type { FailoverChainConfig } from './providers/failover.js';
|
|
39
|
+
export type { LLMProvider, ProviderConfig, StreamTextOptions, StreamTextResult, GenerateTextOptions, GenerateTextResult, TokenUsage, StreamEvent, } from './providers/types.js';
|
|
40
|
+
export { runAgent, transition } from './agent/loop.js';
|
|
41
|
+
export type { AgentState, AgentContext, AgentLoopConfig, TransitionResult, RunAgentOptions, ToolCall, ToolResult, DoneReason, ThinkingState, StreamingState, ExecutingState, ConfirmingState, CompactingState, DispatchingState, DoneState, DispatchConfig, } from './agent/loop-types.js';
|
|
42
|
+
export { DEFAULT_LOOP_CONFIG } from './agent/loop-types.js';
|
|
43
|
+
export { createToolRegistry } from './tools/registry.js';
|
|
44
|
+
export type { ToolDefinition, ToolContext, ToolCategory, ToolMetadata, ToolRegistry, } from './tools/types.js';
|
|
45
|
+
export { createMcpToolDefinition, registerMcpTools, } from './tools/mcp-tool-adapter.js';
|
|
46
|
+
export { createStoreWriteTool, createStoreBatchTool, createStoreQueryTool, registerStoreTools, storeToToolName, QUERY_STORE_TOOL_NAME, } from './tools/store-tools.js';
|
|
47
|
+
export { createRequestTool, REQUEST_TOOL_NAME } from './tools/request-tool.js';
|
|
48
|
+
export type { ConnectionsMap, CreateRequestToolOptions } from './tools/request-tool.js';
|
|
49
|
+
export { createReadRepoFileTool, createWriteRepoFileTool, createDeleteRepoFileTool, createInternalApiTool, registerAdminFileTools, } from './tools/admin-file-tools.js';
|
|
50
|
+
export { StandaloneSessionManager } from './session/manager.js';
|
|
51
|
+
export type { Session, CreateSessionOptions, SessionManagerOptions as StandaloneSessionManagerOptions, TurnUsage, AutomationResult, PersistedSession, } from './session/types.js';
|
|
52
|
+
export { buildSessionComponents, PRESENT_TOOL_NAME, STOP_EXECUTION_TOOL_NAME } from './session/session-builder.js';
|
|
53
|
+
export type { SessionComponents, BuildSessionComponentsOptions, SessionType } from './session/session-builder.js';
|
|
54
|
+
export { createToolContextFactory } from './session/tool-context-factory.js';
|
|
55
|
+
export type { ToolContextFactoryOptions } from './session/tool-context-factory.js';
|
|
56
|
+
export { resolveSession, resolveBundle } from './routes/session-resolver.js';
|
|
57
|
+
export type { BundleResolver, SharedResources, ResolvedSession, ResolveSessionOptions } from './routes/session-resolver.js';
|
|
58
|
+
export { compileContext } from './context/compiler.js';
|
|
59
|
+
export type { CompilerInput, CompilerOutput, CompilerContribution, CompilerConnection, CompilerSkill, CompilerKnowledge, CompilerStore, } from './context/types.js';
|
|
60
|
+
export { AccessJsonPermissionChecker } from './security/permission-checker.js';
|
|
61
|
+
export type { PermissionChecker, PermissionResult, PermissionCheckRequest, } from './security/permission-checker.js';
|
package/dist/src/index.js
CHANGED
|
@@ -6,27 +6,64 @@
|
|
|
6
6
|
import { createServer } from './server.js';
|
|
7
7
|
import { log } from './logger.js';
|
|
8
8
|
export const SERVER_VERSION = '0.1.0';
|
|
9
|
+
// ---------------------------------------------------------------------------
|
|
10
|
+
// Public API
|
|
11
|
+
// ---------------------------------------------------------------------------
|
|
12
|
+
export { createAgent } from './api/create-agent.js';
|
|
13
|
+
// ---------------------------------------------------------------------------
|
|
9
14
|
// Re-export for consumers
|
|
15
|
+
// ---------------------------------------------------------------------------
|
|
10
16
|
export { createServer } from './server.js';
|
|
11
17
|
export { createAIStreamRouter } from './routes/ai-stream.js';
|
|
12
18
|
// Local mode
|
|
13
19
|
export { createLocalServer } from './agent/local-server.js';
|
|
14
|
-
export { SessionManager } from './session/session-manager.js';
|
|
15
20
|
export { ProactiveRunner } from './agent/proactive/proactive-runner.js';
|
|
16
21
|
// Snapshot mode
|
|
17
22
|
export { createSnapshotServer } from './agent/snapshot-server.js';
|
|
18
23
|
// Route creators (used by hosted-runtime to build its own server)
|
|
19
24
|
export { createChatStreamRouter } from './routes/chat-stream.js';
|
|
25
|
+
export { createChatRouter } from './routes/chat.js';
|
|
20
26
|
export { createTaskRouter } from './agent/routes/task.js';
|
|
21
27
|
// Auth types (middleware implementation provided by hosting layer)
|
|
22
28
|
export { getAuthContext } from './middleware/auth.js';
|
|
23
|
-
export { runMessage } from './session/session-runner.js';
|
|
24
29
|
// Output routing (for automation result delivery)
|
|
25
30
|
export { routeOutput } from './output/output-router.js';
|
|
26
31
|
// Error handler
|
|
27
32
|
export { errorHandler } from './middleware/error-handler.js';
|
|
33
|
+
// Typed error classes
|
|
34
|
+
export { AmodalError, ProviderError, RateLimitError, ProviderTimeoutError, ToolExecutionError, StoreError, ConnectionError, SessionError, CompactionError, ConfigError, } from './errors.js';
|
|
28
35
|
// Logger
|
|
29
|
-
export { log, setLogLevel, getLogLevel, LogLevel, initLogLevel, interceptConsole, verbosityToLogLevel } from './logger.js';
|
|
36
|
+
export { log, setLogLevel, getLogLevel, setLogFormat, getLogFormat, setSanitize, LogLevel, initLogLevel, interceptConsole, verbosityToLogLevel, createLogger } from './logger.js';
|
|
37
|
+
// Config
|
|
38
|
+
export { loadConfig } from './config.js';
|
|
39
|
+
// LLM Provider (Vercel AI SDK abstraction)
|
|
40
|
+
export { createProvider } from './providers/create-provider.js';
|
|
41
|
+
export { createFailoverProvider } from './providers/failover.js';
|
|
42
|
+
// Agent loop (state machine)
|
|
43
|
+
export { runAgent, transition } from './agent/loop.js';
|
|
44
|
+
export { DEFAULT_LOOP_CONFIG } from './agent/loop-types.js';
|
|
45
|
+
// Tool registry
|
|
46
|
+
export { createToolRegistry } from './tools/registry.js';
|
|
47
|
+
// MCP tool adapter
|
|
48
|
+
export { createMcpToolDefinition, registerMcpTools, } from './tools/mcp-tool-adapter.js';
|
|
49
|
+
// Store tools (new Zod-based implementations)
|
|
50
|
+
export { createStoreWriteTool, createStoreBatchTool, createStoreQueryTool, registerStoreTools, storeToToolName, QUERY_STORE_TOOL_NAME, } from './tools/store-tools.js';
|
|
51
|
+
// Connection request tool
|
|
52
|
+
export { createRequestTool, REQUEST_TOOL_NAME } from './tools/request-tool.js';
|
|
53
|
+
// Admin file tools
|
|
54
|
+
export { createReadRepoFileTool, createWriteRepoFileTool, createDeleteRepoFileTool, createInternalApiTool, registerAdminFileTools, } from './tools/admin-file-tools.js';
|
|
55
|
+
// Standalone session manager
|
|
56
|
+
export { StandaloneSessionManager } from './session/manager.js';
|
|
57
|
+
// Session builder
|
|
58
|
+
export { buildSessionComponents, PRESENT_TOOL_NAME, STOP_EXECUTION_TOOL_NAME } from './session/session-builder.js';
|
|
59
|
+
// Tool context factory
|
|
60
|
+
export { createToolContextFactory } from './session/tool-context-factory.js';
|
|
61
|
+
// Session resolver
|
|
62
|
+
export { resolveSession, resolveBundle } from './routes/session-resolver.js';
|
|
63
|
+
// Context compiler
|
|
64
|
+
export { compileContext } from './context/compiler.js';
|
|
65
|
+
// Permission checker
|
|
66
|
+
export { AccessJsonPermissionChecker } from './security/permission-checker.js';
|
|
30
67
|
// ---------------------------------------------------------------------------
|
|
31
68
|
// Environment variable parsing
|
|
32
69
|
// ---------------------------------------------------------------------------
|
|
@@ -48,30 +85,11 @@ async function main() {
|
|
|
48
85
|
const port = getEnvInt('PORT', 3000);
|
|
49
86
|
const host = getEnvOrDefault('HOST', '0.0.0.0');
|
|
50
87
|
const sessionTtlMs = getEnvInt('SESSION_TTL_MS', 30 * 60 * 1000);
|
|
51
|
-
// LLM config comes from env. Default matches the platform API default.
|
|
52
|
-
const model = getEnvOrDefault('MODEL', 'claude-sonnet-4-20250514');
|
|
53
|
-
// WORKSPACE_DIR scopes file tools and shell_exec. In Docker, set to
|
|
54
|
-
// /workspace so the agent cannot read server source code. When unset,
|
|
55
|
-
// falls back to process.cwd() for local dev.
|
|
56
|
-
const workspaceDir = process.env['WORKSPACE_DIR'] || process.cwd();
|
|
57
|
-
// Base config params — minimal, org-agnostic defaults.
|
|
58
|
-
// Org-specific config (tools, skills, knowledge, base_prompt, agent_context)
|
|
59
|
-
// loaded per session using the API key from each request.
|
|
60
|
-
const baseParams = {
|
|
61
|
-
sessionId: 'server-init',
|
|
62
|
-
model,
|
|
63
|
-
cwd: workspaceDir,
|
|
64
|
-
targetDir: workspaceDir,
|
|
65
|
-
debugMode: process.env['DEBUG'] === 'true',
|
|
66
|
-
interactive: false,
|
|
67
|
-
noBrowser: true,
|
|
68
|
-
};
|
|
69
88
|
// Create and start server
|
|
70
89
|
let serverInstance;
|
|
71
90
|
try {
|
|
72
91
|
const corsOrigin = process.env['CORS_ORIGIN'] || undefined;
|
|
73
92
|
serverInstance = createServer({
|
|
74
|
-
baseParams,
|
|
75
93
|
config: {
|
|
76
94
|
port,
|
|
77
95
|
host,
|
package/dist/src/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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"}
|
package/dist/src/logger.d.ts
CHANGED
|
@@ -4,39 +4,23 @@
|
|
|
4
4
|
* SPDX-License-Identifier: MIT
|
|
5
5
|
*/
|
|
6
6
|
/**
|
|
7
|
-
*
|
|
7
|
+
* Runtime logger — wraps the core logger and adds runtime-specific
|
|
8
|
+
* utilities (CLI flag parsing, console interception).
|
|
8
9
|
*
|
|
9
|
-
*
|
|
10
|
-
*
|
|
11
|
-
* Default: "info".
|
|
12
|
-
*
|
|
13
|
-
* Usage:
|
|
14
|
-
* import { log } from './logger.js';
|
|
15
|
-
* log.info('Server started', 'server'); // [INFO] [server] Server started
|
|
16
|
-
* log.debug('Details here', 'session'); // only printed when LOG_LEVEL=debug
|
|
17
|
-
* log.error('Something broke'); // [ERROR] Something broke
|
|
10
|
+
* The Logger interface and core implementation live in @amodalai/core.
|
|
11
|
+
* This module re-exports them and adds runtime-only functions.
|
|
18
12
|
*/
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
export declare
|
|
30
|
-
/** Get the current log level. */
|
|
31
|
-
export declare function getLogLevel(): LogLevel;
|
|
32
|
-
export declare const log: {
|
|
33
|
-
trace: (message: string, tag?: string) => void;
|
|
34
|
-
debug: (message: string, tag?: string) => void;
|
|
35
|
-
info: (message: string, tag?: string) => void;
|
|
36
|
-
warn: (message: string, tag?: string) => void;
|
|
37
|
-
error: (message: string, tag?: string) => void;
|
|
38
|
-
fatal: (message: string, tag?: string) => void;
|
|
39
|
-
};
|
|
13
|
+
import { createLogger as coreCreateLogger, setLogLevel as coreSetLogLevel, getLogLevel as coreGetLogLevel, setLogFormat as coreSetLogFormat, getLogFormat as coreGetLogFormat, setSanitize as coreSetSanitize, LogLevel } from '@amodalai/core';
|
|
14
|
+
import type { Logger, LoggerConfig, LogFormat } from '@amodalai/core';
|
|
15
|
+
export { LogLevel };
|
|
16
|
+
export type { Logger, LoggerConfig, LogFormat };
|
|
17
|
+
export declare const log: Logger;
|
|
18
|
+
export declare const createLogger: typeof coreCreateLogger;
|
|
19
|
+
export declare const setLogLevel: typeof coreSetLogLevel;
|
|
20
|
+
export declare const getLogLevel: typeof coreGetLogLevel;
|
|
21
|
+
export declare const setLogFormat: typeof coreSetLogFormat;
|
|
22
|
+
export declare const getLogFormat: typeof coreGetLogFormat;
|
|
23
|
+
export declare const setSanitize: typeof coreSetSanitize;
|
|
40
24
|
/**
|
|
41
25
|
* Convert -v count and --quiet flag to a LogLevel.
|
|
42
26
|
* --quiet → ERROR, default → INFO, -v → DEBUG, -vv → TRACE
|
package/dist/src/logger.js
CHANGED
|
@@ -4,81 +4,22 @@
|
|
|
4
4
|
* SPDX-License-Identifier: MIT
|
|
5
5
|
*/
|
|
6
6
|
/**
|
|
7
|
-
*
|
|
7
|
+
* Runtime logger — wraps the core logger and adds runtime-specific
|
|
8
|
+
* utilities (CLI flag parsing, console interception).
|
|
8
9
|
*
|
|
9
|
-
*
|
|
10
|
-
*
|
|
11
|
-
* Default: "info".
|
|
12
|
-
*
|
|
13
|
-
* Usage:
|
|
14
|
-
* import { log } from './logger.js';
|
|
15
|
-
* log.info('Server started', 'server'); // [INFO] [server] Server started
|
|
16
|
-
* log.debug('Details here', 'session'); // only printed when LOG_LEVEL=debug
|
|
17
|
-
* log.error('Something broke'); // [ERROR] Something broke
|
|
10
|
+
* The Logger interface and core implementation live in @amodalai/core.
|
|
11
|
+
* This module re-exports them and adds runtime-only functions.
|
|
18
12
|
*/
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
const LEVEL_LABELS = {
|
|
30
|
-
[LogLevel.TRACE]: 'TRACE',
|
|
31
|
-
[LogLevel.DEBUG]: 'DEBUG',
|
|
32
|
-
[LogLevel.INFO]: 'INFO',
|
|
33
|
-
[LogLevel.WARN]: 'WARN',
|
|
34
|
-
[LogLevel.ERROR]: 'ERROR',
|
|
35
|
-
[LogLevel.FATAL]: 'FATAL',
|
|
36
|
-
[LogLevel.NONE]: '',
|
|
37
|
-
};
|
|
38
|
-
function parseLogLevel(value) {
|
|
39
|
-
switch (value?.toLowerCase()) {
|
|
40
|
-
case 'trace':
|
|
41
|
-
return LogLevel.TRACE;
|
|
42
|
-
case 'debug':
|
|
43
|
-
return LogLevel.DEBUG;
|
|
44
|
-
case 'info':
|
|
45
|
-
return LogLevel.INFO;
|
|
46
|
-
case 'warn':
|
|
47
|
-
return LogLevel.WARN;
|
|
48
|
-
case 'error':
|
|
49
|
-
return LogLevel.ERROR;
|
|
50
|
-
case 'fatal':
|
|
51
|
-
return LogLevel.FATAL;
|
|
52
|
-
case 'none':
|
|
53
|
-
return LogLevel.NONE;
|
|
54
|
-
default:
|
|
55
|
-
return LogLevel.INFO;
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
let currentLevel = parseLogLevel(process.env['LOG_LEVEL']);
|
|
59
|
-
/** Update the runtime log level programmatically. */
|
|
60
|
-
export function setLogLevel(level) {
|
|
61
|
-
currentLevel = level;
|
|
62
|
-
}
|
|
63
|
-
/** Get the current log level. */
|
|
64
|
-
export function getLogLevel() {
|
|
65
|
-
return currentLevel;
|
|
66
|
-
}
|
|
67
|
-
function write(level, message, tag) {
|
|
68
|
-
if (level < currentLevel)
|
|
69
|
-
return;
|
|
70
|
-
const label = LEVEL_LABELS[level];
|
|
71
|
-
const prefix = tag ? `[${label}] [${tag}] ` : `[${label}] `;
|
|
72
|
-
process.stderr.write(`${prefix}${message}\n`);
|
|
73
|
-
}
|
|
74
|
-
export const log = {
|
|
75
|
-
trace: (message, tag) => write(LogLevel.TRACE, message, tag),
|
|
76
|
-
debug: (message, tag) => write(LogLevel.DEBUG, message, tag),
|
|
77
|
-
info: (message, tag) => write(LogLevel.INFO, message, tag),
|
|
78
|
-
warn: (message, tag) => write(LogLevel.WARN, message, tag),
|
|
79
|
-
error: (message, tag) => write(LogLevel.ERROR, message, tag),
|
|
80
|
-
fatal: (message, tag) => write(LogLevel.FATAL, message, tag),
|
|
81
|
-
};
|
|
13
|
+
import { log as coreLog, createLogger as coreCreateLogger, setLogLevel as coreSetLogLevel, getLogLevel as coreGetLogLevel, setLogFormat as coreSetLogFormat, getLogFormat as coreGetLogFormat, setSanitize as coreSetSanitize, LogLevel, } from '@amodalai/core';
|
|
14
|
+
// Re-export core logger API
|
|
15
|
+
export { LogLevel };
|
|
16
|
+
export const log = coreLog;
|
|
17
|
+
export const createLogger = coreCreateLogger;
|
|
18
|
+
export const setLogLevel = coreSetLogLevel;
|
|
19
|
+
export const getLogLevel = coreGetLogLevel;
|
|
20
|
+
export const setLogFormat = coreSetLogFormat;
|
|
21
|
+
export const getLogFormat = coreGetLogFormat;
|
|
22
|
+
export const setSanitize = coreSetSanitize;
|
|
82
23
|
/**
|
|
83
24
|
* Convert -v count and --quiet flag to a LogLevel.
|
|
84
25
|
* --quiet → ERROR, default → INFO, -v → DEBUG, -vv → TRACE
|
|
@@ -98,7 +39,7 @@ export function verbosityToLogLevel(verbosity, quiet) {
|
|
|
98
39
|
*/
|
|
99
40
|
export function initLogLevel(opts) {
|
|
100
41
|
if (process.env['LOG_LEVEL']) {
|
|
101
|
-
// Env var already handled by the module-level initializer
|
|
42
|
+
// Env var already handled by the module-level initializer in core
|
|
102
43
|
return;
|
|
103
44
|
}
|
|
104
45
|
setLogLevel(verbosityToLogLevel(opts.verbosity ?? 0, opts.quiet ?? false));
|
|
@@ -114,22 +55,22 @@ export function interceptConsole() {
|
|
|
114
55
|
const origError = console.error;
|
|
115
56
|
const origDebug = console.debug;
|
|
116
57
|
console.log = (...args) => {
|
|
117
|
-
if (
|
|
58
|
+
if (getLogLevel() <= LogLevel.TRACE) {
|
|
118
59
|
origLog.apply(console, args);
|
|
119
60
|
}
|
|
120
61
|
};
|
|
121
62
|
console.debug = (...args) => {
|
|
122
|
-
if (
|
|
63
|
+
if (getLogLevel() <= LogLevel.TRACE) {
|
|
123
64
|
origDebug.apply(console, args);
|
|
124
65
|
}
|
|
125
66
|
};
|
|
126
67
|
console.warn = (...args) => {
|
|
127
|
-
if (
|
|
68
|
+
if (getLogLevel() <= LogLevel.DEBUG) {
|
|
128
69
|
origWarn.apply(console, args);
|
|
129
70
|
}
|
|
130
71
|
};
|
|
131
72
|
console.error = (...args) => {
|
|
132
|
-
if (
|
|
73
|
+
if (getLogLevel() <= LogLevel.WARN) {
|
|
133
74
|
// Suppress known noisy upstream messages
|
|
134
75
|
if (typeof args[0] === 'string' && args[0].includes('Current logger will'))
|
|
135
76
|
return;
|
package/dist/src/logger.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/logger.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/logger.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH;;;;;;GAMG;AAEH,OAAO,EACL,GAAG,IAAI,OAAO,EACd,YAAY,IAAI,gBAAgB,EAChC,WAAW,IAAI,eAAe,EAC9B,WAAW,IAAI,eAAe,EAC9B,YAAY,IAAI,gBAAgB,EAChC,YAAY,IAAI,gBAAgB,EAChC,WAAW,IAAI,eAAe,EAC9B,QAAQ,GACT,MAAM,gBAAgB,CAAC;AAIxB,4BAA4B;AAC5B,OAAO,EAAE,QAAQ,EAAE,CAAC;AAGpB,MAAM,CAAC,MAAM,GAAG,GAAW,OAAO,CAAC;AACnC,MAAM,CAAC,MAAM,YAAY,GAAG,gBAAgB,CAAC;AAC7C,MAAM,CAAC,MAAM,WAAW,GAAG,eAAe,CAAC;AAC3C,MAAM,CAAC,MAAM,WAAW,GAAG,eAAe,CAAC;AAC3C,MAAM,CAAC,MAAM,YAAY,GAAG,gBAAgB,CAAC;AAC7C,MAAM,CAAC,MAAM,YAAY,GAAG,gBAAgB,CAAC;AAC7C,MAAM,CAAC,MAAM,WAAW,GAAG,eAAe,CAAC;AAE3C;;;GAGG;AACH,MAAM,UAAU,mBAAmB,CAAC,SAAiB,EAAE,KAAc;IACnE,IAAI,KAAK;QAAE,OAAO,QAAQ,CAAC,KAAK,CAAC;IACjC,IAAI,SAAS,IAAI,CAAC;QAAE,OAAO,QAAQ,CAAC,KAAK,CAAC;IAC1C,IAAI,SAAS,IAAI,CAAC;QAAE,OAAO,QAAQ,CAAC,KAAK,CAAC;IAC1C,OAAO,QAAQ,CAAC,IAAI,CAAC;AACvB,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,YAAY,CAAC,IAA2C;IACtE,IAAI,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC;QAC7B,kEAAkE;QAClE,OAAO;IACT,CAAC;IACD,WAAW,CAAC,mBAAmB,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,EAAE,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,CAAC,CAAC;AAC7E,CAAC;AAED;;;GAGG;AACH,+BAA+B;AAC/B,MAAM,UAAU,gBAAgB;IAC9B,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC;IAC5B,MAAM,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;IAC9B,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC;IAChC,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC;IAEhC,OAAO,CAAC,GAAG,GAAG,CAAC,GAAG,IAAe,EAAE,EAAE;QACnC,IAAI,WAAW,EAAE,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;YACpC,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QAC/B,CAAC;IACH,CAAC,CAAC;IAEF,OAAO,CAAC,KAAK,GAAG,CAAC,GAAG,IAAe,EAAE,EAAE;QACrC,IAAI,WAAW,EAAE,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;YACpC,SAAS,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QACjC,CAAC;IACH,CAAC,CAAC;IAEF,OAAO,CAAC,IAAI,GAAG,CAAC,GAAG,IAAe,EAAE,EAAE;QACpC,IAAI,WAAW,EAAE,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;YACpC,QAAQ,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QAChC,CAAC;IACH,CAAC,CAAC;IAEF,OAAO,CAAC,KAAK,GAAG,CAAC,GAAG,IAAe,EAAE,EAAE;QACrC,IAAI,WAAW,EAAE,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC;YACnC,yCAAyC;YACzC,IAAI,OAAO,IAAI,CAAC,CAAC,CAAC,KAAK,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,qBAAqB,CAAC;gBAAE,OAAO;YACnF,SAAS,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QACjC,CAAC;IACH,CAAC,CAAC;AACJ,CAAC;AACD,8BAA8B"}
|