@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,244 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* abbie status — config + content sync health overview.
|
|
3
|
-
*
|
|
4
|
-
* Reads local sync state + sidecar manifest, reports:
|
|
5
|
-
* - Last successful sync time
|
|
6
|
-
* - Per-agent managed keys + drift detection
|
|
7
|
-
* - Content sync (rules/skills/hooks) status
|
|
8
|
-
* - Convex reachability
|
|
9
|
-
* - Pending changes
|
|
10
|
-
*/
|
|
11
|
-
|
|
12
|
-
import { existsSync, readFileSync, statSync, readdirSync } from "node:fs";
|
|
13
|
-
import { join } from "node:path";
|
|
14
|
-
import { homedir } from "node:os";
|
|
15
|
-
import { Flags } from "@oclif/core";
|
|
16
|
-
import { isConvexConfigured } from "@creativeintelligence/sdk/convex";
|
|
17
|
-
import { getStoredClerkId } from "@creativeintelligence/sdk/config";
|
|
18
|
-
import { getAdapter, getSyncDir, type SidecarManifest, type ConfigSyncState } from "../../lib/config-sync/index.js";
|
|
19
|
-
import { getLatestBackup } from "../../lib/config-sync/writer.js";
|
|
20
|
-
import type { ContentSyncState, ContentManifest } from "../../lib/content-sync/types.js";
|
|
21
|
-
import { BaseCommand } from "../base-command.js";
|
|
22
|
-
|
|
23
|
-
type StatusResult = {
|
|
24
|
-
authenticated: boolean;
|
|
25
|
-
convexConfigured: boolean;
|
|
26
|
-
lastSyncAt: number | null;
|
|
27
|
-
consecutiveFailures: number;
|
|
28
|
-
agents: {
|
|
29
|
-
agent: string;
|
|
30
|
-
configPath: string;
|
|
31
|
-
configExists: boolean;
|
|
32
|
-
managedKeys: string[];
|
|
33
|
-
lastSyncAt: number | null;
|
|
34
|
-
hasBackup: boolean;
|
|
35
|
-
drift: boolean;
|
|
36
|
-
}[];
|
|
37
|
-
content?: {
|
|
38
|
-
lastSyncAt: number | null;
|
|
39
|
-
consecutiveFailures: number;
|
|
40
|
-
rules: { managed: string[]; lastSyncAt: number | null };
|
|
41
|
-
skills: { managed: string[]; lastSyncAt: number | null };
|
|
42
|
-
hooks: { managed: string[]; lastSyncAt: number | null };
|
|
43
|
-
};
|
|
44
|
-
};
|
|
45
|
-
|
|
46
|
-
export default class StatusCommand extends BaseCommand {
|
|
47
|
-
static override summary = "Config sync health overview";
|
|
48
|
-
|
|
49
|
-
static override description = `Shows the current state of MCP config sync:
|
|
50
|
-
- Authentication status
|
|
51
|
-
- Last successful sync time
|
|
52
|
-
- Per-agent managed keys and drift detection
|
|
53
|
-
- Backup availability`;
|
|
54
|
-
|
|
55
|
-
static override examples = [
|
|
56
|
-
"$ abbie status",
|
|
57
|
-
"$ abbie status --json --quiet",
|
|
58
|
-
];
|
|
59
|
-
|
|
60
|
-
static override flags = {
|
|
61
|
-
...BaseCommand.baseFlags,
|
|
62
|
-
};
|
|
63
|
-
|
|
64
|
-
async execute(): Promise<StatusResult> {
|
|
65
|
-
const { flags } = await this.parse(StatusCommand);
|
|
66
|
-
this.parsedFlags = flags;
|
|
67
|
-
|
|
68
|
-
const syncDir = getSyncDir();
|
|
69
|
-
const statePath = `${syncDir}/config-sync-state.json`;
|
|
70
|
-
const manifestPath = `${syncDir}/managed-sections.json`;
|
|
71
|
-
|
|
72
|
-
// Load state
|
|
73
|
-
let state: ConfigSyncState = {
|
|
74
|
-
lastHash: "",
|
|
75
|
-
lastSuccessAt: 0,
|
|
76
|
-
consecutiveFailures: 0,
|
|
77
|
-
nextRetryAt: 0,
|
|
78
|
-
};
|
|
79
|
-
if (existsSync(statePath)) {
|
|
80
|
-
try {
|
|
81
|
-
state = JSON.parse(readFileSync(statePath, "utf-8"));
|
|
82
|
-
} catch {
|
|
83
|
-
// ignore
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
// Load manifest
|
|
88
|
-
let manifest: SidecarManifest = {};
|
|
89
|
-
if (existsSync(manifestPath)) {
|
|
90
|
-
try {
|
|
91
|
-
manifest = JSON.parse(readFileSync(manifestPath, "utf-8"));
|
|
92
|
-
} catch {
|
|
93
|
-
// ignore
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
const authenticated = !!getStoredClerkId();
|
|
98
|
-
const convexConfigured = isConvexConfigured();
|
|
99
|
-
|
|
100
|
-
// Build per-agent status
|
|
101
|
-
const AGENTS = ["claude", "codex", "copilot", "gemini", "opencode"] as const;
|
|
102
|
-
const agents = AGENTS.map((agent) => {
|
|
103
|
-
const adapter = getAdapter(agent);
|
|
104
|
-
const manifestEntry = manifest[agent];
|
|
105
|
-
const configPath = adapter?.configPath() ?? "(unknown)";
|
|
106
|
-
const configFileExists = adapter?.configExists() ?? false;
|
|
107
|
-
const managedKeys = manifestEntry?.managedKeys ?? [];
|
|
108
|
-
const lastAgentSyncAt = manifestEntry?.lastSyncAt ?? null;
|
|
109
|
-
const hasBackup = !!getLatestBackup(agent);
|
|
110
|
-
|
|
111
|
-
// Drift detection: check if managed keys in the file match manifest
|
|
112
|
-
let drift = false;
|
|
113
|
-
if (adapter && configFileExists && managedKeys.length > 0 && agent !== "opencode") {
|
|
114
|
-
try {
|
|
115
|
-
const current = adapter.read();
|
|
116
|
-
// For JSON adapters, check if managed keys are present
|
|
117
|
-
const mcpServers = (current as Record<string, unknown>).mcpServers as Record<string, unknown> | undefined;
|
|
118
|
-
if (mcpServers) {
|
|
119
|
-
for (const key of managedKeys) {
|
|
120
|
-
if (!(key in mcpServers)) {
|
|
121
|
-
drift = true;
|
|
122
|
-
break;
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
} catch {
|
|
127
|
-
// Can't read — count as drift
|
|
128
|
-
drift = true;
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
return {
|
|
133
|
-
agent,
|
|
134
|
-
configPath,
|
|
135
|
-
configExists: configFileExists,
|
|
136
|
-
managedKeys,
|
|
137
|
-
lastSyncAt: lastAgentSyncAt,
|
|
138
|
-
hasBackup,
|
|
139
|
-
drift,
|
|
140
|
-
};
|
|
141
|
-
});
|
|
142
|
-
|
|
143
|
-
// Load content sync state
|
|
144
|
-
const contentStatePath = `${syncDir}/content-sync-state.json`;
|
|
145
|
-
const contentManifestPath = `${syncDir}/content-manifest.json`;
|
|
146
|
-
|
|
147
|
-
let contentState: ContentSyncState = {
|
|
148
|
-
lastHash: "",
|
|
149
|
-
lastSuccessAt: 0,
|
|
150
|
-
consecutiveFailures: 0,
|
|
151
|
-
nextRetryAt: 0,
|
|
152
|
-
};
|
|
153
|
-
if (existsSync(contentStatePath)) {
|
|
154
|
-
try {
|
|
155
|
-
contentState = JSON.parse(readFileSync(contentStatePath, "utf-8"));
|
|
156
|
-
} catch {
|
|
157
|
-
// ignore
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
let contentManifest: ContentManifest = {};
|
|
162
|
-
if (existsSync(contentManifestPath)) {
|
|
163
|
-
try {
|
|
164
|
-
contentManifest = JSON.parse(readFileSync(contentManifestPath, "utf-8"));
|
|
165
|
-
} catch {
|
|
166
|
-
// ignore
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
const content = {
|
|
171
|
-
lastSyncAt: contentState.lastSuccessAt || null,
|
|
172
|
-
consecutiveFailures: contentState.consecutiveFailures,
|
|
173
|
-
rules: {
|
|
174
|
-
managed: contentManifest.rules?.managedFiles ?? [],
|
|
175
|
-
lastSyncAt: contentManifest.rules?.lastSyncAt ?? null,
|
|
176
|
-
},
|
|
177
|
-
skills: {
|
|
178
|
-
managed: contentManifest.skills?.managedDirs ?? [],
|
|
179
|
-
lastSyncAt: contentManifest.skills?.lastSyncAt ?? null,
|
|
180
|
-
},
|
|
181
|
-
hooks: {
|
|
182
|
-
managed: contentManifest.hooks?.managedFiles ?? [],
|
|
183
|
-
lastSyncAt: contentManifest.hooks?.lastSyncAt ?? null,
|
|
184
|
-
},
|
|
185
|
-
};
|
|
186
|
-
|
|
187
|
-
const result: StatusResult = {
|
|
188
|
-
authenticated,
|
|
189
|
-
convexConfigured,
|
|
190
|
-
lastSyncAt: state.lastSuccessAt || null,
|
|
191
|
-
consecutiveFailures: state.consecutiveFailures,
|
|
192
|
-
agents,
|
|
193
|
-
content,
|
|
194
|
-
};
|
|
195
|
-
|
|
196
|
-
// Format output
|
|
197
|
-
const isJson = flags.json || flags.format === "json";
|
|
198
|
-
if (!isJson) {
|
|
199
|
-
this.log(` auth: ${authenticated ? "✓" : "✗ (run abbie login)"}`);
|
|
200
|
-
this.log(` convex: ${convexConfigured ? "✓" : "✗ (not configured)"}`);
|
|
201
|
-
|
|
202
|
-
if (state.lastSuccessAt) {
|
|
203
|
-
const ago = Math.round((Date.now() - state.lastSuccessAt) / 1000);
|
|
204
|
-
this.log(` last config sync: ${ago}s ago`);
|
|
205
|
-
} else {
|
|
206
|
-
this.log(" last config sync: never");
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
if (state.consecutiveFailures > 0) {
|
|
210
|
-
this.log(` config failures: ${state.consecutiveFailures} consecutive`);
|
|
211
|
-
}
|
|
212
|
-
|
|
213
|
-
this.log("");
|
|
214
|
-
this.log(" config sync (MCP connections → agent configs):");
|
|
215
|
-
for (const a of agents) {
|
|
216
|
-
const status = a.configExists ? "✓" : "·";
|
|
217
|
-
const keys = a.managedKeys.length > 0 ? ` [${a.managedKeys.join(", ")}]` : "";
|
|
218
|
-
const driftMark = a.drift ? " ⚠ drift" : "";
|
|
219
|
-
const backupMark = a.hasBackup ? "" : " (no backup)";
|
|
220
|
-
this.log(` ${status} ${a.agent}: ${a.configPath}${keys}${driftMark}${backupMark}`);
|
|
221
|
-
}
|
|
222
|
-
|
|
223
|
-
this.log("");
|
|
224
|
-
this.log(" content sync (Convex → ~/.abbie/ rules/skills/hooks):");
|
|
225
|
-
if (content.lastSyncAt) {
|
|
226
|
-
const ago = Math.round((Date.now() - content.lastSyncAt) / 1000);
|
|
227
|
-
this.log(` last sync: ${ago}s ago`);
|
|
228
|
-
} else {
|
|
229
|
-
this.log(" last sync: never");
|
|
230
|
-
}
|
|
231
|
-
if (content.consecutiveFailures > 0) {
|
|
232
|
-
this.log(` failures: ${content.consecutiveFailures} consecutive`);
|
|
233
|
-
}
|
|
234
|
-
const rulesCount = content.rules.managed.length;
|
|
235
|
-
const skillsCount = content.skills.managed.length;
|
|
236
|
-
const hooksCount = content.hooks.managed.length;
|
|
237
|
-
this.log(` rules: ${rulesCount} managed${rulesCount > 0 ? ` [${content.rules.managed.join(", ")}]` : ""}`);
|
|
238
|
-
this.log(` skills: ${skillsCount} managed${skillsCount > 0 ? ` [${content.skills.managed.join(", ")}]` : ""}`);
|
|
239
|
-
this.log(` hooks: ${hooksCount} managed${hooksCount > 0 ? ` [${content.hooks.managed.join(", ")}]` : ""}`);
|
|
240
|
-
}
|
|
241
|
-
|
|
242
|
-
return result;
|
|
243
|
-
}
|
|
244
|
-
}
|
package/src/cli/commands/sync.ts
DELETED
|
@@ -1,174 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* abbie sync — on-demand sync from Convex to local files.
|
|
3
|
-
*
|
|
4
|
-
* Syncs both:
|
|
5
|
-
* 1. MCP connections → local agent config files (claude, codex, copilot, gemini)
|
|
6
|
-
* 2. Rules/skills/hooks → ~/.abbie/ local files
|
|
7
|
-
*
|
|
8
|
-
* Default: dry-run showing planned changes.
|
|
9
|
-
* --apply: write changes.
|
|
10
|
-
* --force: skip hash comparison.
|
|
11
|
-
* --agent: sync specific agent only (config sync only).
|
|
12
|
-
* --type: sync specific content type only (content sync only).
|
|
13
|
-
*/
|
|
14
|
-
|
|
15
|
-
import { Flags } from "@oclif/core";
|
|
16
|
-
import { api, getHttpClient, isConvexConfigured } from "@creativeintelligence/sdk/convex";
|
|
17
|
-
import { getStoredClerkId } from "@creativeintelligence/sdk/config";
|
|
18
|
-
import { ConfigSyncRunner, type ConfigSyncAgent, type SyncTickResult } from "../../lib/config-sync/index.js";
|
|
19
|
-
import { ContentSyncRunner } from "../../lib/content-sync/index.js";
|
|
20
|
-
import type { ContentSyncTickResult, ContentType } from "../../lib/content-sync/types.js";
|
|
21
|
-
import { BaseCommand } from "../base-command.js";
|
|
22
|
-
|
|
23
|
-
type CombinedSyncResult = {
|
|
24
|
-
config: SyncTickResult;
|
|
25
|
-
content: ContentSyncTickResult;
|
|
26
|
-
};
|
|
27
|
-
|
|
28
|
-
export default class SyncCommand extends BaseCommand {
|
|
29
|
-
static override summary = "Sync Convex state to local config and content files";
|
|
30
|
-
|
|
31
|
-
static override description = `Syncs two pipelines from Convex to local:
|
|
32
|
-
|
|
33
|
-
1. Config sync: MCP connections → agent config files
|
|
34
|
-
(~/.claude/.mcp.json, ~/.codex/config.toml, etc.)
|
|
35
|
-
|
|
36
|
-
2. Content sync: rules/skills/hooks → ~/.abbie/ files
|
|
37
|
-
(~/.abbie/rules/*.md, ~/.abbie/skills/*/SKILL.md, ~/.abbie/hooks/*)
|
|
38
|
-
|
|
39
|
-
Default mode is dry-run — shows what would change without writing.
|
|
40
|
-
Use --apply to actually write the changes.`;
|
|
41
|
-
|
|
42
|
-
static override examples = [
|
|
43
|
-
"$ abbie sync",
|
|
44
|
-
"$ abbie sync --apply",
|
|
45
|
-
"$ abbie sync --force --apply",
|
|
46
|
-
"$ abbie sync --agent claude --apply",
|
|
47
|
-
"$ abbie sync --type rules --apply",
|
|
48
|
-
"$ abbie sync --json --quiet",
|
|
49
|
-
];
|
|
50
|
-
|
|
51
|
-
static override flags = {
|
|
52
|
-
...BaseCommand.baseFlags,
|
|
53
|
-
apply: Flags.boolean({
|
|
54
|
-
description: "Apply changes (default is dry-run)",
|
|
55
|
-
default: false,
|
|
56
|
-
}),
|
|
57
|
-
force: Flags.boolean({
|
|
58
|
-
char: "f",
|
|
59
|
-
description: "Skip hash comparison, force re-sync",
|
|
60
|
-
default: false,
|
|
61
|
-
}),
|
|
62
|
-
agent: Flags.string({
|
|
63
|
-
char: "a",
|
|
64
|
-
description: "Sync specific agent only (config sync)",
|
|
65
|
-
options: ["claude", "codex", "copilot", "gemini", "opencode"],
|
|
66
|
-
}),
|
|
67
|
-
type: Flags.string({
|
|
68
|
-
char: "t",
|
|
69
|
-
description: "Sync specific content type only (content sync)",
|
|
70
|
-
options: ["rules", "skills", "hooks"],
|
|
71
|
-
}),
|
|
72
|
-
};
|
|
73
|
-
|
|
74
|
-
async execute(): Promise<CombinedSyncResult> {
|
|
75
|
-
const { flags } = await this.parse(SyncCommand);
|
|
76
|
-
this.parsedFlags = flags;
|
|
77
|
-
|
|
78
|
-
if (!isConvexConfigured()) {
|
|
79
|
-
this.logWarn("Convex not configured. Run `abbie login` first.");
|
|
80
|
-
return {
|
|
81
|
-
config: { ok: false, reason: "convex-not-configured", changes: [] },
|
|
82
|
-
content: { ok: false, reason: "convex-not-configured", changes: [] },
|
|
83
|
-
};
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
const clerkId = getStoredClerkId();
|
|
87
|
-
if (!clerkId) {
|
|
88
|
-
this.logWarn("Not authenticated. Run `abbie login` first.");
|
|
89
|
-
return {
|
|
90
|
-
config: { ok: false, reason: "not-authenticated", changes: [] },
|
|
91
|
-
content: { ok: false, reason: "not-authenticated", changes: [] },
|
|
92
|
-
};
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
const dryRun = !flags.apply;
|
|
96
|
-
const agents = flags.agent ? [flags.agent as ConfigSyncAgent] : undefined;
|
|
97
|
-
const types = flags.type ? [flags.type as ContentType] : undefined;
|
|
98
|
-
|
|
99
|
-
// Set up decrypt function using @lnittman/convex-encryption
|
|
100
|
-
let decryptFn: ((v: string) => Promise<string>) | undefined;
|
|
101
|
-
try {
|
|
102
|
-
const { decryptIfEncrypted } = await import("@lnittman/convex-encryption");
|
|
103
|
-
decryptFn = async (v: string) => {
|
|
104
|
-
const result = await decryptIfEncrypted(v);
|
|
105
|
-
return result ?? v;
|
|
106
|
-
};
|
|
107
|
-
} catch {
|
|
108
|
-
// Encryption package not available — pass through
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
const client = getHttpClient();
|
|
112
|
-
|
|
113
|
-
// Config sync (MCP connections → agent config files)
|
|
114
|
-
const configRunner = new ConfigSyncRunner({
|
|
115
|
-
fetchSnapshot: async () => {
|
|
116
|
-
return await client.query(api.configSync.getSnapshot, { clerkId });
|
|
117
|
-
},
|
|
118
|
-
decrypt: decryptFn,
|
|
119
|
-
agents,
|
|
120
|
-
});
|
|
121
|
-
|
|
122
|
-
const configResult = await configRunner.tick({ force: flags.force, dryRun });
|
|
123
|
-
|
|
124
|
-
// Content sync (rules/skills/hooks → ~/.abbie/)
|
|
125
|
-
const contentRunner = new ContentSyncRunner({
|
|
126
|
-
fetchSnapshot: async () => {
|
|
127
|
-
return await client.query(api.contentSync.getSnapshot, { clerkId });
|
|
128
|
-
},
|
|
129
|
-
types,
|
|
130
|
-
});
|
|
131
|
-
|
|
132
|
-
const contentResult = await contentRunner.tick({ force: flags.force, dryRun });
|
|
133
|
-
|
|
134
|
-
// Format output
|
|
135
|
-
const isJson = flags.json || flags.format === "json";
|
|
136
|
-
if (!isJson) {
|
|
137
|
-
if (dryRun) {
|
|
138
|
-
this.logInfo("dry-run (use --apply to write changes)");
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
// Config sync results
|
|
142
|
-
this.log("");
|
|
143
|
-
this.log(" config sync (MCP → agent configs):");
|
|
144
|
-
if (configResult.reason === "unchanged") {
|
|
145
|
-
this.log(" no changes");
|
|
146
|
-
} else {
|
|
147
|
-
for (const change of configResult.changes) {
|
|
148
|
-
const icon = change.action === "error" ? "✗" : change.action === "skipped" ? "·" : "✓";
|
|
149
|
-
const added = change.keysAdded.length > 0 ? ` +${change.keysAdded.join(",")}` : "";
|
|
150
|
-
const removed = change.keysRemoved.length > 0 ? ` -${change.keysRemoved.join(",")}` : "";
|
|
151
|
-
const err = change.error ? ` (${change.error})` : "";
|
|
152
|
-
this.log(` ${icon} ${change.agent}: ${change.action}${added}${removed}${err}`);
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
// Content sync results
|
|
157
|
-
this.log("");
|
|
158
|
-
this.log(" content sync (Convex → ~/.abbie/):");
|
|
159
|
-
if (contentResult.reason === "unchanged") {
|
|
160
|
-
this.log(" no changes");
|
|
161
|
-
} else if (contentResult.changes.length === 0) {
|
|
162
|
-
this.log(" no content in Convex");
|
|
163
|
-
} else {
|
|
164
|
-
for (const change of contentResult.changes) {
|
|
165
|
-
const icon = change.action === "error" ? "✗" : change.action === "unchanged" ? "·" : "✓";
|
|
166
|
-
const err = change.error ? ` (${change.error})` : "";
|
|
167
|
-
this.log(` ${icon} ${change.type}/${change.name}: ${change.action}${err}`);
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
return { config: configResult, content: contentResult };
|
|
173
|
-
}
|
|
174
|
-
}
|
|
@@ -1,255 +0,0 @@
|
|
|
1
|
-
import { execSync } from "node:child_process";
|
|
2
|
-
import { writeFileSync } from "node:fs";
|
|
3
|
-
import { Args, Flags } from "@oclif/core";
|
|
4
|
-
import { getActiveSessionManager } from "../../../lib/active-sessions.js";
|
|
5
|
-
import { AgentSessionMiner } from "../../../lib/agent-sessions.js";
|
|
6
|
-
import {
|
|
7
|
-
type AbbieSessionData,
|
|
8
|
-
mapToAgentTrace,
|
|
9
|
-
validateAgentTrace,
|
|
10
|
-
} from "../../../lib/agent-trace.js";
|
|
11
|
-
import { SessionStateManager } from "../../../lib/session-state.js";
|
|
12
|
-
import { BaseCommand } from "../../base-command.js";
|
|
13
|
-
|
|
14
|
-
function normalizeTraceUrl(candidate: string | undefined): string | undefined {
|
|
15
|
-
if (!candidate) {
|
|
16
|
-
return undefined;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
const normalized = candidate.replace(/\\\//g, "/").replace(/&/gi, "&").trim();
|
|
20
|
-
if (!normalized) {
|
|
21
|
-
return undefined;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
try {
|
|
25
|
-
const parsed = new URL(normalized);
|
|
26
|
-
const isBraintrustHost = parsed.hostname.toLowerCase().includes("braintrust");
|
|
27
|
-
|
|
28
|
-
parsed.pathname = parsed.pathname
|
|
29
|
-
.replace(/(?:%22|%27|%7d|%7b|%3e|%3c|%29|%5d)+$/i, "")
|
|
30
|
-
.replace(/\/+$/, "");
|
|
31
|
-
parsed.hash = "";
|
|
32
|
-
|
|
33
|
-
const traceMatch = parsed.pathname.match(/\/traces?\/([^/?#]+)/i);
|
|
34
|
-
if (traceMatch?.[1]) {
|
|
35
|
-
parsed.search = "";
|
|
36
|
-
parsed.pathname = parsed.pathname.replace(/(\/traces?\/[^/?#]+).*/i, "$1");
|
|
37
|
-
return parsed.toString();
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
if (isBraintrustHost && /\/object$/i.test(parsed.pathname)) {
|
|
41
|
-
const objectType = parsed.searchParams.get("object_type");
|
|
42
|
-
const objectId = parsed.searchParams.get("object_id");
|
|
43
|
-
const id = parsed.searchParams.get("id");
|
|
44
|
-
if (!objectType || !objectId || !id) {
|
|
45
|
-
return undefined;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
const searchParams = new URLSearchParams();
|
|
49
|
-
searchParams.set("object_type", objectType);
|
|
50
|
-
searchParams.set("object_id", objectId);
|
|
51
|
-
searchParams.set("id", id);
|
|
52
|
-
parsed.search = `?${searchParams.toString()}`;
|
|
53
|
-
return parsed.toString();
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
return undefined;
|
|
57
|
-
} catch {
|
|
58
|
-
return undefined;
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
export default class TraceExport extends BaseCommand {
|
|
63
|
-
static override description =
|
|
64
|
-
"Export a session as an Agent Trace v0.1 record (interoperability format)";
|
|
65
|
-
static override hidden = false;
|
|
66
|
-
|
|
67
|
-
static override examples = [
|
|
68
|
-
"<%= config.bin %> trace export SESSION_ID",
|
|
69
|
-
"<%= config.bin %> trace export SESSION_ID --json --quiet",
|
|
70
|
-
"<%= config.bin %> trace export SESSION_ID --output trace.json",
|
|
71
|
-
"<%= config.bin %> trace export --last",
|
|
72
|
-
];
|
|
73
|
-
|
|
74
|
-
static override args = {
|
|
75
|
-
sessionId: Args.string({
|
|
76
|
-
description: "Session ID to export (or use --last for most recent)",
|
|
77
|
-
required: false,
|
|
78
|
-
}),
|
|
79
|
-
};
|
|
80
|
-
|
|
81
|
-
static override flags = {
|
|
82
|
-
...BaseCommand.baseFlags,
|
|
83
|
-
last: Flags.boolean({
|
|
84
|
-
description: "Export the most recent session",
|
|
85
|
-
default: false,
|
|
86
|
-
}),
|
|
87
|
-
output: Flags.string({
|
|
88
|
-
char: "o",
|
|
89
|
-
description: "Write trace to file instead of stdout",
|
|
90
|
-
}),
|
|
91
|
-
validate: Flags.boolean({
|
|
92
|
-
description: "Validate output against Agent Trace schema",
|
|
93
|
-
default: true,
|
|
94
|
-
allowNo: true,
|
|
95
|
-
}),
|
|
96
|
-
};
|
|
97
|
-
|
|
98
|
-
protected async execute(): Promise<unknown> {
|
|
99
|
-
const { args, flags } = await this.parse(TraceExport);
|
|
100
|
-
this.parsedFlags = flags;
|
|
101
|
-
|
|
102
|
-
const isJson = flags.json || flags.format === "json";
|
|
103
|
-
|
|
104
|
-
// Resolve session ID
|
|
105
|
-
let sessionId = args.sessionId;
|
|
106
|
-
if (flags.last && !sessionId) {
|
|
107
|
-
sessionId = await this.findLastSession();
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
if (!sessionId) {
|
|
111
|
-
this.error("Provide a session ID or use --last");
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
// Collect session data from all sources
|
|
115
|
-
const sessionData = await this.collectSessionData(sessionId);
|
|
116
|
-
if (!sessionData) {
|
|
117
|
-
this.error(`No session found for: ${sessionId}`);
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
// Map to Agent Trace
|
|
121
|
-
const trace = mapToAgentTrace(sessionData);
|
|
122
|
-
|
|
123
|
-
// Validate
|
|
124
|
-
if (flags.validate) {
|
|
125
|
-
const errors = validateAgentTrace(trace);
|
|
126
|
-
if (errors.length > 0) {
|
|
127
|
-
if (!isJson) {
|
|
128
|
-
this.logWarn(`Validation warnings: ${errors.join("; ")}`);
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
// Output
|
|
134
|
-
const json = JSON.stringify(trace, null, 2);
|
|
135
|
-
|
|
136
|
-
if (flags.output) {
|
|
137
|
-
writeFileSync(flags.output, json);
|
|
138
|
-
if (!isJson && !flags.quiet) {
|
|
139
|
-
this.logInfo(`Wrote Agent Trace to ${flags.output}`);
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
if (isJson) {
|
|
144
|
-
return trace;
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
if (!flags.output) {
|
|
148
|
-
this.log(json);
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
return trace;
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
private async findLastSession(): Promise<string | undefined> {
|
|
155
|
-
const manager = getActiveSessionManager();
|
|
156
|
-
const sessions = await manager.listAsync();
|
|
157
|
-
|
|
158
|
-
// Prefer completed sessions, then any
|
|
159
|
-
const completed = sessions.filter((s) => s.status === "completed");
|
|
160
|
-
const target = completed.length > 0 ? completed : sessions;
|
|
161
|
-
|
|
162
|
-
if (target.length === 0) return undefined;
|
|
163
|
-
|
|
164
|
-
// Sort by started_at descending
|
|
165
|
-
target.sort((a, b) => new Date(b.started_at).getTime() - new Date(a.started_at).getTime());
|
|
166
|
-
|
|
167
|
-
return target[0].session_id;
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
private async collectSessionData(sessionId: string): Promise<AbbieSessionData | null> {
|
|
171
|
-
// Source 1: Active sessions (store-first with local fallback)
|
|
172
|
-
const manager = getActiveSessionManager();
|
|
173
|
-
const active = await manager.getAsync(sessionId);
|
|
174
|
-
|
|
175
|
-
// Source 2: Session state (SQLite)
|
|
176
|
-
let sessionState: {
|
|
177
|
-
agent?: string;
|
|
178
|
-
project?: string | null;
|
|
179
|
-
status?: string;
|
|
180
|
-
started_at?: string;
|
|
181
|
-
ended_at?: string | null;
|
|
182
|
-
metadata?: Record<string, unknown>;
|
|
183
|
-
} | null = null;
|
|
184
|
-
try {
|
|
185
|
-
const stateManager = new SessionStateManager();
|
|
186
|
-
sessionState = stateManager.get(sessionId);
|
|
187
|
-
} catch {
|
|
188
|
-
// SQLite not available
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
// Source 3: Mined sessions (agent-specific session files)
|
|
192
|
-
const miner = new AgentSessionMiner();
|
|
193
|
-
let mined: { files_modified?: string[]; commits?: string[]; summary?: string } | null = null;
|
|
194
|
-
try {
|
|
195
|
-
const allMined = miner.mineAll();
|
|
196
|
-
mined = allMined.find((s) => s.id === sessionId) ?? null;
|
|
197
|
-
} catch {
|
|
198
|
-
// Mining failed
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
// Source 4: Git commits during session window
|
|
202
|
-
let gitCommits: string[] = [];
|
|
203
|
-
const cwd = active?.cwd || (sessionState?.metadata?.cwd as string | undefined);
|
|
204
|
-
if (cwd) {
|
|
205
|
-
const startedAt = active?.started_at || sessionState?.started_at;
|
|
206
|
-
if (startedAt) {
|
|
207
|
-
try {
|
|
208
|
-
const out = execSync(`git log --format=%H --since="${startedAt}" 2>/dev/null`, {
|
|
209
|
-
cwd,
|
|
210
|
-
encoding: "utf-8",
|
|
211
|
-
stdio: ["pipe", "pipe", "pipe"],
|
|
212
|
-
}).trim();
|
|
213
|
-
if (out) gitCommits = out.split("\n").map((h: string) => h.slice(0, 7));
|
|
214
|
-
} catch {
|
|
215
|
-
// Not a git repo
|
|
216
|
-
}
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
// Merge all sources
|
|
221
|
-
const agent = active?.agent || (sessionState?.agent as string) || "unknown";
|
|
222
|
-
const project = active?.project || (sessionState?.project as string) || null;
|
|
223
|
-
const metadata = sessionState?.metadata as Record<string, unknown> | undefined;
|
|
224
|
-
const metadataTraceUrl =
|
|
225
|
-
(typeof metadata?.traceUrl === "string" ? metadata.traceUrl : undefined) ||
|
|
226
|
-
(typeof metadata?.trace_url === "string" ? metadata.trace_url : undefined) ||
|
|
227
|
-
(typeof metadata?.braintrust === "object" &&
|
|
228
|
-
metadata?.braintrust !== null &&
|
|
229
|
-
typeof (metadata.braintrust as Record<string, unknown>).trace_url === "string"
|
|
230
|
-
? ((metadata.braintrust as Record<string, unknown>).trace_url as string)
|
|
231
|
-
: undefined);
|
|
232
|
-
const traceUrl = normalizeTraceUrl(active?.trace_url || metadataTraceUrl);
|
|
233
|
-
|
|
234
|
-
if (!active && !sessionState) {
|
|
235
|
-
return null;
|
|
236
|
-
}
|
|
237
|
-
|
|
238
|
-
return {
|
|
239
|
-
sessionId,
|
|
240
|
-
agent,
|
|
241
|
-
project,
|
|
242
|
-
status: active?.status || (sessionState?.status as string) || "unknown",
|
|
243
|
-
startedAt: active?.started_at || sessionState?.started_at || new Date().toISOString(),
|
|
244
|
-
endedAt: sessionState?.ended_at || null,
|
|
245
|
-
traceId: active?.trace_id || (sessionState?.metadata?.trace_id as string | undefined),
|
|
246
|
-
traceUrl,
|
|
247
|
-
issue: active?.issue || (sessionState?.metadata?.issue as string | undefined),
|
|
248
|
-
branch: sessionState?.metadata?.git_branch as string | undefined,
|
|
249
|
-
commits: gitCommits.length > 0 ? gitCommits : mined?.commits,
|
|
250
|
-
filesModified: mined?.files_modified,
|
|
251
|
-
model: sessionState?.metadata?.model as string | undefined,
|
|
252
|
-
cwd,
|
|
253
|
-
};
|
|
254
|
-
}
|
|
255
|
-
}
|