diff options
author | t.me/xtekky <98614666+xtekky@users.noreply.github.com> | 2023-04-20 16:34:19 +0200 |
---|---|---|
committer | t.me/xtekky <98614666+xtekky@users.noreply.github.com> | 2023-04-20 16:34:19 +0200 |
commit | a485cfb180094f14b3fe27ea218d2890033768a3 (patch) | |
tree | 8cf4b2f08fb79271a9dc30a0f8843c5561c5d9c9 /unfinished/theb.ai/__init__.py | |
parent | ora.sh (diff) | |
download | gpt4free-a485cfb180094f14b3fe27ea218d2890033768a3.tar gpt4free-a485cfb180094f14b3fe27ea218d2890033768a3.tar.gz gpt4free-a485cfb180094f14b3fe27ea218d2890033768a3.tar.bz2 gpt4free-a485cfb180094f14b3fe27ea218d2890033768a3.tar.lz gpt4free-a485cfb180094f14b3fe27ea218d2890033768a3.tar.xz gpt4free-a485cfb180094f14b3fe27ea218d2890033768a3.tar.zst gpt4free-a485cfb180094f14b3fe27ea218d2890033768a3.zip |
Diffstat (limited to 'unfinished/theb.ai/__init__.py')
-rw-r--r-- | unfinished/theb.ai/__init__.py | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/unfinished/theb.ai/__init__.py b/unfinished/theb.ai/__init__.py new file mode 100644 index 00000000..a90a32f5 --- /dev/null +++ b/unfinished/theb.ai/__init__.py @@ -0,0 +1,57 @@ +from curl_cffi import requests +from json import loads +from re import findall +from threading import Thread +from queue import Queue, Empty + +class Completion: + # experimental + part1 = '{"role":"assistant","id":"chatcmpl' + part2 = '"},"index":0,"finish_reason":null}]}}' + regex = rf'{part1}(.*){part2}' + + timer = None + message_queue = Queue() + stream_completed = False + + def request(): + headers = { + 'authority' : 'chatbot.theb.ai', + 'content-type': 'application/json', + 'origin' : 'https://chatbot.theb.ai', + 'user-agent' : 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/112.0.0.0 Safari/537.36', + } + + requests.post('https://chatbot.theb.ai/api/chat-process', headers=headers, content_callback=Completion.handle_stream_response, + json = { + 'prompt' : 'hello world', + 'options': {} + } + ) + + Completion.stream_completed = True + + @staticmethod + def create(): + Thread(target=Completion.request).start() + + while Completion.stream_completed != True 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) + + except Empty: + pass + + @staticmethod + def handle_stream_response(response): + Completion.message_queue.put(response.decode()) + +def start(): + for message in Completion.create(): + yield message['delta'] + +if __name__ == '__main__': + for message in start(): + print(message) |