Jarvis-Brain 0.1.5.2__py3-none-any.whl → 0.1.5.10__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.5.2
3
+ Version: 0.1.5.10
4
4
  Summary: Jarvis brain mcp
5
5
  Requires-Python: >=3.10
6
6
  Requires-Dist: beautifulsoup4
@@ -0,0 +1,10 @@
1
+ mcp_tools/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
2
+ mcp_tools/dp_tools.py,sha256=TqHQRFKKIImXKnGpuCQ8TatARLpezos3iV9nCcdEzrY,9224
3
+ mcp_tools/main.py,sha256=SiLF-tcEdApkzMjTZJEpVYX5d-LPW7aqy6A6lCBA7YQ,829
4
+ tools/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
5
+ tools/browser_manager.py,sha256=J8aNQECiQvucsUjLJQ9N-3f2xoyoCIxjV-kJ7YcoHv4,1849
6
+ tools/tools.py,sha256=TaWs-CNXy-py9BFmCnJrQ09ke938xXpImf-N2Qo_Rvc,4708
7
+ jarvis_brain-0.1.5.10.dist-info/METADATA,sha256=LfotsulMPGBk8opa0nS4ZZPrQi0S8UynJ-0F-KTrWfY,242
8
+ jarvis_brain-0.1.5.10.dist-info/WHEEL,sha256=WLgqFyCfm_KASv4WHyYy0P3pM_m7J5L9k2skdKLirC8,87
9
+ jarvis_brain-0.1.5.10.dist-info/entry_points.txt,sha256=YFQT4xpkUqt5dM5wlKPQQOqcjMuFrT9iuRAzIpAyH7U,51
10
+ jarvis_brain-0.1.5.10.dist-info/RECORD,,
mcp_tools/dp_tools.py CHANGED
@@ -1,8 +1,8 @@
1
+ import hashlib
1
2
  import json
2
3
  import os
3
4
  from typing import Any
4
5
 
5
- from DrissionPage._elements.none_element import NoneElement
6
6
  from fastmcp import FastMCP
7
7
 
8
8
  from tools.tools import compress_html, requests_html, dp_headless_html, assert_waf_cookie, dp_mcp_message_pack
@@ -12,6 +12,8 @@ waf_status_code_dict = {
12
12
  412: "瑞数",
13
13
  521: "加速乐"
14
14
  }
15
+ # 一轮最大输入,以免单个html最大长度超过ai最大输入
16
+ ont_turn_max_token = 25000
15
17
 
16
18
 
17
19
  def register_visit_url(mcp: FastMCP, browser_manager):
@@ -33,15 +35,20 @@ def register_get_html(mcp: FastMCP, browser_manager):
33
35
  async def get_html(browser_port: int, tab_id: str) -> dict[str, Any]:
34
36
  _browser = browser_manager.get_browser(browser_port)
35
37
  tab = _browser.get_tab(tab_id)
36
- file_name = tab.title + f"_{tab_id}.html"
38
+ file_name = str(tab.title).replace("/", "_").replace(":", "_")
37
39
  if not os.path.exists(html_source_code_local_save_path):
38
40
  os.makedirs(html_source_code_local_save_path)
39
- abs_path = os.path.join(html_source_code_local_save_path, file_name)
40
- with open(abs_path, "w", encoding="utf-8") as f:
41
- min_html, compress_rate = compress_html(tab.html)
42
- f.write(min_html)
43
- return dp_mcp_message_pack(f"已保存tab页:【{tab_id}】的html源码", tab_id=tab_id, html_local_path=abs_path)
44
-
41
+ min_html, compress_rate = compress_html(tab.html)
42
+ html_str_list = [min_html[i:i + ont_turn_max_token] for i in range(0, len(min_html), ont_turn_max_token)]
43
+ html_file_list = []
44
+ for index, html_str in enumerate(html_str_list):
45
+ file_name = file_name + f"_{tab_id}_segment{index}.html"
46
+ abs_path = os.path.join(html_source_code_local_save_path, file_name)
47
+ with open(abs_path, "w", encoding="utf-8") as f:
48
+ f.write(html_str)
49
+ html_file_list.append(abs_path)
50
+ message = f"已保存tab页:【{tab_id}】的html源码片段共{len(html_file_list)}个"
51
+ return dp_mcp_message_pack(message, tab_id=tab_id, htmls_local_path=html_file_list)
45
52
 
46
53
  def register_get_new_tab(mcp: FastMCP, browser_manager):
