这些审计记录原本堆积在 docs/audit/changes/changes/ 嵌套误产物目录下(由开发机迁移
79d3c2e 前后的不明批量操作产生)。由于同期 .gitignore 屏蔽了 docs/audit/ 全目录,
它们从未入过 git 任何分支 history。删除即永久丢失。
按 docs/specs/audit-gap-recovery/tasks.md 阶段 1 执行,将全部 96 份 D 类孤本
(主目录无同名、git history 亦无记录)复制到 docs/audit/changes/ 主目录入仓。
涵盖主题: P1-P18 全栈集成 / 多模块累积变更 / ETL bug 修复 / 业务日切 /
召回与任务引擎改造 / 租户管理与审批 / 董事会财务 / 客户与助教详情 /
DDL 基线合并 / Kiro 到 Claude Code 迁移
阶段 2(B 类内容漂移 1 份)和阶段 4(嵌套目录删除)独立推进。
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
11 KiB
11 KiB
变更审计记录:小程序权限体系统一改造(W1-W5)
| 字段 | 值 |
|---|---|
| 日期 | 2026-03-27 09:55:17 |
| Prompt-ID | P20260327-083929 |
| Session-ID | 0ecf5499 |
| Session 路径 | docs/audit/session_logs/2026-03/27/11_476da926_075522 |
操作摘要
小程序权限体系统一改造——后端为权限唯一真相源,前端根据权限码动态控制页面/tab/按钮可见性。涵盖 5 个工作项(W1-W5):refresh_token 有效期延长、/api/xcx/me 返回 permissions 列表、角色-权限码映射修正、后端端点从 require_approved 迁移到 require_permission("xxx")、前端权限守卫重写为权限码驱动。
变更范围
- W1 — Token 有效期:
apps/backend/app/config.py— refresh_token 有效期从 7 天延长至 30 天 - W2 — 权限下发:
apps/backend/app/schemas/xcx_auth.pyUserStatusResponse 新增permissions: list[str]字段;apps/backend/app/routers/xcx_auth.py/api/xcx/me返回当前用户的 permissions 列表 - W3 — 角色权限映射:
db/zqyy_app/migrations/2026-03-27__fix_role_permissions.sql修正角色-权限码映射关系 - W4 — 后端端点权限化:
xcx_tasks.py:7 个端点从require_approved→require_permission("view_tasks")xcx_performance.py:2 个端点 →require_permission("view_tasks")xcx_customers.py:2 个端点 →require_permission("view_board_customer")xcx_coaches.py:1 个端点 →require_permission("view_board_coach")
- W5 — 前端权限守卫重写:
auth-guard.ts:重写为权限码驱动(不再基于角色硬编码)app.ts:改用syncPermissions同步权限typings/index.d.ts:globalData 新增permissions字段- 看板页面(board-finance/board-customer/board-coach):
.ts+.wxml改为动态二级 tab,根据权限码控制可见性
风险与回滚
- 风险点:
- 权限码不匹配:若数据库
auth.role_permissions映射遗漏某权限码,对应角色用户将被 403 拒绝 - 前后端权限一致性:前端 tab 可见性依赖
permissions数组,后端 API 依赖require_permission,两者必须使用相同的权限码字符串 - refresh_token 延长至 30 天:已签发的旧 token(7 天有效期)不受影响,新 token 才生效
- 迁移脚本依赖
auth.roles和auth.permissions表已存在且包含正确的角色/权限记录
- 权限码不匹配:若数据库
- 回滚要点:
- 数据库:回滚
2026-03-27__fix_role_permissions.sql中的映射变更 - 后端:将 12 个端点的
require_permission(...)改回require_approved;移除 UserStatusResponse 的permissions字段;恢复 config.py 的 7 天有效期 - 前端:恢复
auth-guard.ts为角色驱动版本;恢复app.ts的syncVisibleTabs;恢复看板页面的静态 tab 逻辑
- 数据库:回滚
改动注解
apps/backend/app/config.py
- 变更类型:修改
- 原始原因:W1 要求延长 refresh_token 有效期,减少用户频繁重新登录
- 思路分析:将
REFRESH_TOKEN_EXPIRE_DAYS从 7 改为 30,属于配置级变更,不影响 token 签发/验证逻辑 - 修改结果:新签发的 refresh_token 有效期 30 天,已签发的旧 token 不受影响
apps/backend/app/schemas/xcx_auth.py
- 变更类型:修改
- 原始原因:W2 需要在
/api/xcx/me响应中携带权限码列表,供前端做动态可见性控制 - 思路分析:在
UserStatusResponsePydantic model 中新增permissions: list[str]字段,默认空列表 - 修改结果:前端可通过
me.permissions获取当前用户的全部权限码
apps/backend/app/routers/xcx_auth.py
- 变更类型:修改
- 原始原因:W2 配合 schema 变更,在
/api/xcx/me路由中查询并填充 permissions - 思路分析:从
auth.role_permissions+auth.permissions表 JOIN 查询当前用户角色对应的权限码列表 - 修改结果:approved 用户调用
/api/xcx/me时,响应中包含完整的 permissions 数组
apps/backend/app/routers/xcx_tasks.py
- 变更类型:修改
- 原始原因:W4 将端点级鉴权从"已审核即可访问"升级为"需持有特定权限码"
- 思路分析:7 个端点的依赖注入从
require_approved替换为require_permission("view_tasks"),实现细粒度权限控制 - 修改结果:仅持有
view_tasks权限码的角色可访问任务相关端点
apps/backend/app/routers/xcx_performance.py
- 变更类型:修改
- 原始原因:W4 绩效端点同样需要权限码控制
- 思路分析:2 个端点改为
require_permission("view_tasks"),与任务模块共享同一权限码(绩效是任务的子功能) - 修改结果:绩效端点与任务端点权限一致
apps/backend/app/routers/xcx_customers.py
- 变更类型:修改
- 原始原因:W4 客户看板端点需要独立权限码
- 思路分析:2 个端点改为
require_permission("view_board_customer") - 修改结果:仅持有
view_board_customer权限码的角色可访问客户看板
apps/backend/app/routers/xcx_coaches.py
- 变更类型:修改
- 原始原因:W4 助教看板端点需要独立权限码
- 思路分析:1 个端点改为
require_permission("view_board_coach") - 修改结果:仅持有
view_board_coach权限码的角色可访问助教看板
db/zqyy_app/migrations/2026-03-27__fix_role_permissions.sql
- 变更类型:新增
- 原始原因:W3 需要修正角色-权限码映射,确保各角色拥有正确的权限集合
- 思路分析:迁移脚本操作
auth.role_permissions表,建立角色与权限码的多对多映射 - 修改结果:数据库中角色权限映射与 W4/W5 的权限码使用保持一致
apps/miniprogram/miniprogram/utils/auth-guard.ts
- 变更类型:修改
- 原始原因:W5 将前端权限守卫从角色硬编码改为权限码驱动
- 思路分析:重写核心逻辑——不再维护
PAGE_ROLES角色→页面映射,改为从globalData.permissions读取权限码,页面/tab 可见性由权限码决定 - 修改结果:前端权限判断与后端权限码完全对齐,新增权限码时只需更新数据库映射,无需改前端代码
apps/miniprogram/miniprogram/app.ts
- 变更类型:修改
- 原始原因:W5 全局入口需要同步权限码到 globalData
- 思路分析:将
syncVisibleTabs替换为syncPermissions,在/api/xcx/me返回后将 permissions 存入 globalData - 修改结果:小程序启动时自动同步权限码,后续页面/组件可直接读取
apps/miniprogram/typings/index.d.ts
- 变更类型:修改
- 原始原因:W5 TypeScript 类型定义需要同步新增 permissions 字段
- 思路分析:在
IAppOption.globalData接口中新增permissions: string[] - 修改结果:全局类型安全,IDE 自动补全支持
apps/miniprogram/miniprogram/pages/board-finance/board-finance.ts
- 变更类型:修改
- 原始原因:W5 财务看板二级 tab 需要根据权限码动态显示
- 思路分析:从 globalData.permissions 过滤出当前用户可见的二级 tab,动态渲染
- 修改结果:不同角色看到不同的二级 tab 组合
apps/miniprogram/miniprogram/pages/board-finance/board-finance.wxml
- 变更类型:修改
- 原始原因:W5 配合 .ts 的动态 tab 逻辑,模板需要支持动态渲染
- 思路分析:tab 列表改为
wx:for遍历动态数组 - 修改结果:模板与逻辑层联动,tab 可见性由权限码控制
apps/miniprogram/miniprogram/pages/board-customer/board-customer.ts
- 变更类型:修改
- 原始原因:W5 客户看板同上
- 思路分析:同 board-finance 的动态 tab 方案
- 修改结果:客户看板二级 tab 权限码驱动
apps/miniprogram/miniprogram/pages/board-customer/board-customer.wxml
- 变更类型:修改
- 原始原因:W5 配合动态 tab
- 思路分析:同 board-finance.wxml
- 修改结果:模板支持动态 tab 渲染
apps/miniprogram/miniprogram/pages/board-coach/board-coach.ts
- 变更类型:修改
- 原始原因:W5 助教看板同上
- 思路分析:同 board-finance 的动态 tab 方案
- 修改结果:助教看板二级 tab 权限码驱动
apps/miniprogram/miniprogram/pages/board-coach/board-coach.wxml
- 变更类型:修改
- 原始原因:W5 配合动态 tab
- 思路分析:同 board-finance.wxml
- 修改结果:模板支持动态 tab 渲染
本次对话文件变更
新增文件
docs/audit/prompt_logs/prompt_log_20260327_083929.mddocs/audit/session_logs/2026-03/27/11_476da926_075522/main_01_db3ab14f.mddocs/audit/session_logs/2026-03/27/11_476da926_075522/sub_01_db3ab14f.md
删除文件
docs/audit/session_logs/2026-03/27/11_476da926_075522/main_01_77123f5a.md
验证
- 数据库验证:执行迁移后
SELECT r.code, p.code FROM auth.role_permissions rp JOIN auth.roles r ON r.id=rp.role_id JOIN auth.permissions p ON p.id=rp.permission_id ORDER BY r.code, p.code;确认映射正确 - 后端验证:
GET /api/xcx/me返回的permissions数组包含当前角色对应的全部权限码 - 前端验证:
- coach 登录 → 看到任务 tab,看不到客户/助教看板 tab
- staff 登录 → 看到看板 tab,看不到任务 tab
- head_coach/manager 登录 → 看到全部 tab
- 无权限用户访问受保护端点 → 返回 403
- 迁移状态:⚠️
2026-03-27__fix_role_permissions.sql需确认已在测试库执行
文件清单
| 文件 | 操作 | 工作项 |
|---|---|---|
apps/backend/app/config.py |
修改 | W1 |
apps/backend/app/schemas/xcx_auth.py |
修改 | W2 |
apps/backend/app/routers/xcx_auth.py |
修改 | W2 |
apps/backend/app/routers/xcx_tasks.py |
修改 | W4 |
apps/backend/app/routers/xcx_performance.py |
修改 | W4 |
apps/backend/app/routers/xcx_customers.py |
修改 | W4 |
apps/backend/app/routers/xcx_coaches.py |
修改 | W4 |
db/zqyy_app/migrations/2026-03-27__fix_role_permissions.sql |
新增 | W3 |
apps/miniprogram/miniprogram/utils/auth-guard.ts |
修改 | W5 |
apps/miniprogram/miniprogram/app.ts |
修改 | W5 |
apps/miniprogram/typings/index.d.ts |
修改 | W5 |
apps/miniprogram/miniprogram/pages/board-finance/board-finance.ts |
修改 | W5 |
apps/miniprogram/miniprogram/pages/board-finance/board-finance.wxml |
修改 | W5 |
apps/miniprogram/miniprogram/pages/board-customer/board-customer.ts |
修改 | W5 |
apps/miniprogram/miniprogram/pages/board-customer/board-customer.wxml |
修改 | W5 |
apps/miniprogram/miniprogram/pages/board-coach/board-coach.ts |
修改 | W5 |
apps/miniprogram/miniprogram/pages/board-coach/board-coach.wxml |
修改 | W5 |