56 lines
3.5 KiB
Markdown
56 lines
3.5 KiB
Markdown
# module-puzzle 独立模块 package 说明
|
||
|
||
日期:`2026-04-29`
|
||
|
||
## 1. package 职责
|
||
|
||
`module-puzzle` 是拼图创作、作品 profile 与运行态规则模块 package,后续负责:
|
||
|
||
1. Puzzle Agent 会话、消息、锚点包与结果草稿的纯领域模型。
|
||
2. 拼图作品 profile、发布门禁、标签规则与作品列表投影。
|
||
3. 拼图运行态开局、交换、拖动、合并、拆分、过关和下一关推荐规则。
|
||
4. 与 `spacetime-module` 的拼图表、reducer、procedure 和事件聚合对接。
|
||
|
||
## 2. 当前阶段说明
|
||
|
||
当前阶段已经不再只是目录占位,已先固定拼图领域 contract 与最小规则函数。
|
||
|
||
当前已落地:
|
||
|
||
1. `src/domain.rs` 承接 Puzzle 基础 ID 前缀、标签数量、洗牌次数常量、基础枚举、Agent session、message、anchor、result draft、work profile、runtime board/run 等领域类型。
|
||
2. `src/commands.rs` 承接 SpacetimeDB procedure/reducer 写入输入。
|
||
3. `src/application.rs` 承接 procedure 返回包装、标签归一化、草稿编译、发布覆盖、开局、交换、拖动、合并、拆分和下一关推荐的纯规则。
|
||
4. `src/errors.rs` 承接拼图字段错误与中文错误文案。
|
||
5. `src/events.rs` 承接草稿变化、作品发布和运行态推进的最小领域事件。
|
||
6. `spacetime-types` feature 下可供 SpacetimeDB 绑定复用的类型派生。
|
||
7. 正式平台 Puzzle 运行态已经接入后端真相源:结果页草稿预览、作品开局、交换、拖动、下一关和排行榜都通过 Rust API / SpacetimeDB procedure 裁决。
|
||
8. 旧 `/api/runtime/puzzle/runs/local-next-level` 已由 `WP-DEL` 物理删除;正式 API 只保留 run scoped 的 `/api/runtime/puzzle/runs/{run_id}/next-level`。
|
||
|
||
当前 crate 仍然只承接:
|
||
|
||
1. 拼图领域常量、枚举、快照类型和纯规则。
|
||
2. 字段校验、标签归一化与运行态规则。
|
||
3. 后续 `spacetime-module` 聚合表时需要复用的领域边界。
|
||
|
||
当前阶段明确不提前进入:
|
||
|
||
1. 图片生成、OSS 上传或 AI prompt 编排。
|
||
2. Axum 路由、SSE 或前端展示状态。
|
||
3. SpacetimeDB table、reducer、procedure 的直接定义。
|
||
|
||
当前设计依据:
|
||
|
||
1. [../../../docs/technical/SERVER_RS_DDD_WP_PZ_DOMAIN_ENUM_REHOME_2026-04-29.md](../../../docs/technical/SERVER_RS_DDD_WP_PZ_DOMAIN_ENUM_REHOME_2026-04-29.md)
|
||
2. [../../../docs/technical/SERVER_RS_DDD_WP_PZ_DOMAIN_SPLIT_2026-04-29.md](../../../docs/technical/SERVER_RS_DDD_WP_PZ_DOMAIN_SPLIT_2026-04-29.md)
|
||
3. [../../../docs/technical/SERVER_RS_DDD_WP_PZ_RUNTIME_BACKEND_TRUTH_CLOSURE_2026-05-01.md](../../../docs/technical/SERVER_RS_DDD_WP_PZ_RUNTIME_BACKEND_TRUTH_CLOSURE_2026-05-01.md)
|
||
4. [../../../docs/technical/SERVER_RS_DDD_WP_DEL_CLEANUP_2026-05-01.md](../../../docs/technical/SERVER_RS_DDD_WP_DEL_CLEANUP_2026-05-01.md)
|
||
5. [../../../docs/technical/PUZZLE_CREATION_AND_RUNTIME_MINIMAL_IMPLEMENTATION_2026-04-22.md](../../../docs/technical/PUZZLE_CREATION_AND_RUNTIME_MINIMAL_IMPLEMENTATION_2026-04-22.md)
|
||
6. [../../../docs/technical/PUZZLE_RESULT_AUTOSAVE_AND_TAG_GATE_FIX_2026-04-28.md](../../../docs/technical/PUZZLE_RESULT_AUTOSAVE_AND_TAG_GATE_FIX_2026-04-28.md)
|
||
|
||
## 3. 边界约束
|
||
|
||
1. `module-puzzle` 不直接调用图片生成、OSS、HTTP、SSE 或 SpacetimeDB SDK。
|
||
2. 领域函数不依赖前端临时状态,拼图运行态真相最终由 SpacetimeDB 表承载。
|
||
3. `api-server` 负责 LLM、图片生成和请求响应映射;`spacetime-module` 负责表、reducer、procedure 与事件。
|
||
4. 后续迁移必须优先复用现有 `domain.rs`、`commands.rs`、`application.rs`、`events.rs`、`errors.rs` 骨架。
|