@openparachute/agent 0.1.2 → 0.2.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.parachute/module.json +124 -8
- package/LICENSE +2 -16
- package/README.md +118 -166
- package/package.json +35 -42
- package/scripts/spawn-agent.ts +371 -0
- package/src/_parked/interactive-spawn.test.ts +324 -0
- package/src/_parked/interactive-spawn.ts +701 -0
- package/src/agent-defs.test.ts +1504 -0
- package/src/agent-defs.ts +1702 -0
- package/src/agent-mcp-config.test.ts +115 -0
- package/src/agent-mcp-config.ts +115 -0
- package/src/agents.test.ts +360 -0
- package/src/agents.ts +379 -0
- package/src/auth.test.ts +46 -0
- package/src/auth.ts +140 -0
- package/src/backends/attached-queue.test.ts +376 -0
- package/src/backends/attached-queue.ts +372 -0
- package/src/backends/programmatic.test.ts +1715 -0
- package/src/backends/programmatic.ts +927 -0
- package/src/backends/registry.test.ts +1494 -0
- package/src/backends/registry.ts +1202 -0
- package/src/backends/stream-json.test.ts +570 -0
- package/src/backends/stream-json.ts +392 -0
- package/src/backends/types.ts +223 -0
- package/src/bridge.ts +417 -0
- package/src/channel-backend-wiring.test.ts +237 -0
- package/src/credentials.test.ts +274 -0
- package/src/credentials.ts +380 -0
- package/src/cron.test.ts +342 -0
- package/src/cron.ts +380 -0
- package/src/daemon-agent-def-api.test.ts +166 -0
- package/src/daemon-agent-defs-api.test.ts +953 -0
- package/src/daemon-agent-env-api.test.ts +338 -0
- package/src/daemon-attached-queue-store.test.ts +65 -0
- package/src/daemon-config-api.test.ts +962 -0
- package/src/daemon-jobs-api.test.ts +271 -0
- package/src/daemon-vault-chat.test.ts +250 -0
- package/src/daemon.test.ts +746 -0
- package/src/daemon.ts +3314 -0
- package/src/def-vaults.test.ts +136 -0
- package/src/def-vaults.ts +165 -0
- package/src/delivery-state.test.ts +110 -0
- package/src/delivery-state.ts +154 -0
- package/src/effective-env.test.ts +114 -0
- package/src/effective-env.ts +184 -0
- package/src/env-compat.ts +39 -0
- package/src/grants.test.ts +638 -0
- package/src/grants.ts +675 -0
- package/src/hub-jwt.test.ts +161 -0
- package/src/hub-jwt.ts +182 -0
- package/src/jobs.test.ts +245 -0
- package/src/jobs.ts +266 -0
- package/src/mcp-http.test.ts +265 -0
- package/src/mcp-http.ts +771 -0
- package/src/mint-token.test.ts +152 -0
- package/src/mint-token.ts +139 -0
- package/src/module-manifest.test.ts +158 -0
- package/src/oauth-discovery.ts +134 -0
- package/src/programmatic-wiring.test.ts +838 -0
- package/src/registry.test.ts +227 -0
- package/src/registry.ts +228 -0
- package/src/resolve-port.test.ts +64 -0
- package/src/routing.test.ts +184 -0
- package/src/routing.ts +76 -0
- package/src/runner.test.ts +506 -0
- package/src/runner.ts +255 -0
- package/src/sandbox/config.test.ts +150 -0
- package/src/sandbox/config.ts +102 -0
- package/src/sandbox/egress.test.ts +113 -0
- package/src/sandbox/egress.ts +123 -0
- package/src/sandbox/index.ts +180 -0
- package/src/sandbox/live-seatbelt.test.ts +277 -0
- package/src/sandbox/mounts.test.ts +154 -0
- package/src/sandbox/mounts.ts +133 -0
- package/src/sandbox/sandbox.test.ts +168 -0
- package/src/sandbox/types.ts +382 -0
- package/src/services-manifest.test.ts +106 -0
- package/src/services-manifest.ts +95 -0
- package/src/spa-serve.test.ts +116 -0
- package/src/spa-serve.ts +116 -0
- package/src/spawn-agent-cli.test.ts +172 -0
- package/src/spawn-agent.test.ts +1218 -0
- package/src/spawn-agent.ts +569 -0
- package/src/spawn-deps.test.ts +54 -0
- package/src/spawn-deps.ts +166 -0
- package/src/telegram/api.ts +153 -0
- package/src/terminal-assets.test.ts +50 -0
- package/src/terminal-assets.ts +79 -0
- package/src/terminal-ui.ts +305 -0
- package/src/terminal.test.ts +530 -0
- package/src/terminal.ts +458 -0
- package/src/transport.ts +270 -0
- package/src/transports/http-ui.test.ts +455 -0
- package/src/transports/http-ui.ts +201 -0
- package/src/transports/telegram.test.ts +174 -0
- package/src/transports/telegram.ts +426 -0
- package/src/transports/vault.test.ts +2011 -0
- package/src/transports/vault.ts +1790 -0
- package/src/ui-kit.test.ts +178 -0
- package/src/ui-kit.ts +402 -0
- package/tsconfig.json +8 -14
- package/web/ui/dist/assets/index-C-iWdFFV.css +1 -0
- package/web/ui/dist/assets/index-VFETBk0a.js +60 -0
- package/web/ui/dist/index.html +15 -0
- package/web/ui/tsconfig.json +2 -1
- package/.claude/scheduled_tasks.lock +0 -1
- package/.claude/settings.json +0 -5
- package/.claude/skills/add-atomic-chat-tool/SKILL.md +0 -243
- package/.claude/skills/add-atomic-chat-tool/atomic-chat-mcp-stdio.ts +0 -229
- package/.claude/skills/add-codex/SKILL.md +0 -161
- package/.claude/skills/add-dashboard/SKILL.md +0 -138
- package/.claude/skills/add-dashboard/resources/dashboard-pusher.ts +0 -495
- package/.claude/skills/add-emacs/SKILL.md +0 -296
- package/.claude/skills/add-gcal-tool/SKILL.md +0 -210
- package/.claude/skills/add-gchat/REMOVE.md +0 -6
- package/.claude/skills/add-gchat/SKILL.md +0 -92
- package/.claude/skills/add-gchat/VERIFY.md +0 -3
- package/.claude/skills/add-github/REMOVE.md +0 -6
- package/.claude/skills/add-github/SKILL.md +0 -148
- package/.claude/skills/add-github/VERIFY.md +0 -3
- package/.claude/skills/add-gmail-tool/SKILL.md +0 -229
- package/.claude/skills/add-imessage/REMOVE.md +0 -6
- package/.claude/skills/add-imessage/SKILL.md +0 -113
- package/.claude/skills/add-imessage/VERIFY.md +0 -3
- package/.claude/skills/add-karpathy-llm-wiki/SKILL.md +0 -110
- package/.claude/skills/add-karpathy-llm-wiki/llm-wiki.md +0 -75
- package/.claude/skills/add-linear/REMOVE.md +0 -6
- package/.claude/skills/add-linear/SKILL.md +0 -168
- package/.claude/skills/add-linear/VERIFY.md +0 -3
- package/.claude/skills/add-macos-statusbar/SKILL.md +0 -133
- package/.claude/skills/add-macos-statusbar/add/src/statusbar.swift +0 -147
- package/.claude/skills/add-matrix/REMOVE.md +0 -6
- package/.claude/skills/add-matrix/SKILL.md +0 -148
- package/.claude/skills/add-matrix/VERIFY.md +0 -3
- package/.claude/skills/add-ollama-provider/SKILL.md +0 -179
- package/.claude/skills/add-ollama-tool/SKILL.md +0 -193
- package/.claude/skills/add-opencode/SKILL.md +0 -229
- package/.claude/skills/add-parallel/SKILL.md +0 -290
- package/.claude/skills/add-resend/REMOVE.md +0 -6
- package/.claude/skills/add-resend/SKILL.md +0 -93
- package/.claude/skills/add-resend/VERIFY.md +0 -3
- package/.claude/skills/add-signal/REMOVE.md +0 -13
- package/.claude/skills/add-signal/SKILL.md +0 -318
- package/.claude/skills/add-signal/VERIFY.md +0 -5
- package/.claude/skills/add-slack/REMOVE.md +0 -6
- package/.claude/skills/add-slack/SKILL.md +0 -112
- package/.claude/skills/add-slack/VERIFY.md +0 -3
- package/.claude/skills/add-teams/REMOVE.md +0 -6
- package/.claude/skills/add-teams/SKILL.md +0 -207
- package/.claude/skills/add-teams/VERIFY.md +0 -3
- package/.claude/skills/add-vercel/SKILL.md +0 -147
- package/.claude/skills/add-vercel/container-skills/vercel-cli/SKILL.md +0 -103
- package/.claude/skills/add-webex/REMOVE.md +0 -6
- package/.claude/skills/add-webex/SKILL.md +0 -88
- package/.claude/skills/add-webex/VERIFY.md +0 -3
- package/.claude/skills/add-wechat/REMOVE.md +0 -49
- package/.claude/skills/add-wechat/SKILL.md +0 -170
- package/.claude/skills/add-wechat/scripts/wire-dm.ts +0 -172
- package/.claude/skills/add-whatsapp/SKILL.md +0 -264
- package/.claude/skills/add-whatsapp-cloud/REMOVE.md +0 -6
- package/.claude/skills/add-whatsapp-cloud/SKILL.md +0 -95
- package/.claude/skills/add-whatsapp-cloud/VERIFY.md +0 -3
- package/.claude/skills/claw/SKILL.md +0 -131
- package/.claude/skills/claw/scripts/claw +0 -374
- package/.claude/skills/convert-to-apple-container/SKILL.md +0 -212
- package/.claude/skills/customize/SKILL.md +0 -110
- package/.claude/skills/debug/SKILL.md +0 -349
- package/.claude/skills/get-qodo-rules/SKILL.md +0 -122
- package/.claude/skills/get-qodo-rules/references/output-format.md +0 -41
- package/.claude/skills/get-qodo-rules/references/pagination.md +0 -33
- package/.claude/skills/get-qodo-rules/references/repository-scope.md +0 -26
- package/.claude/skills/init-first-agent/SKILL.md +0 -120
- package/.claude/skills/init-onecli/SKILL.md +0 -270
- package/.claude/skills/manage-channels/SKILL.md +0 -87
- package/.claude/skills/manage-mounts/SKILL.md +0 -47
- package/.claude/skills/migrate-from-openclaw/MIGRATE_CRONS.md +0 -100
- package/.claude/skills/migrate-from-openclaw/SKILL.md +0 -447
- package/.claude/skills/migrate-from-openclaw/scripts/discover-openclaw.ts +0 -734
- package/.claude/skills/migrate-from-openclaw/scripts/extract-channel-credentials.ts +0 -476
- package/.claude/skills/migrate-nanoclaw/SKILL.md +0 -484
- package/.claude/skills/migrate-nanoclaw/diagnostics.md +0 -51
- package/.claude/skills/qodo-pr-resolver/SKILL.md +0 -326
- package/.claude/skills/qodo-pr-resolver/resources/providers.md +0 -329
- package/.claude/skills/update-nanoclaw/SKILL.md +0 -243
- package/.claude/skills/update-nanoclaw/diagnostics.md +0 -48
- package/.claude/skills/update-skills/SKILL.md +0 -130
- package/.claude/skills/use-native-credential-proxy/SKILL.md +0 -167
- package/.claude/skills/x-integration/SKILL.md +0 -417
- package/.claude/skills/x-integration/agent.ts +0 -243
- package/.claude/skills/x-integration/host.ts +0 -155
- package/.claude/skills/x-integration/lib/browser.ts +0 -148
- package/.claude/skills/x-integration/lib/config.ts +0 -62
- package/.claude/skills/x-integration/scripts/like.ts +0 -56
- package/.claude/skills/x-integration/scripts/post.ts +0 -66
- package/.claude/skills/x-integration/scripts/quote.ts +0 -80
- package/.claude/skills/x-integration/scripts/reply.ts +0 -74
- package/.claude/skills/x-integration/scripts/retweet.ts +0 -62
- package/.claude/skills/x-integration/scripts/setup.ts +0 -87
- package/.github/CODEOWNERS +0 -10
- package/.github/PULL_REQUEST_TEMPLATE.md +0 -18
- package/.github/workflows/bump-version.yml +0 -35
- package/.github/workflows/ci.yml +0 -39
- package/.github/workflows/label-pr.yml +0 -40
- package/.github/workflows/update-tokens.yml +0 -43
- package/.husky/pre-commit +0 -1
- package/.mcp.json +0 -3
- package/.nvmrc +0 -1
- package/.prettierrc +0 -4
- package/CHANGELOG.md +0 -263
- package/CLAUDE.md +0 -307
- package/CODE_OF_CONDUCT.md +0 -128
- package/CONTRIBUTING.md +0 -159
- package/CONTRIBUTORS.md +0 -26
- package/LICENSE-NANOCLAW-MIT +0 -21
- package/README_ja.md +0 -194
- package/README_zh.md +0 -194
- package/assets/nanoclaw-favicon.png +0 -0
- package/assets/nanoclaw-icon.png +0 -0
- package/assets/nanoclaw-logo-dark.png +0 -0
- package/assets/nanoclaw-logo.png +0 -0
- package/assets/nanoclaw-profile.jpeg +0 -0
- package/assets/nanoclaw-sales.png +0 -0
- package/assets/social-preview.jpg +0 -0
- package/config-examples/mount-allowlist.json +0 -25
- package/container/.dockerignore +0 -2
- package/container/CLAUDE.md +0 -21
- package/container/Dockerfile +0 -121
- package/container/agent-runner/bun.lock +0 -243
- package/container/agent-runner/package.json +0 -22
- package/container/agent-runner/scripts/sdk-signal-probe.ts +0 -169
- package/container/agent-runner/src/config.ts +0 -55
- package/container/agent-runner/src/db/connection.ts +0 -267
- package/container/agent-runner/src/db/index.ts +0 -20
- package/container/agent-runner/src/db/messages-in.ts +0 -138
- package/container/agent-runner/src/db/messages-out.ts +0 -143
- package/container/agent-runner/src/db/session-routing.ts +0 -30
- package/container/agent-runner/src/db/session-state.test.ts +0 -100
- package/container/agent-runner/src/db/session-state.ts +0 -79
- package/container/agent-runner/src/destinations.ts +0 -135
- package/container/agent-runner/src/formatter.test.ts +0 -167
- package/container/agent-runner/src/formatter.ts +0 -260
- package/container/agent-runner/src/index.ts +0 -110
- package/container/agent-runner/src/integration.test.ts +0 -121
- package/container/agent-runner/src/mcp-tools/agents.instructions.md +0 -26
- package/container/agent-runner/src/mcp-tools/agents.ts +0 -66
- package/container/agent-runner/src/mcp-tools/core.instructions.md +0 -27
- package/container/agent-runner/src/mcp-tools/core.ts +0 -262
- package/container/agent-runner/src/mcp-tools/index.ts +0 -22
- package/container/agent-runner/src/mcp-tools/interactive.instructions.md +0 -22
- package/container/agent-runner/src/mcp-tools/interactive.ts +0 -169
- package/container/agent-runner/src/mcp-tools/scheduling.instructions.md +0 -40
- package/container/agent-runner/src/mcp-tools/scheduling.ts +0 -299
- package/container/agent-runner/src/mcp-tools/self-mod.instructions.md +0 -25
- package/container/agent-runner/src/mcp-tools/self-mod.ts +0 -120
- package/container/agent-runner/src/mcp-tools/server.ts +0 -54
- package/container/agent-runner/src/mcp-tools/types.ts +0 -6
- package/container/agent-runner/src/poll-loop.test.ts +0 -248
- package/container/agent-runner/src/poll-loop.ts +0 -437
- package/container/agent-runner/src/providers/claude.ts +0 -379
- package/container/agent-runner/src/providers/factory.test.ts +0 -19
- package/container/agent-runner/src/providers/factory.ts +0 -13
- package/container/agent-runner/src/providers/index.ts +0 -6
- package/container/agent-runner/src/providers/mock.ts +0 -77
- package/container/agent-runner/src/providers/provider-registry.ts +0 -33
- package/container/agent-runner/src/providers/types.ts +0 -82
- package/container/agent-runner/src/scheduling/task-script.ts +0 -121
- package/container/agent-runner/src/timezone.test.ts +0 -93
- package/container/agent-runner/src/timezone.ts +0 -107
- package/container/agent-runner/tsconfig.json +0 -14
- package/container/build.sh +0 -48
- package/container/entrypoint.sh +0 -16
- package/container/skills/agent-browser/SKILL.md +0 -159
- package/container/skills/frontend-engineer/SKILL.md +0 -157
- package/container/skills/self-customize/SKILL.md +0 -87
- package/container/skills/slack-formatting/SKILL.md +0 -94
- package/container/skills/vercel-cli/SKILL.md +0 -111
- package/container/skills/welcome/SKILL.md +0 -85
- package/docs/APPLE-CONTAINER-NETWORKING.md +0 -90
- package/docs/BRANCH-FORK-MAINTENANCE.md +0 -81
- package/docs/README.md +0 -25
- package/docs/SDK_DEEP_DIVE.md +0 -643
- package/docs/SECURITY.md +0 -162
- package/docs/agent-runner-details.md +0 -749
- package/docs/api-details.md +0 -365
- package/docs/architecture-diagram.html +0 -422
- package/docs/architecture-diagram.md +0 -215
- package/docs/architecture.md +0 -751
- package/docs/audit/2026-04-30-channel-endpoint-audit.md +0 -36
- package/docs/build-and-runtime.md +0 -80
- package/docs/cross-mount-stress/README.md +0 -112
- package/docs/cross-mount-stress/container-writer-retry.mjs +0 -55
- package/docs/cross-mount-stress/container-writer-slow.mjs +0 -42
- package/docs/cross-mount-stress/container-writer.mjs +0 -47
- package/docs/cross-mount-stress/host-writer-retry.mjs +0 -55
- package/docs/cross-mount-stress/host-writer-slow.mjs +0 -43
- package/docs/cross-mount-stress/host-writer.mjs +0 -47
- package/docs/db-central.md +0 -316
- package/docs/db-session.md +0 -183
- package/docs/db.md +0 -119
- package/docs/design/2026-04-29-vault-management-ui.md +0 -231
- package/docs/design/2026-04-30-channel-wiring-rework.md +0 -234
- package/docs/design/2026-05-01-channel-wiring-approvals-deep-dive.md +0 -272
- package/docs/design/2026-05-02-channel-policy-and-approval-routing.md +0 -250
- package/docs/docker-sandboxes.md +0 -359
- package/docs/isolation-model.md +0 -88
- package/docs/ollama.md +0 -79
- package/docs/parachute-integration.md +0 -109
- package/docs/post-night-rebirth-reflections.md +0 -151
- package/eslint.config.js +0 -32
- package/pnpm-workspace.yaml +0 -8
- package/repo-tokens/README.md +0 -113
- package/repo-tokens/action.yml +0 -186
- package/repo-tokens/badge.svg +0 -23
- package/repo-tokens/examples/green.svg +0 -14
- package/repo-tokens/examples/red.svg +0 -14
- package/repo-tokens/examples/yellow-green.svg +0 -14
- package/repo-tokens/examples/yellow.svg +0 -14
- package/scripts/chat.ts +0 -101
- package/scripts/cleanup-sessions.sh +0 -150
- package/scripts/init-cli-agent.ts +0 -172
- package/scripts/init-first-agent.ts +0 -378
- package/scripts/parachute.ts +0 -158
- package/scripts/run-migrations.ts +0 -105
- package/scripts/sanity-live-poll.ts +0 -95
- package/scripts/seed-discord.ts +0 -80
- package/scripts/test-v2-agent.ts +0 -106
- package/scripts/test-v2-channel-e2e.ts +0 -265
- package/scripts/test-v2-host.ts +0 -184
- package/src/channels/adapter.ts +0 -214
- package/src/channels/api-translator.test.ts +0 -306
- package/src/channels/api-translator.ts +0 -214
- package/src/channels/ask-question.ts +0 -46
- package/src/channels/channel-registry.test.ts +0 -421
- package/src/channels/channel-registry.ts +0 -313
- package/src/channels/chat-sdk-bridge.test.ts +0 -84
- package/src/channels/chat-sdk-bridge.ts +0 -652
- package/src/channels/cli.ts +0 -276
- package/src/channels/discord.ts +0 -90
- package/src/channels/index.ts +0 -17
- package/src/channels/telegram-markdown-sanitize.test.ts +0 -78
- package/src/channels/telegram-markdown-sanitize.ts +0 -55
- package/src/channels/telegram-pairing.test.ts +0 -254
- package/src/channels/telegram-pairing.ts +0 -339
- package/src/channels/telegram.ts +0 -279
- package/src/channels/trust-hint.test.ts +0 -48
- package/src/channels/trust-hint.ts +0 -75
- package/src/claude-md-compose.migrate.test.ts +0 -64
- package/src/claude-md-compose.ts +0 -205
- package/src/command-gate.ts +0 -63
- package/src/config.test.ts +0 -93
- package/src/config.ts +0 -128
- package/src/container-config.ts +0 -167
- package/src/container-runner.test.ts +0 -32
- package/src/container-runner.ts +0 -576
- package/src/container-runtime.test.ts +0 -269
- package/src/container-runtime.ts +0 -167
- package/src/db/_bun-sqlite-shim.ts +0 -88
- package/src/db/agent-activity.test.ts +0 -155
- package/src/db/agent-activity.ts +0 -121
- package/src/db/agent-groups.ts +0 -77
- package/src/db/connection.migrate.test.ts +0 -176
- package/src/db/connection.ts +0 -259
- package/src/db/db-v2.test.ts +0 -440
- package/src/db/dropped-messages.ts +0 -44
- package/src/db/index.ts +0 -40
- package/src/db/messaging-groups.ts +0 -252
- package/src/db/migrations/001-initial.ts +0 -112
- package/src/db/migrations/002-chat-sdk-state.ts +0 -36
- package/src/db/migrations/008-dropped-messages.ts +0 -27
- package/src/db/migrations/009-drop-pending-credentials.ts +0 -13
- package/src/db/migrations/010-engage-modes.ts +0 -103
- package/src/db/migrations/011-pending-sender-approvals.ts +0 -40
- package/src/db/migrations/012-channel-registration.ts +0 -48
- package/src/db/migrations/013-approval-render-metadata.ts +0 -27
- package/src/db/migrations/014-secrets.ts +0 -44
- package/src/db/migrations/015-secrets-drop-host-pattern.ts +0 -18
- package/src/db/migrations/016-secret-assignments.ts +0 -30
- package/src/db/migrations/017-agent-activity.ts +0 -40
- package/src/db/migrations/018-oauth-app-configs.ts +0 -34
- package/src/db/migrations/019-oauth-app-connections.ts +0 -48
- package/src/db/migrations/020-agent-app-connections.ts +0 -28
- package/src/db/migrations/021-pending-oauth-states.ts +0 -35
- package/src/db/migrations/022-app-connections-provider.ts +0 -25
- package/src/db/migrations/023-agent-group-secret-mode.test.ts +0 -124
- package/src/db/migrations/023-agent-group-secret-mode.ts +0 -65
- package/src/db/migrations/024-collapse-approvals.test.ts +0 -249
- package/src/db/migrations/024-collapse-approvals.ts +0 -182
- package/src/db/migrations/025-secret-mode-check.test.ts +0 -155
- package/src/db/migrations/025-secret-mode-check.ts +0 -49
- package/src/db/migrations/026-user-dms-bot-id.test.ts +0 -116
- package/src/db/migrations/026-user-dms-bot-id.ts +0 -54
- package/src/db/migrations/027-provider-credentials.ts +0 -41
- package/src/db/migrations/_test-helpers.ts +0 -41
- package/src/db/migrations/index.ts +0 -127
- package/src/db/migrations/module-agent-to-agent-destinations.ts +0 -84
- package/src/db/migrations/module-approvals-pending-approvals.ts +0 -42
- package/src/db/migrations/module-approvals-title-options.ts +0 -40
- package/src/db/schema.ts +0 -258
- package/src/db/session-db.test.ts +0 -93
- package/src/db/session-db.ts +0 -325
- package/src/db/sessions.ts +0 -241
- package/src/delivery.test.ts +0 -148
- package/src/delivery.ts +0 -445
- package/src/env.ts +0 -74
- package/src/group-folder.test.ts +0 -35
- package/src/group-folder.ts +0 -44
- package/src/group-init.ts +0 -92
- package/src/host-core.test.ts +0 -456
- package/src/host-sweep.test.ts +0 -146
- package/src/host-sweep.ts +0 -287
- package/src/index.ts +0 -232
- package/src/install-slug.ts +0 -33
- package/src/log.test.ts +0 -81
- package/src/log.ts +0 -117
- package/src/mcp/http.ts +0 -72
- package/src/mcp/server.ts +0 -92
- package/src/mcp/stdio.ts +0 -51
- package/src/mcp/tools/activity.ts +0 -88
- package/src/mcp/tools/agent-groups.ts +0 -183
- package/src/mcp/tools/approvals.ts +0 -122
- package/src/mcp/tools/channels.test.ts +0 -126
- package/src/mcp/tools/channels.ts +0 -134
- package/src/mcp/tools/index.ts +0 -27
- package/src/mcp/tools/oauth.ts +0 -48
- package/src/mcp/tools/secrets.ts +0 -169
- package/src/mcp/tools/sessions.ts +0 -135
- package/src/mcp/types.ts +0 -51
- package/src/modules/agent-to-agent/agent-route.test.ts +0 -46
- package/src/modules/agent-to-agent/agent-route.ts +0 -223
- package/src/modules/agent-to-agent/create-agent.ts +0 -127
- package/src/modules/agent-to-agent/db/agent-destinations.ts +0 -135
- package/src/modules/agent-to-agent/index.ts +0 -22
- package/src/modules/agent-to-agent/write-destinations.ts +0 -59
- package/src/modules/approvals/agent.md +0 -45
- package/src/modules/approvals/index.ts +0 -21
- package/src/modules/approvals/picks.test.ts +0 -291
- package/src/modules/approvals/primitive.ts +0 -279
- package/src/modules/approvals/project.md +0 -27
- package/src/modules/approvals/response-handler.ts +0 -87
- package/src/modules/index.ts +0 -24
- package/src/modules/interactive/agent.md +0 -21
- package/src/modules/interactive/index.ts +0 -69
- package/src/modules/interactive/project.md +0 -12
- package/src/modules/mount-security/expand-path.test.ts +0 -82
- package/src/modules/mount-security/index.ts +0 -459
- package/src/modules/mount-security/migrate.test.ts +0 -91
- package/src/modules/permissions/access.ts +0 -28
- package/src/modules/permissions/channel-approval.test.ts +0 -389
- package/src/modules/permissions/channel-approval.ts +0 -188
- package/src/modules/permissions/db/agent-group-members.ts +0 -44
- package/src/modules/permissions/db/pending-channel-approvals.test.ts +0 -86
- package/src/modules/permissions/db/pending-channel-approvals.ts +0 -66
- package/src/modules/permissions/db/pending-sender-approvals.ts +0 -60
- package/src/modules/permissions/db/user-dms.ts +0 -58
- package/src/modules/permissions/db/user-roles.ts +0 -85
- package/src/modules/permissions/db/users.ts +0 -38
- package/src/modules/permissions/index.ts +0 -421
- package/src/modules/permissions/permissions.test.ts +0 -358
- package/src/modules/permissions/sender-approval.test.ts +0 -641
- package/src/modules/permissions/sender-approval.ts +0 -165
- package/src/modules/permissions/user-dm.ts +0 -200
- package/src/modules/provider-credentials/db.ts +0 -121
- package/src/modules/provider-credentials/index.ts +0 -12
- package/src/modules/provider-credentials/spawn.test.ts +0 -206
- package/src/modules/provider-credentials/spawn.ts +0 -114
- package/src/modules/scheduling/actions.ts +0 -113
- package/src/modules/scheduling/db.test.ts +0 -282
- package/src/modules/scheduling/db.ts +0 -148
- package/src/modules/scheduling/index.ts +0 -34
- package/src/modules/scheduling/recurrence.test.ts +0 -98
- package/src/modules/scheduling/recurrence.ts +0 -54
- package/src/modules/self-mod/agent.md +0 -30
- package/src/modules/self-mod/apply.ts +0 -85
- package/src/modules/self-mod/index.ts +0 -30
- package/src/modules/self-mod/project.md +0 -39
- package/src/modules/self-mod/request.ts +0 -91
- package/src/modules/typing/index.ts +0 -165
- package/src/oauth/agent-app-connections.ts +0 -103
- package/src/oauth/app-configs.test.ts +0 -64
- package/src/oauth/app-configs.ts +0 -114
- package/src/oauth/app-connections.test.ts +0 -109
- package/src/oauth/app-connections.ts +0 -178
- package/src/oauth/crypto.ts +0 -56
- package/src/oauth/flow.ts +0 -104
- package/src/oauth/providers/google.test.ts +0 -38
- package/src/oauth/providers/google.ts +0 -46
- package/src/oauth/providers/index.ts +0 -48
- package/src/oauth/state-store.test.ts +0 -54
- package/src/oauth/state-store.ts +0 -93
- package/src/parachute/README.md +0 -27
- package/src/parachute/create-agent.test.ts +0 -83
- package/src/parachute/create-agent.ts +0 -122
- package/src/parachute/group-status.test.ts +0 -165
- package/src/parachute/group-status.ts +0 -136
- package/src/parachute/types.ts +0 -41
- package/src/parachute/vault-mcp.test.ts +0 -251
- package/src/parachute/vault-mcp.ts +0 -232
- package/src/platform-id.test.ts +0 -104
- package/src/platform-id.ts +0 -109
- package/src/providers/index.ts +0 -6
- package/src/providers/provider-container-registry.ts +0 -58
- package/src/response-registry.ts +0 -45
- package/src/router.ts +0 -530
- package/src/secrets/crypto.test.ts +0 -45
- package/src/secrets/crypto.ts +0 -55
- package/src/secrets/index.ts +0 -461
- package/src/secrets/master-key.ts +0 -70
- package/src/secrets/secrets.test.ts +0 -651
- package/src/session-manager.attachments.test.ts +0 -171
- package/src/session-manager.dup-skip.test.ts +0 -173
- package/src/session-manager.migrate.test.ts +0 -59
- package/src/session-manager.ts +0 -451
- package/src/startup-bootstrap.test.ts +0 -226
- package/src/startup-bootstrap.ts +0 -207
- package/src/state-sqlite.ts +0 -182
- package/src/timezone.test.ts +0 -64
- package/src/timezone.ts +0 -37
- package/src/types.ts +0 -233
- package/src/web/auth.test.ts +0 -335
- package/src/web/auth.ts +0 -214
- package/src/web/discord-validate.test.ts +0 -77
- package/src/web/discord-validate.ts +0 -88
- package/src/web/hub-discovery.test.ts +0 -98
- package/src/web/hub-discovery.ts +0 -69
- package/src/web/routes/activity.ts +0 -106
- package/src/web/routes/agent-provider.test.ts +0 -282
- package/src/web/routes/agent-provider.ts +0 -309
- package/src/web/routes/approvals.ts +0 -185
- package/src/web/routes/apps.ts +0 -434
- package/src/web/routes/channels-mg-detail.test.ts +0 -324
- package/src/web/routes/channels-mga-detail.test.ts +0 -472
- package/src/web/routes/channels.ts +0 -311
- package/src/web/routes/oauth-providers.ts +0 -42
- package/src/web/routes/secrets.test.ts +0 -220
- package/src/web/routes/secrets.ts +0 -317
- package/src/web/routes/sessions.ts +0 -123
- package/src/web/routes/settings.test.ts +0 -106
- package/src/web/routes/settings.ts +0 -247
- package/src/web/routes/setup-status.ts +0 -205
- package/src/web/routes/vaults.test.ts +0 -389
- package/src/web/routes/vaults.ts +0 -225
- package/src/web/server-version.test.ts +0 -16
- package/src/web/server.ts +0 -1024
- package/src/web/services-manifest.test.ts +0 -148
- package/src/web/services-manifest.ts +0 -66
- package/src/web/static-serve.test.ts +0 -255
- package/src/web/static-serve.ts +0 -104
- package/src/web/telegram-validate.test.ts +0 -116
- package/src/web/telegram-validate.ts +0 -107
- package/src/web/vault-proxy.test.ts +0 -214
- package/src/web/vault-proxy.ts +0 -120
- package/src/web/wire-channel.ts +0 -181
- package/src/webhook-server.ts +0 -134
- package/vitest.config.ts +0 -18
- package/web/README.md +0 -63
- package/web/ui/index.html +0 -13
- package/web/ui/package.json +0 -35
- package/web/ui/pnpm-lock.yaml +0 -2164
- package/web/ui/scripts/verify-base.mjs +0 -31
- package/web/ui/src/App.tsx +0 -88
- package/web/ui/src/components/ActivityFeed.tsx +0 -444
- package/web/ui/src/components/AgentGroupPicker.tsx +0 -263
- package/web/ui/src/components/AgentProviderCards.tsx +0 -220
- package/web/ui/src/components/CredentialForm.tsx +0 -214
- package/web/ui/src/components/ScopeGrants.tsx +0 -74
- package/web/ui/src/components/StatusDot.tsx +0 -43
- package/web/ui/src/components/VaultPicker.tsx +0 -127
- package/web/ui/src/components/setup/AdapterInstallStep.tsx +0 -178
- package/web/ui/src/components/setup/AgentGroupStep.tsx +0 -43
- package/web/ui/src/components/setup/ChannelPickStep.tsx +0 -74
- package/web/ui/src/components/setup/DoneStep.tsx +0 -49
- package/web/ui/src/components/setup/PrereqStep.tsx +0 -129
- package/web/ui/src/components/setup/TestConnectionStep.tsx +0 -108
- package/web/ui/src/components/setup/TestMessageStep.tsx +0 -104
- package/web/ui/src/components/setup/WireChannelStep.tsx +0 -166
- package/web/ui/src/components/setup/types.ts +0 -105
- package/web/ui/src/lib/api.test.ts +0 -410
- package/web/ui/src/lib/api.ts +0 -1248
- package/web/ui/src/lib/auth.test.ts +0 -352
- package/web/ui/src/lib/auth.ts +0 -405
- package/web/ui/src/lib/channel-adapters.ts +0 -136
- package/web/ui/src/main.tsx +0 -19
- package/web/ui/src/routes/ApprovalsList.tsx +0 -294
- package/web/ui/src/routes/Apps.tsx +0 -613
- package/web/ui/src/routes/ChannelWireDetail.test.tsx +0 -233
- package/web/ui/src/routes/ChannelWireDetail.tsx +0 -403
- package/web/ui/src/routes/ChannelsList.tsx +0 -158
- package/web/ui/src/routes/GroupDetail.test.tsx +0 -206
- package/web/ui/src/routes/GroupDetail.tsx +0 -880
- package/web/ui/src/routes/GroupList.tsx +0 -187
- package/web/ui/src/routes/MessagingGroupDetail.test.tsx +0 -233
- package/web/ui/src/routes/MessagingGroupDetail.tsx +0 -306
- package/web/ui/src/routes/NewGroupWizard.tsx +0 -390
- package/web/ui/src/routes/OAuthCallback.tsx +0 -56
- package/web/ui/src/routes/SecretsList.tsx +0 -942
- package/web/ui/src/routes/SessionsList.tsx +0 -220
- package/web/ui/src/routes/SettingsAgentProvider.tsx +0 -109
- package/web/ui/src/routes/SettingsApprovals.tsx +0 -234
- package/web/ui/src/routes/SetupWizard.tsx +0 -219
- package/web/ui/src/routes/VaultDetail.test.tsx +0 -363
- package/web/ui/src/routes/VaultDetail.tsx +0 -960
- package/web/ui/src/routes/VaultsList.tsx +0 -295
- package/web/ui/src/routes/WireChannelPage.tsx +0 -413
- package/web/ui/src/styles.css +0 -608
- package/web/ui/src/test/setup.ts +0 -23
- package/web/ui/src/vite-env.d.ts +0 -10
- package/web/ui/vite.config.ts +0 -34
- package/web/ui/vitest.config.ts +0 -25
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Cross-mount visibility regression test for the two-DB session architecture.
|
|
3
|
-
*
|
|
4
|
-
* What this catches: any change that breaks host→container write propagation
|
|
5
|
-
* across the Docker bind mount. The v2 session DB design relies on three
|
|
6
|
-
* invariants working together:
|
|
7
|
-
*
|
|
8
|
-
* 1. journal_mode = DELETE on every session DB (not WAL)
|
|
9
|
-
* 2. Host opens-writes-closes the DB file on every write
|
|
10
|
-
* 3. One writer per file (inbound = host, outbound = container)
|
|
11
|
-
*
|
|
12
|
-
* This script exercises a long-lived container-side reader polling a DB
|
|
13
|
-
* while the host writes. If visibility is working, the reader sees each
|
|
14
|
-
* write within one poll period. If any of the invariants regresses, the
|
|
15
|
-
* reader either sees nothing, sees only the first write, or sees updates
|
|
16
|
-
* only after the host closes its connection for good.
|
|
17
|
-
*
|
|
18
|
-
* Expected passing output (DELETE mode, close-per-write):
|
|
19
|
-
* reader sees each seq within ~1s of it being written.
|
|
20
|
-
* Anything else is a regression — investigate BEFORE assuming it's flaky.
|
|
21
|
-
*
|
|
22
|
-
* Keep this around. It ran for ~20 minutes once to map the failure modes
|
|
23
|
-
* and it takes about 60s to run — cheap insurance.
|
|
24
|
-
*
|
|
25
|
-
* Requires: Docker Desktop running, parachute-agent-image-<slug>:latest built.
|
|
26
|
-
*/
|
|
27
|
-
|
|
28
|
-
import { spawn, spawnSync } from "node:child_process";
|
|
29
|
-
import { join } from "node:path";
|
|
30
|
-
import { mkdirSync, rmSync } from "node:fs";
|
|
31
|
-
import Database from "better-sqlite3";
|
|
32
|
-
|
|
33
|
-
const dbDir = join("/tmp", `parachute-agent-live-${Date.now()}`);
|
|
34
|
-
mkdirSync(dbDir, { recursive: true });
|
|
35
|
-
spawnSync("chmod", ["777", dbDir]);
|
|
36
|
-
const dbPath = join(dbDir, "live.db");
|
|
37
|
-
|
|
38
|
-
for (const journalMode of ["DELETE", "WAL"]) {
|
|
39
|
-
console.log(`\n=== ${journalMode} ===`);
|
|
40
|
-
rmSync(dbPath, { force: true });
|
|
41
|
-
rmSync(dbPath + "-wal", { force: true });
|
|
42
|
-
rmSync(dbPath + "-shm", { force: true });
|
|
43
|
-
rmSync(dbPath + "-journal", { force: true });
|
|
44
|
-
|
|
45
|
-
const db = new Database(dbPath);
|
|
46
|
-
db.pragma(`journal_mode = ${journalMode}`);
|
|
47
|
-
db.pragma("synchronous = FULL");
|
|
48
|
-
db.exec("CREATE TABLE msgs (seq INTEGER PRIMARY KEY, content TEXT)");
|
|
49
|
-
db.close();
|
|
50
|
-
|
|
51
|
-
// Start container poller in background
|
|
52
|
-
const contProc = spawn("docker", [
|
|
53
|
-
"run", "--rm", "-w", "/app",
|
|
54
|
-
"-v", `${dbDir}:/workspace`,
|
|
55
|
-
"--entrypoint", "node",
|
|
56
|
-
// Resolve the per-checkout image name produced by container/build.sh.
|
|
57
|
-
// Hardcoded for diagnostics only; not in the build chain.
|
|
58
|
-
`parachute-agent-image-${process.env.INSTALL_SLUG ?? "unknown"}:latest`,
|
|
59
|
-
"-e",
|
|
60
|
-
`const Database = require('better-sqlite3');
|
|
61
|
-
const db = new Database('/workspace/live.db', { readonly: true });
|
|
62
|
-
db.pragma('busy_timeout = 2000');
|
|
63
|
-
const stmt = db.prepare('SELECT COUNT(*) as n, MAX(seq) as hi FROM msgs');
|
|
64
|
-
let count = 0;
|
|
65
|
-
const timer = setInterval(() => {
|
|
66
|
-
const r = stmt.get();
|
|
67
|
-
console.log('poll t=' + (Date.now() % 100000) + ' count=' + r.n + ' max=' + r.hi);
|
|
68
|
-
if (++count >= 10) { clearInterval(timer); db.close(); }
|
|
69
|
-
}, 1000);`,
|
|
70
|
-
], { stdio: ["ignore", "pipe", "pipe"] });
|
|
71
|
-
|
|
72
|
-
contProc.stdout.on("data", (d) => process.stdout.write(` [cont] ${d}`));
|
|
73
|
-
contProc.stderr.on("data", (d) => process.stderr.write(` [cont-err] ${d}`));
|
|
74
|
-
|
|
75
|
-
// Give container a moment to start
|
|
76
|
-
const waitUntil = Date.now() + 2000;
|
|
77
|
-
while (Date.now() < waitUntil) {}
|
|
78
|
-
|
|
79
|
-
// Host opens, writes, CLOSES each time (matches production session-manager pattern)
|
|
80
|
-
for (let i = 1; i <= 8; i++) {
|
|
81
|
-
const h = new Database(dbPath);
|
|
82
|
-
h.pragma(`journal_mode = ${journalMode}`);
|
|
83
|
-
h.pragma("synchronous = FULL");
|
|
84
|
-
h.prepare("INSERT INTO msgs (seq, content) VALUES (?, ?)").run(i, `msg-${i}`);
|
|
85
|
-
h.close();
|
|
86
|
-
console.log(` [host] wrote+closed seq=${i} t=${Date.now() % 100000}`);
|
|
87
|
-
const sleepUntil = Date.now() + 1000;
|
|
88
|
-
while (Date.now() < sleepUntil) {}
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
// Wait for container to finish
|
|
92
|
-
await new Promise<void>((res) => contProc.once("exit", () => res()));
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
rmSync(dbDir, { recursive: true, force: true });
|
package/scripts/seed-discord.ts
DELETED
|
@@ -1,80 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Seed the v2 central DB with a Discord agent group + messaging group.
|
|
3
|
-
*
|
|
4
|
-
* Usage: pnpm exec tsx scripts/seed-discord.ts
|
|
5
|
-
*/
|
|
6
|
-
import { CENTRAL_DB_PATH } from '../src/config.js';
|
|
7
|
-
import { initDb, migrateCentralDbLocation, migrateMasterKeyLocation } from '../src/db/connection.js';
|
|
8
|
-
import { runMigrations } from '../src/db/migrations/index.js';
|
|
9
|
-
import { createAgentGroup, getAgentGroup } from '../src/db/agent-groups.js';
|
|
10
|
-
import {
|
|
11
|
-
createMessagingGroup,
|
|
12
|
-
createMessagingGroupAgent,
|
|
13
|
-
getMessagingGroup,
|
|
14
|
-
} from '../src/db/messaging-groups.js';
|
|
15
|
-
|
|
16
|
-
migrateCentralDbLocation();
|
|
17
|
-
migrateMasterKeyLocation();
|
|
18
|
-
const db = initDb(CENTRAL_DB_PATH);
|
|
19
|
-
runMigrations(db);
|
|
20
|
-
|
|
21
|
-
const AGENT_GROUP_ID = 'ag-main';
|
|
22
|
-
const MESSAGING_GROUP_ID = 'mg-discord';
|
|
23
|
-
const CHANNEL_ID = 'discord:1470188214710046894:1491569326447132673';
|
|
24
|
-
|
|
25
|
-
// Agent group
|
|
26
|
-
if (!getAgentGroup(AGENT_GROUP_ID)) {
|
|
27
|
-
createAgentGroup({
|
|
28
|
-
id: AGENT_GROUP_ID,
|
|
29
|
-
name: 'Main',
|
|
30
|
-
folder: 'main',
|
|
31
|
-
agent_provider: 'claude',
|
|
32
|
-
created_at: new Date().toISOString(),
|
|
33
|
-
});
|
|
34
|
-
console.log('Created agent group:', AGENT_GROUP_ID);
|
|
35
|
-
} else {
|
|
36
|
-
console.log('Agent group already exists:', AGENT_GROUP_ID);
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
// Messaging group
|
|
40
|
-
if (!getMessagingGroup(MESSAGING_GROUP_ID)) {
|
|
41
|
-
createMessagingGroup({
|
|
42
|
-
id: MESSAGING_GROUP_ID,
|
|
43
|
-
channel_type: 'discord',
|
|
44
|
-
platform_id: CHANNEL_ID,
|
|
45
|
-
name: 'Discord Test',
|
|
46
|
-
is_group: 1,
|
|
47
|
-
unknown_sender_policy: 'strict',
|
|
48
|
-
created_at: new Date().toISOString(),
|
|
49
|
-
});
|
|
50
|
-
console.log('Created messaging group:', MESSAGING_GROUP_ID);
|
|
51
|
-
} else {
|
|
52
|
-
console.log('Messaging group already exists:', MESSAGING_GROUP_ID);
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
// Link
|
|
56
|
-
try {
|
|
57
|
-
createMessagingGroupAgent({
|
|
58
|
-
id: 'mga-discord',
|
|
59
|
-
messaging_group_id: MESSAGING_GROUP_ID,
|
|
60
|
-
agent_group_id: AGENT_GROUP_ID,
|
|
61
|
-
// Discord group channel → mention-sticky default. Mention once, stay
|
|
62
|
-
// subscribed to the thread. Admins can tune via /manage-channels.
|
|
63
|
-
engage_mode: 'mention-sticky',
|
|
64
|
-
engage_pattern: null,
|
|
65
|
-
sender_scope: 'all',
|
|
66
|
-
ignored_message_policy: 'drop',
|
|
67
|
-
session_mode: 'shared',
|
|
68
|
-
priority: 0,
|
|
69
|
-
created_at: new Date().toISOString(),
|
|
70
|
-
});
|
|
71
|
-
console.log('Created messaging_group_agent link');
|
|
72
|
-
} catch (err: any) {
|
|
73
|
-
if (err.message?.includes('UNIQUE')) {
|
|
74
|
-
console.log('Messaging group agent link already exists');
|
|
75
|
-
} else {
|
|
76
|
-
throw err;
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
console.log('Done! Run: pnpm run build && node dist/index.js');
|
package/scripts/test-v2-agent.ts
DELETED
|
@@ -1,106 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Quick integration test: create a session DB, insert a message,
|
|
3
|
-
* run the v2 poll loop with the Claude provider, verify output.
|
|
4
|
-
*
|
|
5
|
-
* Usage: pnpm exec tsx scripts/test-v2-agent.ts
|
|
6
|
-
*/
|
|
7
|
-
import Database from 'better-sqlite3';
|
|
8
|
-
import fs from 'fs';
|
|
9
|
-
|
|
10
|
-
const TEST_DIR = '/tmp/paraclaw-v2-test';
|
|
11
|
-
const DB_PATH = `${TEST_DIR}/session.db`;
|
|
12
|
-
|
|
13
|
-
// Clean up
|
|
14
|
-
if (fs.existsSync(TEST_DIR)) fs.rmSync(TEST_DIR, { recursive: true });
|
|
15
|
-
fs.mkdirSync(TEST_DIR, { recursive: true });
|
|
16
|
-
|
|
17
|
-
// Create session DB
|
|
18
|
-
const db = new Database(DB_PATH);
|
|
19
|
-
db.pragma('journal_mode = WAL');
|
|
20
|
-
db.exec(`
|
|
21
|
-
CREATE TABLE messages_in (
|
|
22
|
-
id TEXT PRIMARY KEY, kind TEXT NOT NULL, timestamp TEXT NOT NULL,
|
|
23
|
-
status TEXT DEFAULT 'pending', status_changed TEXT, process_after TEXT,
|
|
24
|
-
recurrence TEXT, tries INTEGER DEFAULT 0, platform_id TEXT,
|
|
25
|
-
channel_type TEXT, thread_id TEXT, content TEXT NOT NULL
|
|
26
|
-
);
|
|
27
|
-
CREATE TABLE messages_out (
|
|
28
|
-
id TEXT PRIMARY KEY, in_reply_to TEXT, timestamp TEXT NOT NULL,
|
|
29
|
-
delivered INTEGER DEFAULT 0, deliver_after TEXT, recurrence TEXT,
|
|
30
|
-
kind TEXT NOT NULL, platform_id TEXT, channel_type TEXT,
|
|
31
|
-
thread_id TEXT, content TEXT NOT NULL
|
|
32
|
-
);
|
|
33
|
-
`);
|
|
34
|
-
|
|
35
|
-
// Insert test message
|
|
36
|
-
db.prepare(`INSERT INTO messages_in (id, kind, timestamp, status, content) VALUES (?, 'chat', datetime('now'), 'pending', ?)`).run(
|
|
37
|
-
'test-1',
|
|
38
|
-
JSON.stringify({ sender: 'Gavriel', text: 'Say "Hello from v2!" and nothing else. Do not use any tools.' }),
|
|
39
|
-
);
|
|
40
|
-
console.log('✓ Session DB created with test message');
|
|
41
|
-
db.close();
|
|
42
|
-
|
|
43
|
-
// Set env and run the poll loop
|
|
44
|
-
process.env.SESSION_DB_PATH = DB_PATH;
|
|
45
|
-
process.env.AGENT_PROVIDER = 'claude';
|
|
46
|
-
|
|
47
|
-
const { getSessionDb, closeSessionDb } = await import('../container/agent-runner/src/db/connection.js');
|
|
48
|
-
const { getUndeliveredMessages } = await import('../container/agent-runner/src/db/messages-out.js');
|
|
49
|
-
const { getPendingMessages } = await import('../container/agent-runner/src/db/messages-in.js');
|
|
50
|
-
const { createProvider } = await import('../container/agent-runner/src/providers/factory.js');
|
|
51
|
-
const { runPollLoop } = await import('../container/agent-runner/src/poll-loop.js');
|
|
52
|
-
|
|
53
|
-
const provider = createProvider('claude');
|
|
54
|
-
|
|
55
|
-
console.log('✓ Claude provider created');
|
|
56
|
-
console.log('⏳ Starting poll loop (will timeout after 60s)...');
|
|
57
|
-
|
|
58
|
-
// Run with timeout
|
|
59
|
-
const timeout = setTimeout(() => {
|
|
60
|
-
console.log('\n✗ Timed out after 60s');
|
|
61
|
-
printResults();
|
|
62
|
-
process.exit(1);
|
|
63
|
-
}, 60_000);
|
|
64
|
-
|
|
65
|
-
// Poll for results in parallel
|
|
66
|
-
const resultChecker = setInterval(() => {
|
|
67
|
-
try {
|
|
68
|
-
const out = getUndeliveredMessages();
|
|
69
|
-
if (out.length > 0) {
|
|
70
|
-
clearTimeout(timeout);
|
|
71
|
-
clearInterval(resultChecker);
|
|
72
|
-
console.log('\n✓ Got response!');
|
|
73
|
-
printResults();
|
|
74
|
-
process.exit(0);
|
|
75
|
-
}
|
|
76
|
-
} catch {
|
|
77
|
-
// DB might be locked, retry
|
|
78
|
-
}
|
|
79
|
-
}, 500);
|
|
80
|
-
|
|
81
|
-
function printResults() {
|
|
82
|
-
const db2 = new Database(DB_PATH, { readonly: true });
|
|
83
|
-
const inRows = db2.prepare('SELECT * FROM messages_in').all() as Array<Record<string, unknown>>;
|
|
84
|
-
const outRows = db2.prepare('SELECT * FROM messages_out').all() as Array<Record<string, unknown>>;
|
|
85
|
-
console.log('\n--- messages_in ---');
|
|
86
|
-
for (const r of inRows) {
|
|
87
|
-
console.log(` [${r.id}] status=${r.status} kind=${r.kind} content=${r.content}`);
|
|
88
|
-
}
|
|
89
|
-
console.log('\n--- messages_out ---');
|
|
90
|
-
for (const r of outRows) {
|
|
91
|
-
console.log(` [${r.id}] kind=${r.kind} content=${r.content}`);
|
|
92
|
-
}
|
|
93
|
-
db2.close();
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
// Start the poll loop (runs forever, we exit from the checker above)
|
|
97
|
-
try {
|
|
98
|
-
await runPollLoop({
|
|
99
|
-
provider,
|
|
100
|
-
cwd: TEST_DIR,
|
|
101
|
-
mcpServers: {},
|
|
102
|
-
env: { ...process.env },
|
|
103
|
-
});
|
|
104
|
-
} catch (err) {
|
|
105
|
-
// Expected — we force exit
|
|
106
|
-
}
|
|
@@ -1,265 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* End-to-end test of v2 channel adapter pipeline:
|
|
3
|
-
*
|
|
4
|
-
* Mock adapter → onInbound → router → session DB → Docker container →
|
|
5
|
-
* agent-runner → Claude → messages_out → delivery → mock adapter.deliver()
|
|
6
|
-
*
|
|
7
|
-
* Usage: pnpm exec tsx scripts/test-v2-channel-e2e.ts
|
|
8
|
-
*/
|
|
9
|
-
import Database from 'better-sqlite3';
|
|
10
|
-
import fs from 'fs';
|
|
11
|
-
import path from 'path';
|
|
12
|
-
|
|
13
|
-
const TEST_DIR = '/tmp/paraclaw-v2-channel-e2e';
|
|
14
|
-
if (fs.existsSync(TEST_DIR)) fs.rmSync(TEST_DIR, { recursive: true });
|
|
15
|
-
fs.mkdirSync(TEST_DIR, { recursive: true });
|
|
16
|
-
|
|
17
|
-
// --- Step 1: Init central DB ---
|
|
18
|
-
console.log('\n=== Step 1: Init central DB ===');
|
|
19
|
-
|
|
20
|
-
import { initDb } from '../src/db/connection.js';
|
|
21
|
-
import { runMigrations } from '../src/db/migrations/index.js';
|
|
22
|
-
import { createAgentGroup } from '../src/db/agent-groups.js';
|
|
23
|
-
import { createMessagingGroup, createMessagingGroupAgent } from '../src/db/messaging-groups.js';
|
|
24
|
-
|
|
25
|
-
const centralDb = initDb(path.join(TEST_DIR, 'v2.db'));
|
|
26
|
-
runMigrations(centralDb);
|
|
27
|
-
|
|
28
|
-
// Create groups dir for agent folder mount
|
|
29
|
-
const groupsDir = path.resolve(process.cwd(), 'groups');
|
|
30
|
-
const testGroupDir = path.join(groupsDir, 'test-channel-e2e');
|
|
31
|
-
fs.mkdirSync(testGroupDir, { recursive: true });
|
|
32
|
-
fs.writeFileSync(path.join(testGroupDir, 'CLAUDE.md'), '# Test Agent\nYou are a test agent. Be brief.\n');
|
|
33
|
-
|
|
34
|
-
createAgentGroup({
|
|
35
|
-
id: 'ag-chan',
|
|
36
|
-
name: 'Channel E2E Agent',
|
|
37
|
-
folder: 'test-channel-e2e',
|
|
38
|
-
agent_provider: 'claude',
|
|
39
|
-
created_at: new Date().toISOString(),
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
createMessagingGroup({
|
|
43
|
-
id: 'mg-chan',
|
|
44
|
-
channel_type: 'mock',
|
|
45
|
-
platform_id: 'mock-channel-1',
|
|
46
|
-
name: 'Mock Channel',
|
|
47
|
-
is_group: 0,
|
|
48
|
-
unknown_sender_policy: 'public',
|
|
49
|
-
created_at: new Date().toISOString(),
|
|
50
|
-
});
|
|
51
|
-
|
|
52
|
-
createMessagingGroupAgent({
|
|
53
|
-
id: 'mga-chan',
|
|
54
|
-
messaging_group_id: 'mg-chan',
|
|
55
|
-
agent_group_id: 'ag-chan',
|
|
56
|
-
engage_mode: 'pattern',
|
|
57
|
-
engage_pattern: '.',
|
|
58
|
-
sender_scope: 'all',
|
|
59
|
-
ignored_message_policy: 'drop',
|
|
60
|
-
session_mode: 'shared',
|
|
61
|
-
priority: 0,
|
|
62
|
-
created_at: new Date().toISOString(),
|
|
63
|
-
});
|
|
64
|
-
|
|
65
|
-
console.log('✓ Central DB initialized');
|
|
66
|
-
|
|
67
|
-
// --- Step 2: Set up mock channel adapter + delivery ---
|
|
68
|
-
console.log('\n=== Step 2: Set up mock channel adapter & delivery ===');
|
|
69
|
-
|
|
70
|
-
import { routeInbound } from '../src/router.js';
|
|
71
|
-
import { setDeliveryAdapter, startActiveDeliveryPoll, stopDeliveryPolls } from '../src/delivery.js';
|
|
72
|
-
import { getChannelAdapter, registerChannelAdapter, initChannelAdapters } from '../src/channels/channel-registry.js';
|
|
73
|
-
import { findSession } from '../src/db/sessions.js';
|
|
74
|
-
import { sessionDbPath } from '../src/session-manager.js';
|
|
75
|
-
import type { ChannelAdapter, ChannelSetup, OutboundMessage } from '../src/channels/adapter.js';
|
|
76
|
-
|
|
77
|
-
// Track delivered messages
|
|
78
|
-
const deliveredMessages: Array<{ platformId: string; threadId: string | null; message: OutboundMessage }> = [];
|
|
79
|
-
let lastDeliveryTime = 0;
|
|
80
|
-
const startTime = Date.now();
|
|
81
|
-
|
|
82
|
-
// Create mock adapter
|
|
83
|
-
const mockAdapter: ChannelAdapter = {
|
|
84
|
-
name: 'mock',
|
|
85
|
-
channelType: 'mock',
|
|
86
|
-
|
|
87
|
-
async setup(config: ChannelSetup) {
|
|
88
|
-
console.log(` ✓ Mock adapter setup with ${config.conversations.length} conversations`);
|
|
89
|
-
},
|
|
90
|
-
|
|
91
|
-
async deliver(platformId, threadId, message) {
|
|
92
|
-
deliveredMessages.push({ platformId, threadId, message });
|
|
93
|
-
lastDeliveryTime = Date.now();
|
|
94
|
-
const elapsed = Math.floor((Date.now() - startTime) / 1000);
|
|
95
|
-
const content = message.content as Record<string, unknown>;
|
|
96
|
-
const text = ((content.text as string) || '').slice(0, 120);
|
|
97
|
-
console.log(` ✓ [${elapsed}s] Delivered #${deliveredMessages.length}: ${text}...`);
|
|
98
|
-
},
|
|
99
|
-
|
|
100
|
-
async setTyping() {},
|
|
101
|
-
async teardown() {},
|
|
102
|
-
isConnected() { return true; },
|
|
103
|
-
};
|
|
104
|
-
|
|
105
|
-
// Register mock adapter
|
|
106
|
-
registerChannelAdapter('mock', { factory: () => mockAdapter });
|
|
107
|
-
|
|
108
|
-
// Init channel adapters — this calls setup() with conversation configs from central DB
|
|
109
|
-
await initChannelAdapters((adapter) => ({
|
|
110
|
-
conversations: [
|
|
111
|
-
{
|
|
112
|
-
platformId: 'mock-channel-1',
|
|
113
|
-
agentGroupId: 'ag-chan',
|
|
114
|
-
engageMode: 'pattern',
|
|
115
|
-
engagePattern: '.',
|
|
116
|
-
sessionMode: 'shared',
|
|
117
|
-
},
|
|
118
|
-
],
|
|
119
|
-
onInbound(platformId, threadId, message) {
|
|
120
|
-
routeInbound({
|
|
121
|
-
channelType: adapter.channelType,
|
|
122
|
-
platformId,
|
|
123
|
-
threadId,
|
|
124
|
-
message: {
|
|
125
|
-
id: message.id,
|
|
126
|
-
kind: message.kind,
|
|
127
|
-
content: JSON.stringify(message.content),
|
|
128
|
-
timestamp: message.timestamp,
|
|
129
|
-
},
|
|
130
|
-
}).catch((err) => console.error('Route error:', err));
|
|
131
|
-
},
|
|
132
|
-
onMetadata() {},
|
|
133
|
-
}));
|
|
134
|
-
|
|
135
|
-
// Set up delivery adapter bridge
|
|
136
|
-
setDeliveryAdapter({
|
|
137
|
-
async deliver(channelType, platformId, threadId, kind, content) {
|
|
138
|
-
const adapter = getChannelAdapter(channelType);
|
|
139
|
-
if (!adapter) return;
|
|
140
|
-
await adapter.deliver(platformId, threadId, { kind, content: JSON.parse(content) });
|
|
141
|
-
},
|
|
142
|
-
});
|
|
143
|
-
|
|
144
|
-
// Start delivery polling
|
|
145
|
-
startActiveDeliveryPoll();
|
|
146
|
-
console.log('✓ Mock adapter & delivery configured');
|
|
147
|
-
|
|
148
|
-
// --- Step 3: Simulate inbound message through adapter ---
|
|
149
|
-
console.log('\n=== Step 3: Simulate inbound message ===');
|
|
150
|
-
|
|
151
|
-
// This is what a real adapter would do when receiving a platform message
|
|
152
|
-
const adapterSetup = (mockAdapter as { _setup?: ChannelSetup })._setup;
|
|
153
|
-
|
|
154
|
-
// Call routeInbound directly (simulating onInbound callback)
|
|
155
|
-
await routeInbound({
|
|
156
|
-
channelType: 'mock',
|
|
157
|
-
platformId: 'mock-channel-1',
|
|
158
|
-
threadId: null,
|
|
159
|
-
message: {
|
|
160
|
-
id: 'msg-chan-1',
|
|
161
|
-
kind: 'chat',
|
|
162
|
-
content: JSON.stringify({
|
|
163
|
-
sender: 'Gavriel',
|
|
164
|
-
text: 'Call the send_message tool 3 times: text="Update 1", text="Update 2", text="Update 3". Make each call separately. After all 3, say "Done".',
|
|
165
|
-
}),
|
|
166
|
-
timestamp: new Date().toISOString(),
|
|
167
|
-
},
|
|
168
|
-
});
|
|
169
|
-
|
|
170
|
-
const session = findSession('mg-chan', null);
|
|
171
|
-
if (!session) {
|
|
172
|
-
console.log('✗ No session created!');
|
|
173
|
-
cleanup();
|
|
174
|
-
process.exit(1);
|
|
175
|
-
}
|
|
176
|
-
console.log(`✓ Session: ${session.id}`);
|
|
177
|
-
console.log(`✓ Container status: ${session.container_status}`);
|
|
178
|
-
|
|
179
|
-
import { execSync } from 'child_process';
|
|
180
|
-
const checkContainerLogs = () => {
|
|
181
|
-
try {
|
|
182
|
-
const containers = execSync('docker ps -a --filter name=paraclaw-v2-test-channel --format "{{.Names}}"').toString().trim();
|
|
183
|
-
for (const name of containers.split('\n').filter(Boolean)) {
|
|
184
|
-
console.log(`\nContainer logs (${name}):`);
|
|
185
|
-
console.log(execSync(`docker logs ${name} 2>&1`).toString());
|
|
186
|
-
}
|
|
187
|
-
} catch { /* ignore */ }
|
|
188
|
-
};
|
|
189
|
-
|
|
190
|
-
const sessDbPath = sessionDbPath('ag-chan', session.id);
|
|
191
|
-
console.log(`✓ Session DB: ${sessDbPath}`);
|
|
192
|
-
|
|
193
|
-
// --- Step 4: Wait for delivery through mock adapter ---
|
|
194
|
-
console.log('\n=== Step 4: Waiting for delivery through mock adapter... ===');
|
|
195
|
-
const TIMEOUT_MS = 300_000;
|
|
196
|
-
|
|
197
|
-
// Wait for deliveries — resolve when no new ones for 30s after first delivery
|
|
198
|
-
await new Promise<void>((resolve) => {
|
|
199
|
-
const poll = () => {
|
|
200
|
-
if (lastDeliveryTime > 0 && Date.now() - lastDeliveryTime > 30_000) {
|
|
201
|
-
resolve();
|
|
202
|
-
return;
|
|
203
|
-
}
|
|
204
|
-
if (Date.now() - startTime > TIMEOUT_MS) {
|
|
205
|
-
console.log(`\n✗ Timed out after ${TIMEOUT_MS / 1000}s`);
|
|
206
|
-
// Check session DB directly
|
|
207
|
-
try {
|
|
208
|
-
const db = new Database(sessDbPath, { readonly: true });
|
|
209
|
-
const out = db.prepare('SELECT * FROM messages_out').all();
|
|
210
|
-
console.log(` messages_out rows: ${out.length}`);
|
|
211
|
-
if (out.length > 0) console.log(' (messages exist but delivery failed)');
|
|
212
|
-
db.close();
|
|
213
|
-
} catch { /* ignore */ }
|
|
214
|
-
checkContainerLogs();
|
|
215
|
-
cleanup();
|
|
216
|
-
process.exit(1);
|
|
217
|
-
}
|
|
218
|
-
const elapsed = Math.floor((Date.now() - startTime) / 1000);
|
|
219
|
-
if (elapsed > 0 && elapsed % 10 === 0) {
|
|
220
|
-
process.stdout.write(` ${elapsed}s...`);
|
|
221
|
-
}
|
|
222
|
-
setTimeout(poll, 1000);
|
|
223
|
-
};
|
|
224
|
-
poll();
|
|
225
|
-
});
|
|
226
|
-
|
|
227
|
-
// --- Step 5: Print results ---
|
|
228
|
-
console.log('\n\n=== Results ===');
|
|
229
|
-
|
|
230
|
-
console.log('\nSession DB:');
|
|
231
|
-
try {
|
|
232
|
-
const db = new Database(sessDbPath, { readonly: true });
|
|
233
|
-
const inRows = db.prepare('SELECT * FROM messages_in').all() as Array<Record<string, unknown>>;
|
|
234
|
-
const outRows = db.prepare('SELECT * FROM messages_out').all() as Array<Record<string, unknown>>;
|
|
235
|
-
db.close();
|
|
236
|
-
|
|
237
|
-
console.log(` messages_in: ${inRows.length} row(s)`);
|
|
238
|
-
for (const r of inRows) {
|
|
239
|
-
console.log(` [${r.id}] status=${r.status} kind=${r.kind}`);
|
|
240
|
-
}
|
|
241
|
-
console.log(` messages_out: ${outRows.length} row(s)`);
|
|
242
|
-
for (const r of outRows) {
|
|
243
|
-
const content = JSON.parse(r.content as string);
|
|
244
|
-
console.log(` [${r.id}] kind=${r.kind} delivered=${r.delivered}`);
|
|
245
|
-
console.log(` → ${content.text}`);
|
|
246
|
-
}
|
|
247
|
-
} catch (err) {
|
|
248
|
-
console.log(` (could not read session DB: ${err})`);
|
|
249
|
-
}
|
|
250
|
-
|
|
251
|
-
console.log('\nDelivered through mock adapter:');
|
|
252
|
-
for (const d of deliveredMessages) {
|
|
253
|
-
const content = d.message.content as Record<string, unknown>;
|
|
254
|
-
console.log(` → [${d.platformId}] ${content.text}`);
|
|
255
|
-
}
|
|
256
|
-
|
|
257
|
-
console.log('\n✓ Full channel adapter pipeline verified!');
|
|
258
|
-
|
|
259
|
-
cleanup();
|
|
260
|
-
process.exit(0);
|
|
261
|
-
|
|
262
|
-
function cleanup() {
|
|
263
|
-
stopDeliveryPolls();
|
|
264
|
-
fs.rmSync(testGroupDir, { recursive: true, force: true });
|
|
265
|
-
}
|