vibesurf 0.1.39__py3-none-any.whl → 0.1.41__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.

Potentially problematic release.


This version of vibesurf might be problematic. Click here for more details.

vibe_surf/_version.py CHANGED
@@ -28,7 +28,7 @@ version_tuple: VERSION_TUPLE
28
28
  commit_id: COMMIT_ID
29
29
  __commit_id__: COMMIT_ID
30
30
 
31
- __version__ = version = '0.1.39'
32
- __version_tuple__ = version_tuple = (0, 1, 39)
31
+ __version__ = version = '0.1.41'
32
+ __version_tuple__ = version_tuple = (0, 1, 41)
33
33
 
34
34
  __commit_id__ = commit_id = None
@@ -507,15 +507,8 @@ async def _vibesurf_agent_node_impl(state: VibeSurfState) -> VibeSurfState:
507
507
  llm=vibesurf_agent.llm,
508
508
  file_system=vibesurf_agent.file_system,
509
509
  )
510
- if action_name in ['skill_search', 'skill_crawl', 'skill_summary', 'skill_deep_research']:
511
- state.current_step = "END"
512
- # Format final response
513
- final_response = f"{result.extracted_content}" or f"{result.error}"
514
- state.final_response = final_response
515
- logger.debug(final_response)
516
- state.is_complete = True
517
- else:
518
- state.current_step = "vibesurf_agent"
510
+
511
+ state.current_step = "vibesurf_agent"
519
512
 
520
513
  if result.extracted_content:
521
514
  vibesurf_agent.message_history.append(
@@ -45,11 +45,11 @@ class AgentBrowserProfile(BrowserProfile):
45
45
  'id': 'edibdbjcniadpccecjdfdjjppcpchdlm',
46
46
  'url': 'https://clients2.google.com/service/update2/crx?response=redirect&prodversion=130&acceptformat=crx3&x=id%3Dedibdbjcniadpccecjdfdjjppcpchdlm%26uc',
47
47
  },
48
- {
49
- 'name': 'Force Background Tab',
50
- 'id': 'gidlfommnbibbmegmgajdbikelkdcmcl',
51
- 'url': 'https://clients2.google.com/service/update2/crx?response=redirect&prodversion=133&acceptformat=crx3&x=id%3Dgidlfommnbibbmegmgajdbikelkdcmcl%26uc',
52
- },
48
+ # {
49
+ # 'name': 'Force Background Tab',
50
+ # 'id': 'gidlfommnbibbmegmgajdbikelkdcmcl',
51
+ # 'url': 'https://clients2.google.com/service/update2/crx?response=redirect&prodversion=133&acceptformat=crx3&x=id%3Dgidlfommnbibbmegmgajdbikelkdcmcl%26uc',
52
+ # },
53
53
  # {
54
54
  # 'name': 'ClearURLs',
55
55
  # 'id': 'lckanjgmijmafbedllaakclkaicjfmnk',
@@ -206,7 +206,7 @@ class AgentBrowserSession(BrowserSession):
206
206
  assert self._cdp_client_root is not None
207
207
  await self._cdp_client_root.start()
208
208
  await self._cdp_client_root.send.Target.setAutoAttach(
209
- params={'autoAttach': True, 'waitForDebuggerOnStart': False, 'flatten': True}
209
+ params={'autoAttach': False, 'waitForDebuggerOnStart': False, 'flatten': True}
210
210
  )
211
211
  self.logger.debug('CDP client connected successfully')
212
212
 
@@ -228,39 +228,9 @@ class AgentBrowserSession(BrowserSession):
228
228
  from browser_use.utils import is_new_tab_page
229
229
 
230
230
  # Collect all targets that need redirection
