Files
codex-console/README.md
2026-03-21 23:00:03 +08:00

209 lines
5.5 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
# codex-console
基于 [cnlimiter/codex-manager](https://github.com/cnlimiter/codex-manager) 持续修复和维护的增强版本。
这个版本的目标很直接: 把近期 OpenAI 注册链路里那些“昨天还能跑,今天突然翻车”的坑补上,让注册、登录、拿 token、打包运行都更稳一点。
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](LICENSE)
[![Python](https://img.shields.io/badge/Python-3.10%2B-blue.svg)](https://www.python.org/)
## 致谢
首先感谢上游项目作者 [cnlimiter](https://github.com/cnlimiter) 提供的优秀基础工程。
本仓库是在原项目思路和结构之上进行兼容性修复、流程调整和体验优化,适合作为一个“当前可用的修复维护版”继续使用。
## 这个分支修了什么
为适配当前注册链路,这个分支重点补了下面几个问题:
1. 新增 Sentinel POW 求解逻辑
OpenAI 现在会强制校验 Sentinel POW原先直接传空值已经不行了这里补上了实际求解流程。
2. 注册和登录拆成两段
现在注册完成后通常不会直接返回可用 token而是跳转到绑定手机或后续页面。
本分支改成“先注册成功,再单独走一次登录流程拿 token”避免卡死在旧逻辑里。
3. 去掉重复发送验证码
登录流程里服务端本身会自动发送验证码邮件,旧逻辑再手动发一次,容易让新旧验证码打架。
现在改成直接等待系统自动发来的那封验证码邮件。
4. 修复重新登录流程的页面判断问题
针对重新登录时页面流转变化,调整了登录入口和密码提交逻辑,减少卡在错误页面的情况。
5. 优化终端和 Web UI 提示文案
保留可读性的前提下,把一些提示改得更友好一点,出错时至少不至于像在挨骂。
## 核心能力
- Web UI 管理注册任务和账号数据
- 支持批量注册、日志实时查看、基础任务管理
- 支持多种邮箱服务接码
- 支持 SQLite 和远程 PostgreSQL
- 支持打包为 Windows/Linux/macOS 可执行文件
- 更适配当前 OpenAI 注册与登录链路
## 环境要求
- Python 3.10+
- `uv`(推荐)或 `pip`
## 安装依赖
```bash
# 使用 uv推荐
uv sync
# 或使用 pip
pip install -r requirements.txt
```
## 环境变量配置
可选。复制 `.env.example``.env` 后按需修改:
```bash
cp .env.example .env
```
常用变量如下:
| 变量 | 说明 | 默认值 |
| --- | --- | --- |
| `APP_HOST` | 监听主机 | `0.0.0.0` |
| `APP_PORT` | 监听端口 | `8000` |
| `APP_ACCESS_PASSWORD` | Web UI 访问密钥 | `admin123` |
| `APP_DATABASE_URL` | 数据库连接字符串 | `data/database.db` |
优先级:
`命令行参数 > 环境变量(.env) > 数据库设置 > 默认值`
## 启动 Web UI
```bash
# 默认启动127.0.0.1:8000
python webui.py
# 指定地址和端口
python webui.py --host 0.0.0.0 --port 8080
# 调试模式(热重载)
python webui.py --debug
# 设置 Web UI 访问密钥
python webui.py --access-password mypassword
# 组合参数
python webui.py --host 0.0.0.0 --port 8080 --access-password mypassword
```
说明:
- `--access-password` 的优先级高于数据库中的密钥设置
- 该参数只对本次启动生效
- 打包后的 exe 也支持这个参数
例如:
```bash
codex-console.exe --access-password mypassword
```
启动后访问:
[http://127.0.0.1:8000](http://127.0.0.1:8000)
## Docker 部署
### 使用 docker-compose
```bash
docker-compose up -d
```
你可以在 `docker-compose.yml` 中修改环境变量,比如端口和访问密码。
### 使用 docker run
```bash
docker run -d \
-p 1455:1455 \
-e WEBUI_HOST=0.0.0.0 \
-e WEBUI_PORT=1455 \
-e WEBUI_ACCESS_PASSWORD=your_secure_password \
-v $(pwd)/data:/app/data \
--name codex-console \
ghcr.io/<yourname>/codex-console:latest
```
说明:
- `WEBUI_HOST`: 监听主机,默认 `0.0.0.0`
- `WEBUI_PORT`: 监听端口,默认 `1455`
- `WEBUI_ACCESS_PASSWORD`: Web UI 访问密码
- `DEBUG`: 设为 `1``true` 可开启调试模式
- `LOG_LEVEL`: 日志级别,例如 `info``debug`
注意:
`-v $(pwd)/data:/app/data` 很重要,这会把数据库和账号数据持久化到宿主机。否则容器一重启,数据也可能跟着表演消失术。
## 使用远程 PostgreSQL
```bash
export APP_DATABASE_URL="postgresql://user:password@host:5432/dbname"
python webui.py
```
也支持 `DATABASE_URL`,但优先级低于 `APP_DATABASE_URL`
## 打包为可执行文件
```bash
# Windows
build.bat
# Linux/macOS
bash build.sh
```
Windows 打包完成后,默认会在 `dist/` 目录生成类似下面的文件:
```text
dist/codex-console-windows-X64.exe
```
如果打包失败,优先检查:
- Python 是否已加入 PATH
- 依赖是否安装完整
- 杀毒软件是否拦截了 PyInstaller 产物
- 终端里是否有更具体的报错日志
## 项目定位
这个仓库更适合作为:
- 原项目的修复增强版
- 当前注册链路的兼容维护版
- 自己二次开发的基础版本
如果你准备公开发布,建议在仓库描述里明确写上:
`Forked and fixed from cnlimiter/codex-manager`
这样既方便别人理解来源,也对上游作者更尊重。
## 仓库命名
当前仓库名:
`codex-console`
## 免责声明
本项目仅供学习、研究和技术交流使用,请遵守相关平台和服务条款,不要用于违规、滥用或非法用途。
因使用本项目产生的任何风险和后果,由使用者自行承担。