@bastani/atomic 0.8.26-alpha.6 → 0.8.26-alpha.7

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.
Files changed (240) hide show
  1. package/CHANGELOG.md +18 -0
  2. package/README.md +7 -4
  3. package/dist/builtin/intercom/CHANGELOG.md +6 -0
  4. package/dist/builtin/intercom/package.json +2 -2
  5. package/dist/builtin/mcp/CHANGELOG.md +6 -0
  6. package/dist/builtin/mcp/package.json +3 -3
  7. package/dist/builtin/subagents/CHANGELOG.md +6 -0
  8. package/dist/builtin/subagents/agents/codebase-online-researcher.md +9 -9
  9. package/dist/builtin/subagents/agents/debugger.md +6 -6
  10. package/dist/builtin/subagents/package.json +4 -4
  11. package/dist/builtin/subagents/prompts/parallel-handoff-plan.md +1 -1
  12. package/dist/builtin/subagents/skills/browser/EXAMPLES.md +151 -0
  13. package/dist/builtin/subagents/skills/browser/LICENSE.txt +21 -0
  14. package/dist/builtin/subagents/skills/browser/REFERENCE.md +451 -0
  15. package/dist/builtin/subagents/skills/browser/SKILL.md +170 -0
  16. package/dist/builtin/subagents/skills/subagent/SKILL.md +4 -4
  17. package/dist/builtin/web-access/CHANGELOG.md +6 -0
  18. package/dist/builtin/web-access/package.json +2 -2
  19. package/dist/builtin/workflows/CHANGELOG.md +11 -0
  20. package/dist/builtin/workflows/builtin/deep-research-codebase.ts +4 -1
  21. package/dist/builtin/workflows/builtin/goal.ts +127 -99
  22. package/dist/builtin/workflows/builtin/open-claude-design.ts +224 -147
  23. package/dist/builtin/workflows/builtin/ralph.ts +160 -197
  24. package/dist/builtin/workflows/package.json +2 -2
  25. package/dist/builtin/workflows/skills/research-codebase/SKILL.md +1 -1
  26. package/dist/builtin/workflows/src/tui/stage-chat-view.ts +9 -0
  27. package/dist/core/agent-session.d.ts +28 -1
  28. package/dist/core/agent-session.d.ts.map +1 -1
  29. package/dist/core/agent-session.js +110 -28
  30. package/dist/core/agent-session.js.map +1 -1
  31. package/dist/core/compaction/branch-summarization.d.ts +1 -1
  32. package/dist/core/compaction/branch-summarization.d.ts.map +1 -1
  33. package/dist/core/compaction/branch-summarization.js +6 -3
  34. package/dist/core/compaction/branch-summarization.js.map +1 -1
  35. package/dist/core/compaction/compaction.d.ts.map +1 -1
  36. package/dist/core/compaction/compaction.js +23 -10
  37. package/dist/core/compaction/compaction.js.map +1 -1
  38. package/dist/core/compaction/context-compaction.d.ts +61 -0
  39. package/dist/core/compaction/context-compaction.d.ts.map +1 -0
  40. package/dist/core/compaction/context-compaction.js +602 -0
  41. package/dist/core/compaction/context-compaction.js.map +1 -0
  42. package/dist/core/compaction/index.d.ts +1 -0
  43. package/dist/core/compaction/index.d.ts.map +1 -1
  44. package/dist/core/compaction/index.js +1 -0
  45. package/dist/core/compaction/index.js.map +1 -1
  46. package/dist/core/index.d.ts +1 -1
  47. package/dist/core/index.d.ts.map +1 -1
  48. package/dist/core/index.js.map +1 -1
  49. package/dist/core/session-manager.d.ts +41 -1
  50. package/dist/core/session-manager.d.ts.map +1 -1
  51. package/dist/core/session-manager.js +146 -7
  52. package/dist/core/session-manager.js.map +1 -1
  53. package/dist/core/slash-commands.d.ts.map +1 -1
  54. package/dist/core/slash-commands.js +1 -0
  55. package/dist/core/slash-commands.js.map +1 -1
  56. package/dist/index.d.ts +3 -3
  57. package/dist/index.d.ts.map +1 -1
  58. package/dist/index.js +2 -2
  59. package/dist/index.js.map +1 -1
  60. package/dist/modes/index.d.ts +1 -1
  61. package/dist/modes/index.d.ts.map +1 -1
  62. package/dist/modes/index.js.map +1 -1
  63. package/dist/modes/interactive/components/chat-session-host.d.ts.map +1 -1
  64. package/dist/modes/interactive/components/chat-session-host.js +17 -0
  65. package/dist/modes/interactive/components/chat-session-host.js.map +1 -1
  66. package/dist/modes/interactive/interactive-mode.d.ts +1 -0
  67. package/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  68. package/dist/modes/interactive/interactive-mode.js +74 -0
  69. package/dist/modes/interactive/interactive-mode.js.map +1 -1
  70. package/dist/modes/rpc/rpc-client.d.ts +12 -7
  71. package/dist/modes/rpc/rpc-client.d.ts.map +1 -1
  72. package/dist/modes/rpc/rpc-client.js +8 -1
  73. package/dist/modes/rpc/rpc-client.js.map +1 -1
  74. package/dist/modes/rpc/rpc-mode.d.ts.map +1 -1
  75. package/dist/modes/rpc/rpc-mode.js +4 -0
  76. package/dist/modes/rpc/rpc-mode.js.map +1 -1
  77. package/dist/modes/rpc/rpc-types.d.ts +13 -2
  78. package/dist/modes/rpc/rpc-types.d.ts.map +1 -1
  79. package/dist/modes/rpc/rpc-types.js.map +1 -1
  80. package/docs/compaction.md +42 -23
  81. package/docs/custom-provider.md +11 -9
  82. package/docs/extensions.md +35 -35
  83. package/docs/index.md +1 -8
  84. package/docs/json.md +14 -11
  85. package/docs/packages.md +2 -0
  86. package/docs/providers.md +4 -1
  87. package/docs/quickstart.md +5 -12
  88. package/docs/rpc.md +44 -8
  89. package/docs/sdk.md +1 -8
  90. package/docs/session-format.md +25 -12
  91. package/docs/sessions.md +2 -1
  92. package/docs/skills.md +1 -15
  93. package/docs/termux.md +9 -10
  94. package/docs/themes.md +2 -2
  95. package/docs/tmux.md +3 -3
  96. package/docs/tui.md +19 -32
  97. package/docs/usage.md +2 -0
  98. package/docs/workflows.md +44 -2
  99. package/package.json +4 -12
  100. package/dist/builtin/subagents/skills/browser-use/SKILL.md +0 -234
  101. package/dist/builtin/subagents/skills/browser-use/references/cdp-python.md +0 -76
  102. package/dist/builtin/subagents/skills/browser-use/references/multi-session.md +0 -92
  103. package/node_modules/@earendil-works/pi-tui/README.md +0 -779
  104. package/node_modules/@earendil-works/pi-tui/dist/autocomplete.d.ts +0 -54
  105. package/node_modules/@earendil-works/pi-tui/dist/autocomplete.d.ts.map +0 -1
  106. package/node_modules/@earendil-works/pi-tui/dist/autocomplete.js +0 -632
  107. package/node_modules/@earendil-works/pi-tui/dist/autocomplete.js.map +0 -1
  108. package/node_modules/@earendil-works/pi-tui/dist/components/box.d.ts +0 -22
  109. package/node_modules/@earendil-works/pi-tui/dist/components/box.d.ts.map +0 -1
  110. package/node_modules/@earendil-works/pi-tui/dist/components/box.js +0 -104
  111. package/node_modules/@earendil-works/pi-tui/dist/components/box.js.map +0 -1
  112. package/node_modules/@earendil-works/pi-tui/dist/components/cancellable-loader.d.ts +0 -22
  113. package/node_modules/@earendil-works/pi-tui/dist/components/cancellable-loader.d.ts.map +0 -1
  114. package/node_modules/@earendil-works/pi-tui/dist/components/cancellable-loader.js +0 -35
  115. package/node_modules/@earendil-works/pi-tui/dist/components/cancellable-loader.js.map +0 -1
  116. package/node_modules/@earendil-works/pi-tui/dist/components/editor.d.ts +0 -249
  117. package/node_modules/@earendil-works/pi-tui/dist/components/editor.d.ts.map +0 -1
  118. package/node_modules/@earendil-works/pi-tui/dist/components/editor.js +0 -1857
  119. package/node_modules/@earendil-works/pi-tui/dist/components/editor.js.map +0 -1
  120. package/node_modules/@earendil-works/pi-tui/dist/components/image.d.ts +0 -28
  121. package/node_modules/@earendil-works/pi-tui/dist/components/image.d.ts.map +0 -1
  122. package/node_modules/@earendil-works/pi-tui/dist/components/image.js +0 -89
  123. package/node_modules/@earendil-works/pi-tui/dist/components/image.js.map +0 -1
  124. package/node_modules/@earendil-works/pi-tui/dist/components/input.d.ts +0 -37
  125. package/node_modules/@earendil-works/pi-tui/dist/components/input.d.ts.map +0 -1
  126. package/node_modules/@earendil-works/pi-tui/dist/components/input.js +0 -378
  127. package/node_modules/@earendil-works/pi-tui/dist/components/input.js.map +0 -1
  128. package/node_modules/@earendil-works/pi-tui/dist/components/loader.d.ts +0 -31
  129. package/node_modules/@earendil-works/pi-tui/dist/components/loader.d.ts.map +0 -1
  130. package/node_modules/@earendil-works/pi-tui/dist/components/loader.js +0 -69
  131. package/node_modules/@earendil-works/pi-tui/dist/components/loader.js.map +0 -1
  132. package/node_modules/@earendil-works/pi-tui/dist/components/markdown.d.ts +0 -96
  133. package/node_modules/@earendil-works/pi-tui/dist/components/markdown.d.ts.map +0 -1
  134. package/node_modules/@earendil-works/pi-tui/dist/components/markdown.js +0 -644
  135. package/node_modules/@earendil-works/pi-tui/dist/components/markdown.js.map +0 -1
  136. package/node_modules/@earendil-works/pi-tui/dist/components/select-list.d.ts +0 -50
  137. package/node_modules/@earendil-works/pi-tui/dist/components/select-list.d.ts.map +0 -1
  138. package/node_modules/@earendil-works/pi-tui/dist/components/select-list.js +0 -159
  139. package/node_modules/@earendil-works/pi-tui/dist/components/select-list.js.map +0 -1
  140. package/node_modules/@earendil-works/pi-tui/dist/components/settings-list.d.ts +0 -50
  141. package/node_modules/@earendil-works/pi-tui/dist/components/settings-list.d.ts.map +0 -1
  142. package/node_modules/@earendil-works/pi-tui/dist/components/settings-list.js +0 -185
  143. package/node_modules/@earendil-works/pi-tui/dist/components/settings-list.js.map +0 -1
  144. package/node_modules/@earendil-works/pi-tui/dist/components/spacer.d.ts +0 -12
  145. package/node_modules/@earendil-works/pi-tui/dist/components/spacer.d.ts.map +0 -1
  146. package/node_modules/@earendil-works/pi-tui/dist/components/spacer.js +0 -23
  147. package/node_modules/@earendil-works/pi-tui/dist/components/spacer.js.map +0 -1
  148. package/node_modules/@earendil-works/pi-tui/dist/components/text.d.ts +0 -19
  149. package/node_modules/@earendil-works/pi-tui/dist/components/text.d.ts.map +0 -1
  150. package/node_modules/@earendil-works/pi-tui/dist/components/text.js +0 -89
  151. package/node_modules/@earendil-works/pi-tui/dist/components/text.js.map +0 -1
  152. package/node_modules/@earendil-works/pi-tui/dist/components/truncated-text.d.ts +0 -13
  153. package/node_modules/@earendil-works/pi-tui/dist/components/truncated-text.d.ts.map +0 -1
  154. package/node_modules/@earendil-works/pi-tui/dist/components/truncated-text.js +0 -51
  155. package/node_modules/@earendil-works/pi-tui/dist/components/truncated-text.js.map +0 -1
  156. package/node_modules/@earendil-works/pi-tui/dist/editor-component.d.ts +0 -39
  157. package/node_modules/@earendil-works/pi-tui/dist/editor-component.d.ts.map +0 -1
  158. package/node_modules/@earendil-works/pi-tui/dist/editor-component.js +0 -2
  159. package/node_modules/@earendil-works/pi-tui/dist/editor-component.js.map +0 -1
  160. package/node_modules/@earendil-works/pi-tui/dist/fuzzy.d.ts +0 -16
  161. package/node_modules/@earendil-works/pi-tui/dist/fuzzy.d.ts.map +0 -1
  162. package/node_modules/@earendil-works/pi-tui/dist/fuzzy.js +0 -110
  163. package/node_modules/@earendil-works/pi-tui/dist/fuzzy.js.map +0 -1
  164. package/node_modules/@earendil-works/pi-tui/dist/index.d.ts +0 -23
  165. package/node_modules/@earendil-works/pi-tui/dist/index.d.ts.map +0 -1
  166. package/node_modules/@earendil-works/pi-tui/dist/index.js +0 -32
  167. package/node_modules/@earendil-works/pi-tui/dist/index.js.map +0 -1
  168. package/node_modules/@earendil-works/pi-tui/dist/keybindings.d.ts +0 -193
  169. package/node_modules/@earendil-works/pi-tui/dist/keybindings.d.ts.map +0 -1
  170. package/node_modules/@earendil-works/pi-tui/dist/keybindings.js +0 -174
  171. package/node_modules/@earendil-works/pi-tui/dist/keybindings.js.map +0 -1
  172. package/node_modules/@earendil-works/pi-tui/dist/keys.d.ts +0 -184
  173. package/node_modules/@earendil-works/pi-tui/dist/keys.d.ts.map +0 -1
  174. package/node_modules/@earendil-works/pi-tui/dist/keys.js +0 -1173
  175. package/node_modules/@earendil-works/pi-tui/dist/keys.js.map +0 -1
  176. package/node_modules/@earendil-works/pi-tui/dist/kill-ring.d.ts +0 -28
  177. package/node_modules/@earendil-works/pi-tui/dist/kill-ring.d.ts.map +0 -1
  178. package/node_modules/@earendil-works/pi-tui/dist/kill-ring.js +0 -44
  179. package/node_modules/@earendil-works/pi-tui/dist/kill-ring.js.map +0 -1
  180. package/node_modules/@earendil-works/pi-tui/dist/native-modifiers.d.ts +0 -3
  181. package/node_modules/@earendil-works/pi-tui/dist/native-modifiers.d.ts.map +0 -1
  182. package/node_modules/@earendil-works/pi-tui/dist/native-modifiers.js +0 -53
  183. package/node_modules/@earendil-works/pi-tui/dist/native-modifiers.js.map +0 -1
  184. package/node_modules/@earendil-works/pi-tui/dist/stdin-buffer.d.ts +0 -50
  185. package/node_modules/@earendil-works/pi-tui/dist/stdin-buffer.d.ts.map +0 -1
  186. package/node_modules/@earendil-works/pi-tui/dist/stdin-buffer.js +0 -361
  187. package/node_modules/@earendil-works/pi-tui/dist/stdin-buffer.js.map +0 -1
  188. package/node_modules/@earendil-works/pi-tui/dist/terminal-image.d.ts +0 -90
  189. package/node_modules/@earendil-works/pi-tui/dist/terminal-image.d.ts.map +0 -1
  190. package/node_modules/@earendil-works/pi-tui/dist/terminal-image.js +0 -366
  191. package/node_modules/@earendil-works/pi-tui/dist/terminal-image.js.map +0 -1
  192. package/node_modules/@earendil-works/pi-tui/dist/terminal.d.ts +0 -113
  193. package/node_modules/@earendil-works/pi-tui/dist/terminal.d.ts.map +0 -1
  194. package/node_modules/@earendil-works/pi-tui/dist/terminal.js +0 -472
  195. package/node_modules/@earendil-works/pi-tui/dist/terminal.js.map +0 -1
  196. package/node_modules/@earendil-works/pi-tui/dist/tui.d.ts +0 -227
  197. package/node_modules/@earendil-works/pi-tui/dist/tui.d.ts.map +0 -1
  198. package/node_modules/@earendil-works/pi-tui/dist/tui.js +0 -1106
  199. package/node_modules/@earendil-works/pi-tui/dist/tui.js.map +0 -1
  200. package/node_modules/@earendil-works/pi-tui/dist/undo-stack.d.ts +0 -17
  201. package/node_modules/@earendil-works/pi-tui/dist/undo-stack.d.ts.map +0 -1
  202. package/node_modules/@earendil-works/pi-tui/dist/undo-stack.js +0 -25
  203. package/node_modules/@earendil-works/pi-tui/dist/undo-stack.js.map +0 -1
  204. package/node_modules/@earendil-works/pi-tui/dist/utils.d.ts +0 -84
  205. package/node_modules/@earendil-works/pi-tui/dist/utils.d.ts.map +0 -1
  206. package/node_modules/@earendil-works/pi-tui/dist/utils.js +0 -1029
  207. package/node_modules/@earendil-works/pi-tui/dist/utils.js.map +0 -1
  208. package/node_modules/@earendil-works/pi-tui/dist/word-navigation.d.ts +0 -25
  209. package/node_modules/@earendil-works/pi-tui/dist/word-navigation.d.ts.map +0 -1
  210. package/node_modules/@earendil-works/pi-tui/dist/word-navigation.js +0 -96
  211. package/node_modules/@earendil-works/pi-tui/dist/word-navigation.js.map +0 -1
  212. package/node_modules/@earendil-works/pi-tui/native/darwin/prebuilds/darwin-arm64/darwin-modifiers.node +0 -0
  213. package/node_modules/@earendil-works/pi-tui/native/darwin/prebuilds/darwin-x64/darwin-modifiers.node +0 -0
  214. package/node_modules/@earendil-works/pi-tui/native/win32/prebuilds/win32-arm64/win32-console-mode.node +0 -0
  215. package/node_modules/@earendil-works/pi-tui/native/win32/prebuilds/win32-x64/win32-console-mode.node +0 -0
  216. package/node_modules/@earendil-works/pi-tui/package.json +0 -47
  217. package/node_modules/get-east-asian-width/index.d.ts +0 -60
  218. package/node_modules/get-east-asian-width/index.js +0 -30
  219. package/node_modules/get-east-asian-width/license +0 -9
  220. package/node_modules/get-east-asian-width/lookup-data.js +0 -21
  221. package/node_modules/get-east-asian-width/lookup.js +0 -138
  222. package/node_modules/get-east-asian-width/package.json +0 -71
  223. package/node_modules/get-east-asian-width/readme.md +0 -65
  224. package/node_modules/get-east-asian-width/utilities.js +0 -24
  225. package/node_modules/marked/LICENSE.md +0 -44
  226. package/node_modules/marked/README.md +0 -106
  227. package/node_modules/marked/bin/main.js +0 -282
  228. package/node_modules/marked/bin/marked.js +0 -15
  229. package/node_modules/marked/lib/marked.cjs +0 -2211
  230. package/node_modules/marked/lib/marked.cjs.map +0 -7
  231. package/node_modules/marked/lib/marked.d.cts +0 -728
  232. package/node_modules/marked/lib/marked.d.ts +0 -728
  233. package/node_modules/marked/lib/marked.esm.js +0 -2189
  234. package/node_modules/marked/lib/marked.esm.js.map +0 -7
  235. package/node_modules/marked/lib/marked.umd.js +0 -2213
  236. package/node_modules/marked/lib/marked.umd.js.map +0 -7
  237. package/node_modules/marked/man/marked.1 +0 -111
  238. package/node_modules/marked/man/marked.1.md +0 -92
  239. package/node_modules/marked/marked.min.js +0 -69
  240. package/node_modules/marked/package.json +0 -111
