mirror repo from original : https://github.com/xiangsx/gpt4free-ts.git
Go to file
xiangsx 9eb7eca33e feat: update 2024-09-04 09:15:02 +08:00
.github/workflows feat: update docker-image.yml 2023-06-23 19:23:44 +08:00
model Merge remote-tracking branch 'origin/master' 2024-09-04 09:06:51 +08:00
utils feat: update config 2024-09-04 09:09:49 +08:00
.dockerignore feat: update 2023-06-23 19:19:38 +08:00
.gitignore feat: update 2023-06-23 19:19:38 +08:00
.prettierrc feat(base): 开源绝大部分站点 2023-09-10 22:26:06 +08:00
Dockerfile feat(openchat4): 更新docker 2024-06-18 13:53:42 +08:00
HowToUse.md feat: Update HowToUse.md 2023-08-09 16:32:12 +08:00
LICENSE.txt feat: add README.md 2023-05-04 21:40:33 +08:00
README.md feat: update 2024-09-04 09:15:02 +08:00
README_ja.md Add Japanese README 2023-06-11 12:33:31 +09:00
README_zh.md feat: update 2024-09-04 09:15:02 +08:00
asyncstore.ts feat: 全链路追踪 2024-01-15 13:48:46 +08:00
docker-compose.yaml feat(forefront): volume run dir 2023-06-06 13:14:41 +08:00
index.ts feat: 处理log 2024-02-26 08:33:47 +08:00
koa.d.ts feat: 增加trace日志 2024-02-23 13:04:29 +08:00
package.json feat(openchat4): pow 2024-09-01 19:05:50 +08:00
router.ts feat(luma): 增加信息显示 2024-08-28 16:27:08 +08:00
tsconfig.json feat: update docekr 2023-07-06 23:48:14 +08:00
yarn.lock feat(openchat4): pow 2024-09-01 19:05:50 +08:00

README.md

GPT4Free TypeScript Version 🆓

Providing a free OpenAI GPT-4 API!

English | 中文 | 日本語

Discord Server

You can join our discord: discord.gg/gptgod for further updates. gpt4free Discord

🆓 Free OpenAI Key

WebSite: https://gptgod.online

Api Base URL: https://api.gptgod.online

Api Key: sk-OsMMq65tXdfOIlTUYtocSL7NCsmA7CerN77OkEv29dODg1EA

Support Models: gpt-4-all,gpt-3.5-turbo,gpt-3.5-turbo-16k,net-gpt-3.5-turbo,net-gpt-3.5-turbo-16k,claude-1-100k,google-palm,llama-2-70b,llama-2-13b,llama-2-7b,code-llama-34b,code-llama-13b,code-llama-7b,qwen-72b,stable-diffusion,mixtral-8x7b,mistral-medium

🚩 Reverse target

I suggest you fork this project first. Some websites may go offline at any time.

Still striving to keep updating.

Have implemented models here: If you do not want your website to appear here, please raise an issue and I will remove it immediately. Unfortunately, most of the sites here are no longer available.

Update At 2023-09-10

Site Models
you gpt-3.5-turbo
phind net-gpt-3.5-turbo
forefront gpt-3.5-turbo, claude
mcbbs gpt-3.5-turbo, gpt-3.5-turbo-16k
chatdemo gpt-3.5-turbo, gpt-3.5-turbo-16k
vita gpt-3.5-turbo
skailar gpt-4
fakeopen gpt-3.5-turbo, gpt-3.5-turbo-16k, gpt-4
easychat gpt-4
better gpt-3.5-turbo, gpt-3.5-turbo-16k, gpt-4
pweb gpt-3.5-turbo, gpt-3.5-turbo-16k
bai gpt-3.5-turbo
gra gpt-3.5-turbo, gpt-3.5-turbo-16k
magic gpt-3.5-turbo, gpt-4, claude-instance, claude, claude-100k
chim gpt-3.5-turbo, gpt-3.5-turbo-16k, gpt-4
ram gpt-3.5-turbo-16k
chur gpt-3.5-turbo, gpt-3.5-turbo-16k
xun gpt-3.5-turbo, gpt-3.5-turbo-16k
vvm gpt-3.5-turbo, gpt-3.5-turbo-16k, gpt-4
poef
claude claude-2-100k
cursor gpt-3.5-turbo, gpt-4
chatbase gpt-3.5-turbo
ails gpt-3.5-turbo
sincode gpt-3.5-turbo, gpt-4
openai too much
jasper gpt-3.5-turbo, gpt-4
pap
acytoo gpt-3.5-turbo
google search
www url
ddg search

🏃‍♂️ Run

First of all, you should create file .env.

All operation methods require this step.

http_proxy=http://host:port
rapid_api_key=xxxxxxxxxx
EMAIL_TYPE=temp-email44
DEBUG=0
POOL_SIZE=0
PHIND_POOL_SIZE=0
  • http_proxy: config your proxy if you can not access target website directly; If you dont need proxy, delete this line;
  • forefront use env(this site has been removed):
    • rapid_api_key: you should config this if you use forefront api, this apikey is used for receive register email, get api key here
    • EMAIL_TYPE: temp email type includes temp-email temp-email44 tempmail-lol
      • temp-email: soft limit 100req/days, if over use money, need bind credit card! Very Stable!
      • temp-email44: hard limit 100req/days! Stable!
      • tempmail-lol: nothing need, limit 25request/5min. Not Stable.
    • DEBUG: Valid when use forefront You can set =1 when you run local. show reverse process
    • POOL_SIZE: forefront concurrency size. Keep set=1 until you run it successfully!!! You can engage in {POOL_SIZE} conversations concurrently. More pool size, More conversation can be done simultaneously, But use more RAM
  • phind use env:
    • PHIND_POOL_SIZE: phind concurrency size.You can engage in {POOL_SIZE} conversations concurrently. More pool size, More conversation can be done simultaneously, But use more RAM

