Pandora
潘多拉 (Pandora),一个不只是命令行的 ChatGPT。
潘多拉实现了网页版 ChatGPT 的主要操作。后端优化,绕过 Cloudflare,速度喜人。
潘多拉 Pandora
一个不只是命令行的 "ChatGPT"
README in English »
查看Demo
·
报告Bug
·
提出新特性
目录
- 为什么要用
- 界面截图
- 如何运行
- 程序参数
- Docker环境变量
- 关于 Access Token
- HTTP服务文档
- 操作命令
- 高阶设置
- Cloud模式
- 使用Cloudflare Workers代理
- 其他说明
为什么要用
- 高峰期能绕过官方限制,继续使用。
- 应答速度直逼
PLUS
,白嫖用户的福音。 - 官方故障的时候,它可能还是能跑。
- 多模式:网页/命令行/API,私有化部署。
- 不会像官方那样无故断线、报错。
界面截图
如何运行
-
Python版本目测起码要
3.7
-
pip安装运行
pip install pandora-chatgpt pandora
-
如果你想支持
gpt-3.5-turbo
模式:pip install 'pandora-chatgpt[api]' pandora
-
如果你想启用
cloud
模式:pip install 'pandora-chatgpt[cloud]' pandora-cloud
-
-
编译运行
pip install . pandora
-
如果你想支持
gpt-3.5-turbo
模式:pip install '.[api]' pandora
-
如果你想启用
cloud
模式:pip install '.[cloud]' pandora-cloud
-
-
Docker Hub运行
docker pull pengzhile/pandora docker run -it --rm pengzhile/pandora
-
Docker编译运行
docker build -t pandora . docker run -it --rm pandora
-
输入用户名密码登录即可,登录密码理论上不显示出来,莫慌。
-
简单而粗暴,不失优雅。
程序参数
- 可通过
pandora --help
查看。 -p
或--proxy
指定代理,格式:protocol://user:pass@ip:port
。-t
或--token_file
指定一个存放Access Token
的文件,使用Access Token
登录。-s
或--server
以http
服务方式启动,格式:ip:port
。-a
或--api
使用gpt-3.5-turbo
API请求,你可能需要向OpenAI
支付费用。--tokens_file
指定一个存放多Access Token
的文件,内容为{"key": "token"}
的形式。--sentry
启用sentry
框架来发送错误报告供作者查错,敏感信息不会被发送。-v
或--verbose
显示调试信息,且出错时打印异常堆栈信息,供查错使用。
Docker环境变量
PANDORA_ACCESS_TOKEN
指定Access Token
字符串。PANDORA_TOKENS_FILE
指定一个存放多Access Token
的文件路径。PANDORA_PROXY
指定代理,格式:protocol://user:pass@ip:port
。PANDORA_SERVER
以http
服务方式启动,格式:ip:port
。PANDORA_API
使用gpt-3.5-turbo
API请求,你可能需要向OpenAI
支付费用。PANDORA_SENTRY
启用sentry
框架来发送错误报告供作者查错,敏感信息不会被发送。PANDORA_VERBOSE
显示调试信息,且出错时打印异常堆栈信息,供查错使用。- 使用Docker方式,设置环境变量即可,无视上述
程序参数
。
关于 Access Token
- 使用
Access Token
方式登录,可以无代理直连。 - 这个服务 可以帮你安全有效拿到
Access Token
,无论是否第三方登录。 - 其中
accessToken
字段的那一长串内容即是Access Token
。 Access Token
可以复制保存,其有效期目前为1个月
。- 不要泄露你的
Access Token
,使用它可以操纵你的账号。
HTTP服务文档
- 如果你以
http
服务方式启动,现在你可以打开一个极简版的ChatGPT
了。通过你指定的http://ip:port
来访问。 - 通过
http://ip:port/?token=xxx
,传递一个Token的名字,可以切换到对应的Access Token
。 - API文档见:doc/HTTP-API.md
操作命令
- 对话界面连敲两次
Enter
发送你的输入给ChatGPT
。 - 对话界面使用
/?
可以打印支持的操作命令。 /title
重新设置当前对话的标题。/select
回到选择会话界面。/reload
重新加载当前会话所有内容,F5
你能懂吧。/regen
如果对ChatGPT
当前回答不满意,可以让它重新回答。/continue
让ChatGPT
继续输出回复的剩余部分。/edit
编辑你之前的一个提问。/new
直接开启一个新会话。/del
删除当前会话,回到会话选择界面。/token
打印当前的Access Token
,也许你用得上,但不要泄露。/copy
复制ChatGPT
上一次回复的内容到剪贴板。/copy_code
复制ChatGPT
上一次回复的代码到剪贴板/clear
清屏,应该不用解释。/version
打印Pandora
的版本信息。/exit
退出潘多拉
。
高阶设置
- 本部分内容不理解的朋友,请勿擅动!
- 环境变量
OPENAI_API_PREFIX
可以替换OpenAI Api的前缀https://api.openai.com
。 - 环境变量
CHATGPT_API_PREFIX
可以替换ChatGPT Api的前缀https://ai.fakeopen.com
。 - 如果你想持久存储
Docker
中Pandora
产生的数据,你可以挂载宿主机目录至/data
。 - 如果你在国内使用
pip
安装缓慢,可以考虑切换至腾讯的源:pip config set global.index-url https://mirrors.cloud.tencent.com/pypi/simple
- 镜像同步版本可能不及时,如果出现这种情况建议切换至官方源:
pip config set global.index-url https://pypi.org/simple
- 默认使用
sqlite3
存储会话数据,如果你希望更换至mysql
,可以这么做:- 执行
pip install PyMySQL
安装驱动。 - 设置环境变量:
DATABASE_URI
为类似mysql+pymysql://user:pass@localhost/dbname
的连接字符串。
- 执行
- 环境变量指定
OPENAI_EMAIL
可以替代登录输入用户名,OPENAI_PASSWORD
则可以替代输入密码。 - 环境变量
API_SYSTEM_PROMPT
可以替换api
模式下的系统prompt
。
Cloud模式
- 搭建一个跟官方很像的
ChatGPT
服务,不能说很像,只能说一样。 - 该模式使用
pandora-cloud
启动,前提是你如前面所说安装好了。 - Docker环境变量:
PANDORA_CLOUD
启动cloud
模式。 - 该模式参数含义与普通模式相同,可
--help
查看。
使用Cloudflare Workers代理
-
如果你感觉默认的
https://ai.fakeopen.com
在你那里可能被墙了,可以使用如下方法自行代理。 -
你需要一个
Cloudflare
账号,如果没有,可以注册一个。 -
登录后,点击
Workers
,然后点击Create a Worker
,填入服务名称后点击创建服务
。 -
点开你刚才创建的服务,点击
快速编辑
按钮,贴入下面的代码,然后点击保存并部署
。export default { async fetch(request, env) { const url = new URL(request.url); url.host = 'ai.fakeopen.com'; return fetch(new Request(url, request)) } }
-
点击
触发器
选项卡,可以添加自定义访问域名。 -
参考
高阶设置
中的环境变量使用你的服务地址进行替换。
其他说明
- 项目是站在其他巨人的肩膀上,感谢!
- 报错、BUG之类的提出
Issue
,我会修复。 - 因为之后
ChatGPT
的API变动,我可能不会跟进修复。 - 喜欢的可以给颗星,都是老朋友了。
- 不影响
PHP是世界上最好的编程语言!
贡献者们
感谢所有让这个项目变得更好的贡献者们!