223 lines
11 KiB
Markdown
223 lines
11 KiB
Markdown
<!-- event: create author: "yoi ticket" at: 2026-06-26T17:42:10Z -->
|
||
|
||
## 作成
|
||
|
||
LocalTicketBackend によって作成されました。
|
||
|
||
---
|
||
|
||
<!-- event: intake_summary author: hare at: 2026-06-26T17:45:26Z -->
|
||
|
||
## Intake summary
|
||
|
||
Marked ready by `yoi ticket state`.
|
||
|
||
---
|
||
|
||
<!-- event: state_changed author: "yoi ticket" at: 2026-06-26T17:45:26Z from: planning to: ready reason: cli_state field: state -->
|
||
|
||
## State changed
|
||
|
||
Marked ready by `yoi ticket state`.
|
||
|
||
|
||
---
|
||
|
||
<!-- event: state_changed author: workspace-panel at: 2026-06-26T17:45:40Z from: ready to: queued reason: queued field: state -->
|
||
|
||
## State changed
|
||
|
||
Ticket を `workspace-panel` が queued にしました。
|
||
|
||
|
||
---
|
||
|
||
<!-- event: decision author: yoi-orchestrator at: 2026-06-26T17:46:30Z -->
|
||
|
||
## Decision
|
||
|
||
Routing decision: implementation_ready
|
||
|
||
Reason:
|
||
- Dashboard Queue により routing 許可済み。
|
||
- Relations はなし、OrchestrationPlan も未設定だった。blocking dependency は見当たらない。
|
||
- Current `inprogress` is 0。orchestration worktree is clean and current HEAD already contains Runtime/Backend/WebSocket/WebConsole/TUI foundations.
|
||
- Ticket body は navigation/route model、attach routing、UX redesign、protocol rendering model、input/observation、Non-goals、acceptance criteria が具体的。
|
||
|
||
Evidence checked:
|
||
- Ticket body: Workspace top Worker list から任意 Worker Console、`runtime_id + worker_id` authority、Companion を通常 Worker として扱う、standalone Console sidebar entry / old `/console` fallback removal、protocol::Event rendering semantics、degrade path、validation requirements。
|
||
- Relations: none。
|
||
- Orchestration plan: accepted plan `orch-plan-20260626-174605-1` recorded。
|
||
- Workspace state: queued 1 / inprogress 0、orchestration clean、child spawned count 0。
|
||
|
||
IntentPacket:
|
||
|
||
Intent:
|
||
- Workspace Web Console を Companion 固定 UI から、Worker list 起点の任意 Worker attach Console に再設計する。
|
||
|
||
Binding decisions / invariants:
|
||
- Console target authority は `runtime_id + worker_id`。
|
||
- Browser は Runtime endpoint / credential / socket path / session path を扱わない。
|
||
- Sidebar に standalone `Console` category / navigation entry を残さない。
|
||
- Companion は通常 Worker として list から attach する。Companion 専用 route/sidebar/Console implementation は正規導線に残さない。
|
||
- 旧 `/console` route redirect/fallback 互換は残さない。
|
||
- Backend Worker API / Backend client-facing observation WS を使う。
|
||
- TUI の見た目や keybinding は移植しない。移植対象は `protocol::Event` rendering semantics。
|
||
- 未実装 Runtime/permission/advanced control UI、multi-worker split view、raw provider trace viewer は作らない。
|
||
|
||
Requirements / acceptance criteria:
|
||
- Workspace top Worker list から任意 Worker Console を開ける。
|
||
- Console route/state は `runtime_id + worker_id` を持つ。
|
||
- Worker detail/capabilities、bounded transcript/Snapshot相当、observation WS、input API を使う。
|
||
- `protocol::Event` 由来の user / assistant / thinking / tool call/result / status / error / usage / snapshot / in-flight を表示する。
|
||
- Metadata/diagnostics は compact header/details/collapsible area に逃がし、主 transcript 幅を過剰に占有しない。
|
||
- Streaming 非対応 Worker は transcript-only/manual refresh等の degrade path を明示。
|
||
- Focused Web UI tests/component tests を追加する。
|
||
- `deno task check/build`, `cargo check -p yoi`, `git diff --check`, `nix build .#yoi --no-link` が通る。
|
||
|
||
Implementation latitude:
|
||
- Route naming、Worker list UI placement、component split、protocol event state model、degrade UI の詳細は Coder が existing `web/workspace` style に合わせて選べる。
|
||
- Backend API に小さな不足があれば `crates/workspace-server` で最小 support を追加してよい。
|
||
- Existing Companion provider-less backend can remain as a normal worker source, but no special Console UI path。
|
||
|
||
Escalate if:
|
||
- Browser に Runtime endpoint/token/socket/session path を渡す必要が出る。
|
||
- old `/console` fallback を残さないと navigation が成立しないと判明する。
|
||
- Full TUI parity / tool UI / raw provider trace viewer / multi-worker split view が必要になる。
|
||
- Backend protocol/WS foundation の大幅 redesign が必要になる。
|
||
|
||
Validation:
|
||
- `cargo fmt --all`
|
||
- `cargo check -p yoi`
|
||
- `cd web/workspace && deno task check`
|
||
- `cd web/workspace && deno task build`
|
||
- `git diff --check`
|
||
- 可能なら `nix build .#yoi --no-link`
|
||
|
||
Critical risks / reviewer focus:
|
||
- Companion special-case route/sidebar implementation が残ること。
|
||
- Route target が `runtime_id + worker_id` ではなく worker_id-only になること。
|
||
- Runtime endpoint/token/socket/session path leak。
|
||
- `protocol::Event` を簡易 chat message に潰しすぎること。
|
||
- Metadata/diagnostics が主 transcript を圧迫すること。
|
||
- Old `/console` redirect/fallback compatibility が残ること。
|
||
|
||
---
|
||
|
||
<!-- event: state_changed author: yoi-orchestrator at: 2026-06-26T17:46:39Z from: queued to: inprogress reason: routing_accepted_worker_console_redesign field: state -->
|
||
|
||
## State changed
|
||
|
||
Routing decision: implementation_ready。
|
||
|
||
Ticket body / relations / workspace state / accepted plan を確認し、Workspace Worker Console redesign は unblocked と判断した。Relations はなく、current `inprogress` は 0。accepted plan と IntentPacket は thread / orchestration plan に記録済み。
|
||
|
||
これ以降、worktree creation / coder Worker routing などの implementation side effect に進める。
|
||
|
||
---
|
||
|
||
<!-- event: implementation_report author: yoi-orchestrator at: 2026-06-26T17:47:26Z -->
|
||
|
||
## Implementation report
|
||
|
||
Implementation kickoff:
|
||
|
||
- Worktree created: `/home/hare/Projects/yoi/.worktree/00001KW2GCPYF-worker-console-redesign`
|
||
- Branch: `work/00001KW2GCPYF-worker-console-redesign`
|
||
- Coder Worker spawned: `yoi-coder-00001KW2GCPYF-worker-console`
|
||
|
||
Scope notes:
|
||
- Coder has read access to the implementation worktree and non-recursive workspace root identity path needed by runtime startup.
|
||
- Coder write scope is limited to `web/workspace/**`, `crates/workspace-server/**`, root `Cargo.toml`, `Cargo.lock`, and `package.nix` if dependency/package changes are needed.
|
||
- Coder is instructed not to modify Ticket records and not to operate in root/orchestration worktrees.
|
||
|
||
---
|
||
|
||
<!-- event: implementation_report author: yoi-coder-00001KW2GCPYF-worker-console at: 2026-06-26T18:07:17Z -->
|
||
|
||
## Implementation report
|
||
|
||
Implementation report:
|
||
|
||
実装完了。merge / Ticket 更新 / close / cleanup は行っていない。
|
||
|
||
Commit:
|
||
- `c3fed591095244223e6da7c84ac7f1a2e4cf8cb7 feat: worker attach workspace console`
|
||
|
||
変更概要:
|
||
|
||
### UI / routing
|
||
|
||
- 旧 canonical `/console` route を削除。
|
||
- `web/workspace/src/routes/console/+page.svelte` 削除。
|
||
- 新 Console route を追加。
|
||
- `/runtimes/[runtimeId]/workers/[workerId]/console`
|
||
- Console target authority は `runtime_id + worker_id`。
|
||
- standalone Console / Companion sidebar entry を削除。
|
||
- `CompanionNavSection.svelte` 削除。
|
||
- sidebar は Workers section から各 Worker Console へ attach する形に変更。
|
||
- Workspace top Worker list に `Open Console` attach action を追加。
|
||
- Companion は特別 route ではなく通常 Worker row として attach される想定に変更。
|
||
|
||
### Worker Console
|
||
|
||
- Backend Worker API のみを使う Console を追加。
|
||
- Worker detail: `/api/runtimes/{runtime_id}/workers/{worker_id}`
|
||
- bounded transcript: `/api/runtimes/{runtime_id}/workers/{worker_id}/transcript?limit=200`
|
||
- input: `/api/runtimes/{runtime_id}/workers/{worker_id}/input`
|
||
- observation WS: `/api/runtimes/{runtime_id}/workers/{worker_id}/events/ws`
|
||
- Browser 側では Runtime endpoint / credential / socket path / session path を扱わない。
|
||
- `protocol::Event` 由来の表示モデルを追加。
|
||
- user / assistant / thinking / tool / status / error / usage / snapshot / in-flight を区別表示。
|
||
- transcript-only item と observation event を source として分離。
|
||
- streaming unsupported Worker には明示的 degrade 表示を追加。
|
||
- “bounded transcript + manual refresh” の経路を提示。
|
||
- Worker detail / capabilities / diagnostics は右側 card の compact/collapsible 表示にして、transcript 幅を支配しない構成。
|
||
|
||
### tests
|
||
|
||
- Web Console projection/model tests 追加。
|
||
- protocol segment rendering
|
||
- event projection
|
||
- snapshot / in-flight state
|
||
- Worker target route href encoding
|
||
- UI contract tests 追加。
|
||
- Worker list/sidebar が Worker Console href を使うこと。
|
||
- standalone Companion nav が canonical でないこと。
|
||
- Console page が backend Worker APIs を使い `/api/companion` を使わないこと。
|
||
- `deno task test` を追加。
|
||
|
||
主な変更ファイル:
|
||
- `web/workspace/src/routes/runtimes/[runtimeId]/workers/[workerId]/console/+page.svelte`
|
||
- `web/workspace/src/routes/runtimes/[runtimeId]/workers/[workerId]/console/+page.ts`
|
||
- `web/workspace/src/lib/workspace-console/model.ts`
|
||
- `web/workspace/src/lib/workspace-console/model.test.ts`
|
||
- `web/workspace/src/lib/workspace-console/worker-console.ui.test.ts`
|
||
- `web/workspace/src/lib/workspace-pages/WorkspacePage.svelte`
|
||
- `web/workspace/src/lib/workspace-sidebar/WorkersNavSection.svelte`
|
||
- `web/workspace/src/lib/workspace-sidebar/WorkspaceSidebar.svelte`
|
||
- `web/workspace/src/lib/workspace-sidebar/types.ts`
|
||
- `web/workspace/src/app.css`
|
||
- `web/workspace/deno.json`
|
||
- `web/workspace/tsconfig.json`
|
||
|
||
削除:
|
||
- `web/workspace/src/routes/console/+page.svelte`
|
||
- `web/workspace/src/lib/workspace-sidebar/CompanionNavSection.svelte`
|
||
|
||
Validation:
|
||
- `cargo fmt --all`: success
|
||
- `cargo check -p yoi`: success
|
||
- `cd web/workspace && deno task test`: success(6 tests passed)
|
||
- `cd web/workspace && deno task check`: success(0 errors / 0 warnings)
|
||
- `cd web/workspace && deno task build`: success
|
||
- `git diff --check`: success
|
||
- `nix build .#yoi --no-link`: success(dirty tree warning は実装 commit 前の通常 warning。build 自体は完了)
|
||
|
||
Residual risks / review focus:
|
||
- 実 Runtime / live Worker に対するブラウザ手動操作は未実施。特に observation WS の実イベント順序と snapshot/in-flight 表示の見え方は reviewer 側で確認推奨。
|
||
- `protocol::Event` projection は現在の generated protocol union を広く扱う実装だが、UI は raw trace viewer ではなく compact transcript 表示に寄せている。イベント種類ごとの表示粒度が過不足ないか確認してほしい。
|
||
- `deno task test` の UI contract tests は component runtime harness ではなく、現行 Deno/Svelte 構成に合わせた focused contract tests。将来 component test harness が入るなら置き換え候補。
|
||
|
||
---
|