Jarvis-Brain 0.1.7.1__py3-none-any.whl → 0.1.7.14__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: Jarvis_Brain
3
- Version: 0.1.7.1
3
+ Version: 0.1.7.14
4
4
  Summary: Jarvis brain mcp
5
5
  Requires-Python: >=3.10
6
6
  Requires-Dist: beautifulsoup4
@@ -0,0 +1,11 @@
1
+ mcp_tools/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
2
+ mcp_tools/dp_tools.py,sha256=OcjehVegZ8hRtJunbGkhUPcTHS7BXFdewBU5mbaQX9M,11927
3
+ mcp_tools/main.py,sha256=Fdt2N3oKGwvruuno_ywnuWSlm1BexE9ZY669H2LTo9w,1056
4
+ tools/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
5
+ tools/browser_manager.py,sha256=EXM7n-sDOtdQGpWkVTAZHWhepVU-7PAoUTDNgGF9_fQ,1938
6
+ tools/browser_proxy.py,sha256=cdMRxcUYyaOqGU17lldltHOvt9rxXD5Dwh7hBXEBby4,6780
7
+ tools/tools.py,sha256=TaWs-CNXy-py9BFmCnJrQ09ke938xXpImf-N2Qo_Rvc,4708
8
+ jarvis_brain-0.1.7.14.dist-info/METADATA,sha256=IU02nMa7R0JTNZJJLfczDzoArZruSKFyajqUG-3Wvf8,242
9
+ jarvis_brain-0.1.7.14.dist-info/WHEEL,sha256=WLgqFyCfm_KASv4WHyYy0P3pM_m7J5L9k2skdKLirC8,87
10
+ jarvis_brain-0.1.7.14.dist-info/entry_points.txt,sha256=YFQT4xpkUqt5dM5wlKPQQOqcjMuFrT9iuRAzIpAyH7U,51
11
+ jarvis_brain-0.1.7.14.dist-info/RECORD,,
mcp_tools/dp_tools.py CHANGED
@@ -15,7 +15,7 @@ waf_status_code_dict = {
15
15
  521: "加速乐"
16
16
  }
17
17
  # 一轮最大输入,以免单个html最大长度超过ai最大输入
18
- ont_turn_max_token = 25000
18
+ one_turn_max_token = 20000
19
19
 
20
20
 
21
21
  def register_visit_url(mcp: FastMCP, browser_manager: BrowserManager, client_manager: DPProxyClientManager):