Run local 🖥️

# install module
yarn
# start server
yarn start

Run with docker(Suggest!) 🐳

docker run -p 3000:3000 --env-file .env xiangsx/gpt4free-ts:latest

Deploy with docker-compose 🎭

first, you should create file .env; Follow step "Run with docker

deploy

docker-compose up --build -d

Clash+one-api+gpt4free-ts Start with one command 😮

gpt4free-ts-deploy

🚀 Let's Use GPT4

Find supports model and site http://127.0.0.1:3000/supports [GET]

The same as openai http://127.0.0.1:3000/:site/v1/chat/completions [POST]

The same as openai http://127.0.0.1:3000/v1/chat/completions?site=xxx [POST]

Return when chat complete http://127.0.0.1:3000/ask?prompt=&model=&site=*** [POST/GET]

Return with eventstream http://127.0.0.1:3000/ask/stream?prompt=&model=&site=*** [POST/GET]

Request Params 📝

  • prompt: your question. It can be a string or jsonstr.
    • example jsonstr:[{"role":"user","content":"hello\n"},{"role":"assistant","content":"Hi there! How can I assist you today?"},{"role":"user","content":"who are you"}]
    • example string: who are you
  • model: default gpt3.5-turbo. model include:gpt4 gpt3.5-turbo net-gpt3.5-turbo gpt-3.5-turbo-16k
  • site: default you. target site, include fakeopen better forefront you chatdemo phind vita

Site Support Model 🧩

query supports site and models with api 127.0.0.1:3000/supports

[
  {
    "site": "you",
    "models": [
      "gpt-3.5-turbo"
    ]
  },
  ...
]

Response Params 🔙

Response when chat end(/ask):

interface ChatResponse {
    content: string;
    error?: string;
}

Response with stream like, Suggest!!(/ask/stream):

event: message
data: {"content":"I"}

event: done
data: {"content":"'m"}

event: error
data: {"error":"some thind wrong"}

Example💡

  1. request to site you with history

req:

127.0.0.1:3000/ask?site=you&prompt=[{"role":"user","content":"hello"},{"role":"assistant","content":"Hi there! How can I assist you today?"},{"role":"user","content":"who are you"}]

res:

{
  "content": "Hi there! How can I assist you today?"
}

127.0.0.1:3000/ask?site=you&prompt=[{"role":"user","content":"你好\n"},{"role":"assistant","content":"你好!有什么我可以帮助你的吗?"},{"role":"user","content":"你是谁"}]

  1. request to site you with stream return

req:

127.0.0.1:3000/ask/stream?site=you&prompt=who are you

res:

event: message
data: {"content":"I"}

event: message
data: {"content":"'m"}

event: message
data: {"content":" a"}

event: message
data: {"content":" search"}

event: message
data: {"content":" assistant"}
........
event: done
data: {"content":"done"}

👥 Chat Group

🌟 Star History

Star History Chart

You may join our discord: discord.gg/gpt4free for further updates. gpt4free Discord

This is a replication project for the typescript version of gpt4free

gpt4free logo

This repository is not associated with or endorsed by providers of the APIs contained in this GitHub repository. This project is intended for educational purposes only. This is just a little personal project. Sites may contact me to improve their security or request the removal of their site from this repository.

Please note the following:

  1. Disclaimer: The APIs, services, and trademarks mentioned in this repository belong to their respective owners. This project is not claiming any right over them nor is it affiliated with or endorsed by any of the providers mentioned.

  2. Responsibility: The author of this repository is not responsible for any consequences, damages, or losses arising from the use or misuse of this repository or the content provided by the third-party APIs. Users are solely responsible for their actions and any repercussions that may follow. We strongly recommend the users to follow the TOS of the each Website.

  3. Educational Purposes Only: This repository and its content are provided strictly for educational purposes. By using the information and code provided, users acknowledge that they are using the APIs and models at their own risk and agree to comply with any applicable laws and regulations.

  4. Copyright: All content in this repository, including but not limited to code, images, and documentation, is the intellectual property of the repository author, unless otherwise stated. Unauthorized copying, distribution, or use of any content in this repository is strictly prohibited without the express written consent of the repository author.

  5. Indemnification: Users agree to indemnify, defend, and hold harmless the author of this repository from and against any and all claims, liabilities, damages, losses, or expenses, including legal fees and costs, arising out of or in any way connected with their use or misuse of this repository, its content, or related third-party APIs.

  6. Updates and Changes: The author reserves the right to modify, update, or remove any content, information, or features in this repository at any time without prior notice. Users are responsible for regularly reviewing the content and any changes made to this repository.

By using this repository or any code related to it, you agree to these terms. The author is not responsible for any copies, forks, or reuploads made by other users. This is the author's only account and repository. To prevent impersonation or irresponsible actions, you may comply with the GNU GPL license this Repository uses.