@creativeintelligence/abbie 0.1.4 → 0.1.5
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/cli/commands/start.js +2 -1
- package/oclif.manifest.json +1 -1
- package/package.json +9 -5
- package/dist/cli/base-command.d.ts.map +0 -1
- package/dist/cli/commands/agent/list.d.ts.map +0 -1
- package/dist/cli/commands/annotation/ack.d.ts.map +0 -1
- package/dist/cli/commands/annotation/create.d.ts.map +0 -1
- package/dist/cli/commands/annotation/events.d.ts.map +0 -1
- package/dist/cli/commands/annotation/export.d.ts.map +0 -1
- package/dist/cli/commands/annotation/import.d.ts.map +0 -1
- package/dist/cli/commands/annotation/ingest.d.ts.map +0 -1
- package/dist/cli/commands/annotation/list.d.ts.map +0 -1
- package/dist/cli/commands/annotation/reply.d.ts.map +0 -1
- package/dist/cli/commands/annotation/resolve.d.ts.map +0 -1
- package/dist/cli/commands/auto/index.d.ts.map +0 -1
- package/dist/cli/commands/backlog/add.d.ts.map +0 -1
- package/dist/cli/commands/backlog/claim.d.ts.map +0 -1
- package/dist/cli/commands/backlog/complete.d.ts.map +0 -1
- package/dist/cli/commands/backlog/list.d.ts.map +0 -1
- package/dist/cli/commands/backlog/pick.d.ts.map +0 -1
- package/dist/cli/commands/backlog/sync.d.ts.map +0 -1
- package/dist/cli/commands/bootstrap.d.ts.map +0 -1
- package/dist/cli/commands/bridge.d.ts.map +0 -1
- package/dist/cli/commands/context/inject.d.ts.map +0 -1
- package/dist/cli/commands/context/list.d.ts.map +0 -1
- package/dist/cli/commands/context/publish.d.ts.map +0 -1
- package/dist/cli/commands/context/read.d.ts.map +0 -1
- package/dist/cli/commands/daemon.d.ts.map +0 -1
- package/dist/cli/commands/digest/index.d.ts.map +0 -1
- package/dist/cli/commands/docs/lint.d.ts.map +0 -1
- package/dist/cli/commands/docs/sync.d.ts.map +0 -1
- package/dist/cli/commands/doctor.d.ts.map +0 -1
- package/dist/cli/commands/find/index.d.ts.map +0 -1
- package/dist/cli/commands/gc.d.ts.map +0 -1
- package/dist/cli/commands/history/index.d.ts.map +0 -1
- package/dist/cli/commands/hooks/guard.d.ts.map +0 -1
- package/dist/cli/commands/hooks/list.d.ts.map +0 -1
- package/dist/cli/commands/hooks/lock.d.ts.map +0 -1
- package/dist/cli/commands/hooks/status.d.ts.map +0 -1
- package/dist/cli/commands/hooks/test.d.ts.map +0 -1
- package/dist/cli/commands/hooks/unlock.d.ts.map +0 -1
- package/dist/cli/commands/index.d.ts.map +0 -1
- package/dist/cli/commands/list.d.ts.map +0 -1
- package/dist/cli/commands/list.e2e.test.d.ts +0 -1
- package/dist/cli/commands/list.e2e.test.js +0 -47
- package/dist/cli/commands/login.d.ts.map +0 -1
- package/dist/cli/commands/logout.d.ts.map +0 -1
- package/dist/cli/commands/panes/broker.d.ts.map +0 -1
- package/dist/cli/commands/panes/pipe-sink.d.ts.map +0 -1
- package/dist/cli/commands/panes/snapshot.d.ts.map +0 -1
- package/dist/cli/commands/plan.d.ts.map +0 -1
- package/dist/cli/commands/plan.e2e.test.d.ts +0 -1
- package/dist/cli/commands/plan.e2e.test.js +0 -74
- package/dist/cli/commands/preview/index.d.ts.map +0 -1
- package/dist/cli/commands/preview/init.d.ts.map +0 -1
- package/dist/cli/commands/preview/list.d.ts.map +0 -1
- package/dist/cli/commands/preview/status.d.ts.map +0 -1
- package/dist/cli/commands/preview/stop.d.ts.map +0 -1
- package/dist/cli/commands/preview/sync.d.ts.map +0 -1
- package/dist/cli/commands/preview/watch.d.ts.map +0 -1
- package/dist/cli/commands/project/add.d.ts.map +0 -1
- package/dist/cli/commands/project/list.d.ts.map +0 -1
- package/dist/cli/commands/project/remove.d.ts.map +0 -1
- package/dist/cli/commands/push.d.ts.map +0 -1
- package/dist/cli/commands/reference/add.d.ts.map +0 -1
- package/dist/cli/commands/reference/delete.d.ts.map +0 -1
- package/dist/cli/commands/reference/extract.d.ts.map +0 -1
- package/dist/cli/commands/reference/list.d.ts.map +0 -1
- package/dist/cli/commands/reference/normalize.d.ts.map +0 -1
- package/dist/cli/commands/reference/open.d.ts.map +0 -1
- package/dist/cli/commands/reference/save.d.ts.map +0 -1
- package/dist/cli/commands/reference/search.d.ts.map +0 -1
- package/dist/cli/commands/reference/show.d.ts.map +0 -1
- package/dist/cli/commands/reference/update-index.d.ts.map +0 -1
- package/dist/cli/commands/reference/update.d.ts.map +0 -1
- package/dist/cli/commands/report/blocked.d.ts.map +0 -1
- package/dist/cli/commands/report/complete.d.ts.map +0 -1
- package/dist/cli/commands/report/progress.d.ts.map +0 -1
- package/dist/cli/commands/report/start.d.ts.map +0 -1
- package/dist/cli/commands/resource/acquire.d.ts.map +0 -1
- package/dist/cli/commands/resource/list.d.ts.map +0 -1
- package/dist/cli/commands/resource/release.d.ts.map +0 -1
- package/dist/cli/commands/resource/wait.d.ts.map +0 -1
- package/dist/cli/commands/review.d.ts.map +0 -1
- package/dist/cli/commands/session/attach.d.ts.map +0 -1
- package/dist/cli/commands/session/await.d.ts.map +0 -1
- package/dist/cli/commands/session/complete.d.ts.map +0 -1
- package/dist/cli/commands/session/create.d.ts.map +0 -1
- package/dist/cli/commands/session/heartbeat.d.ts.map +0 -1
- package/dist/cli/commands/session/list.d.ts.map +0 -1
- package/dist/cli/commands/session/mark-done.d.ts.map +0 -1
- package/dist/cli/commands/session/mine.d.ts.map +0 -1
- package/dist/cli/commands/session/replay.d.ts.map +0 -1
- package/dist/cli/commands/session/run.d.ts.map +0 -1
- package/dist/cli/commands/session/show.d.ts.map +0 -1
- package/dist/cli/commands/session/start.d.ts.map +0 -1
- package/dist/cli/commands/session/state/cleanup.d.ts.map +0 -1
- package/dist/cli/commands/session/state/end.d.ts.map +0 -1
- package/dist/cli/commands/session/state/get.d.ts.map +0 -1
- package/dist/cli/commands/session/state/init.d.ts.map +0 -1
- package/dist/cli/commands/session/state/list.d.ts.map +0 -1
- package/dist/cli/commands/session/state/update.d.ts.map +0 -1
- package/dist/cli/commands/session/stop.d.ts.map +0 -1
- package/dist/cli/commands/session/view.d.ts.map +0 -1
- package/dist/cli/commands/start.d.ts.map +0 -1
- package/dist/cli/commands/state/dump.d.ts.map +0 -1
- package/dist/cli/commands/status.d.ts.map +0 -1
- package/dist/cli/commands/sync.d.ts.map +0 -1
- package/dist/cli/commands/trace/export.d.ts.map +0 -1
- package/dist/cli/commands/triage/claim.d.ts.map +0 -1
- package/dist/cli/commands/triage/list.d.ts.map +0 -1
- package/dist/cli/commands/triage/next.d.ts.map +0 -1
- package/dist/cli/commands/triage/pull.d.ts.map +0 -1
- package/dist/cli/commands/triage/stats.d.ts.map +0 -1
- package/dist/cli/commands/tunnel/list.d.ts.map +0 -1
- package/dist/cli/commands/tunnel/start.d.ts.map +0 -1
- package/dist/cli/commands/tunnel/stop.d.ts.map +0 -1
- package/dist/cli/commands/tunnel/url.d.ts.map +0 -1
- package/dist/cli/commands/web/start.d.ts.map +0 -1
- package/dist/cli/commands/windows/context.d.ts.map +0 -1
- package/dist/cli/commands/windows/focus.d.ts.map +0 -1
- package/dist/cli/commands/windows/list.d.ts.map +0 -1
- package/dist/cli/commands/windows/map.d.ts.map +0 -1
- package/dist/cli/commands/windows/read.d.ts.map +0 -1
- package/dist/cli/commands/windows/search.d.ts.map +0 -1
- package/dist/cli/commands/windows/show.d.ts.map +0 -1
- package/dist/cli/commands/windows/watch.d.ts.map +0 -1
- package/dist/lib/active-sessions.d.ts.map +0 -1
- package/dist/lib/agent-adapters.d.ts.map +0 -1
- package/dist/lib/agent-sessions.d.ts.map +0 -1
- package/dist/lib/agent-trace.d.ts.map +0 -1
- package/dist/lib/analytics.d.ts.map +0 -1
- package/dist/lib/annotations-convex.d.ts.map +0 -1
- package/dist/lib/annotations.d.ts.map +0 -1
- package/dist/lib/auto/discover.d.ts.map +0 -1
- package/dist/lib/auto/ideate.d.ts.map +0 -1
- package/dist/lib/auto/spawn.d.ts.map +0 -1
- package/dist/lib/auto/workspace.d.ts.map +0 -1
- package/dist/lib/backlog.d.ts.map +0 -1
- package/dist/lib/backlog.test.d.ts +0 -1
- package/dist/lib/backlog.test.js +0 -162
- package/dist/lib/config-loader.d.ts.map +0 -1
- package/dist/lib/config-sync/adapters/claude.d.ts.map +0 -1
- package/dist/lib/config-sync/adapters/codex.d.ts.map +0 -1
- package/dist/lib/config-sync/adapters/copilot.d.ts.map +0 -1
- package/dist/lib/config-sync/adapters/gemini.d.ts.map +0 -1
- package/dist/lib/config-sync/adapters/index.d.ts.map +0 -1
- package/dist/lib/config-sync/adapters/opencode.d.ts.map +0 -1
- package/dist/lib/config-sync/index.d.ts.map +0 -1
- package/dist/lib/config-sync/types.d.ts.map +0 -1
- package/dist/lib/config-sync/writer.d.ts.map +0 -1
- package/dist/lib/content-sync/index.d.ts.map +0 -1
- package/dist/lib/content-sync/types.d.ts.map +0 -1
- package/dist/lib/contracts.d.ts.map +0 -1
- package/dist/lib/convex.d.ts.map +0 -1
- package/dist/lib/device.d.ts.map +0 -1
- package/dist/lib/digest/index.d.ts.map +0 -1
- package/dist/lib/docs/lint.d.ts.map +0 -1
- package/dist/lib/docs/lint.test.d.ts +0 -1
- package/dist/lib/docs/lint.test.js +0 -120
- package/dist/lib/docs/sync.d.ts.map +0 -1
- package/dist/lib/doctor/index.d.ts.map +0 -1
- package/dist/lib/doctor/repos.d.ts.map +0 -1
- package/dist/lib/doctor/templates.d.ts.map +0 -1
- package/dist/lib/errors.d.ts.map +0 -1
- package/dist/lib/events.d.ts.map +0 -1
- package/dist/lib/heartbeat.d.ts.map +0 -1
- package/dist/lib/heartbeat.test.d.ts +0 -1
- package/dist/lib/heartbeat.test.js +0 -124
- package/dist/lib/hooks/adapters/claude.d.ts.map +0 -1
- package/dist/lib/hooks/adapters/codex.d.ts.map +0 -1
- package/dist/lib/hooks/adapters/copilot.d.ts.map +0 -1
- package/dist/lib/hooks/context.d.ts.map +0 -1
- package/dist/lib/hooks/index.d.ts.map +0 -1
- package/dist/lib/hooks/registry.d.ts.map +0 -1
- package/dist/lib/hooks/runner.d.ts.map +0 -1
- package/dist/lib/hooks/types.d.ts.map +0 -1
- package/dist/lib/index.test.d.ts +0 -1
- package/dist/lib/index.test.js +0 -334
- package/dist/lib/managed-session.d.ts.map +0 -1
- package/dist/lib/math.d.ts.map +0 -1
- package/dist/lib/math.test.d.ts +0 -1
- package/dist/lib/math.test.js +0 -238
- package/dist/lib/ngrok.d.ts.map +0 -1
- package/dist/lib/nvim/discovery.d.ts.map +0 -1
- package/dist/lib/nvim/discovery.test.d.ts +0 -1
- package/dist/lib/nvim/discovery.test.js +0 -131
- package/dist/lib/nvim/index.d.ts.map +0 -1
- package/dist/lib/nvim/remote.d.ts.map +0 -1
- package/dist/lib/nvim/remote.test.d.ts +0 -1
- package/dist/lib/nvim/remote.test.js +0 -18
- package/dist/lib/panes/broker.d.ts.map +0 -1
- package/dist/lib/panes/index.d.ts.map +0 -1
- package/dist/lib/panes/server.d.ts.map +0 -1
- package/dist/lib/preview/detect.d.ts.map +0 -1
- package/dist/lib/preview/index.d.ts.map +0 -1
- package/dist/lib/preview/manager.d.ts.map +0 -1
- package/dist/lib/preview/schema.d.ts.map +0 -1
- package/dist/lib/preview/sprite.d.ts.map +0 -1
- package/dist/lib/preview/watcher.d.ts.map +0 -1
- package/dist/lib/process/index.d.ts.map +0 -1
- package/dist/lib/process/snapshot.d.ts.map +0 -1
- package/dist/lib/process/snapshot.test.d.ts +0 -1
- package/dist/lib/process/snapshot.test.js +0 -127
- package/dist/lib/project-identity.d.ts.map +0 -1
- package/dist/lib/provider-auth.d.ts.map +0 -1
- package/dist/lib/references.d.ts.map +0 -1
- package/dist/lib/report.d.ts.map +0 -1
- package/dist/lib/resources.d.ts.map +0 -1
- package/dist/lib/resources.test.d.ts +0 -1
- package/dist/lib/resources.test.js +0 -94
- package/dist/lib/runner.d.ts.map +0 -1
- package/dist/lib/runner.test.d.ts +0 -1
- package/dist/lib/runner.test.js +0 -234
- package/dist/lib/session-artifacts.d.ts.map +0 -1
- package/dist/lib/session-manager.d.ts.map +0 -1
- package/dist/lib/session-manager.test.d.ts +0 -1
- package/dist/lib/session-manager.test.js +0 -310
- package/dist/lib/session-result.d.ts.map +0 -1
- package/dist/lib/session-state.d.ts.map +0 -1
- package/dist/lib/slack-workspace.d.ts.map +0 -1
- package/dist/lib/tmux/bridge.d.ts.map +0 -1
- package/dist/lib/tmux/context.d.ts.map +0 -1
- package/dist/lib/tmux/context.test.d.ts +0 -1
- package/dist/lib/tmux/context.test.js +0 -215
- package/dist/lib/tmux/index.d.ts.map +0 -1
- package/dist/lib/tmux/map.d.ts.map +0 -1
- package/dist/lib/tmux/map.test.d.ts +0 -1
- package/dist/lib/tmux/map.test.js +0 -80
- package/dist/lib/tmux/panes.d.ts.map +0 -1
- package/dist/lib/tmux/redaction.d.ts.map +0 -1
- package/dist/lib/tmux/redaction.test.d.ts +0 -1
- package/dist/lib/tmux/redaction.test.js +0 -183
- package/dist/lib/triage-llm.d.ts.map +0 -1
- package/dist/lib/triage-tracker.d.ts.map +0 -1
- package/dist/lib/triage.d.ts.map +0 -1
- package/dist/lib/types.d.ts.map +0 -1
- package/dist/lib/windows/index.d.ts.map +0 -1
- package/dist/lib/windows/inventory.d.ts.map +0 -1
- package/dist/lib/windows/inventory.test.d.ts +0 -1
- package/dist/lib/windows/inventory.test.js +0 -292
- package/dist/lib/windows/types.d.ts.map +0 -1
- package/dist/lib.d.ts.map +0 -1
- package/dist/web/app/@overlay/default.d.ts +0 -1
- package/dist/web/app/@overlay/default.js +0 -3
- package/dist/web/app/about/page.d.ts +0 -1
- package/dist/web/app/about/page.js +0 -6
- package/dist/web/app/layout.d.ts +0 -7
- package/dist/web/app/layout.js +0 -19
- package/dist/web/app/page.d.ts +0 -1
- package/dist/web/app/page.js +0 -38
- package/dist/web/app/settings/page.d.ts +0 -1
- package/dist/web/app/settings/page.js +0 -6
- package/dist/web/app/shortcuts/page.d.ts +0 -1
- package/dist/web/app/shortcuts/page.js +0 -6
- package/dist/web/atoms/sidebar.d.ts +0 -16
- package/dist/web/atoms/sidebar.js +0 -58
- package/dist/web/atoms/state.d.ts +0 -24
- package/dist/web/atoms/state.js +0 -43
- package/dist/web/components/command-palette.d.ts +0 -6
- package/dist/web/components/command-palette.js +0 -297
- package/dist/web/components/main-view.d.ts +0 -1
- package/dist/web/components/main-view.js +0 -93
- package/dist/web/components/overlay/page-overlay.d.ts +0 -16
- package/dist/web/components/overlay/page-overlay.js +0 -84
- package/dist/web/components/pane-view.d.ts +0 -5
- package/dist/web/components/pane-view.js +0 -168
- package/dist/web/components/project-files-view.d.ts +0 -6
- package/dist/web/components/project-files-view.js +0 -205
- package/dist/web/components/project-planning-view.d.ts +0 -6
- package/dist/web/components/project-planning-view.js +0 -146
- package/dist/web/components/session-view.d.ts +0 -6
- package/dist/web/components/session-view.js +0 -211
- package/dist/web/components/sessions-list-view.d.ts +0 -1
- package/dist/web/components/sessions-list-view.js +0 -118
- package/dist/web/components/sidebar/index.d.ts +0 -9
- package/dist/web/components/sidebar/index.js +0 -29
- package/dist/web/components/sidebar/kbd.d.ts +0 -17
- package/dist/web/components/sidebar/kbd.js +0 -47
- package/dist/web/components/sidebar/nav-group.d.ts +0 -22
- package/dist/web/components/sidebar/nav-group.js +0 -43
- package/dist/web/components/sidebar/nav-item.d.ts +0 -17
- package/dist/web/components/sidebar/nav-item.js +0 -38
- package/dist/web/components/sidebar/sidebar-header.d.ts +0 -9
- package/dist/web/components/sidebar/sidebar-header.js +0 -18
- package/dist/web/components/sidebar/sidebar-nav.d.ts +0 -7
- package/dist/web/components/sidebar/sidebar-nav.js +0 -505
- package/dist/web/components/sidebar/sidebar-search.d.ts +0 -7
- package/dist/web/components/sidebar/sidebar-search.js +0 -18
- package/dist/web/components/sidebar/sidebar-settings.d.ts +0 -4
- package/dist/web/components/sidebar/sidebar-settings.js +0 -28
- package/dist/web/components/sidebar/sidebar-transition.d.ts +0 -12
- package/dist/web/components/sidebar/sidebar-transition.js +0 -58
- package/dist/web/components/status-bar.d.ts +0 -1
- package/dist/web/components/status-bar.js +0 -53
- package/dist/web/components/terminal.d.ts +0 -4
- package/dist/web/components/terminal.js +0 -324
- package/dist/web/components/toast.d.ts +0 -7
- package/dist/web/components/toast.js +0 -72
- package/dist/web/hooks/use-keybindings.d.ts +0 -30
- package/dist/web/hooks/use-keybindings.js +0 -322
- package/dist/web/hooks/use-state.d.ts +0 -11
- package/dist/web/hooks/use-state.js +0 -84
- package/dist/web/lib/api.d.ts +0 -179
- package/dist/web/lib/api.js +0 -79
- package/dist/web/lib/paths.d.ts +0 -2
- package/dist/web/lib/paths.js +0 -26
- package/dist/web/lib/utils.d.ts +0 -2
- package/dist/web/lib/utils.js +0 -5
- package/dist/web/lib/ws.d.ts +0 -18
- package/dist/web/lib/ws.js +0 -138
- package/dist/web/next.config.d.ts +0 -3
- package/dist/web/next.config.js +0 -9
- package/scripts/generate-manifest.ts +0 -44
- package/src/cli/base-command.ts +0 -233
- package/src/cli/commands/__tests__/annotations.test.ts +0 -704
- package/src/cli/commands/__tests__/bridge.test.ts +0 -101
- package/src/cli/commands/__tests__/daemon.test.ts +0 -79
- package/src/cli/commands/agent/list.ts +0 -75
- package/src/cli/commands/annotation/ack.ts +0 -37
- package/src/cli/commands/annotation/create.ts +0 -67
- package/src/cli/commands/annotation/events.ts +0 -63
- package/src/cli/commands/annotation/export.ts +0 -67
- package/src/cli/commands/annotation/import.ts +0 -98
- package/src/cli/commands/annotation/ingest.ts +0 -112
- package/src/cli/commands/annotation/list.ts +0 -57
- package/src/cli/commands/annotation/reply.ts +0 -46
- package/src/cli/commands/annotation/resolve.ts +0 -37
- package/src/cli/commands/auto/index.ts +0 -755
- package/src/cli/commands/backlog/add.ts +0 -74
- package/src/cli/commands/backlog/claim.ts +0 -53
- package/src/cli/commands/backlog/complete.ts +0 -51
- package/src/cli/commands/backlog/list.ts +0 -107
- package/src/cli/commands/backlog/pick.ts +0 -50
- package/src/cli/commands/backlog/sync.ts +0 -131
- package/src/cli/commands/bootstrap.ts +0 -205
- package/src/cli/commands/bridge.ts +0 -233
- package/src/cli/commands/context/inject.ts +0 -103
- package/src/cli/commands/context/list.ts +0 -112
- package/src/cli/commands/context/publish.ts +0 -83
- package/src/cli/commands/context/read.ts +0 -85
- package/src/cli/commands/daemon.ts +0 -1809
- package/src/cli/commands/digest/index.ts +0 -245
- package/src/cli/commands/docs/lint.ts +0 -93
- package/src/cli/commands/docs/sync.ts +0 -90
- package/src/cli/commands/doctor.ts +0 -267
- package/src/cli/commands/find/index.ts +0 -313
- package/src/cli/commands/history/index.ts +0 -269
- package/src/cli/commands/hooks/guard.ts +0 -71
- package/src/cli/commands/hooks/list.ts +0 -139
- package/src/cli/commands/hooks/lock.ts +0 -47
- package/src/cli/commands/hooks/status.ts +0 -56
- package/src/cli/commands/hooks/test.ts +0 -190
- package/src/cli/commands/hooks/unlock.ts +0 -56
- package/src/cli/commands/list.e2e.test.ts +0 -58
- package/src/cli/commands/list.ts +0 -96
- package/src/cli/commands/login.ts +0 -236
- package/src/cli/commands/logout.ts +0 -45
- package/src/cli/commands/panes/broker.ts +0 -68
- package/src/cli/commands/panes/pipe-sink.ts +0 -101
- package/src/cli/commands/panes/snapshot.ts +0 -156
- package/src/cli/commands/plan.e2e.test.ts +0 -90
- package/src/cli/commands/plan.ts +0 -68
- package/src/cli/commands/preview/index.ts +0 -282
- package/src/cli/commands/preview/list.ts +0 -116
- package/src/cli/commands/preview/status.ts +0 -137
- package/src/cli/commands/preview/stop.ts +0 -165
- package/src/cli/commands/project/add.ts +0 -110
- package/src/cli/commands/project/list.ts +0 -136
- package/src/cli/commands/project/remove.ts +0 -60
- package/src/cli/commands/push.ts +0 -115
- package/src/cli/commands/reference/add.ts +0 -266
- package/src/cli/commands/reference/delete.ts +0 -67
- package/src/cli/commands/reference/extract.ts +0 -389
- package/src/cli/commands/reference/list.ts +0 -117
- package/src/cli/commands/reference/normalize.ts +0 -90
- package/src/cli/commands/reference/open.ts +0 -92
- package/src/cli/commands/reference/save.ts +0 -103
- package/src/cli/commands/reference/search.ts +0 -85
- package/src/cli/commands/reference/show.ts +0 -174
- package/src/cli/commands/reference/update-index.ts +0 -103
- package/src/cli/commands/reference/update.ts +0 -136
- package/src/cli/commands/report/blocked.ts +0 -165
- package/src/cli/commands/report/complete.ts +0 -179
- package/src/cli/commands/report/progress.ts +0 -142
- package/src/cli/commands/report/start.ts +0 -140
- package/src/cli/commands/resource/acquire.ts +0 -116
- package/src/cli/commands/resource/list.ts +0 -77
- package/src/cli/commands/resource/release.ts +0 -64
- package/src/cli/commands/resource/wait.ts +0 -93
- package/src/cli/commands/review.ts +0 -105
- package/src/cli/commands/session/attach.ts +0 -200
- package/src/cli/commands/session/await.ts +0 -83
- package/src/cli/commands/session/complete.ts +0 -100
- package/src/cli/commands/session/create.ts +0 -92
- package/src/cli/commands/session/heartbeat.ts +0 -63
- package/src/cli/commands/session/list.ts +0 -281
- package/src/cli/commands/session/mark-done.ts +0 -132
- package/src/cli/commands/session/mine.ts +0 -189
- package/src/cli/commands/session/replay.ts +0 -659
- package/src/cli/commands/session/run.ts +0 -44
- package/src/cli/commands/session/show.ts +0 -177
- package/src/cli/commands/session/start.ts +0 -580
- package/src/cli/commands/session/state/cleanup.ts +0 -61
- package/src/cli/commands/session/state/end.ts +0 -47
- package/src/cli/commands/session/state/get.ts +0 -65
- package/src/cli/commands/session/state/init.ts +0 -50
- package/src/cli/commands/session/state/list.ts +0 -68
- package/src/cli/commands/session/state/update.ts +0 -108
- package/src/cli/commands/session/stop.ts +0 -134
- package/src/cli/commands/session/view.ts +0 -186
- package/src/cli/commands/start.ts +0 -256
- package/src/cli/commands/state/dump.ts +0 -449
- package/src/cli/commands/status.ts +0 -244
- package/src/cli/commands/sync.ts +0 -174
- package/src/cli/commands/trace/export.ts +0 -255
- package/src/cli/commands/triage/claim.ts +0 -203
- package/src/cli/commands/triage/list.ts +0 -137
- package/src/cli/commands/triage/next.ts +0 -73
- package/src/cli/commands/triage/pull.ts +0 -97
- package/src/cli/commands/triage/stats.ts +0 -82
- package/src/cli/commands/tunnel/list.ts +0 -113
- package/src/cli/commands/tunnel/start.ts +0 -122
- package/src/cli/commands/tunnel/stop.ts +0 -108
- package/src/cli/commands/tunnel/url.ts +0 -82
- package/src/cli/commands/web/start.ts +0 -125
- package/src/cli/commands/windows/context.ts +0 -439
- package/src/cli/commands/windows/focus.ts +0 -130
- package/src/cli/commands/windows/list.ts +0 -213
- package/src/cli/commands/windows/map.ts +0 -223
- package/src/cli/commands/windows/read.ts +0 -279
- package/src/cli/commands/windows/search.ts +0 -219
- package/src/cli/commands/windows/show.ts +0 -188
- package/src/cli/commands/windows/watch.ts +0 -262
- package/src/lib/__tests__/annotations-convex.test.ts +0 -104
- package/src/lib/active-sessions.ts +0 -1486
- package/src/lib/agent-adapters.ts +0 -412
- package/src/lib/agent-sessions.ts +0 -671
- package/src/lib/agent-trace.test.ts +0 -296
- package/src/lib/agent-trace.ts +0 -513
- package/src/lib/analytics.ts +0 -178
- package/src/lib/annotations-convex.ts +0 -296
- package/src/lib/annotations.test.ts +0 -274
- package/src/lib/annotations.ts +0 -836
- package/src/lib/auto/discover.ts +0 -545
- package/src/lib/auto/ideate.ts +0 -412
- package/src/lib/auto/spawn.ts +0 -549
- package/src/lib/auto/workspace.ts +0 -282
- package/src/lib/backlog.test.ts +0 -194
- package/src/lib/backlog.ts +0 -428
- package/src/lib/config-loader.ts +0 -391
- package/src/lib/config-sync/adapters/claude.ts +0 -91
- package/src/lib/config-sync/adapters/codex.ts +0 -135
- package/src/lib/config-sync/adapters/copilot.ts +0 -98
- package/src/lib/config-sync/adapters/gemini.ts +0 -86
- package/src/lib/config-sync/adapters/index.ts +0 -39
- package/src/lib/config-sync/adapters/opencode.ts +0 -94
- package/src/lib/config-sync/index.ts +0 -399
- package/src/lib/config-sync/types.ts +0 -92
- package/src/lib/config-sync/writer.ts +0 -188
- package/src/lib/content-sync/index.ts +0 -882
- package/src/lib/content-sync/types.ts +0 -104
- package/src/lib/contracts.test.ts +0 -186
- package/src/lib/contracts.ts +0 -195
- package/src/lib/convex.ts +0 -54
- package/src/lib/device.ts +0 -41
- package/src/lib/digest/index.ts +0 -529
- package/src/lib/docs/lint.test.ts +0 -135
- package/src/lib/docs/lint.ts +0 -310
- package/src/lib/docs/sync.ts +0 -184
- package/src/lib/doctor/index.ts +0 -647
- package/src/lib/doctor/repos.ts +0 -381
- package/src/lib/doctor/templates.ts +0 -191
- package/src/lib/errors.ts +0 -111
- package/src/lib/events.ts +0 -479
- package/src/lib/heartbeat.test.ts +0 -164
- package/src/lib/heartbeat.ts +0 -326
- package/src/lib/hooks/adapters/claude.ts +0 -115
- package/src/lib/hooks/adapters/codex.ts +0 -92
- package/src/lib/hooks/adapters/copilot.ts +0 -141
- package/src/lib/hooks/context.ts +0 -174
- package/src/lib/hooks/index.ts +0 -39
- package/src/lib/hooks/registry.ts +0 -101
- package/src/lib/hooks/runner.ts +0 -208
- package/src/lib/hooks/types.ts +0 -89
- package/src/lib/index.test.ts +0 -426
- package/src/lib/managed-session.ts +0 -117
- package/src/lib/math.test.ts +0 -299
- package/src/lib/math.ts +0 -120
- package/src/lib/ngrok.ts +0 -441
- package/src/lib/nvim/discovery.test.ts +0 -157
- package/src/lib/nvim/discovery.ts +0 -181
- package/src/lib/nvim/index.ts +0 -28
- package/src/lib/nvim/remote.test.ts +0 -21
- package/src/lib/nvim/remote.ts +0 -184
- package/src/lib/panes/README.md +0 -20
- package/src/lib/panes/broker.ts +0 -261
- package/src/lib/panes/index.ts +0 -1
- package/src/lib/panes/server.ts +0 -379
- package/src/lib/preview/detect.ts +0 -184
- package/src/lib/preview/index.ts +0 -1
- package/src/lib/process/index.ts +0 -16
- package/src/lib/process/snapshot.test.ts +0 -188
- package/src/lib/process/snapshot.ts +0 -257
- package/src/lib/provider-auth.ts +0 -258
- package/src/lib/references.ts +0 -481
- package/src/lib/report.ts +0 -973
- package/src/lib/resources.test.ts +0 -132
- package/src/lib/resources.ts +0 -429
- package/src/lib/runner.test.ts +0 -288
- package/src/lib/runner.ts +0 -1223
- package/src/lib/session-artifacts.test.ts +0 -107
- package/src/lib/session-artifacts.ts +0 -193
- package/src/lib/session-manager.test.ts +0 -402
- package/src/lib/session-manager.ts +0 -150
- package/src/lib/session-result.test.ts +0 -98
- package/src/lib/session-result.ts +0 -262
- package/src/lib/session-state.ts +0 -470
- package/src/lib/slack-workspace.ts +0 -25
- package/src/lib/tmux/bridge.ts +0 -439
- package/src/lib/tmux/context.test.ts +0 -242
- package/src/lib/tmux/context.ts +0 -380
- package/src/lib/tmux/index.ts +0 -46
- package/src/lib/tmux/map.test.ts +0 -99
- package/src/lib/tmux/map.ts +0 -252
- package/src/lib/tmux/panes.ts +0 -170
- package/src/lib/tmux/redaction.test.ts +0 -231
- package/src/lib/tmux/redaction.ts +0 -201
- package/src/lib/triage-llm.ts +0 -312
- package/src/lib/triage-tracker.ts +0 -400
- package/src/lib/triage.ts +0 -655
- package/src/lib/types.ts +0 -61
- package/src/lib/windows/index.ts +0 -2
- package/src/lib/windows/inventory.test.ts +0 -370
- package/src/lib/windows/inventory.ts +0 -352
- package/src/lib/windows/types.ts +0 -46
- package/src/lib.ts +0 -260
|
@@ -1,236 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* abbie login — authenticate this device via browser-based pairing.
|
|
3
|
-
*
|
|
4
|
-
* Flow:
|
|
5
|
-
* 1. Generate device ID (stable UUID for this machine)
|
|
6
|
-
* 2. Create auth code in Convex (8-char, 10min TTL)
|
|
7
|
-
* 3. Open browser to web app auth page
|
|
8
|
-
* 4. Poll until browser confirms (user clicks "authorize")
|
|
9
|
-
* 5. Save clerkId to ~/.abbie/config.json
|
|
10
|
-
* 6. Optionally trigger initial sync
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
import { Flags } from "@oclif/core";
|
|
14
|
-
import { getDeviceInfo, getStoredClerkId, saveClerkId, getWebUrl } from "@creativeintelligence/sdk/config";
|
|
15
|
-
import { api, getHttpClient, isConvexConfigured } from "@creativeintelligence/sdk/convex";
|
|
16
|
-
import { BaseCommand } from "../base-command.js";
|
|
17
|
-
|
|
18
|
-
const POLL_INTERVAL_MS = 1_500;
|
|
19
|
-
const MAX_POLL_DURATION_MS = 10 * 60 * 1_000; // 10 minutes (matches code TTL)
|
|
20
|
-
|
|
21
|
-
type LoginResult = {
|
|
22
|
-
status: "authenticated" | "already-authenticated" | "expired" | "error";
|
|
23
|
-
clerkId?: string;
|
|
24
|
-
deviceId?: string;
|
|
25
|
-
error?: string;
|
|
26
|
-
};
|
|
27
|
-
|
|
28
|
-
export default class LoginCommand extends BaseCommand {
|
|
29
|
-
static override summary = "Authenticate this device with abbie";
|
|
30
|
-
|
|
31
|
-
static override description = `Pairs this device with your abbie account via browser login.
|
|
32
|
-
|
|
33
|
-
Opens your browser to authorize this CLI. After you confirm in the browser,
|
|
34
|
-
the CLI saves your credentials locally and is ready to sync.
|
|
35
|
-
|
|
36
|
-
If already authenticated, shows current status. Use --force to re-authenticate.`;
|
|
37
|
-
|
|
38
|
-
static override examples = [
|
|
39
|
-
"$ abbie login",
|
|
40
|
-
"$ abbie login --force",
|
|
41
|
-
"$ abbie login --no-open",
|
|
42
|
-
"$ abbie login --json --quiet",
|
|
43
|
-
];
|
|
44
|
-
|
|
45
|
-
static override flags = {
|
|
46
|
-
...BaseCommand.baseFlags,
|
|
47
|
-
force: Flags.boolean({
|
|
48
|
-
char: "f",
|
|
49
|
-
description: "Re-authenticate even if already logged in",
|
|
50
|
-
default: false,
|
|
51
|
-
}),
|
|
52
|
-
open: Flags.boolean({
|
|
53
|
-
description: "Open browser automatically",
|
|
54
|
-
default: true,
|
|
55
|
-
allowNo: true,
|
|
56
|
-
}),
|
|
57
|
-
sync: Flags.boolean({
|
|
58
|
-
description: "Run initial sync after login",
|
|
59
|
-
default: true,
|
|
60
|
-
allowNo: true,
|
|
61
|
-
}),
|
|
62
|
-
};
|
|
63
|
-
|
|
64
|
-
async execute(): Promise<LoginResult> {
|
|
65
|
-
const { flags } = await this.parse(LoginCommand);
|
|
66
|
-
this.parsedFlags = flags;
|
|
67
|
-
|
|
68
|
-
// Check if Convex is reachable
|
|
69
|
-
if (!isConvexConfigured()) {
|
|
70
|
-
this.logWarn("Convex not configured. Set CONVEX_URL env var or convexUrl in ~/.abbie/config.json");
|
|
71
|
-
return { status: "error", error: "convex-not-configured" };
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
// Check existing auth
|
|
75
|
-
const existingClerkId = getStoredClerkId();
|
|
76
|
-
if (existingClerkId && !flags.force) {
|
|
77
|
-
this.logInfo(`already authenticated (${existingClerkId.slice(0, 12)}...)`);
|
|
78
|
-
return {
|
|
79
|
-
status: "already-authenticated",
|
|
80
|
-
clerkId: existingClerkId,
|
|
81
|
-
deviceId: getDeviceInfo().deviceId,
|
|
82
|
-
};
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
const client = getHttpClient();
|
|
86
|
-
const device = getDeviceInfo();
|
|
87
|
-
|
|
88
|
-
// Step 1: Create auth code
|
|
89
|
-
this.logInfo("creating auth code...");
|
|
90
|
-
|
|
91
|
-
let code: string;
|
|
92
|
-
let expiresAt: number;
|
|
93
|
-
try {
|
|
94
|
-
const result = await client.mutation(api.functions.auth.tokens.createAuthCode, {
|
|
95
|
-
deviceId: device.deviceId,
|
|
96
|
-
});
|
|
97
|
-
code = result.code;
|
|
98
|
-
expiresAt = result.expiresAt;
|
|
99
|
-
} catch (err) {
|
|
100
|
-
const message = err instanceof Error ? err.message : String(err);
|
|
101
|
-
this.logWarn(`failed to create auth code: ${message}`);
|
|
102
|
-
return { status: "error", error: message };
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
// Step 2: Open browser
|
|
106
|
-
const webUrl = getWebUrl();
|
|
107
|
-
const authUrl = `${webUrl}/auth/cli?code=${code}`;
|
|
108
|
-
|
|
109
|
-
this.log("");
|
|
110
|
-
this.log(" open this URL to authorize:");
|
|
111
|
-
this.log(` ${authUrl}`);
|
|
112
|
-
this.log("");
|
|
113
|
-
this.log(` code: ${code}`);
|
|
114
|
-
this.log(` device: ${device.hostname} (${device.deviceId.slice(0, 8)}...)`);
|
|
115
|
-
this.log("");
|
|
116
|
-
|
|
117
|
-
if (flags.open) {
|
|
118
|
-
try {
|
|
119
|
-
const { exec } = await import("node:child_process");
|
|
120
|
-
const cmd = process.platform === "darwin"
|
|
121
|
-
? `open "${authUrl}"`
|
|
122
|
-
: process.platform === "win32"
|
|
123
|
-
? `start "${authUrl}"`
|
|
124
|
-
: `xdg-open "${authUrl}"`;
|
|
125
|
-
exec(cmd);
|
|
126
|
-
} catch {
|
|
127
|
-
// Silently ignore — user can open manually
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
// Step 3: Poll for completion
|
|
132
|
-
this.logInfo("waiting for browser authorization...");
|
|
133
|
-
|
|
134
|
-
const startTime = Date.now();
|
|
135
|
-
let clerkId: string | undefined;
|
|
136
|
-
|
|
137
|
-
while (Date.now() - startTime < MAX_POLL_DURATION_MS) {
|
|
138
|
-
try {
|
|
139
|
-
const result = await client.query(api.functions.auth.tokens.pollAuth, {
|
|
140
|
-
code,
|
|
141
|
-
deviceId: device.deviceId,
|
|
142
|
-
});
|
|
143
|
-
|
|
144
|
-
if (result.status === "completed" && result.clerkId) {
|
|
145
|
-
clerkId = result.clerkId;
|
|
146
|
-
break;
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
if (result.status === "expired") {
|
|
150
|
-
this.logWarn("auth code expired. run `abbie login` again.");
|
|
151
|
-
return { status: "expired", deviceId: device.deviceId };
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
if (result.status === "invalid") {
|
|
155
|
-
this.logWarn("auth code invalid.");
|
|
156
|
-
return { status: "error", error: "invalid-code", deviceId: device.deviceId };
|
|
157
|
-
}
|
|
158
|
-
} catch {
|
|
159
|
-
// Network hiccup — retry
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
await new Promise((r) => setTimeout(r, POLL_INTERVAL_MS));
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
if (!clerkId) {
|
|
166
|
-
this.logWarn("timed out waiting for authorization.");
|
|
167
|
-
return { status: "expired", deviceId: device.deviceId };
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
// Step 4: Save credentials
|
|
171
|
-
saveClerkId(clerkId);
|
|
172
|
-
|
|
173
|
-
this.log("");
|
|
174
|
-
this.log(" ✓ authenticated");
|
|
175
|
-
this.log(` user: ${clerkId.slice(0, 16)}...`);
|
|
176
|
-
this.log(` device: ${device.hostname}`);
|
|
177
|
-
this.log("");
|
|
178
|
-
|
|
179
|
-
// Step 5: Optional initial sync
|
|
180
|
-
if (flags.sync) {
|
|
181
|
-
this.logInfo("running initial sync...");
|
|
182
|
-
try {
|
|
183
|
-
await this.runInitialSync(clerkId);
|
|
184
|
-
this.log(" ✓ synced");
|
|
185
|
-
} catch (err) {
|
|
186
|
-
const message = err instanceof Error ? err.message : String(err);
|
|
187
|
-
this.logWarn(`sync failed (non-fatal): ${message}`);
|
|
188
|
-
this.logInfo("run `abbie sync --apply` manually to sync.");
|
|
189
|
-
}
|
|
190
|
-
}
|
|
191
|
-
|
|
192
|
-
this.logInfo("run `abbie daemon` to start live sync.");
|
|
193
|
-
|
|
194
|
-
return {
|
|
195
|
-
status: "authenticated",
|
|
196
|
-
clerkId,
|
|
197
|
-
deviceId: device.deviceId,
|
|
198
|
-
};
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
private async runInitialSync(clerkId: string): Promise<void> {
|
|
202
|
-
const client = getHttpClient();
|
|
203
|
-
|
|
204
|
-
// Import sync runners lazily to avoid circular deps
|
|
205
|
-
const { ConfigSyncRunner } = await import("../../lib/config-sync/index.js");
|
|
206
|
-
const { ContentSyncRunner } = await import("../../lib/content-sync/index.js");
|
|
207
|
-
|
|
208
|
-
let decryptFn: ((v: string) => Promise<string>) | undefined;
|
|
209
|
-
try {
|
|
210
|
-
const { decryptIfEncrypted } = await import("@lnittman/convex-encryption");
|
|
211
|
-
decryptFn = async (v: string) => {
|
|
212
|
-
const result = await decryptIfEncrypted(v);
|
|
213
|
-
return result ?? v;
|
|
214
|
-
};
|
|
215
|
-
} catch {
|
|
216
|
-
// Encryption package not available
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
// Config sync
|
|
220
|
-
const configRunner = new ConfigSyncRunner({
|
|
221
|
-
fetchSnapshot: async () => {
|
|
222
|
-
return await client.query(api.configSync.getSnapshot, { clerkId });
|
|
223
|
-
},
|
|
224
|
-
decrypt: decryptFn,
|
|
225
|
-
});
|
|
226
|
-
await configRunner.tick({ force: true, dryRun: false });
|
|
227
|
-
|
|
228
|
-
// Content sync
|
|
229
|
-
const contentRunner = new ContentSyncRunner({
|
|
230
|
-
fetchSnapshot: async () => {
|
|
231
|
-
return await client.query(api.contentSync.getSnapshot, { clerkId });
|
|
232
|
-
},
|
|
233
|
-
});
|
|
234
|
-
await contentRunner.tick({ force: true, dryRun: false });
|
|
235
|
-
}
|
|
236
|
-
}
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* abbie logout — clear stored credentials from this device.
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import { clearClerkId, getStoredClerkId, getDeviceInfo } from "@creativeintelligence/sdk/config";
|
|
6
|
-
import { BaseCommand } from "../base-command.js";
|
|
7
|
-
|
|
8
|
-
type LogoutResult = {
|
|
9
|
-
status: "logged-out" | "not-authenticated";
|
|
10
|
-
deviceId: string;
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
export default class LogoutCommand extends BaseCommand {
|
|
14
|
-
static override summary = "Clear authentication from this device";
|
|
15
|
-
|
|
16
|
-
static override description = `Removes stored credentials from ~/.abbie/config.json.
|
|
17
|
-
Does not revoke tokens server-side — just clears local state.`;
|
|
18
|
-
|
|
19
|
-
static override examples = [
|
|
20
|
-
"$ abbie logout",
|
|
21
|
-
"$ abbie logout --json --quiet",
|
|
22
|
-
];
|
|
23
|
-
|
|
24
|
-
static override flags = {
|
|
25
|
-
...BaseCommand.baseFlags,
|
|
26
|
-
};
|
|
27
|
-
|
|
28
|
-
async execute(): Promise<LogoutResult> {
|
|
29
|
-
const { flags } = await this.parse(LogoutCommand);
|
|
30
|
-
this.parsedFlags = flags;
|
|
31
|
-
|
|
32
|
-
const device = getDeviceInfo();
|
|
33
|
-
const existing = getStoredClerkId();
|
|
34
|
-
|
|
35
|
-
if (!existing) {
|
|
36
|
-
this.logInfo("not authenticated.");
|
|
37
|
-
return { status: "not-authenticated", deviceId: device.deviceId };
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
clearClerkId();
|
|
41
|
-
this.logInfo(`logged out (was ${existing.slice(0, 12)}...)`);
|
|
42
|
-
|
|
43
|
-
return { status: "logged-out", deviceId: device.deviceId };
|
|
44
|
-
}
|
|
45
|
-
}
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
import { existsSync } from "node:fs";
|
|
2
|
-
import { join } from "node:path";
|
|
3
|
-
import { Flags } from "@oclif/core";
|
|
4
|
-
import { startPanesBroker } from "../../../lib/panes/server.js";
|
|
5
|
-
import { BaseCommand } from "../../base-command.js";
|
|
6
|
-
|
|
7
|
-
export default class PanesBrokerCommand extends BaseCommand {
|
|
8
|
-
static override summary = "Run local panes broker (event-driven tmux streaming)";
|
|
9
|
-
static override hidden = false;
|
|
10
|
-
|
|
11
|
-
static override examples = [
|
|
12
|
-
"$ abbie panes broker",
|
|
13
|
-
"$ abbie panes broker --socket ~/.abbie/run/panes-broker.sock",
|
|
14
|
-
"$ abbie panes broker --fps 30",
|
|
15
|
-
];
|
|
16
|
-
|
|
17
|
-
static override flags = {
|
|
18
|
-
...BaseCommand.baseFlags,
|
|
19
|
-
socket: Flags.string({
|
|
20
|
-
description: "Unix socket path for the broker",
|
|
21
|
-
required: false,
|
|
22
|
-
}),
|
|
23
|
-
fps: Flags.integer({
|
|
24
|
-
description: "Max snapshots per second (throttled)",
|
|
25
|
-
default: 30,
|
|
26
|
-
}),
|
|
27
|
-
force: Flags.boolean({
|
|
28
|
-
description: "Override any existing tmux pipe-pane for a pane",
|
|
29
|
-
default: false,
|
|
30
|
-
}),
|
|
31
|
-
};
|
|
32
|
-
|
|
33
|
-
protected async execute(): Promise<unknown> {
|
|
34
|
-
const { flags } = await this.parse(PanesBrokerCommand);
|
|
35
|
-
this.parsedFlags = flags;
|
|
36
|
-
|
|
37
|
-
const devBin = join(this.config.root, "bin", "dev.js");
|
|
38
|
-
const runBin = join(this.config.root, "bin", "run.js");
|
|
39
|
-
const agentsBinPath = existsSync(devBin) ? devBin : runBin;
|
|
40
|
-
|
|
41
|
-
const broker = await startPanesBroker(
|
|
42
|
-
{
|
|
43
|
-
socketPath: flags.socket,
|
|
44
|
-
fps: flags.fps,
|
|
45
|
-
forcePipe: flags.force,
|
|
46
|
-
},
|
|
47
|
-
{
|
|
48
|
-
agentsBinPath,
|
|
49
|
-
logInfo: (m) => this.logInfo(m),
|
|
50
|
-
logWarn: (m) => this.logWarn(m),
|
|
51
|
-
},
|
|
52
|
-
);
|
|
53
|
-
|
|
54
|
-
// Block forever until killed.
|
|
55
|
-
await new Promise<void>((resolve) => {
|
|
56
|
-
const onStop = async () => {
|
|
57
|
-
process.off("SIGINT", onStop);
|
|
58
|
-
process.off("SIGTERM", onStop);
|
|
59
|
-
await broker.stop();
|
|
60
|
-
resolve();
|
|
61
|
-
};
|
|
62
|
-
process.on("SIGINT", onStop);
|
|
63
|
-
process.on("SIGTERM", onStop);
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
return { socketPath: broker.socketPath };
|
|
67
|
-
}
|
|
68
|
-
}
|
|
@@ -1,101 +0,0 @@
|
|
|
1
|
-
import { createConnection } from "node:net";
|
|
2
|
-
import { Args, Flags } from "@oclif/core";
|
|
3
|
-
import {
|
|
4
|
-
createNdjsonLineParser,
|
|
5
|
-
getDefaultPanesBrokerSocketPath,
|
|
6
|
-
} from "../../../lib/panes/broker.js";
|
|
7
|
-
import { BaseCommand } from "../../base-command.js";
|
|
8
|
-
|
|
9
|
-
export default class PanesPipeSinkCommand extends BaseCommand {
|
|
10
|
-
static override summary = "Internal: tmux pipe-pane sink (stdin <-> broker)";
|
|
11
|
-
static override hidden = true;
|
|
12
|
-
|
|
13
|
-
static override args = {
|
|
14
|
-
pane: Args.string({
|
|
15
|
-
description: "tmux pane id (e.g. %3)",
|
|
16
|
-
required: true,
|
|
17
|
-
}),
|
|
18
|
-
};
|
|
19
|
-
|
|
20
|
-
static override flags = {
|
|
21
|
-
...BaseCommand.baseFlags,
|
|
22
|
-
sock: Flags.string({
|
|
23
|
-
description: "Broker socket path",
|
|
24
|
-
required: false,
|
|
25
|
-
}),
|
|
26
|
-
};
|
|
27
|
-
|
|
28
|
-
protected async execute(): Promise<unknown> {
|
|
29
|
-
const { args, flags } = await this.parse(PanesPipeSinkCommand);
|
|
30
|
-
this.parsedFlags = flags;
|
|
31
|
-
|
|
32
|
-
const paneId = args.pane;
|
|
33
|
-
const socketPath = flags.sock ?? getDefaultPanesBrokerSocketPath();
|
|
34
|
-
|
|
35
|
-
// Connect to broker. If broker isn't running, exit quietly so tmux isn't spammed.
|
|
36
|
-
const socket = createConnection({ path: socketPath });
|
|
37
|
-
|
|
38
|
-
const parser = createNdjsonLineParser<Record<string, unknown>>();
|
|
39
|
-
socket.on("data", (chunk) => parser.pushChunk(chunk));
|
|
40
|
-
|
|
41
|
-
const send = (msg: unknown) => {
|
|
42
|
-
socket.write(`${JSON.stringify(msg)}\n`);
|
|
43
|
-
};
|
|
44
|
-
|
|
45
|
-
const done = new Promise<void>((resolve) => {
|
|
46
|
-
const finish = () => resolve();
|
|
47
|
-
socket.on("error", finish);
|
|
48
|
-
socket.on("close", finish);
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
// Identify as a pipe client for this pane.
|
|
52
|
-
send({
|
|
53
|
-
type: "client.hello",
|
|
54
|
-
at: new Date().toISOString(),
|
|
55
|
-
clientId: `pipe:${paneId}`,
|
|
56
|
-
version: 1,
|
|
57
|
-
pid: process.pid,
|
|
58
|
-
});
|
|
59
|
-
send({ type: "panes.pipe.hello", at: new Date().toISOString(), paneId });
|
|
60
|
-
|
|
61
|
-
parser.onMessage((msg) => {
|
|
62
|
-
if (msg.type !== "panes.pipe.input") return;
|
|
63
|
-
if (msg.paneId !== paneId) return;
|
|
64
|
-
const data = typeof msg.data === "string" ? msg.data : null;
|
|
65
|
-
if (!data) return;
|
|
66
|
-
try {
|
|
67
|
-
const bytes = Buffer.from(data, "base64");
|
|
68
|
-
process.stdout.write(bytes);
|
|
69
|
-
} catch {
|
|
70
|
-
// ignore
|
|
71
|
-
}
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
// Forward raw pane output to broker as base64 chunks.
|
|
75
|
-
process.stdin.on("data", (chunk) => {
|
|
76
|
-
try {
|
|
77
|
-
const buf = Buffer.isBuffer(chunk) ? chunk : Buffer.from(String(chunk));
|
|
78
|
-
send({
|
|
79
|
-
type: "panes.pipe.chunk",
|
|
80
|
-
at: new Date().toISOString(),
|
|
81
|
-
paneId,
|
|
82
|
-
data: buf.toString("base64"),
|
|
83
|
-
});
|
|
84
|
-
} catch {
|
|
85
|
-
// ignore
|
|
86
|
-
}
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
// If stdin ends, exit.
|
|
90
|
-
process.stdin.on("end", () => {
|
|
91
|
-
try {
|
|
92
|
-
socket.end();
|
|
93
|
-
} catch {
|
|
94
|
-
// ignore
|
|
95
|
-
}
|
|
96
|
-
});
|
|
97
|
-
|
|
98
|
-
await done;
|
|
99
|
-
return { ok: true };
|
|
100
|
-
}
|
|
101
|
-
}
|
|
@@ -1,156 +0,0 @@
|
|
|
1
|
-
import { Args, Flags } from "@oclif/core";
|
|
2
|
-
import { capturePane, capturePaneWithAnsi } from "../../../lib/tmux/bridge.js";
|
|
3
|
-
import { isRunning } from "../../../lib/tmux/index.js";
|
|
4
|
-
import { redactContent } from "../../../lib/tmux/redaction.js";
|
|
5
|
-
import * as windows from "../../../lib/windows/index.js";
|
|
6
|
-
import { BaseCommand } from "../../base-command.js";
|
|
7
|
-
|
|
8
|
-
type SnapshotEncoding = "text" | "ansi";
|
|
9
|
-
|
|
10
|
-
type SnapshotResult = {
|
|
11
|
-
tmuxRunning: boolean;
|
|
12
|
-
window: windows.WindowInfo | null;
|
|
13
|
-
ref: string | null;
|
|
14
|
-
paneId: string | null;
|
|
15
|
-
encoding: SnapshotEncoding;
|
|
16
|
-
lines: number;
|
|
17
|
-
content: string;
|
|
18
|
-
redacted: boolean;
|
|
19
|
-
wasRedacted: boolean;
|
|
20
|
-
};
|
|
21
|
-
|
|
22
|
-
function paneRef(window: windows.WindowInfo): string {
|
|
23
|
-
return `${window.session}:${window.window}.${window.pane}`;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
export default class PanesSnapshotCommand extends BaseCommand {
|
|
27
|
-
static override summary = "Capture tmux pane scrollback snapshot";
|
|
28
|
-
static hidden = false;
|
|
29
|
-
|
|
30
|
-
static override examples = [
|
|
31
|
-
"$ abbie panes snapshot",
|
|
32
|
-
"$ abbie panes snapshot %3 --lines 200",
|
|
33
|
-
"$ abbie panes snapshot work:0.0 --lines 500 --ansi",
|
|
34
|
-
"$ abbie panes snapshot --json",
|
|
35
|
-
];
|
|
36
|
-
|
|
37
|
-
static override args = {
|
|
38
|
-
ref: Args.string({
|
|
39
|
-
description: "Pane ID (e.g. %3) or session:window.pane (e.g. work:0.0)",
|
|
40
|
-
required: false,
|
|
41
|
-
}),
|
|
42
|
-
};
|
|
43
|
-
|
|
44
|
-
static override flags = {
|
|
45
|
-
...BaseCommand.baseFlags,
|
|
46
|
-
lines: Flags.integer({
|
|
47
|
-
description: "Number of lines to capture from the bottom",
|
|
48
|
-
default: 200,
|
|
49
|
-
}),
|
|
50
|
-
ansi: Flags.boolean({
|
|
51
|
-
description: "Preserve ANSI escape codes",
|
|
52
|
-
default: false,
|
|
53
|
-
}),
|
|
54
|
-
redact: Flags.boolean({
|
|
55
|
-
description: "Enable redaction",
|
|
56
|
-
default: true,
|
|
57
|
-
allowNo: true,
|
|
58
|
-
}),
|
|
59
|
-
};
|
|
60
|
-
|
|
61
|
-
protected async execute(): Promise<unknown> {
|
|
62
|
-
const { args, flags } = await this.parse(PanesSnapshotCommand);
|
|
63
|
-
this.parsedFlags = flags;
|
|
64
|
-
|
|
65
|
-
const tmuxRunning = await isRunning();
|
|
66
|
-
if (!tmuxRunning) {
|
|
67
|
-
const result: SnapshotResult = {
|
|
68
|
-
tmuxRunning: false,
|
|
69
|
-
window: null,
|
|
70
|
-
ref: null,
|
|
71
|
-
paneId: null,
|
|
72
|
-
encoding: flags.ansi ? "ansi" : "text",
|
|
73
|
-
lines: Math.max(1, flags.lines),
|
|
74
|
-
content: "",
|
|
75
|
-
redacted: flags.redact,
|
|
76
|
-
wasRedacted: false,
|
|
77
|
-
};
|
|
78
|
-
if (!this.jsonEnabled?.()) {
|
|
79
|
-
this.log("tmux is not running");
|
|
80
|
-
}
|
|
81
|
-
return result;
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
const maxLines = Math.max(1, flags.lines);
|
|
85
|
-
const state = args.ref
|
|
86
|
-
? await windows.getWindowState(args.ref, {
|
|
87
|
-
includeNvim: false,
|
|
88
|
-
includeAgent: false,
|
|
89
|
-
includeBuffers: false,
|
|
90
|
-
})
|
|
91
|
-
: await windows.getFocusedWindow({
|
|
92
|
-
includeNvim: false,
|
|
93
|
-
includeAgent: false,
|
|
94
|
-
includeBuffers: false,
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
if (!state) {
|
|
98
|
-
const result: SnapshotResult = {
|
|
99
|
-
tmuxRunning: true,
|
|
100
|
-
window: null,
|
|
101
|
-
ref: null,
|
|
102
|
-
paneId: null,
|
|
103
|
-
encoding: flags.ansi ? "ansi" : "text",
|
|
104
|
-
lines: maxLines,
|
|
105
|
-
content: "",
|
|
106
|
-
redacted: flags.redact,
|
|
107
|
-
wasRedacted: false,
|
|
108
|
-
};
|
|
109
|
-
if (!this.jsonEnabled?.()) {
|
|
110
|
-
this.log("Pane not found");
|
|
111
|
-
}
|
|
112
|
-
return result;
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
const encoding: SnapshotEncoding = flags.ansi ? "ansi" : "text";
|
|
116
|
-
const paneId =
|
|
117
|
-
state.window.paneId || `${state.window.session}:${state.window.window}.${state.window.pane}`;
|
|
118
|
-
|
|
119
|
-
const raw =
|
|
120
|
-
encoding === "ansi"
|
|
121
|
-
? await capturePaneWithAnsi(state.window.window, state.window.pane, {
|
|
122
|
-
session: state.window.session,
|
|
123
|
-
lines: maxLines,
|
|
124
|
-
})
|
|
125
|
-
: await capturePane(state.window.window, state.window.pane, {
|
|
126
|
-
session: state.window.session,
|
|
127
|
-
lines: maxLines,
|
|
128
|
-
});
|
|
129
|
-
|
|
130
|
-
let content = raw;
|
|
131
|
-
let wasRedacted = false;
|
|
132
|
-
if (flags.redact) {
|
|
133
|
-
const redaction = redactContent(raw, "balanced");
|
|
134
|
-
content = redaction.content;
|
|
135
|
-
wasRedacted = redaction.wasRedacted;
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
const result: SnapshotResult = {
|
|
139
|
-
tmuxRunning: true,
|
|
140
|
-
window: state.window,
|
|
141
|
-
ref: paneRef(state.window),
|
|
142
|
-
paneId,
|
|
143
|
-
encoding,
|
|
144
|
-
lines: maxLines,
|
|
145
|
-
content,
|
|
146
|
-
redacted: flags.redact,
|
|
147
|
-
wasRedacted,
|
|
148
|
-
};
|
|
149
|
-
|
|
150
|
-
if (!this.jsonEnabled?.()) {
|
|
151
|
-
this.log(content);
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
return result;
|
|
155
|
-
}
|
|
156
|
-
}
|
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
import { afterAll, beforeAll, describe, expect, it } from "bun:test";
|
|
2
|
-
import { existsSync, mkdtempSync, rmSync } from "node:fs";
|
|
3
|
-
import { tmpdir } from "node:os";
|
|
4
|
-
import { join } from "node:path";
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* E2E tests for abbie plan command.
|
|
8
|
-
* Tests session creation with actual CLI binary.
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
describe("abbie plan (E2E)", () => {
|
|
12
|
-
let testPlansDir: string;
|
|
13
|
-
|
|
14
|
-
beforeAll(() => {
|
|
15
|
-
testPlansDir = mkdtempSync(join(tmpdir(), "agents-plan-test-"));
|
|
16
|
-
});
|
|
17
|
-
|
|
18
|
-
afterAll(() => {
|
|
19
|
-
rmSync(testPlansDir, { recursive: true, force: true });
|
|
20
|
-
});
|
|
21
|
-
|
|
22
|
-
async function runCLI(
|
|
23
|
-
args: string[],
|
|
24
|
-
env: Record<string, string> = {},
|
|
25
|
-
): Promise<{ stdout: string; stderr: string; exitCode: number | null }> {
|
|
26
|
-
const proc = Bun.spawn(["bun", "bin/run.js", "plan", ...args], {
|
|
27
|
-
cwd: `${import.meta.dir}/../../..`,
|
|
28
|
-
env: {
|
|
29
|
-
...process.env,
|
|
30
|
-
HOME: testPlansDir, // Override HOME to use test directory
|
|
31
|
-
...env,
|
|
32
|
-
},
|
|
33
|
-
stdout: "pipe",
|
|
34
|
-
stderr: "pipe",
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
const stdout = await new Response(proc.stdout).text();
|
|
38
|
-
const stderr = await new Response(proc.stderr).text();
|
|
39
|
-
await proc.exited;
|
|
40
|
-
|
|
41
|
-
return { stdout, stderr, exitCode: proc.exitCode };
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
it("creates a new planning session", async () => {
|
|
45
|
-
const { stdout, exitCode } = await runCLI(["--project", "test", "--title", "E2E Test Session"]);
|
|
46
|
-
expect(exitCode).toBe(0);
|
|
47
|
-
expect(stdout).toContain("Created planning session");
|
|
48
|
-
expect(stdout).toContain("test");
|
|
49
|
-
|
|
50
|
-
// Verify session directory was created in ~/.abbie/plans/
|
|
51
|
-
const sessionDir = join(testPlansDir, ".abbie", "plans", "test");
|
|
52
|
-
expect(existsSync(sessionDir)).toBe(true);
|
|
53
|
-
});
|
|
54
|
-
|
|
55
|
-
it("creates session with custom slug", async () => {
|
|
56
|
-
const { stdout, exitCode } = await runCLI([
|
|
57
|
-
"--project",
|
|
58
|
-
"test2",
|
|
59
|
-
"--slug",
|
|
60
|
-
"2025-12-01-custom",
|
|
61
|
-
]);
|
|
62
|
-
expect(exitCode).toBe(0);
|
|
63
|
-
expect(stdout).toContain("2025-12-01-custom");
|
|
64
|
-
|
|
65
|
-
const sessionPath = join(testPlansDir, ".abbie", "plans", "test2", "2025-12-01-custom");
|
|
66
|
-
expect(existsSync(sessionPath)).toBe(true);
|
|
67
|
-
});
|
|
68
|
-
|
|
69
|
-
it("outputs JSON format", async () => {
|
|
70
|
-
const { stdout, exitCode } = await runCLI([
|
|
71
|
-
"--project",
|
|
72
|
-
"test3",
|
|
73
|
-
"--title",
|
|
74
|
-
"JSON Test",
|
|
75
|
-
"--json",
|
|
76
|
-
]);
|
|
77
|
-
expect(exitCode).toBe(0);
|
|
78
|
-
const data = JSON.parse(stdout);
|
|
79
|
-
expect(data).toHaveProperty("project", "test3");
|
|
80
|
-
expect(data).toHaveProperty("slug");
|
|
81
|
-
expect(data).toHaveProperty("path");
|
|
82
|
-
expect(data).toHaveProperty("files");
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
it("errors when no title or slug provided", async () => {
|
|
86
|
-
const { stderr, exitCode } = await runCLI(["--project", "test"]);
|
|
87
|
-
expect(exitCode).toBe(2); // oclif uses exit code 2 for validation errors
|
|
88
|
-
expect(stderr).toContain("Provide --title or --slug");
|
|
89
|
-
});
|
|
90
|
-
});
|