summaryrefslogtreecommitdiffstats
path: root/unfinished/theb.ai/__init__.py
diff options
context:
space:
mode:
authort.me/xtekky <98614666+xtekky@users.noreply.github.com>2023-04-20 16:34:19 +0200
committert.me/xtekky <98614666+xtekky@users.noreply.github.com>2023-04-20 16:34:19 +0200
commita485cfb180094f14b3fe27ea218d2890033768a3 (patch)
tree8cf4b2f08fb79271a9dc30a0f8843c5561c5d9c9 /unfinished/theb.ai/__init__.py
parentora.sh (diff)
downloadgpt4free-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 '')
-rw-r--r--unfinished/theb.ai/__init__.py57
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)