@alexjbarnes/cockpit 0.2.0 → 0.3.0
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/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-bbd15bac6733dfc4.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/.next/static/zr8XZzqb74eHitdlkpo-C/_buildManifest.js +1 -0
- package/bin/cockpit-hook-bridge.mjs +101 -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 → zr8XZzqb74eHitdlkpo-C}/_ssgManifest.js +0 -0
|
@@ -5,16 +5,21 @@ exports.setSessionPrefs = setSessionPrefs;
|
|
|
5
5
|
exports.deleteSessionPrefs = deleteSessionPrefs;
|
|
6
6
|
exports.findChainForCliSession = findChainForCliSession;
|
|
7
7
|
const node_fs_1 = require("node:fs");
|
|
8
|
-
const node_os_1 = require("node:os");
|
|
9
8
|
const node_path_1 = require("node:path");
|
|
10
|
-
const
|
|
11
|
-
const
|
|
9
|
+
const models_1 = require("../lib/models");
|
|
10
|
+
const paths_1 = require("../server/paths");
|
|
11
|
+
function prefsDir() {
|
|
12
|
+
return (0, paths_1.getCockpitDir)();
|
|
13
|
+
}
|
|
14
|
+
function prefsFile() {
|
|
15
|
+
return (0, node_path_1.join)(prefsDir(), "session-prefs.json");
|
|
16
|
+
}
|
|
12
17
|
let cache = null;
|
|
13
18
|
function load() {
|
|
14
19
|
if (cache)
|
|
15
20
|
return cache;
|
|
16
21
|
try {
|
|
17
|
-
cache = JSON.parse((0, node_fs_1.readFileSync)(
|
|
22
|
+
cache = JSON.parse((0, node_fs_1.readFileSync)(prefsFile(), "utf-8"));
|
|
18
23
|
return cache;
|
|
19
24
|
}
|
|
20
25
|
catch {
|
|
@@ -26,13 +31,33 @@ function save() {
|
|
|
26
31
|
if (!cache)
|
|
27
32
|
return;
|
|
28
33
|
try {
|
|
29
|
-
(0, node_fs_1.mkdirSync)(
|
|
30
|
-
(0, node_fs_1.writeFileSync)(
|
|
34
|
+
(0, node_fs_1.mkdirSync)(prefsDir(), { recursive: true });
|
|
35
|
+
(0, node_fs_1.writeFileSync)(prefsFile(), JSON.stringify(cache, null, 2) + "\n");
|
|
31
36
|
}
|
|
32
37
|
catch {
|
|
33
38
|
// best effort
|
|
34
39
|
}
|
|
35
40
|
}
|
|
41
|
+
function normalize(raw) {
|
|
42
|
+
if (!raw)
|
|
43
|
+
return raw;
|
|
44
|
+
const next = { ...raw };
|
|
45
|
+
if (next.model?.includes("[")) {
|
|
46
|
+
const split = (0, models_1.splitLegacyModel)(next.model);
|
|
47
|
+
next.model = split.model;
|
|
48
|
+
if (next.contextSize === undefined)
|
|
49
|
+
next.contextSize = split.contextSize;
|
|
50
|
+
}
|
|
51
|
+
if (next.modelSlots?.main?.includes("[")) {
|
|
52
|
+
const split = (0, models_1.splitLegacyModel)(next.modelSlots.main);
|
|
53
|
+
next.modelSlots = {
|
|
54
|
+
...next.modelSlots,
|
|
55
|
+
main: split.model,
|
|
56
|
+
mainContext: next.modelSlots.mainContext ?? split.contextSize,
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
return next;
|
|
60
|
+
}
|
|
36
61
|
function getSessionPrefs(sessionId) {
|
|
37
62
|
const all = load();
|
|
38
63
|
// Prefer chain resolution. The sidebar lists entries keyed by CLI id (one
|
|
@@ -42,8 +67,8 @@ function getSessionPrefs(sessionId) {
|
|
|
42
67
|
// from before chain resolution was applied at write time.
|
|
43
68
|
const chain = findChainForCliSession(sessionId);
|
|
44
69
|
if (chain && all[chain.cockpitId])
|
|
45
|
-
return all[chain.cockpitId];
|
|
46
|
-
return all[sessionId];
|
|
70
|
+
return normalize(all[chain.cockpitId]);
|
|
71
|
+
return normalize(all[sessionId]);
|
|
47
72
|
}
|
|
48
73
|
function setSessionPrefs(sessionId, prefs) {
|
|
49
74
|
const all = load();
|
|
@@ -4,9 +4,15 @@ exports.getSessionManager = getSessionManager;
|
|
|
4
4
|
exports.setSessionManager = setSessionManager;
|
|
5
5
|
exports.getJobScheduler = getJobScheduler;
|
|
6
6
|
exports.setJobScheduler = setJobScheduler;
|
|
7
|
+
exports.getTerminalManager = getTerminalManager;
|
|
8
|
+
exports.setTerminalManager = setTerminalManager;
|
|
9
|
+
exports.getHookRouter = getHookRouter;
|
|
10
|
+
exports.setHookRouter = setHookRouter;
|
|
7
11
|
const session_manager_1 = require("./session-manager");
|
|
8
12
|
const smKey = "__cockpit_session_manager__";
|
|
9
13
|
const jsKey = "__cockpit_job_scheduler__";
|
|
14
|
+
const tmKey = "__cockpit_terminal_manager__";
|
|
15
|
+
const hrKey = "__cockpit_hook_router__";
|
|
10
16
|
function getSessionManager() {
|
|
11
17
|
const g = globalThis;
|
|
12
18
|
if (!g[smKey]) {
|
|
@@ -23,3 +29,15 @@ function getJobScheduler() {
|
|
|
23
29
|
function setJobScheduler(scheduler) {
|
|
24
30
|
globalThis[jsKey] = scheduler;
|
|
25
31
|
}
|
|
32
|
+
function getTerminalManager() {
|
|
33
|
+
return globalThis[tmKey] || null;
|
|
34
|
+
}
|
|
35
|
+
function setTerminalManager(manager) {
|
|
36
|
+
globalThis[tmKey] = manager;
|
|
37
|
+
}
|
|
38
|
+
function getHookRouter() {
|
|
39
|
+
return globalThis[hrKey] || null;
|
|
40
|
+
}
|
|
41
|
+
function setHookRouter(router) {
|
|
42
|
+
globalThis[hrKey] = router;
|
|
43
|
+
}
|
|
@@ -128,7 +128,6 @@ function processEvents(events, state, options) {
|
|
|
128
128
|
intermediateMessages: [],
|
|
129
129
|
snapshot: null,
|
|
130
130
|
permissionActions: [],
|
|
131
|
-
todoInputs: [],
|
|
132
131
|
compactDone: false,
|
|
133
132
|
};
|
|
134
133
|
for (const event of events) {
|
|
@@ -198,9 +197,6 @@ function processEvents(events, state, options) {
|
|
|
198
197
|
status: "running",
|
|
199
198
|
};
|
|
200
199
|
const isAgent = tool.name === "Agent";
|
|
201
|
-
if (tool.name === "TodoWrite") {
|
|
202
|
-
result.todoInputs.push(tool.input);
|
|
203
|
-
}
|
|
204
200
|
const isFromMainThread = event.assistantMessageId === state.currentAssistantMsgId;
|
|
205
201
|
event.isMainThread = isFromMainThread;
|
|
206
202
|
if (state.agentStack.length > 0 && !isFromMainThread) {
|
|
@@ -286,6 +282,7 @@ function processEvents(events, state, options) {
|
|
|
286
282
|
}
|
|
287
283
|
else if (event.type === "message_done" && event.message) {
|
|
288
284
|
state.thinkingStartedAt = null;
|
|
285
|
+
console.log(`[stream-processor] message_done: interrupted=${!!event.interrupted}, pendingBlocks=${state.pendingBlocks.length}, pendingToolUses=${state.pendingToolUses.length}, currentMsgId=${state.currentAssistantMsgId?.slice(0, 8) ?? "null"}, clearPending=${!!event.clearPending}`);
|
|
289
286
|
if (event.interrupted) {
|
|
290
287
|
if (state.currentAssistantMsgId) {
|
|
291
288
|
event.message.id = state.currentAssistantMsgId;
|
|
@@ -319,54 +316,67 @@ function processEvents(events, state, options) {
|
|
|
319
316
|
result.snapshot = null;
|
|
320
317
|
continue;
|
|
321
318
|
}
|
|
322
|
-
if (
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
state.
|
|
319
|
+
if (event.clearPending) {
|
|
320
|
+
// Transcript-loaded message: blocks are already correct; just clear pending state.
|
|
321
|
+
state.pendingToolUses.length = 0;
|
|
322
|
+
state.pendingBlocks.length = 0;
|
|
323
|
+
state.agentStack.length = 0;
|
|
324
|
+
state.currentAssistantMsgId = null;
|
|
325
|
+
result.statusChange = "idle";
|
|
326
|
+
if (options.compacting)
|
|
327
|
+
result.compactDone = true;
|
|
328
|
+
state.flushedOnMessageDone = true;
|
|
328
329
|
}
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
.
|
|
332
|
-
.map((b) => b.text)
|
|
333
|
-
.join("")
|
|
334
|
-
.trim();
|
|
335
|
-
if (fullText === "No response requested.") {
|
|
336
|
-
state.pendingBlocks.length = 0;
|
|
337
|
-
state.currentAssistantMsgId = null;
|
|
338
|
-
result.statusChange = "idle";
|
|
339
|
-
state.flushedOnMessageDone = true;
|
|
340
|
-
result.snapshot = null;
|
|
341
|
-
continue;
|
|
330
|
+
else {
|
|
331
|
+
if (state.currentAssistantMsgId) {
|
|
332
|
+
event.message.id = state.currentAssistantMsgId;
|
|
342
333
|
}
|
|
343
|
-
const
|
|
344
|
-
if (
|
|
345
|
-
|
|
346
|
-
const errMsg = msgMatch ? `${msgMatch[1]} (HTTP ${apiErrMatch[1]})` : fullText.slice(0, 200);
|
|
347
|
-
state.pendingBlocks.length = 0;
|
|
348
|
-
state.pendingToolUses.length = 0;
|
|
349
|
-
state.agentStack.length = 0;
|
|
350
|
-
state.currentAssistantMsgId = null;
|
|
351
|
-
result.statusChange = "idle";
|
|
352
|
-
result.errors.push(errMsg);
|
|
353
|
-
state.flushedOnMessageDone = true;
|
|
354
|
-
result.snapshot = null;
|
|
355
|
-
continue;
|
|
334
|
+
const hasStreamedText = state.pendingBlocks.some((b) => b.type === "text");
|
|
335
|
+
if (event.message.content && !hasStreamedText) {
|
|
336
|
+
state.pendingBlocks.push({ type: "text", text: event.message.content });
|
|
356
337
|
}
|
|
338
|
+
if (state.pendingToolUses.length === 0) {
|
|
339
|
+
const fullText = state.pendingBlocks
|
|
340
|
+
.filter((b) => b.type === "text")
|
|
341
|
+
.map((b) => b.text)
|
|
342
|
+
.join("")
|
|
343
|
+
.trim();
|
|
344
|
+
if (fullText === "No response requested.") {
|
|
345
|
+
state.pendingBlocks.length = 0;
|
|
346
|
+
state.currentAssistantMsgId = null;
|
|
347
|
+
result.statusChange = "idle";
|
|
348
|
+
state.flushedOnMessageDone = true;
|
|
349
|
+
result.snapshot = null;
|
|
350
|
+
continue;
|
|
351
|
+
}
|
|
352
|
+
const apiErrMatch = fullText.match(/^API Error: (\d+)\s/);
|
|
353
|
+
if (apiErrMatch) {
|
|
354
|
+
const msgMatch = fullText.match(/"message"\s*:\s*"([^"]+)"/);
|
|
355
|
+
const errMsg = msgMatch ? `${msgMatch[1]} (HTTP ${apiErrMatch[1]})` : fullText.slice(0, 200);
|
|
356
|
+
state.pendingBlocks.length = 0;
|
|
357
|
+
state.pendingToolUses.length = 0;
|
|
358
|
+
state.agentStack.length = 0;
|
|
359
|
+
state.currentAssistantMsgId = null;
|
|
360
|
+
result.statusChange = "idle";
|
|
361
|
+
result.errors.push(errMsg);
|
|
362
|
+
state.flushedOnMessageDone = true;
|
|
363
|
+
result.snapshot = null;
|
|
364
|
+
continue;
|
|
365
|
+
}
|
|
366
|
+
}
|
|
367
|
+
event.message.blocks = [...state.pendingBlocks];
|
|
368
|
+
if (event.message.toolUses.length === 0 && state.pendingToolUses.length > 0) {
|
|
369
|
+
event.message.toolUses = [...state.pendingToolUses];
|
|
370
|
+
}
|
|
371
|
+
state.pendingToolUses.length = 0;
|
|
372
|
+
state.pendingBlocks.length = 0;
|
|
373
|
+
state.agentStack.length = 0;
|
|
374
|
+
state.currentAssistantMsgId = null;
|
|
375
|
+
result.statusChange = "idle";
|
|
376
|
+
if (options.compacting)
|
|
377
|
+
result.compactDone = true;
|
|
378
|
+
state.flushedOnMessageDone = true;
|
|
357
379
|
}
|
|
358
|
-
event.message.blocks = [...state.pendingBlocks];
|
|
359
|
-
if (event.message.toolUses.length === 0 && state.pendingToolUses.length > 0) {
|
|
360
|
-
event.message.toolUses = [...state.pendingToolUses];
|
|
361
|
-
}
|
|
362
|
-
state.pendingToolUses.length = 0;
|
|
363
|
-
state.pendingBlocks.length = 0;
|
|
364
|
-
state.agentStack.length = 0;
|
|
365
|
-
state.currentAssistantMsgId = null;
|
|
366
|
-
result.statusChange = "idle";
|
|
367
|
-
if (options.compacting)
|
|
368
|
-
result.compactDone = true;
|
|
369
|
-
state.flushedOnMessageDone = true;
|
|
370
380
|
}
|
|
371
381
|
if (event.type === "permission_request" && event.requestId) {
|
|
372
382
|
const toolName = event.toolName || "";
|
|
@@ -418,5 +428,8 @@ function processEvents(events, state, options) {
|
|
|
418
428
|
result.emit.push(event);
|
|
419
429
|
result.snapshot = buildSnapshot(state);
|
|
420
430
|
}
|
|
431
|
+
if (result.statusChange) {
|
|
432
|
+
console.log(`[stream-processor] statusChange=${result.statusChange}, emitting ${result.emit.length} events: [${result.emit.map((e) => e.type).join(", ")}]`);
|
|
433
|
+
}
|
|
421
434
|
return result;
|
|
422
435
|
}
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.TerminalManager = void 0;
|
|
7
|
+
const node_child_process_1 = require("node:child_process");
|
|
8
|
+
const node_os_1 = __importDefault(require("node:os"));
|
|
9
|
+
const node_pty_1 = require("node-pty");
|
|
10
|
+
const uuid_1 = require("uuid");
|
|
11
|
+
const MAX_BUFFER = 100 * 1024;
|
|
12
|
+
function getLoginShell() {
|
|
13
|
+
if (process.platform === "win32") {
|
|
14
|
+
return process.env.COMSPEC || "cmd.exe";
|
|
15
|
+
}
|
|
16
|
+
try {
|
|
17
|
+
const entry = (0, node_child_process_1.execSync)(`getent passwd ${node_os_1.default.userInfo().username}`, { encoding: "utf8" }).trim();
|
|
18
|
+
const shell = entry.split(":").pop();
|
|
19
|
+
if (shell)
|
|
20
|
+
return shell;
|
|
21
|
+
}
|
|
22
|
+
catch {
|
|
23
|
+
// getent not available (macOS)
|
|
24
|
+
}
|
|
25
|
+
try {
|
|
26
|
+
const shell = (0, node_child_process_1.execSync)(`dscl . -read /Users/${node_os_1.default.userInfo().username} UserShell`, { encoding: "utf8" });
|
|
27
|
+
const match = shell.match(/UserShell:\s*(.+)/);
|
|
28
|
+
if (match)
|
|
29
|
+
return match[1].trim();
|
|
30
|
+
}
|
|
31
|
+
catch {
|
|
32
|
+
// not macOS
|
|
33
|
+
}
|
|
34
|
+
return process.env.SHELL || "/bin/bash";
|
|
35
|
+
}
|
|
36
|
+
class TerminalManager {
|
|
37
|
+
terminals = new Map();
|
|
38
|
+
constructor() {
|
|
39
|
+
setInterval(() => {
|
|
40
|
+
for (const [id, term] of this.terminals) {
|
|
41
|
+
try {
|
|
42
|
+
process.kill(term.pty.pid, 0);
|
|
43
|
+
}
|
|
44
|
+
catch {
|
|
45
|
+
this.terminals.delete(id);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}, 15000);
|
|
49
|
+
}
|
|
50
|
+
createTerminal(cwd, shell, cols = 120, rows = 40) {
|
|
51
|
+
const id = (0, uuid_1.v4)();
|
|
52
|
+
const resolvedShell = shell || getLoginShell();
|
|
53
|
+
const pty = (0, node_pty_1.spawn)(resolvedShell, ["-l"], {
|
|
54
|
+
name: "xterm-256color",
|
|
55
|
+
cols,
|
|
56
|
+
rows,
|
|
57
|
+
cwd,
|
|
58
|
+
env: process.env,
|
|
59
|
+
});
|
|
60
|
+
const instance = { id, pty, cwd, cols, rows, buffer: "", detachOffset: 0, client: null };
|
|
61
|
+
this.terminals.set(id, instance);
|
|
62
|
+
pty.onData((data) => {
|
|
63
|
+
instance.buffer += data;
|
|
64
|
+
if (instance.buffer.length > MAX_BUFFER) {
|
|
65
|
+
instance.buffer = instance.buffer.slice(-MAX_BUFFER);
|
|
66
|
+
if (instance.detachOffset > 0) {
|
|
67
|
+
instance.detachOffset = Math.max(0, instance.detachOffset - (instance.buffer.length - MAX_BUFFER));
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
if (instance.client) {
|
|
71
|
+
instance.client(data);
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
pty.onExit(() => {
|
|
75
|
+
instance.client = null;
|
|
76
|
+
this.terminals.delete(id);
|
|
77
|
+
});
|
|
78
|
+
return id;
|
|
79
|
+
}
|
|
80
|
+
attachClient(id, sendFn) {
|
|
81
|
+
const term = this.terminals.get(id);
|
|
82
|
+
if (!term)
|
|
83
|
+
return false;
|
|
84
|
+
console.log(`[terminal] attachClient ${id.slice(0, 8)} buffer=${term.buffer.length}b detachOffset=${term.detachOffset} cols=${term.cols} rows=${term.rows}`);
|
|
85
|
+
term.client = sendFn;
|
|
86
|
+
return true;
|
|
87
|
+
}
|
|
88
|
+
getBuffer(id) {
|
|
89
|
+
return this.terminals.get(id)?.buffer ?? "";
|
|
90
|
+
}
|
|
91
|
+
getDelta(id) {
|
|
92
|
+
const term = this.terminals.get(id);
|
|
93
|
+
if (!term)
|
|
94
|
+
return "";
|
|
95
|
+
if (term.detachOffset >= term.buffer.length)
|
|
96
|
+
return "";
|
|
97
|
+
return term.buffer.slice(term.detachOffset);
|
|
98
|
+
}
|
|
99
|
+
detachClient(id) {
|
|
100
|
+
const term = this.terminals.get(id);
|
|
101
|
+
if (term) {
|
|
102
|
+
term.detachOffset = term.buffer.length;
|
|
103
|
+
term.client = null;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
getTerminal(id) {
|
|
107
|
+
return this.terminals.get(id);
|
|
108
|
+
}
|
|
109
|
+
writeToTerminal(id, data) {
|
|
110
|
+
const term = this.terminals.get(id);
|
|
111
|
+
if (!term)
|
|
112
|
+
return false;
|
|
113
|
+
term.pty.write(data);
|
|
114
|
+
return true;
|
|
115
|
+
}
|
|
116
|
+
resizeTerminal(id, cols, rows) {
|
|
117
|
+
const term = this.terminals.get(id);
|
|
118
|
+
if (!term)
|
|
119
|
+
return false;
|
|
120
|
+
if (term.cols === cols && term.rows === rows) {
|
|
121
|
+
console.log(`[terminal] resize ${id.slice(0, 8)} no-op (already ${cols}x${rows})`);
|
|
122
|
+
return true;
|
|
123
|
+
}
|
|
124
|
+
const colsChanged = term.cols !== cols;
|
|
125
|
+
console.log(`[terminal] resize ${id.slice(0, 8)} ${term.cols}x${term.rows} -> ${cols}x${rows}${colsChanged ? " (cols changed, clearing buffer)" : ""}`);
|
|
126
|
+
if (colsChanged) {
|
|
127
|
+
term.buffer = "";
|
|
128
|
+
term.detachOffset = 0;
|
|
129
|
+
}
|
|
130
|
+
term.pty.resize(cols, rows);
|
|
131
|
+
term.cols = cols;
|
|
132
|
+
term.rows = rows;
|
|
133
|
+
return true;
|
|
134
|
+
}
|
|
135
|
+
destroyTerminal(id) {
|
|
136
|
+
const term = this.terminals.get(id);
|
|
137
|
+
if (!term)
|
|
138
|
+
return false;
|
|
139
|
+
term.client = null;
|
|
140
|
+
try {
|
|
141
|
+
term.pty.kill();
|
|
142
|
+
}
|
|
143
|
+
catch {
|
|
144
|
+
// already dead
|
|
145
|
+
}
|
|
146
|
+
this.terminals.delete(id);
|
|
147
|
+
return true;
|
|
148
|
+
}
|
|
149
|
+
listTerminals() {
|
|
150
|
+
return Array.from(this.terminals.values()).map((t) => ({ id: t.id, cwd: t.cwd }));
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
exports.TerminalManager = TerminalManager;
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TodoWatcher = void 0;
|
|
4
|
+
const node_fs_1 = require("node:fs");
|
|
5
|
+
const node_path_1 = require("node:path");
|
|
6
|
+
const paths_1 = require("../server/paths");
|
|
7
|
+
const DEBOUNCE_MS = 300;
|
|
8
|
+
const POLL_INTERVAL_MS = 1000;
|
|
9
|
+
/**
|
|
10
|
+
* Watches both ~/.claude/todos/<sessionId>-agent-*.json (TodoWrite) and
|
|
11
|
+
* ~/.claude/tasks/<sessionId>/*.json (TaskCreate/TaskUpdate) for changes,
|
|
12
|
+
* normalizes them to TodoItem[], and calls onUpdate when the list changes.
|
|
13
|
+
*/
|
|
14
|
+
class TodoWatcher {
|
|
15
|
+
cliSessionId;
|
|
16
|
+
onUpdate;
|
|
17
|
+
watchers = [];
|
|
18
|
+
polling = false;
|
|
19
|
+
timer = null;
|
|
20
|
+
lastJson = "";
|
|
21
|
+
stopped = false;
|
|
22
|
+
todosDir;
|
|
23
|
+
tasksDir;
|
|
24
|
+
constructor(cliSessionId, onUpdate) {
|
|
25
|
+
this.cliSessionId = cliSessionId;
|
|
26
|
+
this.onUpdate = onUpdate;
|
|
27
|
+
const base = (0, paths_1.getClaudeDir)();
|
|
28
|
+
this.todosDir = (0, node_path_1.join)(base, "todos");
|
|
29
|
+
this.tasksDir = (0, node_path_1.join)(base, "tasks", cliSessionId);
|
|
30
|
+
}
|
|
31
|
+
start() {
|
|
32
|
+
this.watchDir(this.todosDir);
|
|
33
|
+
this.watchDir(this.tasksDir);
|
|
34
|
+
this.reload();
|
|
35
|
+
}
|
|
36
|
+
stop() {
|
|
37
|
+
this.stopped = true;
|
|
38
|
+
if (this.timer) {
|
|
39
|
+
clearTimeout(this.timer);
|
|
40
|
+
this.timer = null;
|
|
41
|
+
}
|
|
42
|
+
for (const w of this.watchers) {
|
|
43
|
+
w.close();
|
|
44
|
+
}
|
|
45
|
+
this.watchers = [];
|
|
46
|
+
if (this.polling) {
|
|
47
|
+
try {
|
|
48
|
+
(0, node_fs_1.unwatchFile)(this.todosDir);
|
|
49
|
+
}
|
|
50
|
+
catch {
|
|
51
|
+
/* noop */
|
|
52
|
+
}
|
|
53
|
+
try {
|
|
54
|
+
(0, node_fs_1.unwatchFile)(this.tasksDir);
|
|
55
|
+
}
|
|
56
|
+
catch {
|
|
57
|
+
/* noop */
|
|
58
|
+
}
|
|
59
|
+
this.polling = false;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
watchDir(dir) {
|
|
63
|
+
if (!(0, node_fs_1.existsSync)(dir)) {
|
|
64
|
+
this.pollDir(dir);
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
try {
|
|
68
|
+
const w = (0, node_fs_1.watch)(dir, () => this.scheduleReload());
|
|
69
|
+
this.watchers.push(w);
|
|
70
|
+
}
|
|
71
|
+
catch {
|
|
72
|
+
this.pollDir(dir);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
pollDir(dir) {
|
|
76
|
+
this.polling = true;
|
|
77
|
+
(0, node_fs_1.watchFile)(dir, { interval: POLL_INTERVAL_MS }, () => {
|
|
78
|
+
if (this.stopped)
|
|
79
|
+
return;
|
|
80
|
+
if ((0, node_fs_1.existsSync)(dir)) {
|
|
81
|
+
(0, node_fs_1.unwatchFile)(dir);
|
|
82
|
+
try {
|
|
83
|
+
const w = (0, node_fs_1.watch)(dir, () => this.scheduleReload());
|
|
84
|
+
this.watchers.push(w);
|
|
85
|
+
}
|
|
86
|
+
catch {
|
|
87
|
+
/* stay on poll */
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
this.scheduleReload();
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
scheduleReload() {
|
|
94
|
+
if (this.stopped)
|
|
95
|
+
return;
|
|
96
|
+
if (this.timer)
|
|
97
|
+
clearTimeout(this.timer);
|
|
98
|
+
this.timer = setTimeout(() => this.reload(), DEBOUNCE_MS);
|
|
99
|
+
}
|
|
100
|
+
readOnce() {
|
|
101
|
+
const todos = this.readTodos();
|
|
102
|
+
const tasks = this.readTasks();
|
|
103
|
+
return todos.length > 0 ? todos : tasks;
|
|
104
|
+
}
|
|
105
|
+
reload() {
|
|
106
|
+
const todos = this.readTodos();
|
|
107
|
+
const tasks = this.readTasks();
|
|
108
|
+
const merged = todos.length > 0 ? todos : tasks;
|
|
109
|
+
if (merged.length === 0 && this.lastJson === "")
|
|
110
|
+
return;
|
|
111
|
+
const json = JSON.stringify(merged);
|
|
112
|
+
if (json !== this.lastJson) {
|
|
113
|
+
this.lastJson = json;
|
|
114
|
+
this.onUpdate(merged);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
readTodos() {
|
|
118
|
+
try {
|
|
119
|
+
if (!(0, node_fs_1.existsSync)(this.todosDir))
|
|
120
|
+
return [];
|
|
121
|
+
const prefix = `${this.cliSessionId}-agent-`;
|
|
122
|
+
const files = (0, node_fs_1.readdirSync)(this.todosDir).filter((f) => f.startsWith(prefix) && f.endsWith(".json"));
|
|
123
|
+
if (files.length === 0)
|
|
124
|
+
return [];
|
|
125
|
+
const latest = files.sort().pop();
|
|
126
|
+
const raw = JSON.parse((0, node_fs_1.readFileSync)((0, node_path_1.join)(this.todosDir, latest), "utf-8"));
|
|
127
|
+
if (!Array.isArray(raw))
|
|
128
|
+
return [];
|
|
129
|
+
return raw
|
|
130
|
+
.filter((t) => t.content && t.status)
|
|
131
|
+
.map((t) => ({
|
|
132
|
+
content: t.content,
|
|
133
|
+
status: t.status,
|
|
134
|
+
activeForm: t.activeForm || undefined,
|
|
135
|
+
}));
|
|
136
|
+
}
|
|
137
|
+
catch {
|
|
138
|
+
return [];
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
readTasks() {
|
|
142
|
+
try {
|
|
143
|
+
if (!(0, node_fs_1.existsSync)(this.tasksDir))
|
|
144
|
+
return [];
|
|
145
|
+
const files = (0, node_fs_1.readdirSync)(this.tasksDir).filter((f) => f.endsWith(".json"));
|
|
146
|
+
if (files.length === 0)
|
|
147
|
+
return [];
|
|
148
|
+
const tasks = [];
|
|
149
|
+
for (const file of files) {
|
|
150
|
+
try {
|
|
151
|
+
const raw = JSON.parse((0, node_fs_1.readFileSync)((0, node_path_1.join)(this.tasksDir, file), "utf-8"));
|
|
152
|
+
if (raw.status === "deleted")
|
|
153
|
+
continue;
|
|
154
|
+
tasks.push({
|
|
155
|
+
content: raw.subject || raw.description || "",
|
|
156
|
+
status: mapTaskStatus(raw.status),
|
|
157
|
+
activeForm: raw.activeForm || undefined,
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
catch {
|
|
161
|
+
// skip malformed file
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
return tasks;
|
|
165
|
+
}
|
|
166
|
+
catch {
|
|
167
|
+
return [];
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
exports.TodoWatcher = TodoWatcher;
|
|
172
|
+
function mapTaskStatus(status) {
|
|
173
|
+
if (status === "in_progress")
|
|
174
|
+
return "in_progress";
|
|
175
|
+
if (status === "completed")
|
|
176
|
+
return "completed";
|
|
177
|
+
return "pending";
|
|
178
|
+
}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TranscriptWatcher = void 0;
|
|
4
|
+
const node_fs_1 = require("node:fs");
|
|
5
|
+
const transcript_1 = require("./transcript");
|
|
6
|
+
const DEBOUNCE_MS = 250;
|
|
7
|
+
const POLL_INTERVAL_MS = 500;
|
|
8
|
+
class TranscriptWatcher {
|
|
9
|
+
sessionId;
|
|
10
|
+
cwd;
|
|
11
|
+
onUpdate;
|
|
12
|
+
watcher = null;
|
|
13
|
+
polling = false;
|
|
14
|
+
timer = null;
|
|
15
|
+
lastSize = 0;
|
|
16
|
+
stopped = false;
|
|
17
|
+
filePath;
|
|
18
|
+
constructor(sessionId, cwd, onUpdate) {
|
|
19
|
+
this.sessionId = sessionId;
|
|
20
|
+
this.cwd = cwd;
|
|
21
|
+
this.onUpdate = onUpdate;
|
|
22
|
+
this.filePath = (0, transcript_1.getTranscriptPath)(sessionId, cwd);
|
|
23
|
+
}
|
|
24
|
+
start() {
|
|
25
|
+
if ((0, node_fs_1.existsSync)(this.filePath)) {
|
|
26
|
+
this.watchWithInotify();
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
this.watchWithPoll();
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
async stop() {
|
|
33
|
+
this.stopped = true;
|
|
34
|
+
if (this.timer) {
|
|
35
|
+
clearTimeout(this.timer);
|
|
36
|
+
this.timer = null;
|
|
37
|
+
}
|
|
38
|
+
if (this.watcher) {
|
|
39
|
+
this.watcher.close();
|
|
40
|
+
this.watcher = null;
|
|
41
|
+
}
|
|
42
|
+
if (this.polling) {
|
|
43
|
+
(0, node_fs_1.unwatchFile)(this.filePath);
|
|
44
|
+
this.polling = false;
|
|
45
|
+
}
|
|
46
|
+
await this.reload();
|
|
47
|
+
}
|
|
48
|
+
watchWithInotify() {
|
|
49
|
+
try {
|
|
50
|
+
this.watcher = (0, node_fs_1.watch)(this.filePath, () => this.scheduleReload());
|
|
51
|
+
}
|
|
52
|
+
catch {
|
|
53
|
+
this.watchWithPoll();
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
watchWithPoll() {
|
|
57
|
+
this.polling = true;
|
|
58
|
+
(0, node_fs_1.watchFile)(this.filePath, { interval: POLL_INTERVAL_MS }, () => {
|
|
59
|
+
if (this.stopped)
|
|
60
|
+
return;
|
|
61
|
+
if (!this.watcher && (0, node_fs_1.existsSync)(this.filePath)) {
|
|
62
|
+
(0, node_fs_1.unwatchFile)(this.filePath);
|
|
63
|
+
this.polling = false;
|
|
64
|
+
this.watchWithInotify();
|
|
65
|
+
}
|
|
66
|
+
this.scheduleReload();
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
scheduleReload() {
|
|
70
|
+
if (this.stopped)
|
|
71
|
+
return;
|
|
72
|
+
if (this.timer)
|
|
73
|
+
clearTimeout(this.timer);
|
|
74
|
+
this.timer = setTimeout(() => this.reload(), DEBOUNCE_MS);
|
|
75
|
+
}
|
|
76
|
+
async reload() {
|
|
77
|
+
try {
|
|
78
|
+
const result = await (0, transcript_1.loadTranscript)(this.sessionId, this.cwd, { tailLines: 150 });
|
|
79
|
+
if (result.totalSize !== this.lastSize) {
|
|
80
|
+
this.lastSize = result.totalSize;
|
|
81
|
+
this.onUpdate(result.messages, result.lastUsage);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
catch {
|
|
85
|
+
if (!this.stopped) {
|
|
86
|
+
this.timer = setTimeout(() => this.reload(), 100);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
exports.TranscriptWatcher = TranscriptWatcher;
|