@@ -1,76 +0,0 @@
1
- # Raw CDP & Python Session Reference
2
-
3
- The CLI commands handle most browser interactions. Use `browser-use python` with raw CDP when you need browser-level control the CLI doesn't expose — activating a tab so the user sees it, intercepting network requests, emulating devices, or working with Chrome target IDs directly.
4
-
5
- ## How the Python session works
6
-
7
- `browser-use python "statement"` executes one Python statement per call. Variables persist across calls — set a value in one call, use it in the next.
8
-
9
- A `browser` object is pre-injected with sync wrappers for common operations (`browser.goto()`, `browser.click()`, etc.). For anything beyond those, two internals give you full access:
10
-
11
- - `browser._run(coroutine)` — run any async coroutine synchronously (60s timeout)
12
- - `browser._session` — the raw `BrowserSession` with full CDP client access
13
-
14
- ## Getting a CDP client
15
-
16
- ```bash
17
- browser-use python "cdp = browser._run(browser._session.get_or_create_cdp_session())"
18
- ```
19
-
20
- After this, `cdp` persists across calls. Use `cdp.cdp_client.send.<Domain>.<method>()` for any CDP command and `cdp.session_id` for the session parameter.
21
-
22
- ## Recipes
23
-
24
- ### Activate a tab (make it visible to the user)
25
-
26
- The CLI's `tab switch` only changes the agent's internal focus — Chrome's visible tab doesn't change. To actually show the user a specific tab:
27
-
28
- ```bash
29
- # Get all targets to find the target ID
30
- browser-use python "targets = browser._session.session_manager.get_all_page_targets()"
31
- browser-use python "print([(i, t.url) for i, t in enumerate(targets)])"
32
-
33
- # Activate target at index 1 so the user sees it
34
- browser-use python "cdp = browser._run(browser._session.get_or_create_cdp_session(target_id=None, focus=False))"
35
- browser-use python "browser._run(cdp.cdp_client.send.Target.activateTarget(params={'targetId': targets[1].target_id}))"
36
- ```
37
-
38
- ### List all tabs with target IDs
39
-
40
- ```bash
41
- browser-use python "targets = browser._session.session_manager.get_all_page_targets()"
42
- browser-use python "
43
- for i, t in enumerate(targets):
44
- print(f'{i}: {t.target_id[:12]}... {t.url}')
45
- "
46
- ```
47
-
48
- ### Run JavaScript and get the result
49
-
50
- ```bash
51
- browser-use python "cdp = browser._run(browser._session.get_or_create_cdp_session())"
52
- browser-use python "result = browser._run(cdp.cdp_client.send.Runtime.evaluate(params={'expression': 'document.title', 'returnByValue': True}, session_id=cdp.session_id))"
53
- browser-use python "print(result['result']['value'])"
54
- ```
55
-
56
- ### Emulate a mobile device
57
-
58
- ```bash
59
- browser-use python "cdp = browser._run(browser._session.get_or_create_cdp_session())"
60
- browser-use python "browser._run(cdp.cdp_client.send.Emulation.setDeviceMetricsOverride(params={'width': 375, 'height': 812, 'deviceScaleFactor': 3, 'mobile': True}, session_id=cdp.session_id))"
61
- ```
62
-
63
- ### Get cookies via CDP
64
-
65
- ```bash
66
- browser-use python "cdp = browser._run(browser._session.get_or_create_cdp_session())"
67
- browser-use python "cookies = browser._run(cdp.cdp_client.send.Network.getCookies(params={}, session_id=cdp.session_id))"
68
- browser-use python "print(cookies)"
69
- ```
70
-
71
- ## Tips
72
-
73
- - Each `browser-use python` call is one statement. Multi-line strings work for `for` loops and `if` blocks, but you can't mix statements and expressions. Use multiple calls.
74
- - Variables persist: set `cdp = ...` in one call, use `cdp` in the next.
75
- - The `browser._run()` bridge has a 60-second timeout. For long operations, increase it or use the async internals directly.
76
- - All CDP domains are available via `cdp.cdp_client.send.<Domain>.<method>()`. See the [Chrome DevTools Protocol docs](https://chromedevtools.github.io/devtools-protocol/) for the full API.
@@ -1,92 +0,0 @@
1
- # Multiple Browser Sessions
2
-
3
- ## Why use multiple sessions
4
-
5
- When you need more than one browser at a time:
6
- - Cloud browser for scraping + local Chrome for authenticated tasks
7
- - Two different Chrome profiles simultaneously
8
- - Isolated browser for testing that won't affect the user's browsing
9
- - Running a headed browser for debugging while headless runs in background
10
-
11
- ## How sessions are isolated
12
-
13
- Each `--session NAME` gets:
14
- - Its own daemon process
15
- - Its own Unix socket (`~/.browser-use/{name}.sock`)
16
- - Its own PID file and state file
17
- - Its own browser instance (completely independent)
18
- - Its own tab ownership state (multi-agent locks don't cross sessions)
19
-
20
- ## The `--session` flag
21
-
22
- Must be passed on every command targeting that session:
23
-
24
- ```bash
25
- browser-use --session work open <url> # goes to 'work' daemon
26
- browser-use --session work state # reads from 'work' daemon
27
- browser-use state # goes to 'default' daemon (different browser)
28
- ```
29
-
30
- If you forget `--session`, the command goes to the `default` session. This is the most common mistake — you'll interact with the wrong browser.
31
-
32
- ## Combining sessions with browser modes
33
-
34
- ```bash
35
- # Session 1: cloud browser
36
- browser-use --session cloud cloud connect
37
-
38
- # Session 2: connect to user's Chrome
39
- browser-use --session chrome connect
40
-
41
- # Session 3: headed Chromium for debugging
42
- browser-use --session debug --headed open <url>
43
- ```
44
-
45
- Each session is fully independent. The cloud session talks to a remote browser, the chrome session talks to the user's Chrome, and the debug session manages its own Chromium — all running simultaneously.
46
-
47
- ## Listing and managing sessions
48
-
49
- ```bash
50
- browser-use sessions
51
- ```
52
-
53
- Output:
54
- ```
55
- SESSION PHASE PID CONFIG
56
- cloud running 12345 cloud
57
- chrome running 12346 cdp
58
- debug ready 12347 headed
59
- ```
60
-
61
- PHASE shows the daemon lifecycle state: `initializing`, `ready`, `starting`, `running`, `shutting_down`, `stopped`, `failed`.
62
-
63
- ```bash
64
- browser-use --session cloud close # close one session
65
- browser-use close --all # close every session
66
- ```
67
-
68
- ## Common patterns
69
-
70
- **Cloud + local authenticated:**
71
- ```bash
72
- browser-use --session scraper cloud connect
73
- browser-use --session scraper open https://example.com
74
- # ... scrape data ...
75
-
76
- browser-use --session auth --profile "Default" open https://github.com
77
- browser-use --session auth state
78
- # ... interact with authenticated site ...
79
- ```
80
-
81
- **Throwaway test browser:**
82
- ```bash
83
- browser-use --session test --headed open https://localhost:3000
84
- # ... test, debug, inspect ...
85
- browser-use --session test close # done, clean up
86
- ```
87
-
88
- **Environment variable:**
89
- ```bash
90
- export BROWSER_USE_SESSION=work
91
- browser-use open <url> # uses 'work' session without --session flag
92
- ```