@creativeintelligence/abbie 0.1.4 → 0.1.6
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/login.js +26 -0
- 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,188 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it } from "bun:test";
|
|
2
|
-
import {
|
|
3
|
-
buildProcessTree,
|
|
4
|
-
detectAgentType,
|
|
5
|
-
findDeepestDescendant,
|
|
6
|
-
findDescendants,
|
|
7
|
-
isAgentProcess,
|
|
8
|
-
isNvimProcess,
|
|
9
|
-
type ProcessInfo,
|
|
10
|
-
walkParentChain,
|
|
11
|
-
} from "./snapshot.js";
|
|
12
|
-
|
|
13
|
-
// Mock process snapshot for testing
|
|
14
|
-
function createMockSnapshot(): Map<number, ProcessInfo> {
|
|
15
|
-
const snapshot = new Map<number, ProcessInfo>();
|
|
16
|
-
|
|
17
|
-
// Simulate: init(1) → tmux(100) → zsh(200) → nvim(300) → node(400)
|
|
18
|
-
// └→ zsh(250) → codex(350)
|
|
19
|
-
snapshot.set(1, { pid: 1, ppid: 0, tty: "??", cmd: "init", args: "/sbin/init" });
|
|
20
|
-
snapshot.set(100, { pid: 100, ppid: 1, tty: "??", cmd: "tmux", args: "tmux new -s work" });
|
|
21
|
-
snapshot.set(200, { pid: 200, ppid: 100, tty: "ttys001", cmd: "zsh", args: "-zsh" });
|
|
22
|
-
snapshot.set(300, { pid: 300, ppid: 200, tty: "ttys001", cmd: "nvim", args: "nvim src/app.ts" });
|
|
23
|
-
snapshot.set(400, { pid: 400, ppid: 300, tty: "ttys001", cmd: "node", args: "node server.js" });
|
|
24
|
-
snapshot.set(250, { pid: 250, ppid: 100, tty: "ttys002", cmd: "zsh", args: "-zsh" });
|
|
25
|
-
snapshot.set(350, { pid: 350, ppid: 250, tty: "ttys002", cmd: "codex", args: "codex exec -" });
|
|
26
|
-
|
|
27
|
-
return snapshot;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
describe("process snapshot", () => {
|
|
31
|
-
describe("buildProcessTree", () => {
|
|
32
|
-
it("builds parent→children map", () => {
|
|
33
|
-
const snapshot = createMockSnapshot();
|
|
34
|
-
const tree = buildProcessTree(snapshot);
|
|
35
|
-
|
|
36
|
-
expect(tree.get(1)).toContain(100);
|
|
37
|
-
expect(tree.get(100)).toContain(200);
|
|
38
|
-
expect(tree.get(100)).toContain(250);
|
|
39
|
-
expect(tree.get(200)).toContain(300);
|
|
40
|
-
expect(tree.get(300)).toContain(400);
|
|
41
|
-
});
|
|
42
|
-
});
|
|
43
|
-
|
|
44
|
-
describe("walkParentChain", () => {
|
|
45
|
-
it("walks up to init parent", () => {
|
|
46
|
-
const snapshot = createMockSnapshot();
|
|
47
|
-
const chain = walkParentChain(400, snapshot);
|
|
48
|
-
|
|
49
|
-
// Stops at 100 because its ppid is 1 (init)
|
|
50
|
-
expect(chain).toEqual([400, 300, 200, 100]);
|
|
51
|
-
});
|
|
52
|
-
|
|
53
|
-
it("respects maxDepth", () => {
|
|
54
|
-
const snapshot = createMockSnapshot();
|
|
55
|
-
const chain = walkParentChain(400, snapshot, 2);
|
|
56
|
-
|
|
57
|
-
expect(chain).toEqual([400, 300]);
|
|
58
|
-
});
|
|
59
|
-
|
|
60
|
-
it("handles unknown PID", () => {
|
|
61
|
-
const snapshot = createMockSnapshot();
|
|
62
|
-
const chain = walkParentChain(9999, snapshot);
|
|
63
|
-
|
|
64
|
-
expect(chain).toEqual([]);
|
|
65
|
-
});
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
describe("findDescendants", () => {
|
|
69
|
-
it("finds all descendants", () => {
|
|
70
|
-
const snapshot = createMockSnapshot();
|
|
71
|
-
const tree = buildProcessTree(snapshot);
|
|
72
|
-
const descendants = findDescendants(100, tree, snapshot);
|
|
73
|
-
|
|
74
|
-
expect(descendants).toContain(200);
|
|
75
|
-
expect(descendants).toContain(300);
|
|
76
|
-
expect(descendants).toContain(400);
|
|
77
|
-
expect(descendants).toContain(250);
|
|
78
|
-
expect(descendants).toContain(350);
|
|
79
|
-
expect(descendants).not.toContain(100); // not self
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
it("filters descendants", () => {
|
|
83
|
-
const snapshot = createMockSnapshot();
|
|
84
|
-
const tree = buildProcessTree(snapshot);
|
|
85
|
-
const nvimProcesses = findDescendants(100, tree, snapshot, isNvimProcess);
|
|
86
|
-
|
|
87
|
-
expect(nvimProcesses).toEqual([300]);
|
|
88
|
-
});
|
|
89
|
-
});
|
|
90
|
-
|
|
91
|
-
describe("findDeepestDescendant", () => {
|
|
92
|
-
it("finds deepest matching descendant", () => {
|
|
93
|
-
const snapshot = createMockSnapshot();
|
|
94
|
-
const tree = buildProcessTree(snapshot);
|
|
95
|
-
|
|
96
|
-
// node(400) is deeper than nvim(300) but we're looking for nvim
|
|
97
|
-
const deepestNvim = findDeepestDescendant(100, tree, snapshot, isNvimProcess);
|
|
98
|
-
expect(deepestNvim).toBe(300);
|
|
99
|
-
});
|
|
100
|
-
|
|
101
|
-
it("returns null when no match", () => {
|
|
102
|
-
const snapshot = createMockSnapshot();
|
|
103
|
-
const tree = buildProcessTree(snapshot);
|
|
104
|
-
|
|
105
|
-
const result = findDeepestDescendant(100, tree, snapshot, (p) => p.cmd === "emacs");
|
|
106
|
-
expect(result).toBeNull();
|
|
107
|
-
});
|
|
108
|
-
|
|
109
|
-
it("prefers deeper nested nvim", () => {
|
|
110
|
-
const snapshot = createMockSnapshot();
|
|
111
|
-
// Add a nested nvim inside the first nvim
|
|
112
|
-
snapshot.set(310, {
|
|
113
|
-
pid: 310,
|
|
114
|
-
ppid: 300,
|
|
115
|
-
tty: "ttys001",
|
|
116
|
-
cmd: "nvim",
|
|
117
|
-
args: "nvim nested.ts",
|
|
118
|
-
});
|
|
119
|
-
|
|
120
|
-
const tree = buildProcessTree(snapshot);
|
|
121
|
-
const deepestNvim = findDeepestDescendant(100, tree, snapshot, isNvimProcess);
|
|
122
|
-
|
|
123
|
-
expect(deepestNvim).toBe(310); // nested is deeper
|
|
124
|
-
});
|
|
125
|
-
});
|
|
126
|
-
|
|
127
|
-
describe("isNvimProcess", () => {
|
|
128
|
-
it("detects nvim", () => {
|
|
129
|
-
expect(isNvimProcess({ pid: 1, ppid: 0, tty: "??", cmd: "nvim", args: "nvim" })).toBe(true);
|
|
130
|
-
expect(isNvimProcess({ pid: 1, ppid: 0, tty: "??", cmd: "vim", args: "vim" })).toBe(true);
|
|
131
|
-
expect(isNvimProcess({ pid: 1, ppid: 0, tty: "??", cmd: "vi", args: "vi" })).toBe(true);
|
|
132
|
-
});
|
|
133
|
-
|
|
134
|
-
it("rejects non-nvim", () => {
|
|
135
|
-
expect(isNvimProcess({ pid: 1, ppid: 0, tty: "??", cmd: "zsh", args: "zsh" })).toBe(false);
|
|
136
|
-
expect(isNvimProcess({ pid: 1, ppid: 0, tty: "??", cmd: "node", args: "node" })).toBe(false);
|
|
137
|
-
});
|
|
138
|
-
});
|
|
139
|
-
|
|
140
|
-
describe("isAgentProcess", () => {
|
|
141
|
-
it("detects agents", () => {
|
|
142
|
-
expect(isAgentProcess({ pid: 1, ppid: 0, tty: "??", cmd: "claude", args: "claude" })).toBe(
|
|
143
|
-
true,
|
|
144
|
-
);
|
|
145
|
-
expect(isAgentProcess({ pid: 1, ppid: 0, tty: "??", cmd: "codex", args: "codex" })).toBe(
|
|
146
|
-
true,
|
|
147
|
-
);
|
|
148
|
-
expect(isAgentProcess({ pid: 1, ppid: 0, tty: "??", cmd: "copilot", args: "copilot" })).toBe(
|
|
149
|
-
true,
|
|
150
|
-
);
|
|
151
|
-
expect(isAgentProcess({ pid: 1, ppid: 0, tty: "??", cmd: "gemini", args: "gemini" })).toBe(
|
|
152
|
-
true,
|
|
153
|
-
);
|
|
154
|
-
});
|
|
155
|
-
});
|
|
156
|
-
|
|
157
|
-
describe("detectAgentType", () => {
|
|
158
|
-
it("detects direct agent processes", () => {
|
|
159
|
-
expect(detectAgentType({ pid: 1, ppid: 0, tty: "??", cmd: "claude", args: "claude" })).toBe(
|
|
160
|
-
"claude",
|
|
161
|
-
);
|
|
162
|
-
expect(
|
|
163
|
-
detectAgentType({ pid: 1, ppid: 0, tty: "??", cmd: "codex", args: "codex exec" }),
|
|
164
|
-
).toBe("codex");
|
|
165
|
-
});
|
|
166
|
-
|
|
167
|
-
it("detects agents via wrappers", () => {
|
|
168
|
-
expect(
|
|
169
|
-
detectAgentType({
|
|
170
|
-
pid: 1,
|
|
171
|
-
ppid: 0,
|
|
172
|
-
tty: "??",
|
|
173
|
-
cmd: "node",
|
|
174
|
-
args: "node /usr/local/bin/claude",
|
|
175
|
-
}),
|
|
176
|
-
).toBe("claude");
|
|
177
|
-
expect(
|
|
178
|
-
detectAgentType({ pid: 1, ppid: 0, tty: "??", cmd: "bun", args: "bun run codex exec -" }),
|
|
179
|
-
).toBe("codex");
|
|
180
|
-
});
|
|
181
|
-
|
|
182
|
-
it("returns null for non-agents", () => {
|
|
183
|
-
expect(
|
|
184
|
-
detectAgentType({ pid: 1, ppid: 0, tty: "??", cmd: "node", args: "node server.js" }),
|
|
185
|
-
).toBe(null);
|
|
186
|
-
});
|
|
187
|
-
});
|
|
188
|
-
});
|
|
@@ -1,257 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Process snapshot utilities for parent chain walking and descendant search.
|
|
3
|
-
* Used by windows module for nvim discovery and agent-audit correlation.
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
import { spawn } from "node:child_process";
|
|
7
|
-
|
|
8
|
-
export interface ProcessInfo {
|
|
9
|
-
pid: number;
|
|
10
|
-
ppid: number;
|
|
11
|
-
tty: string;
|
|
12
|
-
cmd: string; // executable name
|
|
13
|
-
args: string; // full command line
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
* Execute a command and return stdout.
|
|
18
|
-
*/
|
|
19
|
-
async function exec(command: string, args: string[]): Promise<string> {
|
|
20
|
-
return new Promise((resolve, reject) => {
|
|
21
|
-
const proc = spawn(command, args, { stdio: ["ignore", "pipe", "pipe"] });
|
|
22
|
-
let stdout = "";
|
|
23
|
-
let stderr = "";
|
|
24
|
-
|
|
25
|
-
proc.stdout.on("data", (data) => {
|
|
26
|
-
stdout += data.toString();
|
|
27
|
-
});
|
|
28
|
-
proc.stderr.on("data", (data) => {
|
|
29
|
-
stderr += data.toString();
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
proc.on("close", (code) => {
|
|
33
|
-
if (code === 0) {
|
|
34
|
-
resolve(stdout);
|
|
35
|
-
} else {
|
|
36
|
-
reject(new Error(`${command} failed: ${stderr || `exit code ${code}`}`));
|
|
37
|
-
}
|
|
38
|
-
});
|
|
39
|
-
|
|
40
|
-
proc.on("error", reject);
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
/**
|
|
45
|
-
* Parse a single line of ps output.
|
|
46
|
-
* Format: pid ppid tty comm args
|
|
47
|
-
*/
|
|
48
|
-
function parsePsLine(line: string): ProcessInfo | null {
|
|
49
|
-
const trimmed = line.trim();
|
|
50
|
-
if (!trimmed) return null;
|
|
51
|
-
|
|
52
|
-
// Split on whitespace, but args can contain spaces
|
|
53
|
-
// Format: PID PPID TTY COMM ARGS...
|
|
54
|
-
const match = trimmed.match(/^\s*(\d+)\s+(\d+)\s+(\S+)\s+(\S+)\s+(.*)$/);
|
|
55
|
-
if (!match) {
|
|
56
|
-
// Try simpler format for lines where args might be empty
|
|
57
|
-
const simpleMatch = trimmed.match(/^\s*(\d+)\s+(\d+)\s+(\S+)\s+(\S+)\s*$/);
|
|
58
|
-
if (simpleMatch) {
|
|
59
|
-
return {
|
|
60
|
-
pid: parseInt(simpleMatch[1], 10),
|
|
61
|
-
ppid: parseInt(simpleMatch[2], 10),
|
|
62
|
-
tty: simpleMatch[3],
|
|
63
|
-
cmd: simpleMatch[4],
|
|
64
|
-
args: simpleMatch[4],
|
|
65
|
-
};
|
|
66
|
-
}
|
|
67
|
-
return null;
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
return {
|
|
71
|
-
pid: parseInt(match[1], 10),
|
|
72
|
-
ppid: parseInt(match[2], 10),
|
|
73
|
-
tty: match[3],
|
|
74
|
-
cmd: match[4],
|
|
75
|
-
args: match[5] || match[4],
|
|
76
|
-
};
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* Get a snapshot of all running processes.
|
|
81
|
-
* Uses `ps -axww -o pid=,ppid=,tty=,comm=,args=`
|
|
82
|
-
*/
|
|
83
|
-
export async function getProcessSnapshot(): Promise<Map<number, ProcessInfo>> {
|
|
84
|
-
const snapshot = new Map<number, ProcessInfo>();
|
|
85
|
-
|
|
86
|
-
try {
|
|
87
|
-
// Use ps with custom format: pid, ppid, tty, comm (executable), args (full command)
|
|
88
|
-
const output = await exec("ps", ["-axww", "-o", "pid=,ppid=,tty=,comm=,args="]);
|
|
89
|
-
|
|
90
|
-
for (const line of output.split("\n")) {
|
|
91
|
-
const info = parsePsLine(line);
|
|
92
|
-
if (info) {
|
|
93
|
-
snapshot.set(info.pid, info);
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
} catch {
|
|
97
|
-
// Return empty snapshot on error
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
return snapshot;
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
/**
|
|
104
|
-
* Build a parent→children map from process snapshot.
|
|
105
|
-
*/
|
|
106
|
-
export function buildProcessTree(snapshot: Map<number, ProcessInfo>): Map<number, number[]> {
|
|
107
|
-
const tree = new Map<number, number[]>();
|
|
108
|
-
|
|
109
|
-
for (const [pid, info] of snapshot) {
|
|
110
|
-
const children = tree.get(info.ppid) || [];
|
|
111
|
-
children.push(pid);
|
|
112
|
-
tree.set(info.ppid, children);
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
return tree;
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
/**
|
|
119
|
-
* Walk up the parent chain from a PID.
|
|
120
|
-
* Returns array [pid, ppid, grandparent, ...] up to maxDepth.
|
|
121
|
-
*/
|
|
122
|
-
export function walkParentChain(
|
|
123
|
-
pid: number,
|
|
124
|
-
snapshot: Map<number, ProcessInfo>,
|
|
125
|
-
maxDepth = 10,
|
|
126
|
-
): number[] {
|
|
127
|
-
const chain: number[] = [];
|
|
128
|
-
let currentPid = pid;
|
|
129
|
-
let depth = 0;
|
|
130
|
-
|
|
131
|
-
while (depth < maxDepth) {
|
|
132
|
-
const info = snapshot.get(currentPid);
|
|
133
|
-
if (!info) break;
|
|
134
|
-
|
|
135
|
-
chain.push(currentPid);
|
|
136
|
-
|
|
137
|
-
// Stop at init (pid 1) or if parent is self
|
|
138
|
-
if (info.ppid === 0 || info.ppid === 1 || info.ppid === currentPid) {
|
|
139
|
-
break;
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
currentPid = info.ppid;
|
|
143
|
-
depth++;
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
return chain;
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
/**
|
|
150
|
-
* Find all descendants of a PID matching an optional filter.
|
|
151
|
-
*/
|
|
152
|
-
export function findDescendants(
|
|
153
|
-
pid: number,
|
|
154
|
-
tree: Map<number, number[]>,
|
|
155
|
-
snapshot: Map<number, ProcessInfo>,
|
|
156
|
-
filter?: (p: ProcessInfo) => boolean,
|
|
157
|
-
): number[] {
|
|
158
|
-
const results: number[] = [];
|
|
159
|
-
const stack = [pid];
|
|
160
|
-
const visited = new Set<number>();
|
|
161
|
-
|
|
162
|
-
while (stack.length > 0) {
|
|
163
|
-
const current = stack.pop()!;
|
|
164
|
-
if (visited.has(current)) continue;
|
|
165
|
-
visited.add(current);
|
|
166
|
-
|
|
167
|
-
const info = snapshot.get(current);
|
|
168
|
-
if (info && current !== pid) {
|
|
169
|
-
if (!filter || filter(info)) {
|
|
170
|
-
results.push(current);
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
const children = tree.get(current) || [];
|
|
175
|
-
stack.push(...children);
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
return results;
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
/**
|
|
182
|
-
* Find the deepest descendant matching a filter.
|
|
183
|
-
* Useful for finding the most nested nvim instance.
|
|
184
|
-
*/
|
|
185
|
-
export function findDeepestDescendant(
|
|
186
|
-
pid: number,
|
|
187
|
-
tree: Map<number, number[]>,
|
|
188
|
-
snapshot: Map<number, ProcessInfo>,
|
|
189
|
-
filter: (p: ProcessInfo) => boolean,
|
|
190
|
-
): number | null {
|
|
191
|
-
let deepest: number | null = null;
|
|
192
|
-
let maxDepth = -1;
|
|
193
|
-
|
|
194
|
-
function dfs(current: number, depth: number): void {
|
|
195
|
-
const info = snapshot.get(current);
|
|
196
|
-
if (info && current !== pid && filter(info)) {
|
|
197
|
-
if (depth > maxDepth) {
|
|
198
|
-
maxDepth = depth;
|
|
199
|
-
deepest = current;
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
const children = tree.get(current) || [];
|
|
204
|
-
for (const child of children) {
|
|
205
|
-
dfs(child, depth + 1);
|
|
206
|
-
}
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
dfs(pid, 0);
|
|
210
|
-
return deepest;
|
|
211
|
-
}
|
|
212
|
-
|
|
213
|
-
/**
|
|
214
|
-
* Check if a process is an nvim instance.
|
|
215
|
-
*/
|
|
216
|
-
export function isNvimProcess(info: ProcessInfo): boolean {
|
|
217
|
-
const cmd = info.cmd.toLowerCase();
|
|
218
|
-
return cmd === "nvim" || cmd === "vim" || cmd === "vi";
|
|
219
|
-
}
|
|
220
|
-
|
|
221
|
-
/**
|
|
222
|
-
* Check if a process is a coding agent.
|
|
223
|
-
*/
|
|
224
|
-
export function isAgentProcess(info: ProcessInfo): boolean {
|
|
225
|
-
const cmd = info.cmd.toLowerCase();
|
|
226
|
-
return cmd === "claude" || cmd === "codex" || cmd === "copilot" || cmd === "gemini";
|
|
227
|
-
}
|
|
228
|
-
|
|
229
|
-
/**
|
|
230
|
-
* Detect agent type from process info.
|
|
231
|
-
* Handles wrapper processes (node, bun) running agent scripts.
|
|
232
|
-
*/
|
|
233
|
-
export function detectAgentType(
|
|
234
|
-
info: ProcessInfo,
|
|
235
|
-
): "claude" | "codex" | "copilot" | "gemini" | null {
|
|
236
|
-
const cmd = info.cmd.toLowerCase();
|
|
237
|
-
|
|
238
|
-
// Direct match
|
|
239
|
-
if (cmd === "claude") return "claude";
|
|
240
|
-
if (cmd === "codex") return "codex";
|
|
241
|
-
if (cmd === "copilot") return "copilot";
|
|
242
|
-
if (cmd === "gemini") return "gemini";
|
|
243
|
-
|
|
244
|
-
// Check args for wrapper processes
|
|
245
|
-
const wrappers = ["node", "bun", "npx", "pnpm", "npm"];
|
|
246
|
-
if (wrappers.includes(cmd)) {
|
|
247
|
-
const argsLower = info.args.toLowerCase();
|
|
248
|
-
// Order matters: some wrappers include model names (e.g. "claude-opus-4.6")
|
|
249
|
-
// even when the actual agent CLI is Copilot/Codex. Prefer the CLI name.
|
|
250
|
-
if (argsLower.includes("copilot")) return "copilot";
|
|
251
|
-
if (argsLower.includes("codex")) return "codex";
|
|
252
|
-
if (argsLower.includes("gemini")) return "gemini";
|
|
253
|
-
if (argsLower.includes("claude")) return "claude";
|
|
254
|
-
}
|
|
255
|
-
|
|
256
|
-
return null;
|
|
257
|
-
}
|
package/src/lib/provider-auth.ts
DELETED
|
@@ -1,258 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Provider OAuth Authentication
|
|
3
|
-
*
|
|
4
|
-
* Runs AI provider OAuth flows (Anthropic, OpenAI, Google, GitHub Copilot)
|
|
5
|
-
* using Pi's OAuth libraries, resolved dynamically from Pi's global install.
|
|
6
|
-
*
|
|
7
|
-
* Writes credentials to ~/.pi/agent/auth.json (Pi's auth storage format).
|
|
8
|
-
* This means Pi starts with providers already configured — no /login needed.
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
import { existsSync, readFileSync, writeFileSync, mkdirSync, chmodSync } from "node:fs";
|
|
12
|
-
import { homedir } from "node:os";
|
|
13
|
-
import { join } from "node:path";
|
|
14
|
-
import { execSync } from "node:child_process";
|
|
15
|
-
import { createInterface } from "node:readline";
|
|
16
|
-
import { exec } from "node:child_process";
|
|
17
|
-
|
|
18
|
-
const AUTH_JSON = join(homedir(), ".pi", "agent", "auth.json");
|
|
19
|
-
|
|
20
|
-
// ============================================================================
|
|
21
|
-
// Auth.json helpers
|
|
22
|
-
// ============================================================================
|
|
23
|
-
|
|
24
|
-
export interface ProviderCredential {
|
|
25
|
-
type: "oauth";
|
|
26
|
-
refresh: string;
|
|
27
|
-
access: string;
|
|
28
|
-
expires: number;
|
|
29
|
-
[key: string]: unknown;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
type AuthData = Record<string, ProviderCredential>;
|
|
33
|
-
|
|
34
|
-
export function readAuthJson(): AuthData {
|
|
35
|
-
try {
|
|
36
|
-
if (!existsSync(AUTH_JSON)) return {};
|
|
37
|
-
return JSON.parse(readFileSync(AUTH_JSON, "utf8")) as AuthData;
|
|
38
|
-
} catch {
|
|
39
|
-
return {};
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
function writeAuthJson(data: AuthData): void {
|
|
44
|
-
const dir = join(homedir(), ".pi", "agent");
|
|
45
|
-
mkdirSync(dir, { recursive: true, mode: 0o700 });
|
|
46
|
-
writeFileSync(AUTH_JSON, JSON.stringify(data, null, 2), "utf8");
|
|
47
|
-
chmodSync(AUTH_JSON, 0o600);
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
export function getConnectedProviders(): string[] {
|
|
51
|
-
const data = readAuthJson();
|
|
52
|
-
return Object.entries(data)
|
|
53
|
-
.filter(([, v]) => v?.type === "oauth" && v.access)
|
|
54
|
-
.map(([k]) => k);
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
export function hasAnyProvider(): boolean {
|
|
58
|
-
return getConnectedProviders().length > 0;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
// ============================================================================
|
|
62
|
-
// Provider info
|
|
63
|
-
// ============================================================================
|
|
64
|
-
|
|
65
|
-
export interface ProviderInfo {
|
|
66
|
-
id: string;
|
|
67
|
-
name: string;
|
|
68
|
-
description: string;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
export const PROVIDERS: ProviderInfo[] = [
|
|
72
|
-
{ id: "anthropic", name: "Anthropic", description: "Claude Pro/Max subscription" },
|
|
73
|
-
{ id: "openai-codex", name: "OpenAI", description: "ChatGPT Plus/Pro subscription" },
|
|
74
|
-
{ id: "google-gemini-cli", name: "Google Gemini", description: "Google Cloud Code Assist" },
|
|
75
|
-
{ id: "github-copilot", name: "GitHub Copilot", description: "Copilot Individual/Business" },
|
|
76
|
-
{ id: "google-antigravity", name: "Google Antigravity", description: "Gemini 3, Claude, GPT via Google Cloud" },
|
|
77
|
-
];
|
|
78
|
-
|
|
79
|
-
// ============================================================================
|
|
80
|
-
// Dynamic import of Pi's OAuth module
|
|
81
|
-
// ============================================================================
|
|
82
|
-
|
|
83
|
-
interface OAuthModule {
|
|
84
|
-
getOAuthProvider: (id: string) => any;
|
|
85
|
-
getOAuthProviders: () => any[];
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
async function importPiOAuth(): Promise<OAuthModule | null> {
|
|
89
|
-
// Strategy: find @mariozechner/pi-ai from Pi's global install
|
|
90
|
-
const candidates: string[] = [];
|
|
91
|
-
|
|
92
|
-
// 1. Try resolving from pi binary location
|
|
93
|
-
try {
|
|
94
|
-
const piPath = execSync("which pi", { encoding: "utf8", timeout: 3000 }).trim();
|
|
95
|
-
if (piPath) {
|
|
96
|
-
const { realpathSync } = await import("node:fs");
|
|
97
|
-
const realPath = realpathSync(piPath);
|
|
98
|
-
// pi binary -> bin/pi.mjs -> package root -> node_modules/@mariozechner/pi-ai
|
|
99
|
-
const pkgRoot = join(realPath, "..", "..");
|
|
100
|
-
candidates.push(join(pkgRoot, "node_modules", "@mariozechner", "pi-ai", "dist", "index.js"));
|
|
101
|
-
}
|
|
102
|
-
} catch { /* not found */ }
|
|
103
|
-
|
|
104
|
-
// 2. Try common global paths
|
|
105
|
-
const nodeVersion = process.version.replace("v", "");
|
|
106
|
-
candidates.push(
|
|
107
|
-
join(homedir(), ".nvm", "versions", "node", `v${nodeVersion}`, "lib", "node_modules", "@mariozechner", "pi-coding-agent", "node_modules", "@mariozechner", "pi-ai", "dist", "index.js"),
|
|
108
|
-
join("/usr", "local", "lib", "node_modules", "@mariozechner", "pi-coding-agent", "node_modules", "@mariozechner", "pi-ai", "dist", "index.js"),
|
|
109
|
-
);
|
|
110
|
-
|
|
111
|
-
for (const candidate of candidates) {
|
|
112
|
-
if (existsSync(candidate)) {
|
|
113
|
-
try {
|
|
114
|
-
return await import(candidate) as OAuthModule;
|
|
115
|
-
} catch { /* import failed */ }
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
return null;
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
// ============================================================================
|
|
123
|
-
// CLI OAuth flow helpers
|
|
124
|
-
// ============================================================================
|
|
125
|
-
|
|
126
|
-
function prompt(question: string): Promise<string> {
|
|
127
|
-
const rl = createInterface({ input: process.stdin, output: process.stdout });
|
|
128
|
-
return new Promise((resolve) => {
|
|
129
|
-
rl.question(question, (answer) => {
|
|
130
|
-
rl.close();
|
|
131
|
-
resolve(answer.trim());
|
|
132
|
-
});
|
|
133
|
-
});
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
function openBrowser(url: string): void {
|
|
137
|
-
const cmd = process.platform === "darwin" ? "open" : process.platform === "win32" ? "start" : "xdg-open";
|
|
138
|
-
exec(`${cmd} "${url}"`);
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
// ============================================================================
|
|
142
|
-
// Public API
|
|
143
|
-
// ============================================================================
|
|
144
|
-
|
|
145
|
-
/**
|
|
146
|
-
* Run the provider selection + OAuth flow.
|
|
147
|
-
* Returns the provider ID that was connected, or null if cancelled.
|
|
148
|
-
*/
|
|
149
|
-
export async function connectProvider(
|
|
150
|
-
log: (msg: string) => void,
|
|
151
|
-
): Promise<string | null> {
|
|
152
|
-
const piOAuth = await importPiOAuth();
|
|
153
|
-
|
|
154
|
-
if (!piOAuth) {
|
|
155
|
-
log(" ⚠ could not find Pi's OAuth module");
|
|
156
|
-
log(" connect providers in Pi instead: /login");
|
|
157
|
-
return null;
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
const connected = getConnectedProviders();
|
|
161
|
-
|
|
162
|
-
// Show provider list
|
|
163
|
-
log("");
|
|
164
|
-
log(" connect an AI provider");
|
|
165
|
-
log(" ─────────────────────");
|
|
166
|
-
log("");
|
|
167
|
-
|
|
168
|
-
const providers = piOAuth.getOAuthProviders();
|
|
169
|
-
for (let i = 0; i < providers.length; i++) {
|
|
170
|
-
const p = providers[i];
|
|
171
|
-
const isConnected = connected.includes(p.id);
|
|
172
|
-
const status = isConnected ? " ✓ connected" : "";
|
|
173
|
-
log(` ${i + 1}. ${p.name}${status}`);
|
|
174
|
-
}
|
|
175
|
-
log(` ${providers.length + 1}. skip for now`);
|
|
176
|
-
log("");
|
|
177
|
-
|
|
178
|
-
const choice = await prompt(" select (1-" + (providers.length + 1) + "): ");
|
|
179
|
-
const idx = parseInt(choice, 10) - 1;
|
|
180
|
-
|
|
181
|
-
if (isNaN(idx) || idx < 0 || idx >= providers.length) {
|
|
182
|
-
return null; // skip
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
const provider = providers[idx];
|
|
186
|
-
log("");
|
|
187
|
-
log(` connecting ${provider.name}...`);
|
|
188
|
-
log("");
|
|
189
|
-
|
|
190
|
-
try {
|
|
191
|
-
const credentials = await provider.login({
|
|
192
|
-
onAuth: (info: { url: string; instructions?: string }) => {
|
|
193
|
-
log(` open this URL to authenticate:`);
|
|
194
|
-
log(` ${info.url}`);
|
|
195
|
-
if (info.instructions) {
|
|
196
|
-
log(` ${info.instructions}`);
|
|
197
|
-
}
|
|
198
|
-
log("");
|
|
199
|
-
openBrowser(info.url);
|
|
200
|
-
},
|
|
201
|
-
onPrompt: async (promptInfo: { message: string; placeholder?: string; allowEmpty?: boolean }) => {
|
|
202
|
-
const answer = await prompt(` ${promptInfo.message} `);
|
|
203
|
-
if (!answer && !promptInfo.allowEmpty) {
|
|
204
|
-
throw new Error("Input required");
|
|
205
|
-
}
|
|
206
|
-
return answer;
|
|
207
|
-
},
|
|
208
|
-
onProgress: (message: string) => {
|
|
209
|
-
log(` ${message}`);
|
|
210
|
-
},
|
|
211
|
-
onManualCodeInput: async () => {
|
|
212
|
-
return await prompt(" paste the code or URL: ");
|
|
213
|
-
},
|
|
214
|
-
});
|
|
215
|
-
|
|
216
|
-
// Write to auth.json
|
|
217
|
-
const data = readAuthJson();
|
|
218
|
-
data[provider.id] = { type: "oauth", ...credentials };
|
|
219
|
-
writeAuthJson(data);
|
|
220
|
-
|
|
221
|
-
log(` ✓ ${provider.name} connected`);
|
|
222
|
-
return provider.id;
|
|
223
|
-
} catch (err) {
|
|
224
|
-
const msg = err instanceof Error ? err.message : String(err);
|
|
225
|
-
if (msg.includes("cancelled")) {
|
|
226
|
-
log(" cancelled");
|
|
227
|
-
} else {
|
|
228
|
-
log(` ✗ connection failed: ${msg}`);
|
|
229
|
-
}
|
|
230
|
-
return null;
|
|
231
|
-
}
|
|
232
|
-
}
|
|
233
|
-
|
|
234
|
-
/**
|
|
235
|
-
* Check providers and optionally prompt for connection.
|
|
236
|
-
* Used in the setup wizard.
|
|
237
|
-
*/
|
|
238
|
-
export async function ensureProviderConnected(
|
|
239
|
-
log: (msg: string) => void,
|
|
240
|
-
): Promise<boolean> {
|
|
241
|
-
const connected = getConnectedProviders();
|
|
242
|
-
|
|
243
|
-
if (connected.length > 0) {
|
|
244
|
-
const names = connected.map((id) => {
|
|
245
|
-
const info = PROVIDERS.find((p) => p.id === id);
|
|
246
|
-
return info?.name ?? id;
|
|
247
|
-
});
|
|
248
|
-
log(` [4/4] providers: ${names.join(", ")} ✓`);
|
|
249
|
-
return true;
|
|
250
|
-
}
|
|
251
|
-
|
|
252
|
-
log(" [4/4] connect an AI provider");
|
|
253
|
-
log(" (uses your existing subscription — no API keys needed)");
|
|
254
|
-
log("");
|
|
255
|
-
|
|
256
|
-
const result = await connectProvider(log);
|
|
257
|
-
return result !== null;
|
|
258
|
-
}
|