# 变更日志 ## 2026-05-14 - [修复] `next.config.ts` 添加 `ldapts` 到 `serverExternalPackages`(预防性修复),确保 Next.js standalone 构建包含 LLDAP 客户端模块,避免 SSO 自动创建用户失败(issue-ai 已实际触发,参见 issue-ai CHANGELOG) - [调整] 全局证书切换:Cloudflare Origin CA → Let's Encrypt(`/etc/letsencrypt/live/www.tlyq.ai/`),覆盖全部 7 个子域名,nginx 8 个站点配置同步更新 ## 2026-05-12 - [部署] 云端 JWT 密钥统一为 oa-shared-jwt-secret-tlyq-2026,三站点密钥一致 - [部署] docker-compose 移除 AUTHELIA_URL,添加 LDAP/COOKIE/INTERNAL_API_KEY 环境变量 - [部署] LLDAP admin 密码更新为 3Vm!Y!@RCiPs - [部署] nginx 移除 auth_request,恢复纯反向代理;改为运行时 DNS 解析 - [新增] `src/lib/db-schema.ts`:users 表新增 last_login_at / last_active_at 列 - [新增] `src/lib/auth.ts`:getSession() 更新 last_active_at - [新增] `src/app/api/auth/login/route.ts`:登录时更新 last_login_at 和 last_active_at ## 2026-05-11 - [新增] `src/lib/ldap.ts`:`ldapUserExists()` 函数,检查 LLDAP 中用户是否存在(admin bind 搜索,不可达时容错放行) - [新增] `src/lib/jwt.ts`:共享 JWT 签发/验证(`tlyq_session` cookie,HS256,与 OA/issue 共用密钥) - [调整] `src/lib/auth.ts`:`getSession()` 优先 `tlyq_session`,加入 LLDAP 存在性检查,用户被删除后自动清除 cookie 踢出 - [调整] `src/app/api/auth/login/route.ts`:LDAP 优先认证 + 本地密码缓存回退 + localadmin 应急用户直连 - [调整] `src/app/api/auth/logout/route.ts`:同时清除 `session_assets` 和 `tlyq_session` - [调整] `src/app/api/auth/me/route.ts`:移除 SSO header 路径,改用 `getSession()` 统一获取 - [调整] `src/middleware.ts`:优先 `tlyq_session` → 回退 `session_assets`,移除 SSO 代理路径,放行 `/api/internal/` - [调整] `src/app/(app)/layout.tsx`:移除 SSO header 路径,统一从 `session` cookie 读取用户 - [新增] `src/app/api/internal/roles/route.ts`:内部 API,返回站点可用角色列表(INTERNAL_API_KEY 鉴权) - [新增] `src/app/api/users/[id]/route.ts`:admin/localadmin 用户禁止删除和修改角色 - [调整] `src/app/(app)/settings/users/page.tsx`:admin/localadmin 用户隐藏删除按钮,编辑时角色字段显示为只读 - [新增] `src/lib/db-schema.ts`:预置 localadmin 应急用户(admin 角色,纯本地 BCrypt 认证) ## 2026-05-07 - [新增] 导出功能区分"导出选中"和"导出全部"两种模式,有选中时工具栏显示两个按钮独立操作 - [新增] 角色权限系统完整改造,支持新建角色、编辑角色权限(10 个细粒度权限复选框) - [新增] 用户管理页角色下拉从 API 动态获取,不再硬编码 - [优化] 设备详情页空字段区块自动隐藏(如无数据盘 2 则不显示该卡片) - [优化] 导出权限拆分为 `assets:export:selected`(导出选中)和 `assets:export:all`(导出全部),按钮显隐由权限驱动 - [优化] 内置角色权限自动同步到最新默认值,自定义角色旧权限自动迁移 - [修复] 资产列表 API 和导出 API 的 filter 参数增加字段白名单校验 - [修复] 导出文件名日期改用本地时间,避免 UTC+8 时区偏移 ## 2026-04-30 - [新增] 创建 README 文档 ## 2026-04-29 - [新增] 设备管理列表支持鼠标拖拽自定义列宽(首次拖拽自动快照列宽,最小 60px,支持自动换行) - [优化] 设备状态下拉框改为「腾讯使用/图灵使用/闲置」默认选项,支持自定义新增状态 - [优化] 数据库 106 台设备状态从「在用」迁移为「腾讯使用」 - [修复] 设备详情页/列表页「腾讯使用」状态徽章颜色显示为灰色的问题 - [优化] 列头居中显示,排序/筛选模式切换按钮与排序图标左右对称布局 - [修复] 表头 `overflow-hidden` 导致筛选下拉框被裁切的问题 - [优化] 筛选弹框宽度改为自适应(`w-fit min-w-48 max-w-80`) - [优化] 排序/筛选图标改为可点击,直接点击图标即可触发排序或筛选 - [修复] 列头排序图标使用 `