@alexjbarnes/cockpit 0.1.1 → 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 +28 -3
- package/.next/build-manifest.json +3 -3
- package/.next/prerender-manifest.json +147 -3
- package/.next/react-loadable-manifest.json +19 -3
- package/.next/required-server-files.js +3 -0
- package/.next/required-server-files.json +3 -0
- package/.next/routes-manifest.json +162 -0
- package/.next/server/app/(app)/agents/[name]/page.js +3 -3
- 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 +3 -3
- 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 -0
- package/.next/server/app/(app)/inbox/[id]/page.js.nft.json +1 -0
- package/.next/server/app/(app)/inbox/[id]/page_client-reference-manifest.js +1 -0
- package/.next/server/app/(app)/inbox/page.js +2 -0
- package/.next/server/app/(app)/inbox/page.js.nft.json +1 -0
- package/.next/server/app/(app)/inbox/page_client-reference-manifest.js +1 -0
- 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 +6 -6
- 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 -0
- package/.next/server/app/(app)/settings/notifications/page.js.nft.json +1 -0
- package/.next/server/app/(app)/settings/notifications/page_client-reference-manifest.js +1 -0
- 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 +5 -0
- package/.next/server/app/api/inbox/[id]/route.js.nft.json +1 -0
- package/.next/server/app/api/inbox/[id]/route_client-reference-manifest.js +1 -0
- package/.next/server/app/api/inbox/route.js +5 -0
- package/.next/server/app/api/inbox/route.js.nft.json +1 -0
- package/.next/server/app/api/inbox/route_client-reference-manifest.js +1 -0
- 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 -0
- package/.next/server/app/api/notifications/route.js.nft.json +1 -0
- package/.next/server/app/api/notifications/route_client-reference-manifest.js +1 -0
- package/.next/server/app/api/notifications/test/route.js +5 -0
- package/.next/server/app/api/notifications/test/route.js.nft.json +1 -0
- package/.next/server/app/api/notifications/test/route_client-reference-manifest.js +1 -0
- 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 -0
- package/.next/server/app/api/reviews/pinned/route.js.nft.json +1 -0
- package/.next/server/app/api/reviews/pinned/route_client-reference-manifest.js +1 -0
- 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 -0
- package/.next/server/app/api/sessions/bulk-delete/route.js.nft.json +1 -0
- package/.next/server/app/api/sessions/bulk-delete/route_client-reference-manifest.js +1 -0
- package/.next/server/app/api/sessions/by-ids/route.js +1 -0
- package/.next/server/app/api/sessions/by-ids/route.js.nft.json +1 -0
- package/.next/server/app/api/sessions/by-ids/route_client-reference-manifest.js +1 -0
- package/.next/server/app/api/sessions/group/route.js +1 -0
- package/.next/server/app/api/sessions/group/route.js.nft.json +1 -0
- package/.next/server/app/api/sessions/group/route_client-reference-manifest.js +1 -0
- 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 -0
- package/.next/server/app/api/sessions/search/route.js.nft.json +1 -0
- package/.next/server/app/api/sessions/search/route_client-reference-manifest.js +1 -0
- 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 -0
- package/.next/server/app/inbox.meta +16 -0
- package/.next/server/app/inbox.rsc +23 -0
- package/.next/server/app/inbox.segments/!KGFwcCk/inbox/__PAGE__.segment.rsc +9 -0
- package/.next/server/app/inbox.segments/!KGFwcCk/inbox.segment.rsc +5 -0
- package/.next/server/app/inbox.segments/!KGFwcCk.segment.rsc +7 -0
- package/.next/server/app/inbox.segments/_full.segment.rsc +23 -0
- package/.next/server/app/inbox.segments/_head.segment.rsc +6 -0
- package/.next/server/app/inbox.segments/_index.segment.rsc +5 -0
- package/.next/server/app/inbox.segments/_tree.segment.rsc +2 -0
- 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 -0
- package/.next/server/app/settings/notifications.meta +17 -0
- package/.next/server/app/settings/notifications.rsc +23 -0
- package/.next/server/app/settings/notifications.segments/!KGFwcCk/settings/notifications/__PAGE__.segment.rsc +9 -0
- package/.next/server/app/settings/notifications.segments/!KGFwcCk/settings/notifications.segment.rsc +5 -0
- package/.next/server/app/settings/notifications.segments/!KGFwcCk/settings.segment.rsc +5 -0
- package/.next/server/app/settings/notifications.segments/!KGFwcCk.segment.rsc +7 -0
- package/.next/server/app/settings/notifications.segments/_full.segment.rsc +23 -0
- package/.next/server/app/settings/notifications.segments/_head.segment.rsc +6 -0
- package/.next/server/app/settings/notifications.segments/_index.segment.rsc +5 -0
- package/.next/server/app/settings/notifications.segments/_tree.segment.rsc +2 -0
- 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 +28 -3
- package/.next/server/chunks/1002.js +18 -0
- package/.next/server/chunks/1011.js +1 -0
- package/.next/server/chunks/1979.js +2 -2
- package/.next/server/chunks/{9012.js → 3006.js} +3 -3
- package/.next/server/chunks/3108.js +1 -0
- package/.next/server/chunks/3434.js +1 -0
- package/.next/server/chunks/{6142.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/5965.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/{22086-756d490e3320ad15.js → 31010-6e87f77b97544424.js} +1 -1
- package/.next/static/chunks/3765-d323c6675307a63e.js +20 -0
- package/.next/static/chunks/41487-d802643f4a8fad3c.js +199 -0
- package/.next/static/chunks/48273-bbd15bac6733dfc4.js +6 -0
- package/.next/static/chunks/{80392.bca860d8b5972706.js → 58011.3de5770e8b0d8759.js} +1 -1
- package/.next/static/chunks/63606.a387b0261d6523ab.js +1 -0
- package/.next/static/chunks/6935-f436a624267529fb.js +1 -0
- package/.next/static/chunks/{69427.755a0a4013596f7a.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-ce9e1be301c60fe5.js +1 -0
- 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-c5fd013309ab3eba.js +1 -0
- package/.next/static/chunks/app/(app)/reviews/page-47530d93bb9d4a76.js +1 -0
- 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-229f1db6beb1d19c.js +1 -0
- 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/README.md +14 -4
- package/bin/cockpit-hook-bridge.mjs +101 -0
- package/dist/server.js +49 -2
- 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 +18 -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 +136 -0
- package/dist/src/server/job-lock.js +103 -0
- package/dist/src/server/job-scheduler.js +170 -43
- package/dist/src/server/job-storage.js +32 -20
- package/dist/src/server/notification-settings.js +43 -0
- package/dist/src/server/notifications.js +125 -0
- 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 +838 -152
- 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 +444 -13
- package/dist/src/server/ws-handler.js +251 -74
- 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/server/chunks/8346.js +0 -1
- package/.next/static/V2EfPtTUC96VYyF12K0om/_buildManifest.js +0 -1
- package/.next/static/chunks/30120-1535e9064b17ce74.js +0 -20
- package/.next/static/chunks/66997-652baf5596173fea.js +0 -199
- package/.next/static/chunks/93273-c5cb6dcedef67c81.js +0 -6
- package/.next/static/chunks/app/(app)/agents/[name]/page-44c5691c80f17d38.js +0 -8
- package/.next/static/chunks/app/(app)/agents/page-4ce7a715bc0145dc.js +0 -1
- package/.next/static/chunks/app/(app)/changes/page-84cf4cd3ca347d98.js +0 -1
- package/.next/static/chunks/app/(app)/claude-md/edit/page-fb7117171d0f94d2.js +0 -1
- package/.next/static/chunks/app/(app)/claude-md/page-9503f1415e660911.js +0 -1
- package/.next/static/chunks/app/(app)/commands/[name]/page-6ef571e73b105248.js +0 -6
- package/.next/static/chunks/app/(app)/commands/page-e8a506da73d1c280.js +0 -1
- package/.next/static/chunks/app/(app)/files/page-67a95d351a685d79.js +0 -1
- package/.next/static/chunks/app/(app)/hooks/[event]/page-03f85595561b068a.js +0 -6
- package/.next/static/chunks/app/(app)/hooks/page-5578c83ad353e307.js +0 -1
- package/.next/static/chunks/app/(app)/jobs/[id]/edit/page-51d784c59737778c.js +0 -1
- package/.next/static/chunks/app/(app)/jobs/[id]/page-7d00e7a01c70a261.js +0 -1
- package/.next/static/chunks/app/(app)/jobs/[id]/runs/[runId]/page-665191da233fde19.js +0 -1
- package/.next/static/chunks/app/(app)/jobs/page-8b4ee1166a53d5e1.js +0 -1
- package/.next/static/chunks/app/(app)/layout-8dad55d6ce637a01.js +0 -1
- package/.next/static/chunks/app/(app)/mcp-servers/[name]/page-c30f0d78daf7719e.js +0 -1
- package/.next/static/chunks/app/(app)/mcp-servers/page-737b87d338afdb49.js +0 -1
- package/.next/static/chunks/app/(app)/page-40052655d2a9a84f.js +0 -1
- package/.next/static/chunks/app/(app)/reviews/[owner]/[repo]/[number]/page-1d9179bf5a4de7a4.js +0 -13
- package/.next/static/chunks/app/(app)/reviews/[owner]/[repo]/page-d8a9ee39e7cc056a.js +0 -1
- package/.next/static/chunks/app/(app)/reviews/page-098e6e6fe3123e02.js +0 -1
- package/.next/static/chunks/app/(app)/sessions/[id]/page-a74f7fe8322678ba.js +0 -1
- package/.next/static/chunks/app/(app)/settings/page-1fa46b8ac8e22927.js +0 -1
- package/.next/static/chunks/app/(app)/skills/[name]/page-e6572062a6ad90df.js +0 -6
- package/.next/static/chunks/app/(app)/skills/page-8fca8814aa818ae6.js +0 -1
- package/.next/static/chunks/app/_global-error/page-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/agents/[name]/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/agents/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/auth/check/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/auth/login/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/auth/setup/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/auth/ws-token/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/btw/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/claude-md/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/commands/[name]/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/commands/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/defaults/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/filesystem/browse/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/filesystem/files/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/filesystem/mkdir/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/filesystem/read/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/git/clone/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/git/commit/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/git/diff/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/git/discard/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/git/generate-message/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/git/push/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/git/status/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/github/file-content/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/github/orgs/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/github/prs/checks/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/github/prs/diff/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/github/prs/review/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/github/prs/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/github/prs/view/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/github/repos/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/github/review-session/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/health/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/hooks/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/jobs/[id]/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/transcript/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/jobs/[id]/runs/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/jobs/[id]/trigger/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/jobs/mcp-discover/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/jobs/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/jobs/status/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/mcp-servers/[name]/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/mcp-servers/[name]/test/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/mcp-servers/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/sessions/[id]/context/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/sessions/[id]/mcp/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/sessions/[id]/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/sessions/[id]/search/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/sessions/pinned/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/sessions/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/skills/[name]/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/skills/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/usage/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/version/cockpit/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/app/api/version/route-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/next/dist/client/components/builtin/app-error-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/next/dist/client/components/builtin/forbidden-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/next/dist/client/components/builtin/not-found-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/next/dist/client/components/builtin/unauthorized-b277aba73f9e0212.js +0 -1
- package/.next/static/chunks/webpack-2a5835e108df6f34.js +0 -1
- package/.next/static/css/1e1239c76b265910.css +0 -1
- /package/.next/static/{V2EfPtTUC96VYyF12K0om → zr8XZzqb74eHitdlkpo-C}/_ssgManifest.js +0 -0
|
@@ -5,19 +5,67 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.JobScheduler = void 0;
|
|
7
7
|
const node_fs_1 = require("node:fs");
|
|
8
|
-
const node_os_1 = require("node:os");
|
|
9
8
|
const node_path_1 = __importDefault(require("node:path"));
|
|
10
9
|
const uuid_1 = require("uuid");
|
|
10
|
+
const paths_1 = require("../server/paths");
|
|
11
11
|
const cron_utils_1 = require("./cron-utils");
|
|
12
|
+
const inbox_1 = require("./inbox");
|
|
13
|
+
const job_lock_1 = require("./job-lock");
|
|
12
14
|
const job_storage_1 = require("./job-storage");
|
|
13
|
-
const
|
|
14
|
-
|
|
15
|
+
const transcript_1 = require("./transcript");
|
|
16
|
+
function scratchpadDir() {
|
|
17
|
+
return node_path_1.default.join((0, paths_1.getCockpitDir)(), "jobs");
|
|
18
|
+
}
|
|
19
|
+
const JOB_PROMPT_HEADER = [
|
|
15
20
|
"You are running as an autonomous scheduled job. There is no human operator in this session.",
|
|
16
21
|
"Do not ask clarifying questions. Do not wait for user input. Make reasonable assumptions and proceed.",
|
|
17
|
-
"Complete the task fully, then stop.
|
|
22
|
+
"Complete the task fully, then stop.",
|
|
23
|
+
"",
|
|
24
|
+
"Error reporting: If you cannot complete the task due to permission errors, tool failures, missing data, or any other reason,",
|
|
25
|
+
"your final message MUST include a cockpit-error block explaining the failure.",
|
|
26
|
+
"Format it as a fenced code block tagged cockpit-error containing a JSON object:",
|
|
18
27
|
"",
|
|
19
|
-
"
|
|
28
|
+
"```cockpit-error",
|
|
29
|
+
'{"error":"Brief description of what went wrong","details":"Longer explanation of which tools failed and why"}',
|
|
30
|
+
"```",
|
|
20
31
|
].join("\n");
|
|
32
|
+
function buildJobPrompt(job) {
|
|
33
|
+
const parts = [JOB_PROMPT_HEADER, ""];
|
|
34
|
+
if (job.bypassPermissions) {
|
|
35
|
+
parts.push("Permissions: All tools and MCP servers are available.");
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
const tools = job.allowedTools || [];
|
|
39
|
+
const servers = job.mcpServers || [];
|
|
40
|
+
parts.push("Permissions: Only the tools and MCP servers listed below are allowed. Do not attempt to use any others.");
|
|
41
|
+
if (tools.length > 0)
|
|
42
|
+
parts.push(`Allowed tools: ${tools.join(", ")}`);
|
|
43
|
+
if (servers.length > 0)
|
|
44
|
+
parts.push(`Allowed MCP servers: ${servers.join(", ")}`);
|
|
45
|
+
if (tools.length === 0 && servers.length === 0)
|
|
46
|
+
parts.push("No tools or MCP servers are allowed.");
|
|
47
|
+
}
|
|
48
|
+
if (job.cwd) {
|
|
49
|
+
const storageDir = node_path_1.default.join(scratchpadDir(), job.id);
|
|
50
|
+
parts.push("");
|
|
51
|
+
parts.push(`Storage: If you need to persist any files between runs (state, cache, data), save them in ${storageDir}`);
|
|
52
|
+
parts.push("Do not store persistent files in the working directory as it is a git repository.");
|
|
53
|
+
}
|
|
54
|
+
if (job.inboxOutput) {
|
|
55
|
+
parts.push("");
|
|
56
|
+
parts.push("Output: When you have results to report, include a cockpit-inbox block in your final message.");
|
|
57
|
+
parts.push("If there is nothing to report (e.g. no new data to process), do NOT include an inbox block.");
|
|
58
|
+
parts.push("Format it as a fenced code block tagged cockpit-inbox containing a JSON object:");
|
|
59
|
+
parts.push("");
|
|
60
|
+
parts.push("```cockpit-inbox");
|
|
61
|
+
parts.push(JSON.stringify({ title: "Short descriptive title", body: "Markdown body with your full output", priority: "info" }));
|
|
62
|
+
parts.push("```");
|
|
63
|
+
parts.push("");
|
|
64
|
+
parts.push('The body field supports full markdown. Set priority to "info", "warning", or "error" as appropriate.');
|
|
65
|
+
}
|
|
66
|
+
parts.push("", "Task:", job.prompt);
|
|
67
|
+
return parts.join("\n");
|
|
68
|
+
}
|
|
21
69
|
const SHELL_OPERATORS = /(?:;|&&|\|\||>|<|`|\$\(|<\()/;
|
|
22
70
|
const BACKGROUND_AMPERSAND = /(?:^|[^|])&(?!&)/;
|
|
23
71
|
function hasShellOperators(cmd) {
|
|
@@ -53,33 +101,41 @@ function isToolAllowed(toolName, toolInput, rules) {
|
|
|
53
101
|
}
|
|
54
102
|
return false;
|
|
55
103
|
}
|
|
104
|
+
function normalizeMcpName(name) {
|
|
105
|
+
return name.replace(/[^a-zA-Z0-9]/g, "_");
|
|
106
|
+
}
|
|
56
107
|
function isMcpToolAllowed(toolName, toolInput, enabledServers, mcpToolFilters) {
|
|
57
|
-
|
|
58
|
-
if (!match)
|
|
108
|
+
if (!toolName.startsWith("mcp__"))
|
|
59
109
|
return null;
|
|
60
|
-
const
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
if (
|
|
110
|
+
const remainder = toolName.slice(5);
|
|
111
|
+
for (const serverName of enabledServers) {
|
|
112
|
+
const normalized = normalizeMcpName(serverName);
|
|
113
|
+
const prefix = `${normalized}__`;
|
|
114
|
+
if (!remainder.startsWith(prefix))
|
|
115
|
+
continue;
|
|
116
|
+
const tool = remainder.slice(prefix.length);
|
|
117
|
+
if (!mcpToolFilters || !(serverName in mcpToolFilters))
|
|
68
118
|
return true;
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
119
|
+
const filters = mcpToolFilters[serverName];
|
|
120
|
+
for (const filter of filters) {
|
|
121
|
+
if (filter === tool)
|
|
122
|
+
return true;
|
|
123
|
+
if (filter.includes(":")) {
|
|
124
|
+
let parsed;
|
|
125
|
+
try {
|
|
126
|
+
parsed = JSON.parse(toolInput);
|
|
127
|
+
}
|
|
128
|
+
catch {
|
|
129
|
+
continue;
|
|
130
|
+
}
|
|
131
|
+
const [filterServer, filterTool] = filter.split(":", 2);
|
|
132
|
+
if (parsed.server === filterServer) {
|
|
133
|
+
if (filterTool === "*" || parsed.tool === filterTool)
|
|
134
|
+
return true;
|
|
135
|
+
}
|
|
81
136
|
}
|
|
82
137
|
}
|
|
138
|
+
return false;
|
|
83
139
|
}
|
|
84
140
|
return false;
|
|
85
141
|
}
|
|
@@ -102,6 +158,9 @@ class JobScheduler {
|
|
|
102
158
|
clearInterval(this.timer);
|
|
103
159
|
this.timer = null;
|
|
104
160
|
}
|
|
161
|
+
for (const jobId of this.runningJobs.keys()) {
|
|
162
|
+
(0, job_lock_1.releaseJobLock)(jobId);
|
|
163
|
+
}
|
|
105
164
|
console.log("[scheduler] stopped");
|
|
106
165
|
}
|
|
107
166
|
reloadJobs() {
|
|
@@ -118,18 +177,23 @@ class JobScheduler {
|
|
|
118
177
|
return this.executeJob(job);
|
|
119
178
|
}
|
|
120
179
|
recoverState() {
|
|
180
|
+
(0, job_lock_1.clearStaleLocks)();
|
|
121
181
|
(0, job_storage_1.pruneAllRuns)();
|
|
182
|
+
const now = Date.now();
|
|
122
183
|
const jobs = (0, job_storage_1.loadJobs)();
|
|
123
184
|
for (const job of jobs) {
|
|
124
185
|
const latest = (0, job_storage_1.getLatestRun)(job.id);
|
|
125
186
|
if (latest) {
|
|
126
187
|
this.lastFiredAt.set(job.id, new Date(latest.startedAt));
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
188
|
+
}
|
|
189
|
+
for (const run of (0, job_storage_1.loadRuns)(job.id)) {
|
|
190
|
+
if (run.status === "running") {
|
|
191
|
+
run.status = "failure";
|
|
192
|
+
run.error = "Server restarted while job was running";
|
|
193
|
+
run.completedAt = now;
|
|
194
|
+
run.durationMs = now - run.startedAt;
|
|
195
|
+
(0, job_storage_1.saveRun)(run);
|
|
196
|
+
(0, job_lock_1.forceReleaseJobLock)(job.id);
|
|
133
197
|
}
|
|
134
198
|
}
|
|
135
199
|
}
|
|
@@ -142,6 +206,20 @@ class JobScheduler {
|
|
|
142
206
|
this.lastPruneAt = nowMs;
|
|
143
207
|
(0, job_storage_1.pruneAllRuns)();
|
|
144
208
|
}
|
|
209
|
+
for (const [jobId, run] of this.runningJobs) {
|
|
210
|
+
if (!this.sessionManager.hasRunningProcess(run.sessionId)) {
|
|
211
|
+
console.log(`[scheduler] run ${run.id} for job ${jobId} has no running process, marking as failure`);
|
|
212
|
+
run.status = "failure";
|
|
213
|
+
run.error = "Session process exited unexpectedly";
|
|
214
|
+
run.completedAt = Date.now();
|
|
215
|
+
run.durationMs = run.completedAt - run.startedAt;
|
|
216
|
+
if (run.cwd)
|
|
217
|
+
run.messageCount = (0, transcript_1.countTranscriptMessages)(run.sessionId, run.cwd);
|
|
218
|
+
(0, job_storage_1.saveRun)(run);
|
|
219
|
+
this.runningJobs.delete(jobId);
|
|
220
|
+
(0, job_lock_1.releaseJobLock)(jobId);
|
|
221
|
+
}
|
|
222
|
+
}
|
|
145
223
|
const jobs = (0, job_storage_1.loadJobs)();
|
|
146
224
|
for (const job of jobs) {
|
|
147
225
|
if (!job.enabled)
|
|
@@ -175,11 +253,16 @@ class JobScheduler {
|
|
|
175
253
|
}
|
|
176
254
|
async executeJob(job) {
|
|
177
255
|
const runId = (0, uuid_1.v4)();
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
256
|
+
if (!(0, job_lock_1.acquireJobLock)(job.id, runId)) {
|
|
257
|
+
console.log(`[scheduler] skipping job ${job.name}: another process holds the lock`);
|
|
258
|
+
throw new Error("Could not acquire job lock - another process is running this job");
|
|
181
259
|
}
|
|
182
|
-
const
|
|
260
|
+
const jobCwd = job.cwd || node_path_1.default.join(scratchpadDir(), job.id);
|
|
261
|
+
(0, node_fs_1.mkdirSync)(node_path_1.default.join(scratchpadDir(), job.id), { recursive: true });
|
|
262
|
+
const sessionInfo = this.sessionManager.createSession(jobCwd, `[job] ${job.name}`, {
|
|
263
|
+
bypassPermissions: !!job.bypassPermissions,
|
|
264
|
+
runtime: job.runtime,
|
|
265
|
+
});
|
|
183
266
|
const sessionId = sessionInfo.id;
|
|
184
267
|
const run = {
|
|
185
268
|
id: runId,
|
|
@@ -195,6 +278,8 @@ class JobScheduler {
|
|
|
195
278
|
(0, job_storage_1.saveRun)(run);
|
|
196
279
|
this.runningJobs.set(job.id, run);
|
|
197
280
|
const toolTracker = new Map();
|
|
281
|
+
let lastAssistantText = "";
|
|
282
|
+
const enabledServers = new Set(job.mcpServers || []);
|
|
198
283
|
const unsubEvent = this.sessionManager.subscribe(sessionId, (event) => {
|
|
199
284
|
if (event.type === "tool_use_start" && event.toolId) {
|
|
200
285
|
toolTracker.set(event.toolId, {
|
|
@@ -215,14 +300,29 @@ class JobScheduler {
|
|
|
215
300
|
}
|
|
216
301
|
else if (event.type === "message_done") {
|
|
217
302
|
run.messageCount++;
|
|
303
|
+
if (event.message) {
|
|
304
|
+
let text = event.message.content;
|
|
305
|
+
if (!text && event.message.blocks) {
|
|
306
|
+
text = event.message.blocks
|
|
307
|
+
.filter((b) => b.type === "text")
|
|
308
|
+
.map((b) => b.text)
|
|
309
|
+
.join("\n");
|
|
310
|
+
}
|
|
311
|
+
if (text)
|
|
312
|
+
lastAssistantText = text;
|
|
313
|
+
}
|
|
218
314
|
}
|
|
219
315
|
else if (event.type === "permission_request" && event.requestId) {
|
|
220
|
-
if (
|
|
316
|
+
if (job.bypassPermissions) {
|
|
317
|
+
this.sessionManager.respondToPermission(sessionId, event.requestId, true, event.rawToolInput);
|
|
318
|
+
}
|
|
319
|
+
else {
|
|
221
320
|
const toolName = event.toolName || "unknown";
|
|
222
321
|
const inputStr = event.toolInput || "";
|
|
223
322
|
const mcpResult = isMcpToolAllowed(toolName, inputStr, enabledServers, job.mcpToolFilters);
|
|
224
323
|
const allowed = mcpResult !== null ? mcpResult : isToolAllowed(toolName, inputStr, job.allowedTools || []);
|
|
225
|
-
|
|
324
|
+
console.log(`[scheduler] permission: ${toolName} mcpResult=${mcpResult} allowed=${allowed} servers=[${[...enabledServers]}]`);
|
|
325
|
+
this.sessionManager.respondToPermission(sessionId, event.requestId, allowed, allowed ? (event.rawToolInput ?? {}) : undefined);
|
|
226
326
|
const permEntry = {
|
|
227
327
|
name: toolName,
|
|
228
328
|
input: inputStr,
|
|
@@ -234,7 +334,6 @@ class JobScheduler {
|
|
|
234
334
|
}
|
|
235
335
|
}
|
|
236
336
|
});
|
|
237
|
-
const enabledServers = new Set(job.mcpServers || []);
|
|
238
337
|
const initCleanup = this.sessionManager.onInit(sessionId, (initData) => {
|
|
239
338
|
for (const server of initData.mcpServers) {
|
|
240
339
|
if (!enabledServers.has(server.name)) {
|
|
@@ -243,7 +342,7 @@ class JobScheduler {
|
|
|
243
342
|
}
|
|
244
343
|
});
|
|
245
344
|
if (job.model) {
|
|
246
|
-
this.sessionManager.setModel(sessionId, job.model);
|
|
345
|
+
this.sessionManager.setModel(sessionId, job.model, job.contextSize);
|
|
247
346
|
}
|
|
248
347
|
if (job.thinkingLevel) {
|
|
249
348
|
this.sessionManager.setThinkingLevel(sessionId, job.thinkingLevel);
|
|
@@ -272,18 +371,46 @@ class JobScheduler {
|
|
|
272
371
|
unsubStatus?.();
|
|
273
372
|
unsubError?.();
|
|
274
373
|
initCleanup?.();
|
|
275
|
-
run.status = finalStatus;
|
|
276
374
|
run.completedAt = Date.now();
|
|
277
375
|
run.durationMs = run.completedAt - run.startedAt;
|
|
278
376
|
if (finalStatus === "timeout") {
|
|
279
377
|
run.error = `Exceeded max duration of ${job.maxDurationMinutes || 30} minutes`;
|
|
280
378
|
this.sessionManager.destroySession(sessionId);
|
|
281
379
|
}
|
|
380
|
+
if (finalStatus === "success" && lastAssistantText) {
|
|
381
|
+
const errorBlock = (0, inbox_1.parseErrorBlock)(lastAssistantText);
|
|
382
|
+
if (errorBlock) {
|
|
383
|
+
finalStatus = "failure";
|
|
384
|
+
run.error = errorBlock.details ? `${errorBlock.error}: ${errorBlock.details}` : errorBlock.error;
|
|
385
|
+
}
|
|
386
|
+
}
|
|
387
|
+
run.status = finalStatus;
|
|
388
|
+
const transcriptCount = (0, transcript_1.countTranscriptMessages)(sessionId, jobCwd);
|
|
389
|
+
if (transcriptCount > run.messageCount)
|
|
390
|
+
run.messageCount = transcriptCount;
|
|
282
391
|
(0, job_storage_1.saveRun)(run);
|
|
392
|
+
if (job.inboxOutput && lastAssistantText && finalStatus === "success") {
|
|
393
|
+
const inbox = (0, inbox_1.parseInboxBlock)(lastAssistantText);
|
|
394
|
+
if (inbox) {
|
|
395
|
+
(0, inbox_1.addInboxMessage)({ ...inbox, jobId: job.id, jobName: job.name, runId: run.id, notifyProviders: job.notifyProviders });
|
|
396
|
+
}
|
|
397
|
+
}
|
|
398
|
+
if (finalStatus === "failure" || finalStatus === "timeout") {
|
|
399
|
+
(0, inbox_1.addInboxMessage)({
|
|
400
|
+
title: `Job failed: ${job.name}`,
|
|
401
|
+
body: `**Status:** ${finalStatus}\n\n${run.error || "Job failed with no error message"}`,
|
|
402
|
+
priority: "error",
|
|
403
|
+
jobId: job.id,
|
|
404
|
+
jobName: job.name,
|
|
405
|
+
runId: run.id,
|
|
406
|
+
notifyProviders: job.notifyProviders,
|
|
407
|
+
});
|
|
408
|
+
}
|
|
283
409
|
this.runningJobs.delete(job.id);
|
|
410
|
+
(0, job_lock_1.releaseJobLock)(job.id);
|
|
284
411
|
resolve(run);
|
|
285
412
|
};
|
|
286
|
-
this.sessionManager.sendMessage(sessionId,
|
|
413
|
+
this.sessionManager.sendMessage(sessionId, buildJobPrompt(job));
|
|
287
414
|
});
|
|
288
415
|
}
|
|
289
416
|
}
|
|
@@ -11,21 +11,36 @@ exports.pruneAllRuns = pruneAllRuns;
|
|
|
11
11
|
exports.getLatestRun = getLatestRun;
|
|
12
12
|
exports.getRecentFailureCount = getRecentFailureCount;
|
|
13
13
|
const node_fs_1 = require("node:fs");
|
|
14
|
-
const node_os_1 = require("node:os");
|
|
15
14
|
const node_path_1 = require("node:path");
|
|
16
|
-
const
|
|
17
|
-
const
|
|
18
|
-
|
|
15
|
+
const models_1 = require("../lib/models");
|
|
16
|
+
const paths_1 = require("../server/paths");
|
|
17
|
+
function prefsDir() {
|
|
18
|
+
return (0, paths_1.getCockpitDir)();
|
|
19
|
+
}
|
|
20
|
+
function jobsFile() {
|
|
21
|
+
return (0, node_path_1.join)(prefsDir(), "scheduled-jobs.json");
|
|
22
|
+
}
|
|
23
|
+
function runsDir() {
|
|
24
|
+
return (0, node_path_1.join)(prefsDir(), "job-runs");
|
|
25
|
+
}
|
|
19
26
|
function ensureDir(dir) {
|
|
20
27
|
(0, node_fs_1.mkdirSync)(dir, { recursive: true });
|
|
21
28
|
}
|
|
22
29
|
function runsFile(jobId) {
|
|
23
|
-
return (0, node_path_1.join)(
|
|
30
|
+
return (0, node_path_1.join)(runsDir(), `${jobId}.json`);
|
|
31
|
+
}
|
|
32
|
+
function normalizeJob(raw) {
|
|
33
|
+
if (raw.model?.includes("[")) {
|
|
34
|
+
const split = (0, models_1.splitLegacyModel)(raw.model);
|
|
35
|
+
return { ...raw, model: split.model, contextSize: raw.contextSize ?? split.contextSize };
|
|
36
|
+
}
|
|
37
|
+
return raw;
|
|
24
38
|
}
|
|
25
39
|
function loadJobs() {
|
|
26
40
|
try {
|
|
27
|
-
const data = JSON.parse((0, node_fs_1.readFileSync)(
|
|
28
|
-
|
|
41
|
+
const data = JSON.parse((0, node_fs_1.readFileSync)(jobsFile(), "utf-8"));
|
|
42
|
+
const jobs = data.jobs || [];
|
|
43
|
+
return jobs.map(normalizeJob);
|
|
29
44
|
}
|
|
30
45
|
catch {
|
|
31
46
|
return [];
|
|
@@ -43,16 +58,16 @@ function saveJob(job) {
|
|
|
43
58
|
else {
|
|
44
59
|
jobs.push(job);
|
|
45
60
|
}
|
|
46
|
-
ensureDir(
|
|
47
|
-
(0, node_fs_1.writeFileSync)(
|
|
61
|
+
ensureDir(prefsDir());
|
|
62
|
+
(0, node_fs_1.writeFileSync)(jobsFile(), JSON.stringify({ jobs }, null, 2) + "\n");
|
|
48
63
|
}
|
|
49
64
|
function deleteJob(id) {
|
|
50
65
|
const jobs = loadJobs();
|
|
51
66
|
const filtered = jobs.filter((j) => j.id !== id);
|
|
52
67
|
if (filtered.length === jobs.length)
|
|
53
68
|
return false;
|
|
54
|
-
ensureDir(
|
|
55
|
-
(0, node_fs_1.writeFileSync)(
|
|
69
|
+
ensureDir(prefsDir());
|
|
70
|
+
(0, node_fs_1.writeFileSync)(jobsFile(), JSON.stringify({ jobs: filtered }, null, 2) + "\n");
|
|
56
71
|
const rf = runsFile(id);
|
|
57
72
|
try {
|
|
58
73
|
if ((0, node_fs_1.existsSync)(rf)) {
|
|
@@ -87,7 +102,7 @@ function saveRun(run) {
|
|
|
87
102
|
const job = getJob(run.jobId);
|
|
88
103
|
const maxAgeDays = job?.retentionDays ?? 90;
|
|
89
104
|
pruneRuns(runs, 500, maxAgeDays);
|
|
90
|
-
ensureDir(
|
|
105
|
+
ensureDir(runsDir());
|
|
91
106
|
(0, node_fs_1.writeFileSync)(runsFile(run.jobId), JSON.stringify({ runs }, null, 2) + "\n");
|
|
92
107
|
}
|
|
93
108
|
function pruneRuns(runs, maxCount, maxAgeDays) {
|
|
@@ -109,7 +124,7 @@ function pruneAllRuns() {
|
|
|
109
124
|
const before = runs.length;
|
|
110
125
|
pruneRuns(runs, 500, job.retentionDays ?? 90);
|
|
111
126
|
if (runs.length < before) {
|
|
112
|
-
ensureDir(
|
|
127
|
+
ensureDir(runsDir());
|
|
113
128
|
(0, node_fs_1.writeFileSync)(runsFile(job.id), JSON.stringify({ runs }, null, 2) + "\n");
|
|
114
129
|
}
|
|
115
130
|
}
|
|
@@ -120,16 +135,13 @@ function getLatestRun(jobId) {
|
|
|
120
135
|
return undefined;
|
|
121
136
|
return runs.reduce((latest, r) => (r.startedAt > latest.startedAt ? r : latest));
|
|
122
137
|
}
|
|
123
|
-
function getRecentFailureCount(
|
|
138
|
+
function getRecentFailureCount() {
|
|
124
139
|
const jobs = loadJobs();
|
|
125
|
-
const cutoff = Date.now() - withinMs;
|
|
126
140
|
let count = 0;
|
|
127
141
|
for (const job of jobs) {
|
|
128
|
-
const
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
count++;
|
|
132
|
-
}
|
|
142
|
+
const latest = getLatestRun(job.id);
|
|
143
|
+
if (latest && (latest.status === "failure" || latest.status === "timeout")) {
|
|
144
|
+
count++;
|
|
133
145
|
}
|
|
134
146
|
}
|
|
135
147
|
return count;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getNotificationSettings = getNotificationSettings;
|
|
4
|
+
exports.setNotificationSettings = setNotificationSettings;
|
|
5
|
+
exports.updateNotificationSettings = updateNotificationSettings;
|
|
6
|
+
const node_fs_1 = require("node:fs");
|
|
7
|
+
const node_path_1 = require("node:path");
|
|
8
|
+
const paths_1 = require("../server/paths");
|
|
9
|
+
function configDir() {
|
|
10
|
+
return (0, paths_1.getCockpitDir)();
|
|
11
|
+
}
|
|
12
|
+
function configFile() {
|
|
13
|
+
return (0, node_path_1.join)(configDir(), "notifications.json");
|
|
14
|
+
}
|
|
15
|
+
const fallback = {
|
|
16
|
+
providers: [],
|
|
17
|
+
};
|
|
18
|
+
function getNotificationSettings() {
|
|
19
|
+
try {
|
|
20
|
+
return { ...fallback, ...JSON.parse((0, node_fs_1.readFileSync)(configFile(), "utf-8")) };
|
|
21
|
+
}
|
|
22
|
+
catch {
|
|
23
|
+
return { ...fallback };
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
function setNotificationSettings(settings) {
|
|
27
|
+
try {
|
|
28
|
+
(0, node_fs_1.mkdirSync)(configDir(), { recursive: true });
|
|
29
|
+
(0, node_fs_1.writeFileSync)(configFile(), JSON.stringify(settings, null, 2) + "\n");
|
|
30
|
+
}
|
|
31
|
+
catch {
|
|
32
|
+
// best effort
|
|
33
|
+
}
|
|
34
|
+
return settings;
|
|
35
|
+
}
|
|
36
|
+
function updateNotificationSettings(partial) {
|
|
37
|
+
const current = getNotificationSettings();
|
|
38
|
+
const updated = { ...current, ...partial };
|
|
39
|
+
if (!(0, node_fs_1.existsSync)(configDir()))
|
|
40
|
+
(0, node_fs_1.mkdirSync)(configDir(), { recursive: true });
|
|
41
|
+
(0, node_fs_1.writeFileSync)(configFile(), JSON.stringify(updated, null, 2) + "\n");
|
|
42
|
+
return updated;
|
|
43
|
+
}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.dispatchNotification = dispatchNotification;
|
|
4
|
+
exports.sendTestNotification = sendTestNotification;
|
|
5
|
+
const notification_settings_1 = require("./notification-settings");
|
|
6
|
+
function buildFullUrl(path, baseUrl) {
|
|
7
|
+
if (!path)
|
|
8
|
+
return undefined;
|
|
9
|
+
if (baseUrl)
|
|
10
|
+
return `${baseUrl.replace(/\/$/, "")}${path}`;
|
|
11
|
+
return path;
|
|
12
|
+
}
|
|
13
|
+
function formatPlainMessage(payload, baseUrl) {
|
|
14
|
+
const priorityTag = payload.priority === "error" ? "[ERROR]" : payload.priority === "warning" ? "[WARN]" : "";
|
|
15
|
+
const prefix = priorityTag ? `${priorityTag} ` : "";
|
|
16
|
+
const url = buildFullUrl(payload.url, baseUrl);
|
|
17
|
+
const link = url ? `\n\n${url}` : "";
|
|
18
|
+
return `${prefix}${payload.title}\n\n${payload.body}${link}`;
|
|
19
|
+
}
|
|
20
|
+
const telegramProvider = {
|
|
21
|
+
async send(payload, config, baseUrl) {
|
|
22
|
+
const text = formatPlainMessage(payload, baseUrl);
|
|
23
|
+
const url = `https://api.telegram.org/bot${config.botToken}/sendMessage`;
|
|
24
|
+
const res = await fetch(url, {
|
|
25
|
+
method: "POST",
|
|
26
|
+
headers: { "Content-Type": "application/json" },
|
|
27
|
+
body: JSON.stringify({
|
|
28
|
+
chat_id: config.chatId,
|
|
29
|
+
text,
|
|
30
|
+
disable_web_page_preview: true,
|
|
31
|
+
}),
|
|
32
|
+
});
|
|
33
|
+
if (!res.ok) {
|
|
34
|
+
const body = await res.text();
|
|
35
|
+
throw new Error(`Telegram API ${res.status}: ${body}`);
|
|
36
|
+
}
|
|
37
|
+
},
|
|
38
|
+
};
|
|
39
|
+
const ntfyProvider = {
|
|
40
|
+
async send(payload, config, baseUrl) {
|
|
41
|
+
const serverUrl = (config.serverUrl || "https://ntfy.sh").replace(/\/$/, "");
|
|
42
|
+
const url = `${serverUrl}/${config.topic}`;
|
|
43
|
+
const fullUrl = buildFullUrl(payload.url, baseUrl);
|
|
44
|
+
const headers = {
|
|
45
|
+
Title: payload.title,
|
|
46
|
+
Priority: payload.priority === "error" ? "urgent" : payload.priority === "warning" ? "high" : "default",
|
|
47
|
+
};
|
|
48
|
+
if (config.token) {
|
|
49
|
+
headers.Authorization = `Bearer ${config.token}`;
|
|
50
|
+
}
|
|
51
|
+
if (fullUrl) {
|
|
52
|
+
headers.Click = fullUrl;
|
|
53
|
+
}
|
|
54
|
+
const res = await fetch(url, {
|
|
55
|
+
method: "POST",
|
|
56
|
+
headers,
|
|
57
|
+
body: payload.body,
|
|
58
|
+
});
|
|
59
|
+
if (!res.ok) {
|
|
60
|
+
const body = await res.text();
|
|
61
|
+
throw new Error(`ntfy ${res.status}: ${body}`);
|
|
62
|
+
}
|
|
63
|
+
},
|
|
64
|
+
};
|
|
65
|
+
function getProvider(type) {
|
|
66
|
+
switch (type) {
|
|
67
|
+
case "telegram":
|
|
68
|
+
return telegramProvider;
|
|
69
|
+
case "ntfy":
|
|
70
|
+
return ntfyProvider;
|
|
71
|
+
default:
|
|
72
|
+
return null;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
function matchesFilter(entry, payload) {
|
|
76
|
+
if (!entry.filter)
|
|
77
|
+
return true;
|
|
78
|
+
if (entry.filter.priorities?.length && !entry.filter.priorities.includes(payload.priority)) {
|
|
79
|
+
return false;
|
|
80
|
+
}
|
|
81
|
+
if (entry.filter.sources?.length && !entry.filter.sources.includes(payload.source)) {
|
|
82
|
+
return false;
|
|
83
|
+
}
|
|
84
|
+
return true;
|
|
85
|
+
}
|
|
86
|
+
function dispatchNotification(payload) {
|
|
87
|
+
const settings = (0, notification_settings_1.getNotificationSettings)();
|
|
88
|
+
for (const entry of settings.providers) {
|
|
89
|
+
if (!entry.enabled)
|
|
90
|
+
continue;
|
|
91
|
+
if (payload.providerIds) {
|
|
92
|
+
if (!payload.providerIds.includes(entry.id))
|
|
93
|
+
continue;
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
if (!matchesFilter(entry, payload))
|
|
97
|
+
continue;
|
|
98
|
+
}
|
|
99
|
+
const provider = getProvider(entry.type);
|
|
100
|
+
if (!provider)
|
|
101
|
+
continue;
|
|
102
|
+
provider.send(payload, entry.config, settings.baseUrl).catch((err) => {
|
|
103
|
+
console.error(`[notifications] ${entry.type}/${entry.name} failed:`, err);
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
async function sendTestNotification(entry, baseUrl) {
|
|
108
|
+
const provider = getProvider(entry.type);
|
|
109
|
+
if (!provider)
|
|
110
|
+
return `Unknown provider type: ${entry.type}`;
|
|
111
|
+
const payload = {
|
|
112
|
+
title: "Cockpit Test Notification",
|
|
113
|
+
body: "This is a test notification from Cockpit.",
|
|
114
|
+
priority: "info",
|
|
115
|
+
source: "test",
|
|
116
|
+
url: "/inbox",
|
|
117
|
+
};
|
|
118
|
+
try {
|
|
119
|
+
await provider.send(payload, entry.config, baseUrl);
|
|
120
|
+
return "ok";
|
|
121
|
+
}
|
|
122
|
+
catch (err) {
|
|
123
|
+
return `Failed: ${err instanceof Error ? err.message : String(err)}`;
|
|
124
|
+
}
|
|
125
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
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.getCockpitDir = getCockpitDir;
|
|
7
|
+
exports.getCockpitCacheDir = getCockpitCacheDir;
|
|
8
|
+
exports.getClaudeDir = getClaudeDir;
|
|
9
|
+
exports.getClaudeUserConfigFile = getClaudeUserConfigFile;
|
|
10
|
+
const node_os_1 = require("node:os");
|
|
11
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
12
|
+
function getCockpitDir() {
|
|
13
|
+
return process.env.COCKPIT_CONFIG_DIR ?? node_path_1.default.join((0, node_os_1.homedir)(), ".cockpit");
|
|
14
|
+
}
|
|
15
|
+
function getCockpitCacheDir() {
|
|
16
|
+
return process.env.COCKPIT_CACHE_DIR ?? node_path_1.default.join((0, node_os_1.homedir)(), ".cache", "cockpit");
|
|
17
|
+
}
|
|
18
|
+
function getClaudeDir() {
|
|
19
|
+
return process.env.CLAUDE_CONFIG_DIR ?? node_path_1.default.join((0, node_os_1.homedir)(), ".claude");
|
|
20
|
+
}
|
|
21
|
+
function getClaudeUserConfigFile() {
|
|
22
|
+
return node_path_1.default.join(process.env.CLAUDE_CONFIG_DIR ?? (0, node_os_1.homedir)(), ".claude.json");
|
|
23
|
+
}
|
package/dist/src/server/plans.js
CHANGED
|
@@ -3,24 +3,27 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.findLatestPlanFile = findLatestPlanFile;
|
|
4
4
|
exports.readPlanFile = readPlanFile;
|
|
5
5
|
const node_fs_1 = require("node:fs");
|
|
6
|
-
const node_os_1 = require("node:os");
|
|
7
6
|
const node_path_1 = require("node:path");
|
|
8
|
-
const
|
|
7
|
+
const paths_1 = require("../server/paths");
|
|
8
|
+
function plansDir() {
|
|
9
|
+
return (0, node_path_1.join)((0, paths_1.getClaudeDir)(), "plans");
|
|
10
|
+
}
|
|
9
11
|
function findLatestPlanFile() {
|
|
10
12
|
try {
|
|
11
|
-
const
|
|
13
|
+
const dir = plansDir();
|
|
14
|
+
const files = (0, node_fs_1.readdirSync)(dir).filter((f) => f.endsWith(".md") && !f.includes("-agent-"));
|
|
12
15
|
if (files.length === 0)
|
|
13
16
|
return undefined;
|
|
14
17
|
let latest = files[0];
|
|
15
18
|
let latestMtime = 0;
|
|
16
19
|
for (const f of files) {
|
|
17
|
-
const mtime = (0, node_fs_1.statSync)((0, node_path_1.join)(
|
|
20
|
+
const mtime = (0, node_fs_1.statSync)((0, node_path_1.join)(dir, f)).mtimeMs;
|
|
18
21
|
if (mtime > latestMtime) {
|
|
19
22
|
latestMtime = mtime;
|
|
20
23
|
latest = f;
|
|
21
24
|
}
|
|
22
25
|
}
|
|
23
|
-
return (0, node_path_1.join)(
|
|
26
|
+
return (0, node_path_1.join)(dir, latest);
|
|
24
27
|
}
|
|
25
28
|
catch {
|
|
26
29
|
return undefined;
|