diff options
author | t.me/xtekky <98614666+xtekky@users.noreply.github.com> | 2023-05-01 19:24:07 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-05-01 19:24:07 +0200 |
commit | a13c00f286f3e0bb832a5504125bd7857475615d (patch) | |
tree | 02fe7e7364898c09e4809ef214e44bc518c18f02 /gpt4free/theb/__init__.py | |
parent | Merge pull request #347 from xiangsx/main (diff) | |
parent | theb: multiple messages (diff) | |
download | gpt4free-a13c00f286f3e0bb832a5504125bd7857475615d.tar gpt4free-a13c00f286f3e0bb832a5504125bd7857475615d.tar.gz gpt4free-a13c00f286f3e0bb832a5504125bd7857475615d.tar.bz2 gpt4free-a13c00f286f3e0bb832a5504125bd7857475615d.tar.lz gpt4free-a13c00f286f3e0bb832a5504125bd7857475615d.tar.xz gpt4free-a13c00f286f3e0bb832a5504125bd7857475615d.tar.zst gpt4free-a13c00f286f3e0bb832a5504125bd7857475615d.zip |
Diffstat (limited to 'gpt4free/theb/__init__.py')
-rw-r--r-- | gpt4free/theb/__init__.py | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/gpt4free/theb/__init__.py b/gpt4free/theb/__init__.py index 75a15068..741de34d 100644 --- a/gpt4free/theb/__init__.py +++ b/gpt4free/theb/__init__.py @@ -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): @@ -28,26 +29,33 @@ 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 |