mirror of
https://github.com/claude-code-best/claude-code.git
synced 2026-06-17 13:55:50 +00:00
* feat: 适配 zed acp 协议 * docs: 完善 acp 文档 * feat: integrate feature branches + daemon/job 命令层级化 + 跨平台后台引擎 Cherry-picked from origin/lint/preview (637c908), excluding lint-only changes. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix: correct detectMimeFromBase64 to decode raw bytes from base64 Cherry-picked from origin/lint/preview (ee36954). Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix: daemon 子进程 spawn 跨平台修复 + CliLaunchSpec 集中化重构 Cherry-picked from origin/lint/preview (c5f52cd), excluding lint-only formatting changes. - 新建 src/utils/cliLaunch.ts: 集中化 CLI 子进程启动层 - 修复 --daemon-worker=kind 等号格式解析 - 修复 daemon/bg fast path 缺少 setShellIfWindows() - 修复 checkPathExists 用 existsSync 替代 execSync('dir') - 7 个 spawn 站点迁移到 CliLaunchSpec Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix: merge tsconfig.base.json into tsconfig.json with full compiler options The cherry-pick from637c908dropped jsx/strict/etc settings when removing tsconfig.base.json. This commit restores them in a single tsconfig.json. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix: merge tsconfig.base.json into tsconfig.json with full compiler options The cherry-pick from637c908dropped jsx/strict/etc settings when removing tsconfig.base.json. This commit restores them in a single tsconfig.json. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> --------- Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
52 lines
1.5 KiB
TypeScript
52 lines
1.5 KiB
TypeScript
import { logForDebugging } from '../utils/debug.js'
|
|
|
|
/**
|
|
* Minimal session type for assistant discovery.
|
|
* Only `id` is consumed by main.tsx (L4757); other fields are for chooser display.
|
|
* ID format is `session_*` (compat prefix) — viewer endpoints use /v1/sessions/*.
|
|
*/
|
|
export type AssistantSession = {
|
|
id: string
|
|
title: string
|
|
status: string
|
|
created_at: string
|
|
}
|
|
|
|
/**
|
|
* Discover assistant sessions on Anthropic CCR.
|
|
*
|
|
* Reuses the existing fetchCodeSessionsFromSessionsAPI() which calls
|
|
* GET /v1/sessions with proper OAuth + anthropic-beta headers.
|
|
*
|
|
* Throws on failure — main.tsx L4720-4725 catch displays the error.
|
|
* Does NOT return [] on error (that would silently redirect to install wizard).
|
|
*/
|
|
export async function discoverAssistantSessions(): Promise<AssistantSession[]> {
|
|
const { fetchCodeSessionsFromSessionsAPI } = await import(
|
|
'../utils/teleport/api.js'
|
|
)
|
|
|
|
let allSessions
|
|
try {
|
|
allSessions = await fetchCodeSessionsFromSessionsAPI()
|
|
} catch (err) {
|
|
logForDebugging(
|
|
`[assistant:discovery] fetchCodeSessionsFromSessionsAPI failed: ${err}`,
|
|
)
|
|
throw err
|
|
}
|
|
|
|
// Filter to active/working sessions only — completed/archived are not attachable
|
|
return allSessions
|
|
.filter(
|
|
s =>
|
|
s.status === 'idle' || s.status === 'working' || s.status === 'waiting',
|
|
)
|
|
.map(s => ({
|
|
id: s.id,
|
|
title: s.title || 'Untitled',
|
|
status: s.status,
|
|
created_at: s.created_at ?? '',
|
|
}))
|
|
}
|