@alexjbarnes/cockpit 0.2.0 → 0.3.1
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/.next/BUILD_ID +1 -1
- package/.next/app-path-routes-manifest.json +16 -3
- package/.next/build-manifest.json +3 -3
- package/.next/prerender-manifest.json +99 -3
- package/.next/react-loadable-manifest.json +18 -2
- package/.next/required-server-files.js +3 -0
- package/.next/required-server-files.json +3 -0
- package/.next/routes-manifest.json +86 -0
- package/.next/server/app/(app)/agents/[name]/page.js +2 -2
- package/.next/server/app/(app)/agents/[name]/page.js.nft.json +1 -1
- package/.next/server/app/(app)/agents/[name]/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/agents/page.js +2 -2
- package/.next/server/app/(app)/agents/page.js.nft.json +1 -1
- package/.next/server/app/(app)/agents/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/changes/page.js +2 -2
- package/.next/server/app/(app)/changes/page.js.nft.json +1 -1
- package/.next/server/app/(app)/changes/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/claude-md/edit/page.js +2 -2
- package/.next/server/app/(app)/claude-md/edit/page.js.nft.json +1 -1
- package/.next/server/app/(app)/claude-md/edit/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/claude-md/page.js +2 -2
- package/.next/server/app/(app)/claude-md/page.js.nft.json +1 -1
- package/.next/server/app/(app)/claude-md/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/commands/[name]/page.js +2 -2
- package/.next/server/app/(app)/commands/[name]/page.js.nft.json +1 -1
- package/.next/server/app/(app)/commands/[name]/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/commands/page.js +2 -2
- package/.next/server/app/(app)/commands/page.js.nft.json +1 -1
- package/.next/server/app/(app)/commands/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/files/page.js +2 -2
- package/.next/server/app/(app)/files/page.js.nft.json +1 -1
- package/.next/server/app/(app)/files/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/hooks/[event]/page.js +3 -3
- package/.next/server/app/(app)/hooks/[event]/page.js.nft.json +1 -1
- package/.next/server/app/(app)/hooks/[event]/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/hooks/page.js +2 -2
- package/.next/server/app/(app)/hooks/page.js.nft.json +1 -1
- package/.next/server/app/(app)/hooks/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/inbox/[id]/page.js +2 -2
- package/.next/server/app/(app)/inbox/[id]/page.js.nft.json +1 -1
- package/.next/server/app/(app)/inbox/[id]/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/inbox/page.js +2 -2
- package/.next/server/app/(app)/inbox/page.js.nft.json +1 -1
- package/.next/server/app/(app)/inbox/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/jobs/[id]/edit/page.js +2 -2
- package/.next/server/app/(app)/jobs/[id]/edit/page.js.nft.json +1 -1
- package/.next/server/app/(app)/jobs/[id]/edit/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/jobs/[id]/page.js +2 -2
- package/.next/server/app/(app)/jobs/[id]/page.js.nft.json +1 -1
- package/.next/server/app/(app)/jobs/[id]/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/jobs/[id]/runs/[runId]/page.js +2 -2
- package/.next/server/app/(app)/jobs/[id]/runs/[runId]/page.js.nft.json +1 -1
- package/.next/server/app/(app)/jobs/[id]/runs/[runId]/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/jobs/page.js +2 -2
- package/.next/server/app/(app)/jobs/page.js.nft.json +1 -1
- package/.next/server/app/(app)/jobs/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/mcp-servers/[name]/page.js +2 -2
- package/.next/server/app/(app)/mcp-servers/[name]/page.js.nft.json +1 -1
- package/.next/server/app/(app)/mcp-servers/[name]/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/mcp-servers/page.js +2 -2
- package/.next/server/app/(app)/mcp-servers/page.js.nft.json +1 -1
- package/.next/server/app/(app)/mcp-servers/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/page.js +2 -2
- package/.next/server/app/(app)/page.js.nft.json +1 -1
- package/.next/server/app/(app)/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/reviews/[owner]/[repo]/[number]/page.js +10 -10
- package/.next/server/app/(app)/reviews/[owner]/[repo]/[number]/page.js.nft.json +1 -1
- package/.next/server/app/(app)/reviews/[owner]/[repo]/[number]/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/reviews/[owner]/[repo]/page.js +2 -2
- package/.next/server/app/(app)/reviews/[owner]/[repo]/page.js.nft.json +1 -1
- package/.next/server/app/(app)/reviews/[owner]/[repo]/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/reviews/page.js +2 -2
- package/.next/server/app/(app)/reviews/page.js.nft.json +1 -1
- package/.next/server/app/(app)/reviews/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/sessions/[id]/page.js +2 -2
- package/.next/server/app/(app)/sessions/[id]/page.js.nft.json +1 -1
- package/.next/server/app/(app)/sessions/[id]/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/settings/appearance/page.js +2 -0
- package/.next/server/app/(app)/settings/appearance/page.js.nft.json +1 -0
- package/.next/server/app/(app)/settings/appearance/page_client-reference-manifest.js +1 -0
- package/.next/server/app/(app)/settings/notifications/page.js +2 -2
- package/.next/server/app/(app)/settings/notifications/page.js.nft.json +1 -1
- package/.next/server/app/(app)/settings/notifications/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/settings/page.js +2 -2
- package/.next/server/app/(app)/settings/page.js.nft.json +1 -1
- package/.next/server/app/(app)/settings/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/settings/providers/[id]/page.js +2 -0
- package/.next/server/app/(app)/settings/providers/[id]/page.js.nft.json +1 -0
- package/.next/server/app/(app)/settings/providers/[id]/page_client-reference-manifest.js +1 -0
- package/.next/server/app/(app)/settings/providers/new/page.js +2 -0
- package/.next/server/app/(app)/settings/providers/new/page.js.nft.json +1 -0
- package/.next/server/app/(app)/settings/providers/new/page_client-reference-manifest.js +1 -0
- package/.next/server/app/(app)/settings/providers/page.js +2 -0
- package/.next/server/app/(app)/settings/providers/page.js.nft.json +1 -0
- package/.next/server/app/(app)/settings/providers/page_client-reference-manifest.js +1 -0
- package/.next/server/app/(app)/settings/session/page.js +2 -0
- package/.next/server/app/(app)/settings/session/page.js.nft.json +1 -0
- package/.next/server/app/(app)/settings/session/page_client-reference-manifest.js +1 -0
- package/.next/server/app/(app)/skills/[name]/page.js +3 -3
- package/.next/server/app/(app)/skills/[name]/page.js.nft.json +1 -1
- package/.next/server/app/(app)/skills/[name]/page_client-reference-manifest.js +1 -1
- package/.next/server/app/(app)/skills/page.js +2 -2
- package/.next/server/app/(app)/skills/page.js.nft.json +1 -1
- package/.next/server/app/(app)/skills/page_client-reference-manifest.js +1 -1
- package/.next/server/app/_global-error/page.js +3 -3
- package/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
- package/.next/server/app/_global-error.html +1 -1
- package/.next/server/app/_global-error.rsc +1 -1
- package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/_not-found/page.js +2 -2
- package/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/.next/server/app/_not-found.html +1 -1
- package/.next/server/app/_not-found.rsc +2 -2
- package/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
- package/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_index.segment.rsc +2 -2
- package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/agents.html +1 -1
- package/.next/server/app/agents.rsc +4 -4
- package/.next/server/app/agents.segments/!KGFwcCk/agents/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/agents.segments/!KGFwcCk/agents.segment.rsc +1 -1
- package/.next/server/app/agents.segments/!KGFwcCk.segment.rsc +2 -2
- package/.next/server/app/agents.segments/_full.segment.rsc +4 -4
- package/.next/server/app/agents.segments/_head.segment.rsc +1 -1
- package/.next/server/app/agents.segments/_index.segment.rsc +2 -2
- package/.next/server/app/agents.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/api/agents/[name]/route.js +1 -1
- package/.next/server/app/api/agents/route.js +1 -1
- package/.next/server/app/api/auth/check/route.js +1 -1
- package/.next/server/app/api/auth/login/route.js +1 -1
- package/.next/server/app/api/auth/setup/route.js +1 -1
- package/.next/server/app/api/auth/ws-token/route.js +1 -1
- package/.next/server/app/api/btw/route.js +2 -2
- package/.next/server/app/api/claude-md/route.js +1 -1
- package/.next/server/app/api/commands/[name]/route.js +1 -1
- package/.next/server/app/api/commands/route.js +1 -1
- package/.next/server/app/api/defaults/route.js +1 -1
- package/.next/server/app/api/filesystem/browse/route.js +1 -1
- package/.next/server/app/api/filesystem/files/route.js +1 -1
- package/.next/server/app/api/filesystem/mkdir/route.js +1 -1
- package/.next/server/app/api/filesystem/read/route.js +1 -1
- package/.next/server/app/api/git/clone/route.js +1 -1
- package/.next/server/app/api/git/commit/route.js +1 -1
- package/.next/server/app/api/git/diff/route.js +1 -1
- package/.next/server/app/api/git/discard/route.js +1 -1
- package/.next/server/app/api/git/generate-message/route.js +2 -2
- package/.next/server/app/api/git/push/route.js +1 -1
- package/.next/server/app/api/git/status/route.js +1 -1
- package/.next/server/app/api/github/file-content/route.js +1 -1
- package/.next/server/app/api/github/orgs/route.js +1 -1
- package/.next/server/app/api/github/prs/checks/route.js +1 -1
- package/.next/server/app/api/github/prs/diff/route.js +1 -1
- package/.next/server/app/api/github/prs/review/route.js +1 -1
- package/.next/server/app/api/github/prs/route.js +1 -1
- package/.next/server/app/api/github/prs/view/route.js +1 -1
- package/.next/server/app/api/github/repos/route.js +1 -1
- package/.next/server/app/api/github/review-session/route.js +1 -1
- package/.next/server/app/api/github/review-session/route.js.nft.json +1 -1
- package/.next/server/app/api/health/route.js +1 -1
- package/.next/server/app/api/hooks/route.js +1 -1
- package/.next/server/app/api/inbox/[id]/route.js +2 -2
- package/.next/server/app/api/inbox/route.js +2 -2
- package/.next/server/app/api/jobs/[id]/route.js +1 -1
- package/.next/server/app/api/jobs/[id]/route.js.nft.json +1 -1
- package/.next/server/app/api/jobs/[id]/runs/[runId]/route.js +1 -1
- package/.next/server/app/api/jobs/[id]/runs/[runId]/transcript/route.js +1 -1
- package/.next/server/app/api/jobs/[id]/runs/route.js +1 -1
- package/.next/server/app/api/jobs/[id]/trigger/route.js +1 -1
- package/.next/server/app/api/jobs/[id]/trigger/route.js.nft.json +1 -1
- package/.next/server/app/api/jobs/mcp-discover/route.js +1 -1
- package/.next/server/app/api/jobs/mcp-discover/route.js.nft.json +1 -1
- package/.next/server/app/api/jobs/route.js +1 -1
- package/.next/server/app/api/jobs/route.js.nft.json +1 -1
- package/.next/server/app/api/jobs/status/route.js +1 -1
- package/.next/server/app/api/mcp-servers/[name]/route.js +1 -1
- package/.next/server/app/api/mcp-servers/[name]/test/route.js +1 -1
- package/.next/server/app/api/mcp-servers/route.js +1 -1
- package/.next/server/app/api/notifications/route.js +1 -1
- package/.next/server/app/api/notifications/test/route.js +1 -1
- package/.next/server/app/api/providers/[id]/route.js +1 -0
- package/.next/server/app/api/providers/[id]/route.js.nft.json +1 -0
- package/.next/server/app/api/providers/[id]/route_client-reference-manifest.js +1 -0
- package/.next/server/app/api/providers/route.js +1 -0
- package/.next/server/app/api/providers/route.js.nft.json +1 -0
- package/.next/server/app/api/providers/route_client-reference-manifest.js +1 -0
- package/.next/server/app/api/reviews/pinned/route.js +1 -1
- package/.next/server/app/api/sessions/[id]/context/route.js +1 -1
- package/.next/server/app/api/sessions/[id]/mcp/route.js +1 -1
- package/.next/server/app/api/sessions/[id]/mcp/route.js.nft.json +1 -1
- package/.next/server/app/api/sessions/[id]/route.js +1 -1
- package/.next/server/app/api/sessions/[id]/route.js.nft.json +1 -1
- package/.next/server/app/api/sessions/[id]/search/route.js +1 -1
- package/.next/server/app/api/sessions/[id]/tabs/route.js +1 -0
- package/.next/server/app/api/sessions/[id]/tabs/route.js.nft.json +1 -0
- package/.next/server/app/api/sessions/[id]/tabs/route_client-reference-manifest.js +1 -0
- package/.next/server/app/api/sessions/bulk-delete/route.js +1 -1
- package/.next/server/app/api/sessions/bulk-delete/route.js.nft.json +1 -1
- package/.next/server/app/api/sessions/by-ids/route.js +1 -1
- package/.next/server/app/api/sessions/by-ids/route.js.nft.json +1 -1
- package/.next/server/app/api/sessions/group/route.js +1 -1
- package/.next/server/app/api/sessions/group/route.js.nft.json +1 -1
- package/.next/server/app/api/sessions/pinned/route.js +1 -1
- package/.next/server/app/api/sessions/route.js +1 -1
- package/.next/server/app/api/sessions/route.js.nft.json +1 -1
- package/.next/server/app/api/sessions/search/route.js +1 -1
- package/.next/server/app/api/sessions/thinking/route.js +1 -0
- package/.next/server/app/api/sessions/thinking/route.js.nft.json +1 -0
- package/.next/server/app/api/sessions/thinking/route_client-reference-manifest.js +1 -0
- package/.next/server/app/api/skills/[name]/route.js +1 -1
- package/.next/server/app/api/skills/route.js +1 -1
- package/.next/server/app/api/terminal/[id]/route.js +1 -0
- package/.next/server/app/api/terminal/[id]/route.js.nft.json +1 -0
- package/.next/server/app/api/terminal/[id]/route_client-reference-manifest.js +1 -0
- package/.next/server/app/api/terminal/route.js +1 -0
- package/.next/server/app/api/terminal/route.js.nft.json +1 -0
- package/.next/server/app/api/terminal/route_client-reference-manifest.js +1 -0
- package/.next/server/app/api/usage/route.js +1 -1
- package/.next/server/app/api/version/changelog/route.js +1 -0
- package/.next/server/app/api/version/changelog/route.js.nft.json +1 -0
- package/.next/server/app/api/version/changelog/route_client-reference-manifest.js +1 -0
- package/.next/server/app/api/version/cockpit/changelog/route.js +1 -0
- package/.next/server/app/api/version/cockpit/changelog/route.js.nft.json +1 -0
- package/.next/server/app/api/version/cockpit/changelog/route_client-reference-manifest.js +1 -0
- package/.next/server/app/api/version/cockpit/route.js +1 -1
- package/.next/server/app/api/version/route.js +2 -2
- package/.next/server/app/changes.html +1 -1
- package/.next/server/app/changes.rsc +4 -4
- package/.next/server/app/changes.segments/!KGFwcCk/changes/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/changes.segments/!KGFwcCk/changes.segment.rsc +1 -1
- package/.next/server/app/changes.segments/!KGFwcCk.segment.rsc +2 -2
- package/.next/server/app/changes.segments/_full.segment.rsc +4 -4
- package/.next/server/app/changes.segments/_head.segment.rsc +1 -1
- package/.next/server/app/changes.segments/_index.segment.rsc +2 -2
- package/.next/server/app/changes.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/claude-md/edit.html +1 -1
- package/.next/server/app/claude-md/edit.rsc +4 -4
- package/.next/server/app/claude-md/edit.segments/!KGFwcCk/claude-md/edit/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/claude-md/edit.segments/!KGFwcCk/claude-md/edit.segment.rsc +1 -1
- package/.next/server/app/claude-md/edit.segments/!KGFwcCk/claude-md.segment.rsc +1 -1
- package/.next/server/app/claude-md/edit.segments/!KGFwcCk.segment.rsc +2 -2
- package/.next/server/app/claude-md/edit.segments/_full.segment.rsc +4 -4
- package/.next/server/app/claude-md/edit.segments/_head.segment.rsc +1 -1
- package/.next/server/app/claude-md/edit.segments/_index.segment.rsc +2 -2
- package/.next/server/app/claude-md/edit.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/claude-md.html +1 -1
- package/.next/server/app/claude-md.rsc +4 -4
- package/.next/server/app/claude-md.segments/!KGFwcCk/claude-md/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/claude-md.segments/!KGFwcCk/claude-md.segment.rsc +1 -1
- package/.next/server/app/claude-md.segments/!KGFwcCk.segment.rsc +2 -2
- package/.next/server/app/claude-md.segments/_full.segment.rsc +4 -4
- package/.next/server/app/claude-md.segments/_head.segment.rsc +1 -1
- package/.next/server/app/claude-md.segments/_index.segment.rsc +2 -2
- package/.next/server/app/claude-md.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/commands.html +1 -1
- package/.next/server/app/commands.rsc +4 -4
- package/.next/server/app/commands.segments/!KGFwcCk/commands/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/commands.segments/!KGFwcCk/commands.segment.rsc +1 -1
- package/.next/server/app/commands.segments/!KGFwcCk.segment.rsc +2 -2
- package/.next/server/app/commands.segments/_full.segment.rsc +4 -4
- package/.next/server/app/commands.segments/_head.segment.rsc +1 -1
- package/.next/server/app/commands.segments/_index.segment.rsc +2 -2
- package/.next/server/app/commands.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/files.html +1 -1
- package/.next/server/app/files.rsc +4 -4
- package/.next/server/app/files.segments/!KGFwcCk/files/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/files.segments/!KGFwcCk/files.segment.rsc +1 -1
- package/.next/server/app/files.segments/!KGFwcCk.segment.rsc +2 -2
- package/.next/server/app/files.segments/_full.segment.rsc +4 -4
- package/.next/server/app/files.segments/_head.segment.rsc +1 -1
- package/.next/server/app/files.segments/_index.segment.rsc +2 -2
- package/.next/server/app/files.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/hooks.html +1 -1
- package/.next/server/app/hooks.rsc +4 -4
- package/.next/server/app/hooks.segments/!KGFwcCk/hooks/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/hooks.segments/!KGFwcCk/hooks.segment.rsc +1 -1
- package/.next/server/app/hooks.segments/!KGFwcCk.segment.rsc +2 -2
- package/.next/server/app/hooks.segments/_full.segment.rsc +4 -4
- package/.next/server/app/hooks.segments/_head.segment.rsc +1 -1
- package/.next/server/app/hooks.segments/_index.segment.rsc +2 -2
- package/.next/server/app/hooks.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/inbox.html +1 -1
- package/.next/server/app/inbox.rsc +4 -4
- package/.next/server/app/inbox.segments/!KGFwcCk/inbox/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/inbox.segments/!KGFwcCk/inbox.segment.rsc +1 -1
- package/.next/server/app/inbox.segments/!KGFwcCk.segment.rsc +2 -2
- package/.next/server/app/inbox.segments/_full.segment.rsc +4 -4
- package/.next/server/app/inbox.segments/_head.segment.rsc +1 -1
- package/.next/server/app/inbox.segments/_index.segment.rsc +2 -2
- package/.next/server/app/inbox.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/index.html +1 -1
- package/.next/server/app/index.rsc +4 -4
- package/.next/server/app/index.segments/!KGFwcCk/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/index.segments/!KGFwcCk.segment.rsc +2 -2
- package/.next/server/app/index.segments/_full.segment.rsc +4 -4
- package/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/.next/server/app/index.segments/_index.segment.rsc +2 -2
- package/.next/server/app/index.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/jobs.html +1 -1
- package/.next/server/app/jobs.rsc +4 -4
- package/.next/server/app/jobs.segments/!KGFwcCk/jobs/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/jobs.segments/!KGFwcCk/jobs.segment.rsc +1 -1
- package/.next/server/app/jobs.segments/!KGFwcCk.segment.rsc +2 -2
- package/.next/server/app/jobs.segments/_full.segment.rsc +4 -4
- package/.next/server/app/jobs.segments/_head.segment.rsc +1 -1
- package/.next/server/app/jobs.segments/_index.segment.rsc +2 -2
- package/.next/server/app/jobs.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/login/page.js +2 -2
- package/.next/server/app/login/page_client-reference-manifest.js +1 -1
- package/.next/server/app/login.html +1 -1
- package/.next/server/app/login.rsc +2 -2
- package/.next/server/app/login.segments/_full.segment.rsc +2 -2
- package/.next/server/app/login.segments/_head.segment.rsc +1 -1
- package/.next/server/app/login.segments/_index.segment.rsc +2 -2
- package/.next/server/app/login.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/login.segments/login/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/login.segments/login.segment.rsc +1 -1
- package/.next/server/app/mcp-servers.html +1 -1
- package/.next/server/app/mcp-servers.rsc +4 -4
- package/.next/server/app/mcp-servers.segments/!KGFwcCk/mcp-servers/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/mcp-servers.segments/!KGFwcCk/mcp-servers.segment.rsc +1 -1
- package/.next/server/app/mcp-servers.segments/!KGFwcCk.segment.rsc +2 -2
- package/.next/server/app/mcp-servers.segments/_full.segment.rsc +4 -4
- package/.next/server/app/mcp-servers.segments/_head.segment.rsc +1 -1
- package/.next/server/app/mcp-servers.segments/_index.segment.rsc +2 -2
- package/.next/server/app/mcp-servers.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/reviews.html +1 -1
- package/.next/server/app/reviews.rsc +4 -4
- package/.next/server/app/reviews.segments/!KGFwcCk/reviews/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/reviews.segments/!KGFwcCk/reviews.segment.rsc +1 -1
- package/.next/server/app/reviews.segments/!KGFwcCk.segment.rsc +2 -2
- package/.next/server/app/reviews.segments/_full.segment.rsc +4 -4
- package/.next/server/app/reviews.segments/_head.segment.rsc +1 -1
- package/.next/server/app/reviews.segments/_index.segment.rsc +2 -2
- package/.next/server/app/reviews.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/settings/appearance.html +1 -0
- package/.next/server/app/settings/appearance.meta +17 -0
- package/.next/server/app/settings/appearance.rsc +23 -0
- package/.next/server/app/settings/appearance.segments/!KGFwcCk/settings/appearance/__PAGE__.segment.rsc +9 -0
- package/.next/server/app/settings/appearance.segments/!KGFwcCk/settings/appearance.segment.rsc +5 -0
- package/.next/server/app/settings/appearance.segments/!KGFwcCk/settings.segment.rsc +5 -0
- package/.next/server/app/settings/appearance.segments/!KGFwcCk.segment.rsc +7 -0
- package/.next/server/app/settings/appearance.segments/_full.segment.rsc +23 -0
- package/.next/server/app/settings/appearance.segments/_head.segment.rsc +6 -0
- package/.next/server/app/settings/appearance.segments/_index.segment.rsc +5 -0
- package/.next/server/app/settings/appearance.segments/_tree.segment.rsc +2 -0
- package/.next/server/app/settings/notifications.html +1 -1
- package/.next/server/app/settings/notifications.rsc +4 -4
- package/.next/server/app/settings/notifications.segments/!KGFwcCk/settings/notifications/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/settings/notifications.segments/!KGFwcCk/settings/notifications.segment.rsc +1 -1
- package/.next/server/app/settings/notifications.segments/!KGFwcCk/settings.segment.rsc +1 -1
- package/.next/server/app/settings/notifications.segments/!KGFwcCk.segment.rsc +2 -2
- package/.next/server/app/settings/notifications.segments/_full.segment.rsc +4 -4
- package/.next/server/app/settings/notifications.segments/_head.segment.rsc +1 -1
- package/.next/server/app/settings/notifications.segments/_index.segment.rsc +2 -2
- package/.next/server/app/settings/notifications.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/settings/providers/new.html +1 -0
- package/.next/server/app/settings/providers/new.meta +18 -0
- package/.next/server/app/settings/providers/new.rsc +23 -0
- package/.next/server/app/settings/providers/new.segments/!KGFwcCk/settings/providers/new/__PAGE__.segment.rsc +9 -0
- package/.next/server/app/settings/providers/new.segments/!KGFwcCk/settings/providers/new.segment.rsc +5 -0
- package/.next/server/app/settings/providers/new.segments/!KGFwcCk/settings/providers.segment.rsc +5 -0
- package/.next/server/app/settings/providers/new.segments/!KGFwcCk/settings.segment.rsc +5 -0
- package/.next/server/app/settings/providers/new.segments/!KGFwcCk.segment.rsc +7 -0
- package/.next/server/app/settings/providers/new.segments/_full.segment.rsc +23 -0
- package/.next/server/app/settings/providers/new.segments/_head.segment.rsc +6 -0
- package/.next/server/app/settings/providers/new.segments/_index.segment.rsc +5 -0
- package/.next/server/app/settings/providers/new.segments/_tree.segment.rsc +2 -0
- package/.next/server/app/settings/providers.html +1 -0
- package/.next/server/app/settings/providers.meta +17 -0
- package/.next/server/app/settings/providers.rsc +23 -0
- package/.next/server/app/settings/providers.segments/!KGFwcCk/settings/providers/__PAGE__.segment.rsc +9 -0
- package/.next/server/app/settings/providers.segments/!KGFwcCk/settings/providers.segment.rsc +5 -0
- package/.next/server/app/settings/providers.segments/!KGFwcCk/settings.segment.rsc +5 -0
- package/.next/server/app/settings/providers.segments/!KGFwcCk.segment.rsc +7 -0
- package/.next/server/app/settings/providers.segments/_full.segment.rsc +23 -0
- package/.next/server/app/settings/providers.segments/_head.segment.rsc +6 -0
- package/.next/server/app/settings/providers.segments/_index.segment.rsc +5 -0
- package/.next/server/app/settings/providers.segments/_tree.segment.rsc +2 -0
- package/.next/server/app/settings/session.html +1 -0
- package/.next/server/app/settings/session.meta +17 -0
- package/.next/server/app/settings/session.rsc +23 -0
- package/.next/server/app/settings/session.segments/!KGFwcCk/settings/session/__PAGE__.segment.rsc +9 -0
- package/.next/server/app/settings/session.segments/!KGFwcCk/settings/session.segment.rsc +5 -0
- package/.next/server/app/settings/session.segments/!KGFwcCk/settings.segment.rsc +5 -0
- package/.next/server/app/settings/session.segments/!KGFwcCk.segment.rsc +7 -0
- package/.next/server/app/settings/session.segments/_full.segment.rsc +23 -0
- package/.next/server/app/settings/session.segments/_head.segment.rsc +6 -0
- package/.next/server/app/settings/session.segments/_index.segment.rsc +5 -0
- package/.next/server/app/settings/session.segments/_tree.segment.rsc +2 -0
- package/.next/server/app/settings.html +1 -1
- package/.next/server/app/settings.rsc +4 -4
- package/.next/server/app/settings.segments/!KGFwcCk/settings/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/settings.segments/!KGFwcCk/settings.segment.rsc +1 -1
- package/.next/server/app/settings.segments/!KGFwcCk.segment.rsc +2 -2
- package/.next/server/app/settings.segments/_full.segment.rsc +4 -4
- package/.next/server/app/settings.segments/_head.segment.rsc +1 -1
- package/.next/server/app/settings.segments/_index.segment.rsc +2 -2
- package/.next/server/app/settings.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/skills.html +1 -1
- package/.next/server/app/skills.rsc +4 -4
- package/.next/server/app/skills.segments/!KGFwcCk/skills/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/skills.segments/!KGFwcCk/skills.segment.rsc +1 -1
- package/.next/server/app/skills.segments/!KGFwcCk.segment.rsc +2 -2
- package/.next/server/app/skills.segments/_full.segment.rsc +4 -4
- package/.next/server/app/skills.segments/_head.segment.rsc +1 -1
- package/.next/server/app/skills.segments/_index.segment.rsc +2 -2
- package/.next/server/app/skills.segments/_tree.segment.rsc +2 -2
- package/.next/server/app-paths-manifest.json +16 -3
- package/.next/server/chunks/1002.js +18 -0
- package/.next/server/chunks/1011.js +1 -0
- package/.next/server/chunks/1659.js +1 -1
- package/.next/server/chunks/1979.js +2 -2
- package/.next/server/chunks/2408.js +1 -1
- package/.next/server/chunks/{7627.js → 3006.js} +3 -3
- package/.next/server/chunks/3434.js +1 -0
- package/.next/server/chunks/{5920.js → 4342.js} +1 -1
- package/.next/server/chunks/4352.js +1 -0
- package/.next/server/chunks/4445.js +1 -1
- package/.next/server/chunks/7782.js +6 -0
- package/.next/server/chunks/8148.js +1 -0
- package/.next/server/chunks/9599.js +11 -0
- package/.next/server/middleware-build-manifest.js +1 -1
- package/.next/server/middleware-react-loadable-manifest.js +1 -1
- package/.next/server/pages/404.html +1 -1
- package/.next/server/pages/500.html +1 -1
- package/.next/server/server-reference-manifest.json +1 -1
- package/.next/static/I-rxZaJEzhe3ZUTjSqB11/_buildManifest.js +1 -0
- package/.next/static/chunks/{35922.5bdf78a760129504.js → 13541.056c34ca7fde6869.js} +1 -1
- package/.next/static/chunks/26126-97874904b42befb8.js +1 -0
- package/.next/static/chunks/31010-6e87f77b97544424.js +1 -0
- package/.next/static/chunks/3765-d323c6675307a63e.js +20 -0
- package/.next/static/chunks/{11242-d240a18d4e59390b.js → 41487-d802643f4a8fad3c.js} +5 -5
- package/.next/static/chunks/48273-fb393846bb4333c0.js +6 -0
- package/.next/static/chunks/63606.a387b0261d6523ab.js +1 -0
- package/.next/static/chunks/6935-f436a624267529fb.js +1 -0
- package/.next/static/chunks/{69427.0f379c6bdea95405.js → 69427.a0b463c808aa54c8.js} +1 -1
- package/.next/static/chunks/86939-dfc6f8eb395caa89.js +1 -0
- package/.next/static/chunks/app/(app)/agents/[name]/page-8bdd0359043537d4.js +8 -0
- package/.next/static/chunks/app/(app)/agents/page-6fcfd7ab6781814e.js +1 -0
- package/.next/static/chunks/app/(app)/changes/page-4549a5bd72d77e3e.js +1 -0
- package/.next/static/chunks/app/(app)/claude-md/edit/page-08e6e120e71979f4.js +1 -0
- package/.next/static/chunks/app/(app)/claude-md/page-cd9e2176a12ba241.js +1 -0
- package/.next/static/chunks/app/(app)/commands/[name]/page-7cdfdef29ded0aa0.js +6 -0
- package/.next/static/chunks/app/(app)/commands/page-f126b608b04747ac.js +1 -0
- package/.next/static/chunks/app/(app)/files/page-f526eb95821e000e.js +1 -0
- package/.next/static/chunks/app/(app)/hooks/[event]/page-28038323fd29adfa.js +6 -0
- package/.next/static/chunks/app/(app)/hooks/page-f1f39284e53c0344.js +1 -0
- package/.next/static/chunks/app/(app)/inbox/[id]/page-bc1ff3a0db0114a4.js +1 -0
- package/.next/static/chunks/app/(app)/inbox/page-82e03870103ce9bd.js +1 -0
- package/.next/static/chunks/app/(app)/jobs/[id]/edit/page-7fb788f772ff2129.js +1 -0
- package/.next/static/chunks/app/(app)/jobs/[id]/page-a5856b9ae967ff59.js +1 -0
- package/.next/static/chunks/app/(app)/jobs/[id]/runs/[runId]/page-b7c513402db11db6.js +1 -0
- package/.next/static/chunks/app/(app)/jobs/page-e9bbd6c116b9699f.js +1 -0
- package/.next/static/chunks/app/(app)/{layout-81c1899969de11e6.js → layout-ce9e1be301c60fe5.js} +1 -1
- package/.next/static/chunks/app/(app)/mcp-servers/[name]/page-d6d805a27ec0b0c0.js +1 -0
- package/.next/static/chunks/app/(app)/mcp-servers/page-4b7276d43451cd43.js +1 -0
- package/.next/static/chunks/app/(app)/page-027a5382da30ddb9.js +1 -0
- package/.next/static/chunks/app/(app)/reviews/[owner]/[repo]/[number]/page-9ab2955c455bb5fa.js +13 -0
- package/.next/static/chunks/app/(app)/reviews/[owner]/[repo]/{page-c7473a899c7c59c3.js → page-c5fd013309ab3eba.js} +1 -1
- package/.next/static/chunks/app/(app)/reviews/{page-0e6e7395a4f62b50.js → page-47530d93bb9d4a76.js} +1 -1
- package/.next/static/chunks/app/(app)/sessions/[id]/page-94f891e1b54fd05f.js +1 -0
- package/.next/static/chunks/app/(app)/settings/appearance/page-95902da748ac5f1e.js +1 -0
- package/.next/static/chunks/app/(app)/settings/notifications/{page-a28db2ebc9fd0de8.js → page-229f1db6beb1d19c.js} +1 -1
- package/.next/static/chunks/app/(app)/settings/page-8ed16a66fdde10cd.js +1 -0
- package/.next/static/chunks/app/(app)/settings/providers/[id]/page-13654263246617b3.js +1 -0
- package/.next/static/chunks/app/(app)/settings/providers/new/page-e1798e321ccbc6df.js +1 -0
- package/.next/static/chunks/app/(app)/settings/providers/page-0bb4c1db2ee35b3d.js +1 -0
- package/.next/static/chunks/app/(app)/settings/session/page-ab216a8fa37a0f76.js +1 -0
- package/.next/static/chunks/app/(app)/skills/[name]/page-8ab85d5090967ee4.js +6 -0
- package/.next/static/chunks/app/(app)/skills/page-c52773eacb27c04e.js +1 -0
- package/.next/static/chunks/app/_global-error/page-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/agents/[name]/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/agents/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/auth/check/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/auth/login/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/auth/setup/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/auth/ws-token/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/btw/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/claude-md/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/commands/[name]/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/commands/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/defaults/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/filesystem/browse/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/filesystem/files/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/filesystem/mkdir/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/filesystem/read/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/git/clone/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/git/commit/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/git/diff/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/git/discard/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/git/generate-message/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/git/push/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/git/status/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/github/file-content/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/github/orgs/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/github/prs/checks/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/github/prs/diff/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/github/prs/review/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/github/prs/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/github/prs/view/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/github/repos/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/github/review-session/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/health/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/hooks/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/inbox/[id]/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/inbox/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/jobs/[id]/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/transcript/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/jobs/[id]/runs/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/jobs/[id]/trigger/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/jobs/mcp-discover/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/jobs/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/jobs/status/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/mcp-servers/[name]/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/mcp-servers/[name]/test/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/mcp-servers/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/notifications/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/notifications/test/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/providers/[id]/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/providers/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/reviews/pinned/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/sessions/[id]/context/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/sessions/[id]/mcp/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/sessions/[id]/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/sessions/[id]/search/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/sessions/[id]/tabs/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/sessions/bulk-delete/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/sessions/by-ids/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/sessions/group/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/sessions/pinned/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/sessions/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/sessions/search/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/sessions/thinking/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/skills/[name]/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/skills/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/terminal/[id]/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/terminal/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/usage/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/version/changelog/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/version/cockpit/changelog/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/version/cockpit/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/app/api/version/route-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/e868780c.f24b6da08e62c7b2.js +18 -0
- package/.next/static/chunks/next/dist/client/components/builtin/app-error-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/next/dist/client/components/builtin/forbidden-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/next/dist/client/components/builtin/not-found-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/next/dist/client/components/builtin/unauthorized-fc747760bd4c8a4b.js +1 -0
- package/.next/static/chunks/webpack-e31bb45fa59caed8.js +1 -0
- package/.next/static/css/3f8af4ae6f812d5c.css +1 -0
- package/README.md +12 -3
- package/bin/cockpit-hook-bridge.mjs +170 -0
- package/dist/server.js +11 -1
- package/dist/src/lib/models.js +48 -7
- package/dist/src/server/auth.js +32 -10
- package/dist/src/server/claude-settings.js +153 -0
- package/dist/src/server/cli-init-fetch.js +86 -0
- package/dist/src/server/cron-utils.js +16 -5
- package/dist/src/server/debug-logger.js +2 -2
- package/dist/src/server/defaults.js +16 -7
- package/dist/src/server/fs-watcher.js +50 -0
- package/dist/src/server/hook-bridge-path.js +34 -0
- package/dist/src/server/hook-event-translator.js +211 -0
- package/dist/src/server/hook-router.js +150 -0
- package/dist/src/server/inbox.js +14 -10
- package/dist/src/server/job-lock.js +103 -0
- package/dist/src/server/job-scheduler.js +23 -8
- package/dist/src/server/job-storage.js +28 -13
- package/dist/src/server/notification-settings.js +13 -9
- package/dist/src/server/paths.js +23 -0
- package/dist/src/server/plans.js +8 -5
- package/dist/src/server/providers.js +128 -0
- package/dist/src/server/pty-runtime.js +324 -0
- package/dist/src/server/pty-session.js +178 -0
- package/dist/src/server/session-manager.js +727 -144
- package/dist/src/server/session-prefs.js +33 -8
- package/dist/src/server/singleton.js +18 -0
- package/dist/src/server/stream-processor.js +61 -48
- package/dist/src/server/terminal-manager.js +153 -0
- package/dist/src/server/todo-watcher.js +178 -0
- package/dist/src/server/transcript-watcher.js +91 -0
- package/dist/src/server/transcript.js +177 -11
- package/dist/src/server/ws-handler.js +235 -61
- package/next.config.ts +1 -0
- package/package.json +10 -3
- package/public/fonts/symbols-nerd-font-mono.woff2 +0 -0
- package/.next/server/chunks/1941.js +0 -9
- package/.next/server/chunks/2444.js +0 -6
- package/.next/static/brzairTqHmHwvfgKpdkYX/_buildManifest.js +0 -1
- package/.next/static/chunks/3765-a4c7a493ec83f918.js +0 -20
- package/.next/static/chunks/75866-76a3987dda1295ae.js +0 -1
- package/.next/static/chunks/93273-87110c1449e1e7fd.js +0 -6
- package/.next/static/chunks/app/(app)/agents/[name]/page-3ec9a3460e8e9006.js +0 -8
- package/.next/static/chunks/app/(app)/agents/page-d6d504e7d7757ea2.js +0 -1
- package/.next/static/chunks/app/(app)/changes/page-a09bf4742aa8b5ce.js +0 -1
- package/.next/static/chunks/app/(app)/claude-md/edit/page-ab42921ba2618dc3.js +0 -1
- package/.next/static/chunks/app/(app)/claude-md/page-c4c8b20aa002a94a.js +0 -1
- package/.next/static/chunks/app/(app)/commands/[name]/page-2124ffed9a4e95a3.js +0 -6
- package/.next/static/chunks/app/(app)/commands/page-d5bf1bddd17e31dd.js +0 -1
- package/.next/static/chunks/app/(app)/files/page-04e4e5bf1ca89945.js +0 -1
- package/.next/static/chunks/app/(app)/hooks/[event]/page-d988623e739973b5.js +0 -6
- package/.next/static/chunks/app/(app)/hooks/page-818242d7db432578.js +0 -1
- package/.next/static/chunks/app/(app)/inbox/[id]/page-c33dc94e309ff117.js +0 -1
- package/.next/static/chunks/app/(app)/inbox/page-ca3e1724b5072734.js +0 -1
- package/.next/static/chunks/app/(app)/jobs/[id]/edit/page-3a1c927d76333bf0.js +0 -1
- package/.next/static/chunks/app/(app)/jobs/[id]/page-8e698e00b90968b0.js +0 -1
- package/.next/static/chunks/app/(app)/jobs/[id]/runs/[runId]/page-f942df0b7c1d280b.js +0 -1
- package/.next/static/chunks/app/(app)/jobs/page-7a88cc6ac34550c2.js +0 -1
- package/.next/static/chunks/app/(app)/mcp-servers/[name]/page-3541bf3ccdef9145.js +0 -1
- package/.next/static/chunks/app/(app)/mcp-servers/page-3927dfd03d921040.js +0 -1
- package/.next/static/chunks/app/(app)/page-594120e0ea1df527.js +0 -1
- package/.next/static/chunks/app/(app)/reviews/[owner]/[repo]/[number]/page-74c23b04f5c3ff88.js +0 -13
- package/.next/static/chunks/app/(app)/sessions/[id]/page-435e9fb4dd34007d.js +0 -1
- package/.next/static/chunks/app/(app)/settings/page-f8ada7997c0d5b03.js +0 -1
- package/.next/static/chunks/app/(app)/skills/[name]/page-5dbe1e7682880145.js +0 -6
- package/.next/static/chunks/app/(app)/skills/page-fd1986ad7e060f4d.js +0 -1
- package/.next/static/chunks/app/_global-error/page-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/agents/[name]/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/agents/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/auth/check/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/auth/login/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/auth/setup/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/auth/ws-token/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/btw/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/claude-md/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/commands/[name]/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/commands/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/defaults/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/filesystem/browse/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/filesystem/files/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/filesystem/mkdir/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/filesystem/read/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/git/clone/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/git/commit/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/git/diff/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/git/discard/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/git/generate-message/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/git/push/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/git/status/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/github/file-content/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/github/orgs/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/github/prs/checks/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/github/prs/diff/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/github/prs/review/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/github/prs/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/github/prs/view/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/github/repos/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/github/review-session/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/health/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/hooks/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/inbox/[id]/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/inbox/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/jobs/[id]/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/transcript/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/jobs/[id]/runs/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/jobs/[id]/trigger/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/jobs/mcp-discover/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/jobs/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/jobs/status/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/mcp-servers/[name]/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/mcp-servers/[name]/test/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/mcp-servers/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/notifications/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/notifications/test/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/reviews/pinned/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/sessions/[id]/context/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/sessions/[id]/mcp/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/sessions/[id]/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/sessions/[id]/search/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/sessions/bulk-delete/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/sessions/by-ids/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/sessions/group/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/sessions/pinned/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/sessions/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/sessions/search/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/skills/[name]/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/skills/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/usage/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/version/cockpit/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/app/api/version/route-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/next/dist/client/components/builtin/app-error-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/next/dist/client/components/builtin/forbidden-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/next/dist/client/components/builtin/not-found-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/next/dist/client/components/builtin/unauthorized-65c661eddfc65f5b.js +0 -1
- package/.next/static/chunks/webpack-3461a05957b13f46.js +0 -1
- package/.next/static/css/f04f303b5708dd90.css +0 -1
- /package/.next/static/{brzairTqHmHwvfgKpdkYX → I-rxZaJEzhe3ZUTjSqB11}/_ssgManifest.js +0 -0
|
@@ -5,15 +5,88 @@ const ws_1 = require("ws");
|
|
|
5
5
|
const auth_1 = require("./auth");
|
|
6
6
|
// loadLastUsage no longer needed - usage is returned by loadTranscript
|
|
7
7
|
const debug_logger_1 = require("./debug-logger");
|
|
8
|
+
const fs_watcher_1 = require("./fs-watcher");
|
|
8
9
|
const plans_1 = require("./plans");
|
|
9
|
-
const session_manager_1 = require("./session-manager");
|
|
10
10
|
const session_prefs_1 = require("./session-prefs");
|
|
11
|
-
|
|
11
|
+
const RESIZE_PREFIX = "\x01R";
|
|
12
|
+
function setupTerminalWebSocket(terminalWss, terminalManager) {
|
|
13
|
+
const heartbeat = setInterval(() => {
|
|
14
|
+
for (const ws of terminalWss.clients) {
|
|
15
|
+
const ext = ws;
|
|
16
|
+
if (ext.isAlive === false) {
|
|
17
|
+
ws.terminate();
|
|
18
|
+
continue;
|
|
19
|
+
}
|
|
20
|
+
ext.isAlive = false;
|
|
21
|
+
ws.ping();
|
|
22
|
+
}
|
|
23
|
+
}, 30000);
|
|
24
|
+
terminalWss.on("close", () => {
|
|
25
|
+
clearInterval(heartbeat);
|
|
26
|
+
});
|
|
27
|
+
terminalWss.on("connection", (ws, req) => {
|
|
28
|
+
const ext = ws;
|
|
29
|
+
ext.isAlive = true;
|
|
30
|
+
ws.on("pong", () => {
|
|
31
|
+
ext.isAlive = true;
|
|
32
|
+
});
|
|
33
|
+
const url = new URL(req.url || "", "http://localhost");
|
|
34
|
+
const terminalId = url.searchParams.get("terminalId");
|
|
35
|
+
if (!terminalId) {
|
|
36
|
+
ws.close(1008, "Missing terminalId");
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
const terminal = terminalManager.getTerminal(terminalId);
|
|
40
|
+
if (!terminal) {
|
|
41
|
+
console.log(`[terminal-ws] terminal not found: ${terminalId.slice(0, 8)}`);
|
|
42
|
+
ws.close(1008, "Terminal not found");
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
const wantsReplay = url.searchParams.get("replay") !== "0";
|
|
46
|
+
console.log(`[terminal-ws] connected: ${terminalId.slice(0, 8)} replay=${wantsReplay}`);
|
|
47
|
+
terminalManager.attachClient(terminalId, (data) => {
|
|
48
|
+
if (ws.readyState === ws_1.WebSocket.OPEN) {
|
|
49
|
+
ws.send(data);
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
if (!wantsReplay) {
|
|
53
|
+
const delta = terminalManager.getDelta(terminalId);
|
|
54
|
+
if (delta) {
|
|
55
|
+
console.log(`[terminal-ws] sending delta: ${delta.length}b`);
|
|
56
|
+
ws.send(delta);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
let bufferSent = !wantsReplay;
|
|
60
|
+
ws.on("message", (data) => {
|
|
61
|
+
const str = data.toString();
|
|
62
|
+
if (str.startsWith(RESIZE_PREFIX)) {
|
|
63
|
+
const parts = str.slice(RESIZE_PREFIX.length).split(";");
|
|
64
|
+
const cols = parseInt(parts[0], 10);
|
|
65
|
+
const rows = parseInt(parts[1], 10);
|
|
66
|
+
const replayBuffer = !bufferSent ? terminalManager.getBuffer(terminalId) : null;
|
|
67
|
+
if (cols > 0 && rows > 0) {
|
|
68
|
+
terminalManager.resizeTerminal(terminalId, cols, rows);
|
|
69
|
+
}
|
|
70
|
+
if (!bufferSent) {
|
|
71
|
+
bufferSent = true;
|
|
72
|
+
if (replayBuffer) {
|
|
73
|
+
ws.send("\x1b[2J\x1b[3J\x1b[H" + replayBuffer);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
terminalManager.writeToTerminal(terminalId, str);
|
|
79
|
+
});
|
|
80
|
+
ws.on("close", () => {
|
|
81
|
+
console.log(`[terminal-ws] disconnected: ${terminalId.slice(0, 8)}`);
|
|
82
|
+
terminalManager.detachClient(terminalId);
|
|
83
|
+
});
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
function createWebSocketHandler(server, sessionManager, terminalManager) {
|
|
12
87
|
const wss = new ws_1.WebSocketServer({ noServer: true });
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
// and can cause CLI process stdout backpressure when send() buffers data
|
|
16
|
-
// into a dead socket's TCP buffer.
|
|
88
|
+
const terminalWss = new ws_1.WebSocketServer({ noServer: true });
|
|
89
|
+
setupTerminalWebSocket(terminalWss, terminalManager);
|
|
17
90
|
const heartbeat = setInterval(() => {
|
|
18
91
|
for (const ws of wss.clients) {
|
|
19
92
|
const ext = ws;
|
|
@@ -30,15 +103,31 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
30
103
|
});
|
|
31
104
|
server.on("upgrade", (req, socket, head) => {
|
|
32
105
|
const url = req.url || "";
|
|
106
|
+
console.log(`[ws] upgrade: ${url}`);
|
|
107
|
+
if (url.startsWith("/ws/terminal")) {
|
|
108
|
+
const token = (0, auth_1.extractTokenFromQuery)(url);
|
|
109
|
+
if (!token || !(0, auth_1.validateSession)(token)) {
|
|
110
|
+
socket.write("HTTP/1.1 401 Unauthorized\r\n\r\n");
|
|
111
|
+
socket.destroy();
|
|
112
|
+
return;
|
|
113
|
+
}
|
|
114
|
+
terminalWss.handleUpgrade(req, socket, head, (ws) => {
|
|
115
|
+
terminalWss.emit("connection", ws, req);
|
|
116
|
+
});
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
33
119
|
if (!url.startsWith("/ws")) {
|
|
34
|
-
|
|
120
|
+
console.log(`[ws] upgrade: ignoring non-ws url: ${url}`);
|
|
121
|
+
return;
|
|
35
122
|
}
|
|
36
123
|
const token = (0, auth_1.extractTokenFromQuery)(url);
|
|
37
124
|
if (!token || !(0, auth_1.validateSession)(token)) {
|
|
125
|
+
console.log(`[ws] upgrade: auth failed for ${url} (token=${token?.slice(0, 10)}...)`);
|
|
38
126
|
socket.write("HTTP/1.1 401 Unauthorized\r\n\r\n");
|
|
39
127
|
socket.destroy();
|
|
40
128
|
return;
|
|
41
129
|
}
|
|
130
|
+
console.log(`[ws] upgrade: accepted for ${url}`);
|
|
42
131
|
wss.handleUpgrade(req, socket, head, (ws) => {
|
|
43
132
|
wss.emit("connection", ws, req);
|
|
44
133
|
});
|
|
@@ -55,6 +144,8 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
55
144
|
const sessionCleanups = new Map();
|
|
56
145
|
// Lightweight status-only subscriptions for sidebar
|
|
57
146
|
let watchCleanups = [];
|
|
147
|
+
// Explicit cwd watches requested by pages (e.g. changes view)
|
|
148
|
+
let cwdWatchCleanups = [];
|
|
58
149
|
function subscribeSession(sessionId) {
|
|
59
150
|
const prev = sessionCleanups.get(sessionId);
|
|
60
151
|
if (prev) {
|
|
@@ -63,6 +154,12 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
63
154
|
}
|
|
64
155
|
const cleanups = [];
|
|
65
156
|
sessionCleanups.set(sessionId, cleanups);
|
|
157
|
+
const cwd = sessionManager.getSessionCwd(sessionId);
|
|
158
|
+
if (cwd) {
|
|
159
|
+
cleanups.push((0, fs_watcher_1.watchCwd)(cwd, () => {
|
|
160
|
+
send(ws, { type: "session:fs_changed", cwd });
|
|
161
|
+
}));
|
|
162
|
+
}
|
|
66
163
|
const unsubEvent = sessionManager.subscribe(sessionId, (event) => {
|
|
67
164
|
(0, debug_logger_1.logParsedEvent)(sessionId, event);
|
|
68
165
|
handleParsedEvent(ws, sessionId, event, sessionManager);
|
|
@@ -70,6 +167,7 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
70
167
|
if (unsubEvent)
|
|
71
168
|
cleanups.push(unsubEvent);
|
|
72
169
|
const unsubStatus = sessionManager.onStatus(sessionId, (status) => {
|
|
170
|
+
console.log(`[ws] onStatus fired: ${sessionId.slice(0, 8)} -> ${status}`);
|
|
73
171
|
(0, debug_logger_1.logStatus)(sessionId, status);
|
|
74
172
|
send(ws, { type: "session:status", sessionId, status });
|
|
75
173
|
});
|
|
@@ -85,6 +183,11 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
85
183
|
});
|
|
86
184
|
if (unsubError)
|
|
87
185
|
cleanups.push(unsubError);
|
|
186
|
+
const unsubTranscript = sessionManager.onTranscript(sessionId, (messages) => {
|
|
187
|
+
send(ws, { type: "session:transcript", sessionId, messages });
|
|
188
|
+
});
|
|
189
|
+
if (unsubTranscript)
|
|
190
|
+
cleanups.push(unsubTranscript);
|
|
88
191
|
const unsubSystem = sessionManager.onSystem(sessionId, (text) => {
|
|
89
192
|
send(ws, { type: "session:system", sessionId, text });
|
|
90
193
|
});
|
|
@@ -159,6 +262,7 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
159
262
|
messages: result.messages,
|
|
160
263
|
status: "idle",
|
|
161
264
|
hasMore: result.hasMore,
|
|
265
|
+
promptHistory: result.promptHistory,
|
|
162
266
|
});
|
|
163
267
|
send(ws, { type: "session:connected", sessionId: msg.sessionId });
|
|
164
268
|
send(ws, { type: "session:info_updated", sessionId: msg.sessionId, info: result.info });
|
|
@@ -185,10 +289,6 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
185
289
|
if (prefs?.initData) {
|
|
186
290
|
send(ws, { type: "session:init", sessionId: msg.sessionId, data: prefs.initData });
|
|
187
291
|
}
|
|
188
|
-
const historyTodos = (0, session_manager_1.extractTodosFromHistory)(result.messages);
|
|
189
|
-
if (historyTodos.length > 0) {
|
|
190
|
-
send(ws, { type: "session:todos", sessionId: msg.sessionId, todos: historyTodos });
|
|
191
|
-
}
|
|
192
292
|
});
|
|
193
293
|
break;
|
|
194
294
|
}
|
|
@@ -227,6 +327,36 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
227
327
|
if (correctedStatus !== session.info.status) {
|
|
228
328
|
sessionManager.fixStaleStatus(msg.sessionId);
|
|
229
329
|
}
|
|
330
|
+
// Re-emit any pending permission/question requests BEFORE the
|
|
331
|
+
// history snapshot. Otherwise, on reconnect the client lands the
|
|
332
|
+
// assistant message with the AskUserQuestion tool_use first, and
|
|
333
|
+
// chat-view's Place1 renders nothing until question:request
|
|
334
|
+
// arrives 80+ms later — the chat looks stuck.
|
|
335
|
+
const pendingReqsEarly = sessionManager.getPendingRequests(msg.sessionId);
|
|
336
|
+
for (const req of pendingReqsEarly) {
|
|
337
|
+
if (req.type === "question") {
|
|
338
|
+
send(ws, {
|
|
339
|
+
type: "question:request",
|
|
340
|
+
sessionId: msg.sessionId,
|
|
341
|
+
requestId: req.requestId,
|
|
342
|
+
questions: req.toolInput,
|
|
343
|
+
});
|
|
344
|
+
}
|
|
345
|
+
else {
|
|
346
|
+
const permMsg = {
|
|
347
|
+
type: "permission:request",
|
|
348
|
+
sessionId: msg.sessionId,
|
|
349
|
+
requestId: req.requestId,
|
|
350
|
+
toolName: req.toolName,
|
|
351
|
+
input: req.toolInput,
|
|
352
|
+
};
|
|
353
|
+
if (req.planFilePath) {
|
|
354
|
+
permMsg.planFilePath = req.planFilePath;
|
|
355
|
+
permMsg.planContent = req.planContent;
|
|
356
|
+
}
|
|
357
|
+
send(ws, permMsg);
|
|
358
|
+
}
|
|
359
|
+
}
|
|
230
360
|
// If client already has messages, send only the delta to avoid
|
|
231
361
|
// re-sending 1000+ messages on every mobile reconnect.
|
|
232
362
|
// Uses the last known server message ID instead of a count, since
|
|
@@ -255,6 +385,7 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
255
385
|
messages: session.messages,
|
|
256
386
|
status: correctedStatus,
|
|
257
387
|
hasMore: session.hasMore,
|
|
388
|
+
promptHistory: session.promptHistory,
|
|
258
389
|
});
|
|
259
390
|
}
|
|
260
391
|
}
|
|
@@ -265,23 +396,23 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
265
396
|
messages: session.messages,
|
|
266
397
|
status: correctedStatus,
|
|
267
398
|
hasMore: session.hasMore,
|
|
399
|
+
promptHistory: session.promptHistory,
|
|
268
400
|
});
|
|
269
401
|
}
|
|
270
402
|
// Send in-progress streaming message if the CLI is mid-response.
|
|
271
|
-
//
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
});
|
|
403
|
+
// Skip for PTY sessions - the transcript watcher provides message content.
|
|
404
|
+
if (session.info.runtime !== "pty") {
|
|
405
|
+
const snapshot = correctedStatus === "running" ? sessionManager.getStreamingSnapshot(msg.sessionId) : null;
|
|
406
|
+
if (snapshot) {
|
|
407
|
+
send(ws, {
|
|
408
|
+
type: "session:streaming_snapshot",
|
|
409
|
+
sessionId: msg.sessionId,
|
|
410
|
+
messageId: snapshot.messageId,
|
|
411
|
+
content: snapshot.content,
|
|
412
|
+
toolUses: snapshot.toolUses,
|
|
413
|
+
blocks: snapshot.blocks,
|
|
414
|
+
});
|
|
415
|
+
}
|
|
285
416
|
}
|
|
286
417
|
// Restore compacting indicator if compaction is in progress
|
|
287
418
|
if (sessionManager.isCompacting(msg.sessionId)) {
|
|
@@ -335,6 +466,14 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
335
466
|
text: `__thinking_level::${thinkingLevel}`,
|
|
336
467
|
});
|
|
337
468
|
}
|
|
469
|
+
const runtime = session.info.runtime;
|
|
470
|
+
if (runtime && runtime !== "stream") {
|
|
471
|
+
send(ws, {
|
|
472
|
+
type: "session:system",
|
|
473
|
+
sessionId: msg.sessionId,
|
|
474
|
+
text: `__runtime::${runtime}`,
|
|
475
|
+
});
|
|
476
|
+
}
|
|
338
477
|
const currentUsage = sessionManager.getContextUsage(msg.sessionId);
|
|
339
478
|
const usage = currentUsage || session.lastUsage;
|
|
340
479
|
if (usage) {
|
|
@@ -345,12 +484,7 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
345
484
|
});
|
|
346
485
|
}
|
|
347
486
|
subscribeSession(msg.sessionId);
|
|
348
|
-
|
|
349
|
-
const tTodos0 = performance.now();
|
|
350
|
-
const fullBuffer = sessionManager.getTranscriptBuffer(msg.sessionId);
|
|
351
|
-
sessionManager.rebuildTodosFromHistory(msg.sessionId, fullBuffer.length > 0 ? fullBuffer : session.messages);
|
|
352
|
-
const tTodos1 = performance.now();
|
|
353
|
-
(0, debug_logger_1.debugLog)(`[ws:${wsId}] session ${sid} rebuildTodos in ${(tTodos1 - tTodos0).toFixed(0)}ms`);
|
|
487
|
+
sessionManager.loadTodosFromFiles(msg.sessionId);
|
|
354
488
|
const currentTodos = sessionManager.getTodos(msg.sessionId);
|
|
355
489
|
if (currentTodos.length > 0) {
|
|
356
490
|
send(ws, {
|
|
@@ -374,33 +508,6 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
374
508
|
messages: sessionManager.getQueuedMessages(msg.sessionId),
|
|
375
509
|
paused: sessionManager.isQueuePaused(msg.sessionId),
|
|
376
510
|
});
|
|
377
|
-
// Re-emit any pending permission/question requests that were
|
|
378
|
-
// sent to a previous (now dead) WebSocket connection
|
|
379
|
-
const pendingReqs = sessionManager.getPendingRequests(msg.sessionId);
|
|
380
|
-
for (const req of pendingReqs) {
|
|
381
|
-
if (req.type === "question") {
|
|
382
|
-
send(ws, {
|
|
383
|
-
type: "question:request",
|
|
384
|
-
sessionId: msg.sessionId,
|
|
385
|
-
requestId: req.requestId,
|
|
386
|
-
questions: req.toolInput,
|
|
387
|
-
});
|
|
388
|
-
}
|
|
389
|
-
else {
|
|
390
|
-
const permMsg = {
|
|
391
|
-
type: "permission:request",
|
|
392
|
-
sessionId: msg.sessionId,
|
|
393
|
-
requestId: req.requestId,
|
|
394
|
-
toolName: req.toolName,
|
|
395
|
-
input: req.toolInput,
|
|
396
|
-
};
|
|
397
|
-
if (req.planFilePath) {
|
|
398
|
-
permMsg.planFilePath = req.planFilePath;
|
|
399
|
-
permMsg.planContent = req.planContent;
|
|
400
|
-
}
|
|
401
|
-
send(ws, permMsg);
|
|
402
|
-
}
|
|
403
|
-
}
|
|
404
511
|
const tDone = performance.now();
|
|
405
512
|
(0, debug_logger_1.debugLog)(`[ws:${wsId}] session ${sid} connect complete in ${(tDone - t0).toFixed(0)}ms`);
|
|
406
513
|
});
|
|
@@ -528,8 +635,10 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
528
635
|
break;
|
|
529
636
|
}
|
|
530
637
|
case "question:response": {
|
|
638
|
+
console.log(`[question-debug] question:response for session ${msg.sessionId.slice(0, 8)}, requestId=${msg.requestId}, hadPending=${!!sessionManager.getPendingRequest(msg.sessionId, msg.requestId)}`);
|
|
531
639
|
const pending = sessionManager.getPendingRequest(msg.sessionId, msg.requestId);
|
|
532
640
|
sessionManager.removePendingRequest(msg.sessionId, msg.requestId);
|
|
641
|
+
console.log(`[question-debug] after remove, remaining pending:`, sessionManager.getPendingRequests(msg.sessionId).map((r) => r.requestId));
|
|
533
642
|
const originalQuestions = pending?.rawToolInput?.questions;
|
|
534
643
|
sessionManager.respondToPermission(msg.sessionId, msg.requestId, true, {
|
|
535
644
|
questions: originalQuestions || [],
|
|
@@ -542,7 +651,12 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
542
651
|
break;
|
|
543
652
|
}
|
|
544
653
|
case "session:set_model": {
|
|
545
|
-
|
|
654
|
+
(0, debug_logger_1.debugLog)(`[ws] session:set_model received: sessionId=${msg.sessionId.slice(0, 8)} model=${msg.model} contextSize=${msg.contextSize ?? "(unspecified)"}`);
|
|
655
|
+
sessionManager.setModel(msg.sessionId, msg.model, msg.contextSize);
|
|
656
|
+
break;
|
|
657
|
+
}
|
|
658
|
+
case "session:set_model_slot": {
|
|
659
|
+
sessionManager.setModelSlot(msg.sessionId, msg.slot, msg.modelId);
|
|
546
660
|
break;
|
|
547
661
|
}
|
|
548
662
|
case "permission:set_bypass": {
|
|
@@ -554,6 +668,10 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
554
668
|
}
|
|
555
669
|
break;
|
|
556
670
|
}
|
|
671
|
+
case "session:set_runtime": {
|
|
672
|
+
sessionManager.setRuntime(msg.sessionId, msg.runtime);
|
|
673
|
+
break;
|
|
674
|
+
}
|
|
557
675
|
case "session:restart": {
|
|
558
676
|
sessionManager.restartSession(msg.sessionId);
|
|
559
677
|
break;
|
|
@@ -571,12 +689,18 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
571
689
|
for (const fn of watchCleanups)
|
|
572
690
|
fn();
|
|
573
691
|
watchCleanups = [];
|
|
692
|
+
const watchedCwds = new Set();
|
|
574
693
|
for (const id of msg.sessionIds) {
|
|
575
694
|
const unsubStatus = sessionManager.onStatus(id, (status) => {
|
|
695
|
+
console.log(`[ws] onStatus (watch) fired: ${id.slice(0, 8)} -> ${status}`);
|
|
576
696
|
send(ws, { type: "session:status", sessionId: id, status });
|
|
577
697
|
});
|
|
578
|
-
if (unsubStatus)
|
|
698
|
+
if (unsubStatus) {
|
|
579
699
|
watchCleanups.push(unsubStatus);
|
|
700
|
+
}
|
|
701
|
+
else {
|
|
702
|
+
console.log(`[ws] session:subscribe onStatus returned null for ${id.slice(0, 8)}`);
|
|
703
|
+
}
|
|
580
704
|
const unsubPending = sessionManager.onPending(id, (count) => {
|
|
581
705
|
send(ws, { type: "session:pending", sessionId: id, count });
|
|
582
706
|
});
|
|
@@ -587,9 +711,22 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
587
711
|
});
|
|
588
712
|
if (unsubInfo)
|
|
589
713
|
watchCleanups.push(unsubInfo);
|
|
714
|
+
const cwd = sessionManager.getSessionCwd(id);
|
|
715
|
+
if (cwd && !watchedCwds.has(cwd)) {
|
|
716
|
+
watchedCwds.add(cwd);
|
|
717
|
+
watchCleanups.push((0, fs_watcher_1.watchCwd)(cwd, () => {
|
|
718
|
+
send(ws, { type: "session:fs_changed", cwd });
|
|
719
|
+
}));
|
|
720
|
+
}
|
|
590
721
|
}
|
|
591
722
|
break;
|
|
592
723
|
}
|
|
724
|
+
case "watch:cwd": {
|
|
725
|
+
cwdWatchCleanups.push((0, fs_watcher_1.watchCwd)(msg.cwd, () => {
|
|
726
|
+
send(ws, { type: "session:fs_changed", cwd: msg.cwd });
|
|
727
|
+
}));
|
|
728
|
+
break;
|
|
729
|
+
}
|
|
593
730
|
}
|
|
594
731
|
});
|
|
595
732
|
ws.on("close", (code, _reason) => {
|
|
@@ -603,13 +740,21 @@ function createWebSocketHandler(server, sessionManager) {
|
|
|
603
740
|
for (const fn of watchCleanups)
|
|
604
741
|
fn();
|
|
605
742
|
watchCleanups = [];
|
|
743
|
+
for (const fn of cwdWatchCleanups)
|
|
744
|
+
fn();
|
|
745
|
+
cwdWatchCleanups = [];
|
|
606
746
|
});
|
|
607
747
|
});
|
|
608
748
|
return wss;
|
|
609
749
|
}
|
|
610
750
|
function handleParsedEvent(ws, sessionId, event, sessionManager) {
|
|
751
|
+
// In PTY mode the transcript watcher is the sole source of message content.
|
|
752
|
+
// Only forward non-content events (permissions, rate limits, suggestions, etc.).
|
|
753
|
+
const isPty = sessionManager.getRuntime(sessionId) === "pty";
|
|
611
754
|
switch (event.type) {
|
|
612
755
|
case "thinking":
|
|
756
|
+
if (isPty)
|
|
757
|
+
break;
|
|
613
758
|
send(ws, {
|
|
614
759
|
type: "assistant:thinking",
|
|
615
760
|
sessionId,
|
|
@@ -620,6 +765,8 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
|
|
|
620
765
|
});
|
|
621
766
|
break;
|
|
622
767
|
case "text_delta":
|
|
768
|
+
if (isPty)
|
|
769
|
+
break;
|
|
623
770
|
send(ws, {
|
|
624
771
|
type: "assistant:text",
|
|
625
772
|
sessionId,
|
|
@@ -627,6 +774,8 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
|
|
|
627
774
|
});
|
|
628
775
|
break;
|
|
629
776
|
case "tool_use_start":
|
|
777
|
+
if (isPty)
|
|
778
|
+
break;
|
|
630
779
|
send(ws, {
|
|
631
780
|
type: "assistant:tool_use",
|
|
632
781
|
sessionId,
|
|
@@ -637,6 +786,8 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
|
|
|
637
786
|
});
|
|
638
787
|
break;
|
|
639
788
|
case "tool_done":
|
|
789
|
+
if (isPty)
|
|
790
|
+
break;
|
|
640
791
|
send(ws, {
|
|
641
792
|
type: "assistant:tool_use",
|
|
642
793
|
sessionId,
|
|
@@ -647,6 +798,8 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
|
|
|
647
798
|
});
|
|
648
799
|
break;
|
|
649
800
|
case "tool_result":
|
|
801
|
+
if (isPty)
|
|
802
|
+
break;
|
|
650
803
|
send(ws, {
|
|
651
804
|
type: "assistant:tool_result",
|
|
652
805
|
sessionId,
|
|
@@ -656,6 +809,8 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
|
|
|
656
809
|
});
|
|
657
810
|
break;
|
|
658
811
|
case "message_done":
|
|
812
|
+
if (isPty)
|
|
813
|
+
break;
|
|
659
814
|
if (event.message) {
|
|
660
815
|
send(ws, {
|
|
661
816
|
type: "assistant:message_done",
|
|
@@ -664,7 +819,23 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
|
|
|
664
819
|
});
|
|
665
820
|
}
|
|
666
821
|
break;
|
|
822
|
+
case "streaming_snapshot":
|
|
823
|
+
if (isPty)
|
|
824
|
+
break;
|
|
825
|
+
if (event.message) {
|
|
826
|
+
send(ws, {
|
|
827
|
+
type: "session:streaming_snapshot",
|
|
828
|
+
sessionId,
|
|
829
|
+
messageId: event.message.id,
|
|
830
|
+
content: event.message.content,
|
|
831
|
+
toolUses: event.message.toolUses,
|
|
832
|
+
blocks: event.message.blocks,
|
|
833
|
+
});
|
|
834
|
+
}
|
|
835
|
+
break;
|
|
667
836
|
case "tool_children":
|
|
837
|
+
if (isPty)
|
|
838
|
+
break;
|
|
668
839
|
send(ws, {
|
|
669
840
|
type: "assistant:tool_children",
|
|
670
841
|
sessionId,
|
|
@@ -674,6 +845,8 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
|
|
|
674
845
|
});
|
|
675
846
|
break;
|
|
676
847
|
case "tool_progress":
|
|
848
|
+
if (isPty)
|
|
849
|
+
break;
|
|
677
850
|
send(ws, {
|
|
678
851
|
type: "assistant:tool_progress",
|
|
679
852
|
sessionId,
|
|
@@ -720,7 +893,7 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
|
|
|
720
893
|
taskId: event.taskInfo.taskId,
|
|
721
894
|
toolUseId: event.taskInfo.toolUseId,
|
|
722
895
|
status: isProgress ? "running" : event.taskInfo.status,
|
|
723
|
-
title: isProgress ? undefined : event.taskInfo.description,
|
|
896
|
+
title: isProgress ? undefined : event.taskInfo.title || event.taskInfo.description,
|
|
724
897
|
description: event.taskInfo.description,
|
|
725
898
|
activity: isProgress ? event.taskInfo.description : undefined,
|
|
726
899
|
summary: event.taskInfo.summary,
|
|
@@ -734,6 +907,7 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
|
|
|
734
907
|
const toolName = event.toolName || "";
|
|
735
908
|
const requestId = event.requestId || "";
|
|
736
909
|
if (toolName === "AskUserQuestion") {
|
|
910
|
+
console.log(`[question-debug] live question:request for session ${sessionId.slice(0, 8)}, requestId=${requestId}`);
|
|
737
911
|
send(ws, {
|
|
738
912
|
type: "question:request",
|
|
739
913
|
sessionId,
|
package/next.config.ts
CHANGED
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@alexjbarnes/cockpit",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.3.1",
|
|
4
4
|
"description": "Web UI for Claude Code",
|
|
5
5
|
"license": "Apache-2.0",
|
|
6
6
|
"author": "Alex Barnes (https://github.com/alexjbarnes)",
|
|
@@ -44,6 +44,8 @@
|
|
|
44
44
|
"lint": "biome check src/ tests/ server.ts",
|
|
45
45
|
"lint:fix": "biome check --fix src/ tests/ server.ts",
|
|
46
46
|
"format": "biome format --write src/ tests/ server.ts",
|
|
47
|
+
"pretest:integration": "npm run build",
|
|
48
|
+
"test:integration": "playwright test --config=tests/integration/playwright.config.ts",
|
|
47
49
|
"prepublishOnly": "npm run build"
|
|
48
50
|
},
|
|
49
51
|
"dependencies": {
|
|
@@ -55,12 +57,16 @@
|
|
|
55
57
|
"@pierre/diffs": "^1.1.16",
|
|
56
58
|
"@radix-ui/react-slot": "^1.2.4",
|
|
57
59
|
"@tailwindcss/postcss": "^4",
|
|
60
|
+
"@xterm/addon-fit": "^0.11.0",
|
|
61
|
+
"@xterm/addon-webgl": "^0.19.0",
|
|
62
|
+
"@xterm/xterm": "^6.0.0",
|
|
58
63
|
"class-variance-authority": "^0.7",
|
|
59
64
|
"clsx": "^2",
|
|
60
65
|
"codemirror": "^6.0.2",
|
|
61
66
|
"lucide-react": "^1.8.0",
|
|
62
67
|
"magika": "^1.0.0",
|
|
63
68
|
"next": "^16.2.4",
|
|
69
|
+
"node-pty": "^1.2.0-beta.13",
|
|
64
70
|
"react": "^19",
|
|
65
71
|
"react-dom": "^19",
|
|
66
72
|
"react-markdown": "^10.1.0",
|
|
@@ -78,15 +84,16 @@
|
|
|
78
84
|
},
|
|
79
85
|
"devDependencies": {
|
|
80
86
|
"@biomejs/biome": "^2.4.12",
|
|
87
|
+
"@playwright/test": "^1.60.0",
|
|
81
88
|
"@types/node": "^25.6.0",
|
|
82
89
|
"@types/react": "^19",
|
|
83
90
|
"@types/react-dom": "^19",
|
|
84
91
|
"@types/uuid": "^11.0.0",
|
|
85
92
|
"@types/ws": "^8",
|
|
86
|
-
"@vitest/coverage-v8": "^4.1.
|
|
93
|
+
"@vitest/coverage-v8": "^4.1.5",
|
|
87
94
|
"tsc-alias": "^1.8.10",
|
|
88
95
|
"tsx": "^4.19.2",
|
|
89
96
|
"typescript": "6.0.3",
|
|
90
|
-
"vitest": "^4.1.
|
|
97
|
+
"vitest": "^4.1.6"
|
|
91
98
|
}
|
|
92
99
|
}
|
|
Binary file
|