chore: 排除本地开发文件(plans目录和UI.md)

This commit is contained in:
lulistart
2026-02-18 02:57:08 +08:00
parent 6575f75e37
commit f9c4e52970
3 changed files with 2 additions and 405 deletions

2
.gitignore vendored
View File

@@ -5,3 +5,5 @@ token.json
.DS_Store .DS_Store
database/app.db database/app.db
.env.exa .env.exa
plans/
UI.md

99
UI.md
View File

@@ -1,99 +0,0 @@
🎨 UI 设计风格分析
kiro-unified-manager 的 UI 特点:
现代简约风格 - 使用 Tailwind CSS干净的卡片布局
专业的管理后台风格 - 类似企业级 SaaS 产品
优雅的动画效果 - 淡入淡出、滑动过渡
响应式设计 - 适配不同屏幕尺寸
直观的状态指示 - 颜色编码的状态标签
丰富的交互反馈 - 悬停效果、加载状态
📝 UI 提示词模板
基础风格提示词
请设计一个现代化的管理后台界面,具有以下特点:
**整体风格:**
- 使用简约现代的设计语言,类似 Tailwind CSS 风格
- 采用卡片式布局,白色背景配合浅灰色边框
- 整体配色以蓝色系为主色调(#3b82f6),搭配灰色系辅助色
- 界面干净整洁,留白充足,视觉层次清晰
**布局结构:**
- 顶部导航栏:白色背景,包含 Logo、导航标签和用户信息
- 主内容区域:浅灰色背景(#f9fafb),居中布局,最大宽度限制
- 卡片容器:白色背景,圆角边框,轻微阴影效果
**交互元素:**
- 按钮:圆角设计,主要按钮使用蓝色,次要按钮使用灰色
- 表格:斑马纹效果,悬停高亮
- 表单:简洁的输入框,聚焦时蓝色边框
- 状态标签:彩色圆角标签,不同状态使用不同颜色
**动画效果:**
- 页面切换使用淡入淡出效果
- 按钮悬停有颜色过渡
- 模态框弹出有缩放动画
- 通知消息从右上角滑入
**响应式设计:**
- 移动端友好,自适应布局
- 表格在小屏幕上可横向滚动
- 导航在移动端可折叠
具体组件提示词
**导航栏设计:**
创建一个顶部导航栏白色背景高度64px包含
- 左侧:品牌 Logo + 图标,使用蓝色主题
- 中间:水平导航标签,激活状态有蓝色下边框
- 右侧:用户头像 + 下拉菜单
**数据表格设计:**
设计一个现代化数据表格:
- 表头使用浅灰色背景
- 行间隔使用斑马纹效果
- 悬停行高亮显示
- 状态列使用彩色圆角标签
- 操作列包含彩色文字链接
**模态框设计:**
创建优雅的模态框:
- 半透明黑色遮罩背景
- 白色圆角内容区域
- 顶部标题栏带关闭按钮
- 底部操作按钮区域
- 弹出时有缩放动画效果
**通知消息设计:**
设计右上角通知组件:
- 固定定位在右上角
- 彩色背景(成功绿色、错误红色、信息蓝色)
- 白色文字,包含图标
- 自动消失,滑入滑出动画
**按钮系统:**
- 主要按钮:蓝色背景,白色文字,悬停变深蓝
- 次要按钮:灰色边框,灰色文字,悬停背景变浅灰
- 危险按钮:红色背景,用于删除等操作
- 禁用状态50% 透明度,不可点击
颜色系统提示词
**配色方案:**
- 主色调:蓝色系 (#3b82f6, #2563eb, #1d4ed8)
- 成功色:绿色系 (#10b981, #059669)
- 警告色:黄色系 (#f59e0b, #d97706)
- 错误色:红色系 (#ef4444, #dc2626)
- 中性色:灰色系 (#6b7280, #4b5563, #374151)
- 背景色:浅灰色 (#f9fafb, #f3f4f6)
- 文字色:深灰色 (#111827, #374151, #6b7280)
动画效果提示词
**动画系统:**
- 页面过渡300ms 淡入淡出效果
- 按钮悬停200ms 颜色过渡
- 模态框:弹出时 0.3s 缩放动画,从 0.95 到 1.0
- 通知消息从右侧滑入3秒后自动滑出
- 加载状态:旋转动画的 spinner 图标
- 表格行悬停:背景色平滑过渡
🚀 使用建议
当你要创建类似风格的网站时,可以这样使用提示词:
基础搭建:先使用"基础风格提示词"建立整体框架
组件细化:根据需要使用"具体组件提示词"
样式调整:参考"颜色系统"和"动画效果"进行微调
技术栈:建议使用 Tailwind CSS + Vue.js 或 React

View File

@@ -1,306 +0,0 @@
# GPT2API Node - API 网关后台管理系统架构设计
## 1. 系统概述
构建一个专业的 API 网关后台管理系统,用于管理 OpenAI Codex 代理服务的用户、API Keys 和 Token 账户。
## 2. 核心功能模块
### 2.1 用户认证模块
- 管理员登录/登出
- 密码修改
- Session 管理
- JWT Token 认证
### 2.2 API Key 管理模块
- 创建 API Key自动生成
- 删除 API Key
- 列表展示(包含创建时间、最后使用时间、使用次数)
- API Key 权限控制(可选:限流、配额)
### 2.3 Token 账户管理模块
- JSON 文件导入(支持 CLIProxyAPI 格式)
- 账户列表展示
- 账户状态监控Token 过期时间、刷新状态)
- 账户删除
- 自动 Token 刷新
### 2.4 统计监控模块
- API 调用统计
- 使用量统计
- 错误日志
- 实时状态监控
## 3. 技术架构
### 3.1 后端技术栈
```
- Node.js + Express
- SQLite轻量级数据库
- bcrypt密码加密
- jsonwebtokenJWT 认证)
- multer文件上传
- express-session会话管理
```
### 3.2 前端技术栈
```
- HTML5 + TailwindCSS + DaisyUI
- Vanilla JavaScript无框架保持轻量
- Fetch APIHTTP 请求)
```
### 3.3 数据库设计
#### 表结构
**users 表**(管理员用户)
```sql
CREATE TABLE users (
id INTEGER PRIMARY KEY AUTOINCREMENT,
username TEXT UNIQUE NOT NULL,
password TEXT NOT NULL, -- bcrypt 加密
created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
updated_at DATETIME DEFAULT CURRENT_TIMESTAMP
);
```
**api_keys 表**API 密钥)
```sql
CREATE TABLE api_keys (
id INTEGER PRIMARY KEY AUTOINCREMENT,
key TEXT UNIQUE NOT NULL, -- sk-xxx 格式
name TEXT, -- 密钥名称/备注
created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
last_used_at DATETIME,
usage_count INTEGER DEFAULT 0,
is_active BOOLEAN DEFAULT 1
);
```
**tokens 表**OpenAI Token 账户)
```sql
CREATE TABLE tokens (
id INTEGER PRIMARY KEY AUTOINCREMENT,
name TEXT, -- 账户名称/备注
email TEXT,
account_id TEXT,
access_token TEXT NOT NULL,
refresh_token TEXT NOT NULL,
id_token TEXT,
expired_at DATETIME,
last_refresh_at DATETIME,
is_active BOOLEAN DEFAULT 1,
created_at DATETIME DEFAULT CURRENT_TIMESTAMP
);
```
**api_logs 表**API 调用日志)
```sql
CREATE TABLE api_logs (
id INTEGER PRIMARY KEY AUTOINCREMENT,
api_key_id INTEGER,
token_id INTEGER,
model TEXT,
endpoint TEXT,
status_code INTEGER,
error_message TEXT,
created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
FOREIGN KEY (api_key_id) REFERENCES api_keys(id),
FOREIGN KEY (token_id) REFERENCES tokens(id)
);
```
## 4. API 接口设计
### 4.1 认证接口
```
POST /admin/login # 管理员登录
POST /admin/logout # 管理员登出
POST /admin/change-password # 修改密码
GET /admin/profile # 获取当前用户信息
```
### 4.2 API Key 管理接口
```
GET /admin/api-keys # 获取 API Key 列表
POST /admin/api-keys # 创建新的 API Key
DELETE /admin/api-keys/:id # 删除 API Key
PATCH /admin/api-keys/:id # 更新 API Key启用/禁用)
```
### 4.3 Token 管理接口
```
GET /admin/tokens # 获取 Token 列表
POST /admin/tokens/import # 导入 Token JSON 文件
DELETE /admin/tokens/:id # 删除 Token
POST /admin/tokens/:id/refresh # 手动刷新 Token
```
### 4.4 统计接口
```
GET /admin/stats/overview # 总览统计
GET /admin/stats/usage # 使用量统计
GET /admin/logs # 获取日志
```
### 4.5 代理接口(需要 API Key 认证)
```
POST /v1/chat/completions # OpenAI 兼容接口
GET /v1/models # 模型列表
```
## 5. 前端界面设计
### 5.1 布局结构
```
┌─────────────────────────────────────────┐
│ 顶部导航栏Logo、用户信息、登出
├──────────┬──────────────────────────────┤
│ │ │
│ 左侧 │ │
│ 导航 │ 主内容区域 │
│ 菜单 │ │
│ │ │
│ - 仪表盘│ │
│ - API Keys │
│ - Tokens│ │
│ - 日志 │ │
│ - 设置 │ │
│ │ │
└──────────┴──────────────────────────────┘
```
### 5.2 页面列表
1. **登录页面** - 管理员登录
2. **仪表盘** - 总览统计、快速操作
3. **API Keys 管理** - 列表、创建、删除
4. **Tokens 管理** - 列表、导入、删除、刷新
5. **日志查看** - API 调用日志、错误日志
6. **设置页面** - 密码修改、系统配置
## 6. 安全设计
### 6.1 认证机制
- 管理后台使用 JWT Token 认证
- API 代理使用 API Key 认证
- 密码使用 bcrypt 加密存储
### 6.2 权限控制
- 所有 `/admin/*` 接口需要登录认证
- API Key 验证中间件
- CORS 配置
### 6.3 安全措施
- 密码强度验证
- 登录失败次数限制
- API Key 格式:`sk-` + 32位随机字符
- Token 自动刷新机制
## 7. 部署方案
### 7.1 目录结构
```
gpt2api-node/
├── src/
│ ├── index.js # 主入口
│ ├── config/
│ │ └── database.js # 数据库配置
│ ├── middleware/
│ │ ├── auth.js # 认证中间件
│ │ └── apiKey.js # API Key 验证
│ ├── models/
│ │ ├── User.js
│ │ ├── ApiKey.js
│ │ └── Token.js
│ ├── routes/
│ │ ├── admin.js # 管理接口
│ │ ├── apiKeys.js
│ │ ├── tokens.js
│ │ └── proxy.js # 代理接口
│ ├── services/
│ │ ├── tokenManager.js # Token 管理服务
│ │ └── proxyHandler.js # 代理处理服务
│ └── utils/
│ ├── crypto.js # 加密工具
│ └── logger.js # 日志工具
├── public/
│ ├── admin/
│ │ ├── index.html # 管理后台
│ │ ├── login.html # 登录页
│ │ ├── css/
│ │ └── js/
│ └── assets/
├── database/
│ └── app.db # SQLite 数据库
├── package.json
└── README.md
```
### 7.2 环境变量
```env
PORT=3000
JWT_SECRET=your-secret-key
ADMIN_USERNAME=admin
ADMIN_PASSWORD=admin123
DATABASE_PATH=./database/app.db
```
## 8. 实施计划
### 阶段 1数据库和认证核心
1. 创建数据库模型
2. 实现用户认证系统
3. 创建初始管理员账户
### 阶段 2API Key 管理
1. API Key 生成和存储
2. API Key 验证中间件
3. API Key 管理接口
### 阶段 3Token 管理
1. Token 导入功能
2. Token 自动刷新
3. Token 管理接口
### 阶段 4前端界面
1. 登录页面
2. 管理后台布局
3. 各功能页面实现
### 阶段 5统计和日志
1. API 调用日志记录
2. 统计数据展示
3. 日志查询功能
## 9. 技术难点和解决方案
### 9.1 多 Token 负载均衡
**问题**:多个 Token 账户如何分配请求?
**方案**
- 轮询策略
- 根据 Token 状态(过期时间、使用次数)智能选择
- 失败自动切换
### 9.2 Token 自动刷新
**问题**Token 过期前自动刷新
**方案**
- 定时任务检查即将过期的 Token
- 请求失败时触发刷新
- 刷新失败通知管理员
### 9.3 并发请求处理
**问题**:高并发下的性能
**方案**
- 连接池管理
- 请求队列
- 缓存机制
## 10. 后续扩展
- 多用户支持(不同权限级别)
- API Key 配额限制
- Webhook 通知
- 更详细的统计报表
- Docker 部署支持
- 集群部署支持