@@ -42,11 +42,11 @@ def register_get_html(mcp: FastMCP, browser_manager, client_manager: DPProxyClie
42
42
  async def get_html(browser_port: int, tab_id: str) -> dict[str, Any]:
43
43
  _browser = browser_manager.get_browser(browser_port)
44
44
  tab = _browser.get_tab(tab_id)
45
- file_name_prefix = str(tab.title).replace("/", "_").replace(":", "_")
45
+ file_name_prefix = hashlib.md5(str(tab.title).encode('utf-8')).hexdigest()
46
46
  if not os.path.exists(html_source_code_local_save_path):
47
47
  os.makedirs(html_source_code_local_save_path)
48
48
  min_html, compress_rate = compress_html(tab.html)
49
- html_str_list = [min_html[i:i + ont_turn_max_token] for i in range(0, len(min_html), ont_turn_max_token)]
49
+ html_str_list = [min_html[i:i + one_turn_max_token] for i in range(0, len(min_html), one_turn_max_token)]
50
50
  html_file_list = []
51
51
  for index, html_str in enumerate(html_str_list):
52
52
  file_name = file_name_prefix + f"_{tab_id}_segment{index}.html"
@@ -88,8 +88,12 @@ def register_close_tab(mcp: FastMCP, browser_manager, client_manager: DPProxyCli
88
88
 
89
89
 
90
90
  def register_check_selector(mcp: FastMCP, browser_manager, client_manager: DPProxyClientManager):
91
- @mcp.tool(name="check_selector", description="查找tab页中是否包含元素,并返回元素attr_name所对应的值")
92
- async def check_selector(browser_port: int, tab_id: str, css_selector: str, attr_name: str = "text") -> dict[
91
+ @mcp.tool(name="check_selector",
92
+ description="查找tab页中是否包含元素,并返回元素attr_name所对应的值。"
93
+ "当要选择的元素包含过多元素时,需要传入offset和page_size来分批查看元素,一般不建议调整page_size,更推荐你调整offset"
94
+ "同时如果单个元素属性值太长,函数会进行截断。一般的单个元素的属性值超过300个字符的就会触发截断,截断后会在最后拼接'...'")
95
+ async def check_selector(browser_port: int, tab_id: str, css_selector: str, attr_name: str = "text",
96
+ offset: int = 0, page_size: int = 10) -> dict[
93
97
  str, Any]:
94
98
  _browser = browser_manager.get_browser(browser_port)
95
99
  target_tab = _browser.get_tab(tab_id)
@@ -100,16 +104,28 @@ def register_check_selector(mcp: FastMCP, browser_manager, client_manager: DPPro
100
104
  exist_flag = False
101
105
  if len(target_eles) != 0:
102
106
  exist_flag = True
107
+ if len(target_eles) > page_size:
108
+ target_eles = target_eles[offset:offset + page_size]
109
+ slice_seg = max(300, one_turn_max_token // (page_size + 6))
103
110
  if attr_name == "text":
104
- ele_text_list = [i.text.replace("\n", "") for i in target_eles]
105
- attr_output = "\n".join(ele_text_list)
111
+ ele_attr_list = [i.text.replace("\n", "") for i in target_eles]
112
+ ele_attr_list = [attr_str[:slice_seg] for attr_str in ele_attr_list]
113
+ # 如果经过截断遍历后的字符串长度与截断长度相等,则默认截断了
114
+ ele_attr_list = [attr_str + "..." for attr_str in ele_attr_list if len(attr_str) == slice_seg]
115
+ attr_output = "\n".join(ele_attr_list)
106
116
  else:
107
- attr_output = json.dumps([i.attr(attr_name) for i in target_eles])
117
+ ele_attr_list = [i.attr(attr_name) for i in target_eles]
118
+ ele_attr_list = [attr_str[:slice_seg] for attr_str in ele_attr_list]
119
+ ele_attr_list = [attr_str + "..." for attr_str in ele_attr_list if len(attr_str) == slice_seg]
120
+ attr_output = json.dumps(ele_attr_list)
121
+ # 对attr_output逐个截断,截断的长度为:一轮最大token除以元素个数+3个点+两个引号和逗号
108
122
  return dp_mcp_message_pack(
109
123
  f"已完成tab页:【{tab_id}】对:【{css_selector}】的检查",
110
124
  tab_id=tab_id,
111
125
  selector=css_selector,
112
126
  selector_ele_exist=exist_flag,
127
+ page_size=page_size,
128
+ offset=offset,
113
129
  attr_output=attr_output
114
130
  )
115
131
 
@@ -129,7 +145,7 @@ def register_quit_browser(mcp: FastMCP, browser_manager, client_manager: DPProxy
129
145
 
130
146
  def register_pop_first_packet(mcp: FastMCP, browser_manager, client_manager: DPProxyClientManager):
131
147
  @mcp.tool(name="pop_first_packet",
132
- description="每调用一次就会弹出传入的tab页所监听到的数据包中的第一个packet_message")
148
+ description="每调用一次就会弹出传入的tab页所监听到的数据包中的第一个packet_message,当一个packet_message的response body过长时会被切分成多个包,具体一个请求是否还有下一个包,可以参考body_completed字段")
133
149
  async def pop_first_packet(browser_port: int, tab_id: str) -> dict[str, Any]:
134
150
  _browser = browser_manager.get_browser(browser_port)
135
151
  client = client_manager.get_client(tab_id)
tools/browser_proxy.py CHANGED
@@ -1,12 +1,14 @@
1
1
  import threading
2
2
  from collections import deque
3
-
3
+ import time
4
4
  from DrissionPage import ChromiumPage, ChromiumOptions
5
5
  from DrissionPage._pages.chromium_tab import ChromiumTab
6
6
  from DrissionPage._units.listener import DataPacket
7
7
  from typing import Tuple, Optional
8
8
  import json
9
9
 
10
+ one_turn_max_token = 20000
11
+
10
12
 
11
13
  class DPProxyClient:
12
14
  def __init__(self, driver: ChromiumTab, self_kill=False):
@@ -133,21 +135,27 @@ def check_data_packet(packet: DataPacket, client: DPProxyClient):
133
135
  data = None
134
136
  if packet.request.hasPostData:
135
137
  data = packet.request.postData
136
- temp_dict = {
137
- "url": url,
138
- "method": method,
139
- "request_data": data,
140
- "request_headers": packet.request.headers,
141
- "response_headers": packet.response.headers,
142
- "response_body": packet.response.body,
143
- }
144
- print(temp_dict)
145
- client.packet_queue.append(temp_dict)
138
+ body = packet.response.body
139
+ body_str = json.dumps(body, ensure_ascii=False)
140
+ body_str_list = [body_str[i:i + one_turn_max_token] for i in range(0, len(body_str), one_turn_max_token)]
141
+ body_completed = True
142
+ for index, body_str in enumerate(body_str_list):
143
+ if (index + 1) != len(body_str_list):
144
+ body_completed = False
145
+ temp_dict = {
146
+ "url": url,
147
+ "body_completed": body_completed,
148
+ "method": method,
149
+ "request_data": data,
150
+ "request_headers": dict(packet.request.headers),
151
+ "response_headers": dict(packet.response.headers),
152
+ "response_body_segment": body_str,
153
+ }
154
+ client.packet_queue.append(temp_dict)
146
155
 
147
156
 
148
157
  client_manager = DPProxyClientManager()
149
158
 
150
- #
151
159
  # if __name__ == '__main__':
152
160
  # co = ChromiumOptions().set_user_agent(
153
161
  # "Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/143.0.0.0 Mobile Safari/537.36")
@@ -1,11 +0,0 @@
1
- mcp_tools/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
2
- mcp_tools/dp_tools.py,sha256=ZOmHTIofSeuqiY3YZHNnK72-_MRo22tBAB9NJ4KyEbo,10416
3
- mcp_tools/main.py,sha256=Fdt2N3oKGwvruuno_ywnuWSlm1BexE9ZY669H2LTo9w,1056
4
- tools/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
5
- tools/browser_manager.py,sha256=EXM7n-sDOtdQGpWkVTAZHWhepVU-7PAoUTDNgGF9_fQ,1938
6
- tools/browser_proxy.py,sha256=YbqXT6h0Zz_H1TMGBd8wwPABIGpE0nGLwYzDlA4t674,6320
7
- tools/tools.py,sha256=TaWs-CNXy-py9BFmCnJrQ09ke938xXpImf-N2Qo_Rvc,4708
8
- jarvis_brain-0.1.7.1.dist-info/METADATA,sha256=nLX_3KOUhtCzLP_qScoyY6sdH0CtAWekIlqtfM2RZR0,241
9
- jarvis_brain-0.1.7.1.dist-info/WHEEL,sha256=WLgqFyCfm_KASv4WHyYy0P3pM_m7J5L9k2skdKLirC8,87
10
- jarvis_brain-0.1.7.1.dist-info/entry_points.txt,sha256=YFQT4xpkUqt5dM5wlKPQQOqcjMuFrT9iuRAzIpAyH7U,51
11
- jarvis_brain-0.1.7.1.dist-info/RECORD,,