Merge branch 'main' into feature/delete_poe_account
This commit is contained in:
commit
bcd8592710
6 changed files with 41 additions and 36 deletions
19
README.md
19
README.md
|
@ -32,11 +32,11 @@ Just API's from some language model sites.
|
|||
<td><a href="https://github.com/xtekky/chatgpt-clone/pulls"><img alt="Pull Requests" src="https://img.shields.io/github/issues-pr/xtekky/chatgpt-clone?style=flat-square&labelColor=343b41"/></a></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><a href="https://github.com/mishalhossin/Coding-Chatbot-Gpt4Free"><b>ChatGpt Discord Bot</b></a></td>
|
||||
<td><a href="https://github.com/mishalhossin/Coding-Chatbot-Gpt4Free/stargazers"><img alt="Stars" src="https://img.shields.io/github/stars/mishalhossin/Coding-Chatbot-Gpt4Free?style=flat-square&labelColor=343b41"/></a></td>
|
||||
<td><a href="https://github.com/mishalhossin/Coding-Chatbot-Gpt4Free/network/members"><img alt="Forks" src="https://img.shields.io/github/forks/mishalhossin/Coding-Chatbot-Gpt4Free?style=flat-square&labelColor=343b41"/></a></td>
|
||||
<td><a href="https://github.com/mishalhossin/Coding-Chatbot-Gpt4Free/issues"><img alt="Issues" src="https://img.shields.io/github/issues/mishalhossin/Coding-Chatbot-Gpt4Free?style=flat-square&labelColor=343b41"/></a></td>
|
||||
<td><a href="https://github.com/mishalhossin/Coding-Chatbot-Gpt4Free/pulls"><img alt="Pull Requests" src="https://img.shields.io/github/issues-pr/mishalhossin/Coding-Chatbot-Gpt4Free?style=flat-square&labelColor=343b41"/></a></td>
|
||||
<td><a href="https://github.com/mishalhossin/Discord-Chatbot-Gpt4Free"><b>ChatGpt Discord Bot</b></a></td>
|
||||
<td><a href="https://github.com/mishalhossin/Discord-Chatbot-Gpt4Free/stargazers"><img alt="Stars" src="https://img.shields.io/github/stars/mishalhossin/Discord-Chatbot-Gpt4Free?style=flat-square&labelColor=343b41"/></a></td>
|
||||
<td><a href="https://github.com/mishalhossin/Discord-Chatbot-Gpt4Free/network/members"><img alt="Forks" src="https://img.shields.io/github/forks/mishalhossin/Discord-Chatbot-Gpt4Free?style=flat-square&labelColor=343b41"/></a></td>
|
||||
<td><a href="https://github.com/mishalhossin/Discord-Chatbot-Gpt4Free/issues"><img alt="Issues" src="https://img.shields.io/github/issues/mishalhossin/Discord-Chatbot-Gpt4Free?style=flat-square&labelColor=343b41"/></a></td>
|
||||
<td><a href="https://github.com/mishalhossin/Coding-Chatbot-Gpt4Free/pulls"><img alt="Pull Requests" src="https://img.shields.io/github/issues-pr/mishalhossin/Discord-Chatbot-Gpt4Free?style=flat-square&labelColor=343b41"/></a></td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
@ -86,7 +86,6 @@ Just API's from some language model sites.
|
|||
| [sqlchat.ai](https://sqlchat.ai) | GPT-3.5 |
|
||||
| [bard.google.com](https://bard.google.com) | custom / search |
|
||||
| [bing.com/chat](https://bing.com/chat) | GPT-4/3.5 |
|
||||
| [chat.forefront.ai/](https://chat.forefront.ai/) | GPT-4/3.5 |
|
||||
|
||||
## Best sites <a name="best-sites"></a>
|
||||
|
||||
|
@ -119,7 +118,7 @@ then run:
|
|||
Build
|
||||
|
||||
```
|
||||
docker build -t gpt4free:latest -f Docker/Dockerfile .
|
||||
docker build -t gpt4free:latest .
|
||||
```
|
||||
|
||||
Run
|
||||
|
@ -127,17 +126,13 @@ Run
|
|||
```
|
||||
docker run -p 8501:8501 gpt4free:latest
|
||||
```
|
||||
Another way - docker-compose (no docker build/run needed)
|
||||
```
|
||||
docker-compose up -d
|
||||
```
|
||||
|
||||
## Deploy using docker-compose
|
||||
|
||||
Run the following:
|
||||
|
||||
```
|
||||
docker-compose up -d
|
||||
docker-compose up --build -d
|
||||
```
|
||||
|
||||
## ChatGPT clone
|
||||
|
|
|
@ -3,7 +3,13 @@ version: "3.9"
|
|||
services:
|
||||
gpt4free:
|
||||
build:
|
||||
context: .
|
||||
context: ./
|
||||
dockerfile: Dockerfile
|
||||
container_name: dc_gpt4free
|
||||
# environment:
|
||||
# - http_proxy=http://127.0.0.1:1080 # modify this for your proxy
|
||||
# - https_proxy=http://127.0.0.1:1080 # modify this for your proxy
|
||||
image: img_gpt4free
|
||||
ports:
|
||||
- "8501:8501"
|
||||
- 8501:8501
|
||||
restart: always
|
|
@ -1,12 +0,0 @@
|
|||
version: '3.8'
|
||||
|
||||
services:
|
||||
gpt4:
|
||||
build:
|
||||
context: .
|
||||
dockerfile: Dockerfile
|
||||
image: gpt4free:latest
|
||||
container_name: gpt4
|
||||
ports:
|
||||
- 8501:8501
|
||||
restart: unless-stopped
|
|
@ -6,8 +6,11 @@ from gpt4free import forefront
|
|||
token = forefront.Account.create(logging=False)
|
||||
print(token)
|
||||
# get a response
|
||||
for response in forefront.StreamingCompletion.create(token=token,
|
||||
prompt='hello world', model='gpt-4'):
|
||||
print(response.completion.choices[0].text, end='')
|
||||
for response in forefront.StreamingCompletion.create(
|
||||
token=token,
|
||||
prompt='hello world',
|
||||
model='gpt-4'
|
||||
):
|
||||
print(response.choices[0].text, end='')
|
||||
print("")
|
||||
```
|
|
@ -5,7 +5,10 @@
|
|||
from gpt4free import theb
|
||||
|
||||
# simple streaming completion
|
||||
for token in theb.Completion.create('hello world'):
|
||||
|
||||
while True:
|
||||
x = input()
|
||||
for token in theb.Completion.create(x):
|
||||
print(token, end='', flush=True)
|
||||
print("")
|
||||
```
|
||||
|
|
|
@ -17,6 +17,7 @@ class Completion:
|
|||
timer = None
|
||||
message_queue = Queue()
|
||||
stream_completed = False
|
||||
last_msg_id = None
|
||||
|
||||
@staticmethod
|
||||
def request(prompt: str, proxy: Optional[str] = None):
|
||||
|
@ -29,25 +30,34 @@ class Completion:
|
|||
|
||||
proxies = {'http': 'http://' + proxy, 'https': 'http://' + proxy} if proxy else None
|
||||
|
||||
options = {}
|
||||
if Completion.last_msg_id:
|
||||
options['parentMessageId'] = Completion.last_msg_id
|
||||
|
||||
requests.post(
|
||||
'https://chatbot.theb.ai/api/chat-process',
|
||||
headers=headers,
|
||||
proxies=proxies,
|
||||
content_callback=Completion.handle_stream_response,
|
||||
json={'prompt': prompt, 'options': {}},
|
||||
json={'prompt': prompt, 'options': options},
|
||||
)
|
||||
|
||||
Completion.stream_completed = True
|
||||
|
||||
@staticmethod
|
||||
|
||||
def create(prompt: str, proxy: Optional[str] = None) -> Generator[str, None, None]:
|
||||
Completion.stream_completed = False
|
||||
|
||||
Thread(target=Completion.request, args=[prompt, proxy]).start()
|
||||
|
||||
while not Completion.stream_completed or not Completion.message_queue.empty():
|
||||
try:
|
||||
message = Completion.message_queue.get(timeout=0.01)
|
||||
for message in findall(Completion.regex, message):
|
||||
yield loads(Completion.part1 + message + Completion.part2)['delta']
|
||||
message_json = loads(Completion.part1 + message + Completion.part2)
|
||||
Completion.last_msg_id = message_json['id']
|
||||
yield message_json['delta']
|
||||
|
||||
except Empty:
|
||||
pass
|
||||
|
|
Loading…
Reference in a new issue