6fe04f4893
feat: 添加 Admin 管理后台
...
- 数据库新增 Role 枚举、disabled 字段和 McpCallLog 调用日志表
- 后端新增 requireAdmin 中间件和 /api/admin/* 管理接口(统计、用户、项目、日志)
- MCP 工具调用自动记录详细日志(耗时、参数、响应大小、客户端IP、token估算)
- 前端新增 /admin 路由区域:仪表盘、用户管理、项目管理、调用日志四个页面
- JWT 携带 role 字段,登录/OAuth 增加禁用账号检查
- nginx 配置补充 X-Forwarded-For 透传真实客户端 IP
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-04-04 13:04:44 +08:00
f3fbd3876a
refactor: OpenAPI URL 抓取改为前端执行 + 服务端 CORS 代理
...
- 前端直接 fetch URL 支持 localhost/内网地址
- CORS 失败自动回退到服务端代理 /api/fetch-spec
- 添加 js-yaml 支持 YAML 格式解析
- 服务端移除 specUrl 参数,只接收已解析的 spec 对象
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-04-03 19:28:53 +08:00
49ca1f6e1f
feat: OAuth 登录后返回来源页 + 登录页清理
...
- OAuth 流程透传 redirect 参数,登录后回到触发页面而非固定跳 Dashboard
- 服务端校验 redirect 为相对路径,防止 Open Redirect 攻击
- 隐藏 Apple 登录按钮和邮箱注册入口
- Dark Mode 切换改为下拉菜单样式
- 提取 useClickOutside hook 消除重复代码
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-04-03 17:56:57 +08:00
5e6efdaf59
fix: Docker 构建改用 npm 替代 pnpm + 补全 OAuth/Redis 环境变量
...
- Dockerfile 全部改为 npm install + 全局 tsc,解决 pnpm 符号链接问题
- docker-compose 添加 Redis 服务、OAuth 环境变量透传、web 端口改为可配置
- MCP URL 改用 window.location.origin 适配反向代理
- tsconfig 添加 paths 映射解决 Docker 内模块引用
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-04-03 17:24:52 +08:00
9733b82c9c
feat: 支持 OAuth 无密码用户设置密码和查看 API Key
...
- 新增 POST /auth/set-password 端点(仅限无密码用户)
- /auth/me 返回 hasPassword 字段
- SettingsDialog:无密码用户显示"设置密码"表单(无需当前密码)
- API Key reveal/copy:无密码时引导用户先设置密码
- 中英双语 i18n 支持
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com >
2026-04-03 13:39:46 +08:00
8ed857c31c
merge: 合并 main 分支的 i18n 重构到 login-page 功能分支
...
解决冲突:
- i18n.tsx: 采用 main 的独立文件架构(en.ts/zh.ts),新增 OAuth/branding 翻译 key
- Login.tsx: 保留左右分栏布局,合入 main 的验证消息 i18n 化
- Register.tsx: 同上,合入 main 的 placeholder i18n 化
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com >
2026-04-03 13:31:41 +08:00
9b41878ae7
refactor: 优化 i18n 类型安全与渲染性能
...
- 导出 TranslationKey 类型,翻译 key 拼写错误编译期即报错
- zh.ts 使用 TranslationKey 约束,确保中英文 key 同步
- useMemo 包装 context value,避免不必要的全局重渲染
- ConfirmDialog confirmText 默认值改用 t() 而非硬编码英文
- SchemaProperties 递归组件改为 prop 传递 t,减少 useContext 调用
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-04-03 13:26:57 +08:00
eacaa5be05
refactor: simplify OAuth routes, add type safety, deduplicate UI components
...
- Extract handleOAuthCallback to eliminate GET/POST duplication in oauth.ts
- Add P2002 race condition handling in findOrCreateUser
- Add .unref() to stateStore cleanup timer to not block process exit
- Use Provider union type instead of bare strings throughout OAuth code
- Export API_BASE from api.ts, reuse in OAuthButtons
- Extract MobileBranding component to deduplicate Login/Register mobile brand
- Extract shared Logo component in AuthBranding
- Remove unnecessary WHAT comments
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com >
2026-04-03 13:25:50 +08:00
0bab0ecb93
feat: redesign register page with left-right split layout and OAuth buttons
2026-04-03 13:18:07 +08:00
db4e5540ad
feat: redesign login page with left-right split layout and OAuth buttons
2026-04-03 13:18:05 +08:00
a7027c8aaa
feat: add LoginCallback page and route for OAuth redirect handling
2026-04-03 13:17:53 +08:00
0a48152e0f
feat: add AuthBranding and OAuthButtons components
...
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-04-03 13:15:56 +08:00
6d633eeac4
feat: add i18n translation keys for auth pages
2026-04-03 13:15:42 +08:00
7f44bc8e32
feat: add loginWithTokens method to auth context for OAuth flow
2026-04-03 13:15:38 +08:00
67295c22d1
feat: 全面支持中英文多语言切换
...
将翻译文件拆分为独立的 en.ts/zh.ts,为 t() 函数添加插值支持,
国际化 Dashboard 全部页面和组件(登录、注册、项目管理、设置、
MCP 集成等),修复 ThemeToggle 仅中文标签的 bug,
在 Dashboard header 中添加 LanguageToggle 组件。
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-04-03 13:10:09 +08:00
1712b25748
fix: 修复项目相关页面路由前缀为 /dashboard
...
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com >
2026-04-03 12:29:57 +08:00
7e691a8100
feat: new home web
2026-04-03 00:02:09 +08:00
35511eb877
feat: opt web ux
2026-04-02 22:10:24 +08:00
143b1e8c4b
feat: optimize web ui
2026-04-02 18:22:14 +08:00
a34f486d7c
fix: MCP config type should be 'http' not 'url' for Claude Code
2026-04-02 15:17:51 +08:00
ea1aff7200
fix: correct MCP config snippet - add type:url, use port 3001 directly
2026-04-02 15:12:37 +08:00
afd8b444c7
fix: pre-fetch URL spec then bundle+dereference to handle self-referencing $ref
2026-04-02 15:00:32 +08:00
6aaba810d8
fix: fetch OpenAPI doc from browser to avoid Docker network isolation, add Swagger 2.0 support
2026-04-02 14:51:43 +08:00
5f76abec8b
fix: fix Docker dev proxy and handle non-JSON error responses in frontend
2026-04-02 14:48:40 +08:00
f5907892bf
feat: add Docker Compose setup with Dockerfiles for all services
...
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-04-02 13:39:21 +08:00
c3f8b598af
feat: add React frontend with auth, project list, import, and project detail pages
...
Converts packages/web from vanilla TypeScript Vite scaffold to React with:
- React 19, react-router-dom v7, @tanstack/react-query v5, Tailwind CSS v4
- JWT auth context with auto-refresh token support
- Login/Register pages, protected Layout with auth guard
- Projects list with grid cards and delete action
- ImportDialog supporting URL or file upload with API key display
- ProjectDetail with 4 tabs: Documentation, Modules, MCP Integration, Settings
- All TypeScript compiles cleanly (noEmit check passes)
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-04-02 13:36:45 +08:00
f644dc2dfd
feat: initialize monorepo with shared, server, mcp, and web packages
...
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-04-02 11:28:59 +08:00