47
54
  @mcp.tool(name="get_new_tab", description="使用Drissionpage创建一个新的tab页,在新的tab页中打开url")
@@ -52,7 +59,6 @@ def register_get_new_tab(mcp: FastMCP, browser_manager):
52
59
  tab_id = tab.tab_id
53
60
  return dp_mcp_message_pack(f"已创建新的tab页,并打开链接:{url}", tab_id=tab_id)
54
61
 
55
-
56
62
  def register_switch_tab(mcp: FastMCP, browser_manager):
57
63
  @mcp.tool(name="switch_tab", description="根据传入的tab_id切换到对应的tab页", )
58
64
  async def switch_tab(browser_port: int, tab_id: str) -> dict[str, Any]:
@@ -60,7 +66,6 @@ def register_switch_tab(mcp: FastMCP, browser_manager):
60
66
  _browser.activate_tab(tab_id)
61
67
  return dp_mcp_message_pack(f"已将tab页:【{tab_id}】切换至最前端")
62
68
 
63
-
64
69
  def register_close_tab(mcp: FastMCP, browser_manager):
65
70
  @mcp.tool(name="close_tab", description="根据传入的tab_id关闭tab页", )
66
71
  async def close_tab(browser_port, tab_id) -> dict[str, Any]:
@@ -68,10 +73,10 @@ def register_close_tab(mcp: FastMCP, browser_manager):
68
73
  _browser.close_tabs(tab_id)
69
74
  return dp_mcp_message_pack(f"已将tab页:【{tab_id}】关闭")
70
75
 
71
-
72
76
  def register_check_selector(mcp: FastMCP, browser_manager):
73
77
  @mcp.tool(name="check_selector", description="查找tab页中是否包含元素,并返回元素attr_name所对应的值")
74
- async def check_selector(browser_port: int, tab_id: str, css_selector: str, attr_name: str = "text") -> dict[str, Any]:
78
+ async def check_selector(browser_port: int, tab_id: str, css_selector: str, attr_name: str = "text") -> dict[
79
+ str, Any]:
75
80
  _browser = browser_manager.get_browser(browser_port)
76
81
  target_tab = _browser.get_tab(tab_id)
77
82
  css_selector = css_selector
@@ -94,7 +99,6 @@ def register_check_selector(mcp: FastMCP, browser_manager):
94
99
  attr_output=attr_output
95
100
  )
96
101
 
97
-
98
102
  def register_quit_browser(mcp: FastMCP, browser_manager):
99
103
  @mcp.tool(name="quit_browser", description="退出浏览器会话,关闭浏览器")
100
104
  async def quit_browser(browser_port: int) -> dict[str, Any]:
@@ -107,7 +111,6 @@ def register_quit_browser(mcp: FastMCP, browser_manager):
107
111
  quit_flag=flag
108
112
  )
109
113
 
110
-
111
114
  def register_assert_waf(mcp: FastMCP, browser_manager):
112
115
  @mcp.tool(name="assert_waf",
113
116
  description="通过对比requests、有头浏览器、无头浏览器获取到的html,判断网页是否使用了waf以及是否为动态渲染的网页")
@@ -157,10 +160,17 @@ def register_assert_waf(mcp: FastMCP, browser_manager):
157
160
  head_headless_rate_difference=h_hless_rate_diff
158
161
  )
159
162
 
160
- # def register_highlight_element_captcha(mcp: FastMCP, browser_manager):
161
- # @mcp.tool(name="highlight_element_captcha",
162
- # description="将传入的Selector在页面上高亮,并截屏")
163
- # async def highlight_element_captcha(browser_port: int, tab_id: str, selector: str) -> dict[str, Any]:
164
- # _browser = browser_manager.get_browser(browser_port)
165
- # tab = _browser.get_tab(tab_id)
166
- # tab.ele
163
+ def register_highlight_element_captcha(mcp: FastMCP, browser_manager):
164
+ @mcp.tool(name="highlight_element_captcha", description="将传入的Selector在页面上高亮,并截屏")
165
+ async def highlight_element_captcha(browser_port: int, tab_id: str, css_selector: str) -> dict[str, Any]:
166
+ _browser = browser_manager.get_browser(browser_port)
167
+ tab = _browser.get_tab(tab_id)
168
+ highlight_style = 'background-color: rgba(255, 255, 0, 0.2); outline: 2px solid yellow !important; outline-offset: 2px'
169
+ css_selector = css_selector
170
+ if "css:" not in css_selector:
171
+ css_selector = "css:" + css_selector
172
+
173
+ target_eles = tab.eles(css_selector)
174
+ exist_flag = False
175
+ if len(target_eles) != 0:
176
+ exist_flag = True
mcp_tools/main.py CHANGED
@@ -7,7 +7,7 @@ mcp = FastMCP("Jarvis Brain Mcp Tools")
7
7
 
