---
phase: 04-iframe-markdown-new-system-stabilization
plan: 01
type: execute
wave: 1
depends_on:
- 03-legacy-visual-alignment-pass
files_modified:
- frontend/src/core/iframe-messages.ts
- frontend/src/hooks/use-iframe-skill.ts
- frontend/src/hooks/use-selected-skill-listener.ts
- frontend/src/lib/utils.ts
- frontend/src/components/workspace/chats/use-thread-chat.ts
- frontend/src/core/threads/export.ts
- frontend/src/components/workspace/export-trigger.tsx
- frontend/src/core/utils/markdown-download/use-markdown-download.ts
- frontend/src/core/utils/markdown-download/converter.ts
- frontend/tests/e2e/input-and-compose.spec.ts
- frontend/tests/e2e/message-and-history.spec.ts
autonomous: true
requirements:
- LOGIC-01
- LOGIC-02
must_haves:
truths:
- "iframe 通信链路(selectedSkill / xclaw / fullscreen / clipboard)在前端侧具备可校验输入与容错,不因异常 payload 中断聊天主流程。"
- "markdown 导出链路(markdown/json/docx/pdf)在成功/失败路径均可被用户感知,且失败不破坏会话使用。"
- "artifact 与导出集成保持当前能力边界,不引入后端改造或新业务能力。"
artifacts:
- path: "frontend/src/core/iframe-messages.ts"
provides: "iframe 消息协议真源与类型边界"
- path: "frontend/src/hooks/use-selected-skill-listener.ts"
provides: "selectedSkill 初始化幂等与容错强化"
- path: "frontend/src/core/threads/export.ts"
provides: "导出链路稳定与下载行为可预期"
- path: "frontend/src/core/utils/markdown-download/use-markdown-download.ts"
provides: "docx/pdf 下载状态与错误回调一致性"
key_links:
- from: "iframe-messages.ts"
to: "use-iframe-skill.ts / use-selected-skill-listener.ts"
via: "统一消息类型 + 接收端校验"
pattern: "selectedSkill|XClawUsed|fullscreen|copyToClipboard"
- from: "export-trigger.tsx"
to: "core/threads/export.ts + markdown-download/*"
via: "导出入口与转换实现分层"
pattern: "export|download|docx|pdf"
---
完成 Phase 4 的新系统能力稳定化:在不改后端协议、不扩 scope 的前提下,强化 iframe 通信与 markdown 导出的前端稳定性与可验证性。
Purpose: 落实 LOGIC-01 / LOGIC-02,消除前端可控链路中的不稳定点。
Output: iframe 通信与导出链路具备明确容错、幂等和测试护栏。
@.planning/PROJECT.md
@.planning/REQUIREMENTS.md
@.planning/ROADMAP.md
@.planning/phases/04-iframe-markdown-new-system-stabilization/04-CONTEXT.md
@.planning/phases/03-legacy-visual-alignment-pass/03-UAT.md
@.planning/phases/03-legacy-visual-alignment-pass/03-02-SUMMARY.md
@frontend/src/core/iframe-messages.ts
@frontend/src/hooks/use-iframe-skill.ts
@frontend/src/hooks/use-selected-skill-listener.ts
@frontend/src/core/threads/export.ts
@frontend/src/core/utils/markdown-download/use-markdown-download.ts
Task 1: Iframe 消息协议与技能联动容错加固(LOGIC-01)
frontend/src/core/iframe-messages.ts
frontend/src/hooks/use-iframe-skill.ts
frontend/src/hooks/use-selected-skill-listener.ts
frontend/src/lib/utils.ts
frontend/src/components/workspace/chats/use-thread-chat.ts
- Test 1: 接收非法/缺字段 postMessage 时不会抛出未捕获异常,也不会打断聊天输入与路由。
- Test 2: selectedSkill 重复消息不会重复触发 bootstrap(幂等)。
- Test 3: iframe 场景复制动作始终通过父页面消息代理,非 iframe 场景走原生 clipboard。
统一消息类型入口,补齐接收端最小校验与早返回分支;保留现有成功链路行为不变,仅增强异常输入与重复输入的稳定性。确保 skill bootstrap 失败是“可恢复失败”,不阻断主流程。
cd frontend && npm run lint
iframe 通信链路在异常输入下保持稳定,且核心聊天路径不中断。
Task 2: Markdown 导出链路稳定化(LOGIC-02)
frontend/src/components/workspace/export-trigger.tsx
frontend/src/core/threads/export.ts
frontend/src/core/utils/markdown-download/use-markdown-download.ts
frontend/src/core/utils/markdown-download/converter.ts
- Test 1: 无消息时导出入口禁止触发并给出明确反馈。
- Test 2: markdown/json 导出文件名可预测且可下载。
- Test 3: docx/pdf 转换失败时可见且不影响页面继续操作。
维持“入口(ExportTrigger)- 格式化导出(threads/export)- 文档转换(markdown-download)”分层;补足失败分支可见性与保护逻辑,避免静默失败与状态错乱。
cd frontend && npm run lint
导出链路成功/失败路径可解释,且对会话交互无副作用。
Task 3: 前端可控回归护栏(Phase 4 Integration)
frontend/tests/e2e/input-and-compose.spec.ts
frontend/tests/e2e/message-and-history.spec.ts
frontend/tests/e2e/support/chat-helpers.ts
- Test 1: 关键路由/输入/发送场景在后端异常下仍能给出稳定、可解释结果。
- Test 2: 与历史加载耦合的断言不再制造无意义级联失败。
- Test 3: 导出相关可见状态(有无消息)具备稳定断言。
对现有 E2E 用例做最小必要收敛,优先验证前端可控行为与页面状态;后端不稳定场景保留可定位证据但不污染无关断言。
cd frontend && npm run test:e2e -- input-and-compose.spec.ts message-and-history.spec.ts
Phase 4 风险点拥有前端可控的自动化回归护栏。
## Trust Boundaries
| Boundary | Description |
|----------|-------------|
| `parent window -> iframe child` | postMessage 来源与 payload 不可信,前端需先校验再执行业务逻辑 |
| `UI export action -> file generation` | 导出链路涉及浏览器下载与第三方转换库,需显式处理异常 |
## STRIDE Threat Register
| Threat ID | Category | Component | Disposition | Mitigation Plan |
|-----------|----------|-----------|-------------|-----------------|
| T-04-01 | T (Tampering) | iframe postMessage payload | mitigate | 接收端 schema 最小校验 + 非法消息早返回 |
| T-04-02 | D (Denial of Service) | repeated selectedSkill bootstrap | mitigate | 幂等 key 去重与并发保护,避免重复请求风暴 |
| T-04-03 | R (Repudiation) | export failure observability | mitigate | 转换失败统一可见反馈与日志锚点 |
| T-04-04 | I (Information Disclosure) | artifact/export scope | accept | 本阶段不扩展后端数据面,仅前端稳定化 |
1. `lint` 无 error 级阻塞。
2. Phase 4 目标 E2E 用例可执行并产出稳定结果。
3. 手动抽查 iframe 消息异常输入场景与导出失败场景,确认主流程不被阻断。
- LOGIC-01:iframe 通信与 selectedSkill 链路具备前端容错与幂等,不因异常 payload 导致主流程失败。
- LOGIC-02:markdown 导出链路稳定,失败可见且不中断会话。