231
- redirected_targets = []
232
- redirect_sessions = {} # Store sessions created for redirection to potentially reuse
233
- for target in page_targets:
234
- target_url = target.get('url', '')
235
- if is_new_tab_page(target_url) and target_url != '':
236
- # Redirect chrome://newtab to about:blank to avoid JS issues preventing driving chrome://newtab
237
- target_id = target['targetId']
238
- self.logger.debug(f'🔄 Redirecting {target_url} to about:blank for target {target_id}')
239
- try:
240
- # Create a CDP session for redirection (minimal domains to avoid duplicate event handlers)
241
- # Only enable Page domain for navigation, avoid duplicate event handlers
242
- redirect_session = await CDPSession.for_target(self._cdp_client_root, target_id,
243
- domains=['Page'])
244
- # Navigate to about:blank
245
- await redirect_session.cdp_client.send.Page.navigate(
246
- params={'url': ''}, session_id=redirect_session.session_id
247
- )
248
- redirected_targets.append(target_id)
249
- redirect_sessions[target_id] = redirect_session # Store for potential reuse
250
- # Update the target's URL in our list for later use
251
- target['url'] = ''
252
- # Small delay to ensure navigation completes
253
- await asyncio.sleep(0.1)
254
- except Exception as e:
255
- self.logger.warning(f'Failed to redirect {target_url} to about:blank: {e}')
256
-
257
- # Log summary of redirections
258
- if redirected_targets:
259
- self.logger.debug(f'Redirected {len(redirected_targets)} chrome://newtab pages to about:blank')
260
-
261
231
  if not page_targets:
262
232
  # No pages found, create a new one
263
- new_target = await self._cdp_client_root.send.Target.createTarget(params={'url': ''})
233
+ new_target = await self._cdp_client_root.send.Target.createTarget(params={'url': 'chrome://newtab/'})
264
234
  target_id = new_target['targetId']
265
235
  self.logger.debug(f'📄 Created new blank page with target ID: {target_id}')
266
236
  else:
@@ -268,14 +238,8 @@ class AgentBrowserSession(BrowserSession):
268
238
  target_id = [page for page in page_targets if page.get('type') == 'page'][0]['targetId']
269
239
  self.logger.debug(f'📄 Using existing page with target ID: {target_id}')
270
240
 
271
- # Store the current page target ID and add to pool
272
- # Reuse redirect session if available, otherwise create new one
273
- if target_id in redirect_sessions:
274
- self.logger.debug(f'Reusing redirect session for target {target_id}')
275
- self.agent_focus = redirect_sessions[target_id]
276
- else:
277
- # For the initial connection, we'll use the shared root WebSocket
278
- self.agent_focus = await CDPSession.for_target(self._cdp_client_root, target_id, new_socket=False)
241
+ self.agent_focus = await CDPSession.for_target(self._cdp_client_root, target_id, new_socket=False)
242
+
279
243
  if self.agent_focus:
280
244
  self._cdp_session_pool[target_id] = self.agent_focus
281
245
 
@@ -297,13 +261,12 @@ class AgentBrowserSession(BrowserSession):
297
261
  for idx, target in enumerate(page_targets):
298
262
  target_url = target.get('url', '')
299
263
  self.logger.debug(f'Dispatching TabCreatedEvent for initial tab {idx}: {target_url}')
300
- await self.event_bus.dispatch(TabCreatedEvent(url=target_url, target_id=target['targetId']))
264
+ self.event_bus.dispatch(TabCreatedEvent(url=target_url, target_id=target['targetId']))
301
265
 
302
266
  # Dispatch initial focus event
303
267
  if page_targets:
304
268
  initial_url = page_targets[0].get('url', '')
305
- await self.event_bus.dispatch(
306
- AgentFocusChangedEvent(target_id=page_targets[0]['targetId'], url=initial_url))
269
+ self.event_bus.dispatch(AgentFocusChangedEvent(target_id=page_targets[0]['targetId'], url=initial_url))
307
270
  self.logger.debug(f'Initial agent focus set to tab 0: {initial_url}')
308
271
 
309
272
  except Exception as e:
@@ -329,8 +292,8 @@ class AgentBrowserSession(BrowserSession):
329
292
  self.logger.info(f"Agent {self.id}: Assigned target {target_id}")
330
293
  self.agent_focus = await CDPSession.for_target(self._cdp_client_root, target_id, new_socket=True,
331
294
  cdp_url=self.cdp_url)
332
- await self.agent_focus.cdp_client.send.Target.activateTarget(
333
- params={'targetId': target_id})
295
+ # await self.agent_focus.cdp_client.send.Target.activateTarget(
296
+ # params={'targetId': target_id})
334
297
  await self.agent_focus.cdp_client.send.Runtime.runIfWaitingForDebugger(
335
298
  session_id=self.agent_focus.session_id)