8
8
  # 根据环境变量加载模块
9
9
  enabled_modules = os.getenv("MCP_MODULES", "TeamNode-Dp").split(",")
10
- base_cwd = os.getenv("BASE_CWD", os.environ.get("PWD"))
10
+ base_cwd = os.getenv("BASE_CWD", os.path.expanduser('~'))
11
11
 
12
12
  if "TeamNode-Dp" in enabled_modules:
13
13
  # 页面管理
tools/browser_manager.py CHANGED
@@ -3,6 +3,7 @@ import random
3
3
  from typing import Optional, Tuple
4
4
  import os
5
5
  from DrissionPage import ChromiumPage, ChromiumOptions
6
+ import platform
6
7
 
7
8
 
8
9
  class BrowserManager:
@@ -22,11 +23,12 @@ class BrowserManager:
22
23
  random_port = random.randint(9223, 9934)
23
24
 
24
25
  co = ChromiumOptions().set_local_port(random_port)
26
+ if platform.system() != 'Windows':
27
+ co.set_argument('--no-sandbox')
25
28
  custom_data_dir = os.path.join(os.path.expanduser('~'), 'DrissionPage', "userData", f"{random_port}")
26
-
27
- # 2. 配置浏览器选项,指定该目录
28
- # co = ChromiumOptions()
29
29
  co.set_user_data_path(custom_data_dir) # 设置用户数据路径
30
+ # if not os.path.exists(custom_data_dir):
31
+ # os.makedirs(custom_data_dir)
30
32
  self.browser_pool[random_port] = ChromiumPage(co)
31
33
  return random_port, self.browser_pool[random_port]
32
34
 
tools/tools.py CHANGED
@@ -1,5 +1,6 @@
1
1
  import time
2
-
2
+ import random
3
+ import os
3
4
  import minify_html
4
5
  from DrissionPage import ChromiumPage, ChromiumOptions
5
6
  from bs4 import BeautifulSoup
@@ -21,8 +22,11 @@ def requests_html(url):
21
22
  def dp_headless_html(url):
22
23
  opt = ChromiumOptions().headless(True)
23
24
  opt.set_argument('--no-sandbox')
24
- # 随机端口,固定9222端口的话,可能会被瑞数检测到
25
- opt.auto_port()
25
+ """创建新的浏览器实例"""
26
+ random_port = random.randint(9934, 10034)
27
+ custom_data_dir = os.path.join(os.path.expanduser('~'), 'DrissionPage', "userData", f"{random_port}")
28
+ opt.set_user_data_path(custom_data_dir) # 设置用户数据路径
29
+ opt.set_local_port(random_port)
26
30
  page = ChromiumPage(opt)
27
31
  tab = page.latest_tab
28
32
  tab.get(url)
@@ -1,10 +0,0 @@
1
- mcp_tools/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
2
- mcp_tools/dp_tools.py,sha256=TsktupVxzQkDRH4w-niEqJba3LkeWxIeyyx24ehpqAs,8411
3
- mcp_tools/main.py,sha256=ockDfiMWaNroXf6sJ9dk-jU-_SvoGgP-0t-TbW2XWyw,827
4
- tools/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
5
- tools/browser_manager.py,sha256=G0nUQSmMVWzS08IjO87reEyMCpy-IiM3BxwdNUvcmdI,1740
6
- tools/tools.py,sha256=qPa80xzQWCD8mSdg8isCgyei0XN8a7guGtR2J_MbQDU,4481
7
- jarvis_brain-0.1.5.2.dist-info/METADATA,sha256=s5BNa9hKn38Tk0_S8iGPpDxwZ7h-x2NO1iXLtV8kRzM,241
8
- jarvis_brain-0.1.5.2.dist-info/WHEEL,sha256=WLgqFyCfm_KASv4WHyYy0P3pM_m7J5L9k2skdKLirC8,87
9
- jarvis_brain-0.1.5.2.dist-info/entry_points.txt,sha256=YFQT4xpkUqt5dM5wlKPQQOqcjMuFrT9iuRAzIpAyH7U,51
10
- jarvis_brain-0.1.5.2.dist-info/RECORD,,