pycoze 0.1.196__tar.gz → 0.1.198__tar.gz
Sign up to get free protection for your applications and to get access to all the features.
- {pycoze-0.1.196 → pycoze-0.1.198}/PKG-INFO +1 -1
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/automation/browser/edge_driver_manager.py +1 -1
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/bot/bot.py +16 -6
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze.egg-info/PKG-INFO +1 -1
- {pycoze-0.1.196 → pycoze-0.1.198}/setup.py +1 -1
- {pycoze-0.1.196 → pycoze-0.1.198}/LICENSE +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/README.md +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/__init__.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/ai/__init__.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/ai/vram_reserve.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/automation/__init__.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/automation/browser/__init__.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/bot/__init__.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/bot/agent/__init__.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/bot/agent/agent.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/bot/agent/agent_types/__init__.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/bot/agent/agent_types/const.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/bot/agent/agent_types/openai_func_call_agent.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/bot/agent/assistant.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/bot/agent/chat.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/bot/agent_chat.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/reference/__init__.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/reference/bot.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/reference/lib.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/reference/tool.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/reference/workflow.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/ui/__init__.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/ui/base.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/ui/color.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/ui/typ.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/ui/ui_def.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/utils/__init__.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/utils/arg.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/utils/env.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze/utils/text_or_file.py +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze.egg-info/SOURCES.txt +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze.egg-info/dependency_links.txt +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/pycoze.egg-info/top_level.txt +0 -0
- {pycoze-0.1.196 → pycoze-0.1.198}/setup.cfg +0 -0
@@ -9,7 +9,7 @@ from selenium import webdriver
|
|
9
9
|
def is_network_available():
|
10
10
|
try:
|
11
11
|
# Attempt to access the download URL for Edge Chromium driver to check network connection
|
12
|
-
response = requests.get("https://msedgedriver.azureedge.net/", timeout=
|
12
|
+
response = requests.get("https://msedgedriver.azureedge.net/", timeout=3)
|
13
13
|
return response.status_code == 200
|
14
14
|
except requests.ConnectionError:
|
15
15
|
return False
|
@@ -6,6 +6,7 @@ import threading
|
|
6
6
|
import queue
|
7
7
|
import time
|
8
8
|
import asyncio
|
9
|
+
import multiprocessing
|
9
10
|
|
10
11
|
|
11
12
|
class PeekableQueue(queue.Queue):
|
@@ -15,6 +16,14 @@ class PeekableQueue(queue.Queue):
|
|
15
16
|
except queue.Empty:
|
16
17
|
return None
|
17
18
|
|
19
|
+
|
20
|
+
def run_agent_chat(bot_setting_file, history, should_exit):
|
21
|
+
loop = asyncio.new_event_loop()
|
22
|
+
asyncio.set_event_loop(loop)
|
23
|
+
loop.run_until_complete(agent_chat(bot_setting_file, history, should_exit))
|
24
|
+
loop.close()
|
25
|
+
|
26
|
+
|
18
27
|
def chat(bot_setting_file: str):
|
19
28
|
history = []
|
20
29
|
input_queue = PeekableQueue()
|
@@ -42,13 +51,13 @@ def chat(bot_setting_file: str):
|
|
42
51
|
history.append(HumanMessage(message["content"]))
|
43
52
|
clear_chat_data()
|
44
53
|
|
45
|
-
#
|
46
|
-
should_exit =
|
47
|
-
|
48
|
-
|
54
|
+
# 创建进程退出标志
|
55
|
+
should_exit = multiprocessing.Event()
|
56
|
+
agent_chat_process = multiprocessing.Process(target=run_agent_chat, args=(bot_setting_file, history, should_exit)) # 需要是独立进程,不然无法创建新进程
|
57
|
+
agent_chat_process.start()
|
49
58
|
|
50
59
|
next_input_text = ""
|
51
|
-
while
|
60
|
+
while agent_chat_process.is_alive():
|
52
61
|
if not input_queue.empty():
|
53
62
|
next_input_text = input_queue.peek()
|
54
63
|
if next_input_text == INTERRUPT_MESSAGE:
|
@@ -56,6 +65,7 @@ def chat(bot_setting_file: str):
|
|
56
65
|
should_exit.set() # 设置退出标志
|
57
66
|
break
|
58
67
|
time.sleep(0.1) # 每隔 0.1 秒检查一次
|
68
|
+
time.sleep(0.1) # 每隔 0.1 秒检查一次
|
59
69
|
if next_input_text != INTERRUPT_MESSAGE:
|
60
70
|
history.append(AIMessage(content=CHAT_DATA["output"]))
|
61
71
|
except json.JSONDecodeError:
|
@@ -72,6 +82,6 @@ def chat(bot_setting_file: str):
|
|
72
82
|
def get_chat_response(bot_setting_file: str, input_text: str):
|
73
83
|
history = [HumanMessage(input_text)]
|
74
84
|
clear_chat_data()
|
75
|
-
should_exit =
|
85
|
+
should_exit = multiprocessing.Event()
|
76
86
|
asyncio.run(agent_chat(bot_setting_file, history, should_exit))
|
77
87
|
return CHAT_DATA["output"]
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|