336
299
  self._cdp_session_pool[target_id] = self.agent_focus
@@ -524,7 +487,7 @@ class AgentBrowserSession(BrowserSession):
524
487
  self.agent_focus = session
525
488
 
526
489
  # Activate target without events
527
- await session.cdp_client.send.Target.activateTarget(params={'targetId': target_id})
490
+ # await session.cdp_client.send.Target.activateTarget(params={'targetId': target_id})
528
491
  await session.cdp_client.send.Runtime.runIfWaitingForDebugger(session_id=session.session_id)
529
492
  else:
530
493
  # Use current tab - no tab switching events
@@ -747,7 +710,7 @@ class AgentBrowserSession(BrowserSession):
747
710
  )
748
711
  self.agent_focus = session
749
712
  if focus:
750
- await session.cdp_client.send.Target.activateTarget(params={'targetId': session.target_id})
713
+ # await session.cdp_client.send.Target.activateTarget(params={'targetId': session.target_id})
751
714
  await session.cdp_client.send.Runtime.runIfWaitingForDebugger(session_id=session.session_id)
752
715
  # else:
753
716
  # self.logger.debug(f'[get_or_create_cdp_session] Reusing existing session for {target_id} (focus={focus})')
@@ -780,7 +743,7 @@ class AgentBrowserSession(BrowserSession):
780
743
  f'[get_or_create_cdp_session] Switching agent focus from {self.agent_focus.target_id} to {target_id}'
781
744
  )
782
745
  self.agent_focus = session
783
- await session.cdp_client.send.Target.activateTarget(params={'targetId': session.target_id})
746
+ # await session.cdp_client.send.Target.activateTarget(params={'targetId': session.target_id})
784
747
  await session.cdp_client.send.Runtime.runIfWaitingForDebugger(session_id=session.session_id)
785
748
  else:
786
749
  self.logger.debug(
@@ -33,6 +33,7 @@ const VIBESURF_CONFIG = {
33
33
  github: "https://github.com/vibesurf-ai/VibeSurf",
34
34
  discord: "https://discord.gg/EZ2YnUXP",
35
35
  x: "https://x.com/warmshao",
36
+ reportBug: "https://github.com/vibesurf-ai/VibeSurf/issues/new/choose",
36
37
  website: "https://vibe-surf.com/"
37
38
  },
38
39
 
@@ -1475,7 +1475,7 @@ class VibeSurfUIManager {
1475
1475
  <div class="task-icon">🔍</div>
1476
1476
  <div class="task-content">
1477
1477
  <div class="task-title">Research Founders</div>
1478
- <div class="task-description">Search information about browser-use and browser-use-webui, write a brief report</div>
1478
+ <div class="task-description">Search information about AI browser assistant: VibeSurf, write a brief report</div>
1479
1479
  </div>
1480
1480
  </div>
1481
1481
  <div class="task-suggestion" data-task="news">
@@ -3603,6 +3603,13 @@ class VibeSurfUIManager {
3603
3603
  break;
3604
3604
 
3605
3605
 
3606
+ case 'reportbug':
3607
+ title = 'Report Bug';
3608
+ svg = `<svg width="16" height="16" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
3609
+ <path d="M20 8h-2.81c-.45-.78-1.07-1.45-1.82-1.96L17 4.41 15.59 3l-2.17 2.17C12.96 5.06 12.49 5 12 5c-.49 0-.96.06-1.42.17L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20V8zm-6 8h-4v-2h4v2zm0-4h-4v-2h4v2z" fill="currentColor"/>
3610
+ </svg>`;
3611
+ break;
3612
+
3606
3613
  default:
3607
3614
  console.warn(`[UIManager] Unknown social platform: ${platform}`);
3608
3615
  return null;
@@ -88,7 +88,7 @@
88
88
  <div class="task-icon">🔍</div>
89
89
  <div class="task-content">
90
90
  <div class="task-title">Research Founders</div>
91
- <div class="task-description">Search information about browser-use and browser-use-webui, write a brief report</div>
91
+ <div class="task-description">Search information about AI browser assistant: VibeSurf, write a brief report</div>
92
92
  </div>
93
93
  </div>
94
94
  <div class="task-suggestion" data-task="news">
@@ -65,7 +65,8 @@ class CustomFileSystem(FileSystem):
65
65
 
66
66
  async def display_file(self, full_filename: str) -> str | None:
67
67
  """Display file content using file-specific display method"""
68
- if not self.file_exist(full_filename):
68
+ if_file_exist = await self.file_exist(full_filename)
69
+ if not if_file_exist:
69
70
  return f"{full_filename} does not exist."
70
71
 
71
72
  file_content = await self.read_file(full_filename)
@@ -281,10 +281,10 @@ Format: [index1, index2, index3, ...]
281
281
  if params.tab_id:
282
282
  target_id = await browser_session.get_target_id_from_tab_id(params.tab_id)
283
283
  current_target_id = None
284
- if browser_session.agent_focus:
285
- current_target_id = browser_session.agent_focus.target_id
284
+ if browser_session._dom_watchdog and browser_session._dom_watchdog.enhanced_dom_tree:
285
+ current_target_id = browser_session._dom_watchdog.enhanced_dom_tree.target_id
286
286
  if current_target_id != target_id:
287
- browser_session._dom_watchdog.enhanced_dom_tree = None
287
+ browser_session._dom_watchdog.clear_cache()
288
288
  await browser_session.get_or_create_cdp_session(target_id, focus=True)
289
289
 
290
290
  # Extract structured content using the existing method
@@ -340,10 +340,10 @@ Format: [index1, index2, index3, ...]
340
340
  if params.tab_id:
341
341
  target_id = await browser_session.get_target_id_from_tab_id(params.tab_id)
342
342
  current_target_id = None
343
- if browser_session.agent_focus:
344
- current_target_id = browser_session.agent_focus.target_id
343
+ if browser_session._dom_watchdog and browser_session._dom_watchdog.enhanced_dom_tree:
344
+ current_target_id = browser_session._dom_watchdog.enhanced_dom_tree.target_id
345
345
  if current_target_id != target_id:
346
- browser_session._dom_watchdog.enhanced_dom_tree = None
346
+ browser_session._dom_watchdog.clear_cache()
347
347
  await browser_session.get_or_create_cdp_session(target_id, focus=True)
348
348
 
349
349
  # Extract and summarize content
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: vibesurf
3
- Version: 0.1.39
3
+ Version: 0.1.41
4
4
  Summary: VibeSurf: A powerful browser assistant for vibe surfing
5
5
  Author: WarmShao
6
6
  License: Apache-2.0
@@ -1,5 +1,5 @@
1
1
  vibe_surf/__init__.py,sha256=WtduuMFGauMD_9dpk4fnRnLTAP6ka9Lfu0feAFNzLfo,339
2
- vibe_surf/_version.py,sha256=GLQyQfF__8GWNfm0aitCDkh-g9TqC1PxC7RtPbky6_w,706
2
+ vibe_surf/_version.py,sha256=R-KPGpfpXU0mV8THtGmMmaSD_OLN_0-DypNkYhnTx5c,706
3
3
  vibe_surf/cli.py,sha256=pzJs--bjV6ZU7njJnxK_lh76l3pQ3opg_5V9Hw17PQw,21924
4
4
  vibe_surf/common.py,sha256=_WWMxen5wFwzUjEShn3yDVC1OBFUiJ6Vccadi6tuG6w,1215
5
5
  vibe_surf/logger.py,sha256=k53MFA96QX6t9OfcOf1Zws8PP0OOqjVJfhUD3Do9lKw,3043
@@ -7,7 +7,7 @@ vibe_surf/utils.py,sha256=3j6uRkgjOAIDYmbpW8C-DpYhdf1Kvahz715KSriVIk0,261
7
7
  vibe_surf/agents/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
8
8
  vibe_surf/agents/browser_use_agent.py,sha256=Uj9tbCR5_dbrSSnKuajbL4zP_E9CwLMrdvw0EmDwnC0,34473
9
9
  vibe_surf/agents/report_writer_agent.py,sha256=EiG0ITPGctCGJ8BCc6eVT92Pvb0J39nPArZuXmDUkzg,24097
10
- vibe_surf/agents/vibe_surf_agent.py,sha256=LPkGGJLW_cNzgZGbkZvz5gRPB-JckPZDZ7twJFRNLRU,79057
10
+ vibe_surf/agents/vibe_surf_agent.py,sha256=seSQGS429pu5tp6T_Fc1N2Cl4mO2tXb1uABeqMmv3XA,78594
11
11
  vibe_surf/agents/views.py,sha256=yHjNJloa-aofVTGyuRy08tBYP_Y3XLqt1DUWOUmHRng,4825
12
12
  vibe_surf/agents/prompts/__init__.py,sha256=l4ieA0D8kLJthyNN85FKLNe4ExBa3stY3l-aImLDRD0,36
13
13
  vibe_surf/agents/prompts/report_writer_prompt.py,sha256=sZE8MUT1CDLmRzbnbEQzAvTwJjpITgh2Q8g1_eXmkzE,4454
@@ -43,22 +43,22 @@ vibe_surf/backend/utils/encryption.py,sha256=LYTKJdOrKfQt8U7GUXIEsns6iBeXnZ7jlOP
43
43
  vibe_surf/backend/utils/llm_factory.py,sha256=WO2MI83n9p5YraPnmQhq_OEH3TBznm34kqhHpESnFng,9817
44
44
  vibe_surf/backend/utils/utils.py,sha256=nY5-DGY4MfPumpQxXLQiodO0Db7lChryWIHbY9h971o,1137
45
45
  vibe_surf/browser/__init__.py,sha256=_UToO2fZfSCrfjOcxhn4Qq7ZLbYeyPuUUEmqIva-Yv8,325
46
- vibe_surf/browser/agen_browser_profile.py,sha256=fHk5q6hkwHfoNIuUitUBPJLdqbsZ7xjsLU6vTTlXEQI,6177
47
- vibe_surf/browser/agent_browser_session.py,sha256=q8i4JeL0SANjWUG2Q_Brgq6mmKkMGN7xi1O9Pn6Pi6I,42804
46
+ vibe_surf/browser/agen_browser_profile.py,sha256=QHLL-jCinep98R1zFJA2QT_3EudIpMnRhrNV1CzUxlc,6187
47
+ vibe_surf/browser/agent_browser_session.py,sha256=9EmFIUXxXZHQkLb3cd9dBIg9NT3qi6FmE8TWpeUoqkA,40383
48
48
  vibe_surf/browser/browser_manager.py,sha256=PFJ9flmqR2uokuRZ3PDh_Dy6_6qcQ6kH_eRc1yT6Iq8,11257
49
49
  vibe_surf/browser/utils.py,sha256=bBtpMiyz2ixWOr31GbJwZ8pVYcnxztKjTJJO92z1BDY,35742
50
50
  vibe_surf/browser/watchdogs/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
51
51
  vibe_surf/browser/watchdogs/action_watchdog.py,sha256=6J7ox8hlA3EeRI6YiBxpKCdaybe7n_zp9UpdBWSTc4s,609
52
52
  vibe_surf/browser/watchdogs/dom_watchdog.py,sha256=9fNB-FjqJbeKpKp_UezPeymI-0yTUu_0LB3SEHXfdr8,11023
53
53
  vibe_surf/chrome_extension/background.js,sha256=9YLbLmBl__PPUwN6Edf0EQfE53Br1VfjlUiIkznf4n4,30181
54
- vibe_surf/chrome_extension/config.js,sha256=rd4I2pyEWEYgVKIj7wEcwd8ouotm7ZlGwsRRSWMmAGY,1311
54
+ vibe_surf/chrome_extension/config.js,sha256=nHjjyWcmr1UgiLRJZa5qN-Jgz1CqK3EUzLe-VPA0Z3Q,1387
55
55
  vibe_surf/chrome_extension/content.js,sha256=cB67jK3vIE5zrpXAfi3p50H3EyTqK5xockOph0Q4kQg,13708
56
56
  vibe_surf/chrome_extension/dev-reload.js,sha256=xQpi-1Ekb5P8Ogsm6rUK09QzxafwH0H409zBKmaUFNw,1790
57
57
  vibe_surf/chrome_extension/manifest.json,sha256=B08nHuU-bPc-pUr30Y-of39TjMlrE7D5gP2sZjZ8CrE,1142
58
58
  vibe_surf/chrome_extension/permission-iframe.html,sha256=R6VM1JfrzkfXTTD5mGCKui1dDWTqHEe9n8TtVdZNPNg,948
59
59
  vibe_surf/chrome_extension/permission-request.html,sha256=ct1LTl_9euABiHcqNU6AFcvpCAfANWO0y_dDEAjtwfE,2905
60
60
  vibe_surf/chrome_extension/popup.html,sha256=n3dI_-WbILm0q8O_za6xX0WvOofz5lwT_7YXs0u9RAE,4248
61
- vibe_surf/chrome_extension/sidepanel.html,sha256=TUTdct8EfzqgBZ4lFTRo1oh-SRNatjcLXWBClABW3Ls,47819
61
+ vibe_surf/chrome_extension/sidepanel.html,sha256=GPVNwSHDZEhZVXjEMWvZUu-84qbB0p86Wu-lJC79e-w,47816
62
62
  vibe_surf/chrome_extension/icons/logo.icns,sha256=ZzY1eIKF4dNhNW4CeE1UBQloxNVC7bQx3qcClo3CnMQ,1569615
63
63
  vibe_surf/chrome_extension/icons/logo.png,sha256=PLmv1E6sCGXUE5ZDxr-pFPQd9Gvaw_f1TnYmF8VIssU,566385
64
64
  vibe_surf/chrome_extension/scripts/api-client.js,sha256=qbNoOo33SIoADV5BbSOo_jj9n7FdOPi7v1E5HHhlgSs,16901
@@ -71,7 +71,7 @@ vibe_surf/chrome_extension/scripts/permission-iframe-request.js,sha256=JTin53qSN
71
71
  vibe_surf/chrome_extension/scripts/permission-request.js,sha256=9WEeTqMD0tHm1aX2ySkZgJ23siVZLZWAjVQe2dSmnoI,5168
72
72
  vibe_surf/chrome_extension/scripts/session-manager.js,sha256=rOPGDTyV1oK-qYfqJKK8mpvQFSdnz0_F0wCcbxPfTSw,21887
73
73
  vibe_surf/chrome_extension/scripts/settings-manager.js,sha256=EBMOlAeiEEKY6bDowb_nVT3REtPbNKgMN4xCJoSwFVE,113793
74
- vibe_surf/chrome_extension/scripts/ui-manager.js,sha256=A1dO6tFYoW7Ynh1eneSw_akVG_PtlioBhXhRHTVKQyU,129048
74
+ vibe_surf/chrome_extension/scripts/ui-manager.js,sha256=8hAH1GLLJnsZvTftFFicwzSAsDV7JFedicDKloOZFE8,129666
75
75
  vibe_surf/chrome_extension/scripts/user-settings-storage.js,sha256=5aGuHXwTokX5wKjdNnu3rVkZv9XoD15FmgCELRRE3Xw,14191
76
76
  vibe_surf/chrome_extension/scripts/voice-recorder.js,sha256=rIq9Rhyq-QyeCxJxxZGbnbPC0MCjQtNx6T2UC1g_al4,16852
77
77
  vibe_surf/chrome_extension/styles/activity.css,sha256=aEFa_abskrDQvwsesPVOyJW3rUQUEBQpMKPHhY94CoA,19601
@@ -98,13 +98,13 @@ vibe_surf/telemetry/views.py,sha256=llbXm4GkYLlJc5vYKDDUqcKDCUOJ_ScS22rwzxdSUEc,
98
98
  vibe_surf/tools/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
99
99
  vibe_surf/tools/browser_use_tools.py,sha256=Al65_YfOoMk112oeDz1gRgHC08RsaL19DSFr3oG0vCw,30726
100
100
  vibe_surf/tools/composio_client.py,sha256=hbvUYiTSlNNRvBQmoVkxtJnd6pXm7PaevcTo1nQZEx8,18822
101
- vibe_surf/tools/file_system.py,sha256=wzEWQJUVLE7xLSOIz4Fx7MWkniQaSJhgCGQAZ9eMJ38,19374
101
+ vibe_surf/tools/file_system.py,sha256=p8VqmUPCi7nwj10Q9s4xW4tPBfvr-5GXwAUwUNNIOjA,19418
102
102
  vibe_surf/tools/finance_tools.py,sha256=E8rmblp57e_cp0tFbdZ7BY3_upNlk4Whk0bYc_SFCJE,27284
103
103
  vibe_surf/tools/mcp_client.py,sha256=ZrwzboDBf7-rtzO8JYpBhvKGg88CMfbrXlhtIs8pXSQ,3167
104
104
  vibe_surf/tools/report_writer_tools.py,sha256=2CyTTXOahTKZo7XwyWDDhJ--1mRA0uTtUWxu_DACAY0,776
105
105
  vibe_surf/tools/utils.py,sha256=-Hu60Qu0M_gJpU7Ow8WpgBbZzMv_76DsYYj7eFk6M08,4219
106
106
  vibe_surf/tools/vibesurf_registry.py,sha256=Z-8d9BrJl3RFMEK0Tw1Q5xNHX2kZGsnIGCTBZ3RM-pw,2159
107
- vibe_surf/tools/vibesurf_tools.py,sha256=feBejeVXacbfWjzPsKVqc2dnYVoI-jalAtwdXB6_N4U,113152
107
+ vibe_surf/tools/vibesurf_tools.py,sha256=f3R-dtKkNdNus7nvILy5p84VR9zpVedkrotTNfZfTmc,113278
108
108
  vibe_surf/tools/views.py,sha256=r_xHyBHR-d8cSgvZ-GJVnB4k7pQq9g5gsp882zM70mM,12897
109
109
  vibe_surf/tools/voice_asr.py,sha256=AJG0yq_Jq-j8ulDlbPhVFfK1jch9_ASesis73iki9II,4702
110
110
  vibe_surf/tools/website_api/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -120,9 +120,9 @@ vibe_surf/tools/website_api/xhs/helpers.py,sha256=Dq2RyYKClBQ2ha2yEfpS1mtZswx0z9
120
120
  vibe_surf/tools/website_api/youtube/__init__.py,sha256=QWmZWSqo1O6XtaWP-SuL3HrBLYINjEWEyOy-KCytGDw,1145
121
121
  vibe_surf/tools/website_api/youtube/client.py,sha256=0kKy7fkBNc63hRvDgXaKnguDpDJ92rG8T2nT_Y1F5MQ,51989
122
122
  vibe_surf/tools/website_api/youtube/helpers.py,sha256=GPgqfNirLYjIpk1OObvoXd2Ktq-ahKOOKHO2WwQVXCw,12931
123
- vibesurf-0.1.39.dist-info/licenses/LICENSE,sha256=vRmTjOYvD8RLiSGYYmFHnveYNswtO1uvSk1sd-Eu7sg,2037
124
- vibesurf-0.1.39.dist-info/METADATA,sha256=hVMdqb4nB51Yhlq4V95oYg48qPNr4cmvutCSRA7RpZA,6787
125
- vibesurf-0.1.39.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
126
- vibesurf-0.1.39.dist-info/entry_points.txt,sha256=UxqpvMocL-PR33S6vLF2OmXn-kVzM-DneMeZeHcPMM8,48
127
- vibesurf-0.1.39.dist-info/top_level.txt,sha256=VPZGHqSb6EEqcJ4ZX6bHIuWfon5f6HXl3c7BYpbRqnY,10
128
- vibesurf-0.1.39.dist-info/RECORD,,
123
+ vibesurf-0.1.41.dist-info/licenses/LICENSE,sha256=vRmTjOYvD8RLiSGYYmFHnveYNswtO1uvSk1sd-Eu7sg,2037
124
+ vibesurf-0.1.41.dist-info/METADATA,sha256=zrIxuWbiGLDs7Wac1jxP1z5DliAsS6tC80f44sebKsg,6787
125
+ vibesurf-0.1.41.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
126
+ vibesurf-0.1.41.dist-info/entry_points.txt,sha256=UxqpvMocL-PR33S6vLF2OmXn-kVzM-DneMeZeHcPMM8,48
127
+ vibesurf-0.1.41.dist-info/top_level.txt,sha256=VPZGHqSb6EEqcJ4ZX6bHIuWfon5f6HXl3c7BYpbRqnY,10
128
+ vibesurf-0.1.41.dist-info/RECORD,,