@elizaos/plugin-browser 2.0.0-alpha.9 → 2.0.11-beta.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 (256) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +98 -83
  3. package/auto-enable.ts +24 -0
  4. package/dist/actions/browser-autofill-login.d.ts +43 -0
  5. package/dist/actions/browser-autofill-login.d.ts.map +1 -0
  6. package/dist/actions/browser-autofill-login.js +278 -0
  7. package/dist/actions/browser-autofill-login.js.map +1 -0
  8. package/dist/actions/browser.d.ts +11 -0
  9. package/dist/actions/browser.d.ts.map +1 -0
  10. package/dist/actions/browser.js +412 -0
  11. package/dist/actions/browser.js.map +1 -0
  12. package/dist/actions/manage-browser-bridge.d.ts +34 -0
  13. package/dist/actions/manage-browser-bridge.d.ts.map +1 -0
  14. package/dist/actions/manage-browser-bridge.js +572 -0
  15. package/dist/actions/manage-browser-bridge.js.map +1 -0
  16. package/dist/bridge-policy.d.ts +10 -0
  17. package/dist/bridge-policy.d.ts.map +1 -0
  18. package/dist/bridge-policy.js +37 -0
  19. package/dist/bridge-policy.js.map +1 -0
  20. package/dist/bridge-readiness.d.ts +16 -0
  21. package/dist/bridge-readiness.d.ts.map +1 -0
  22. package/dist/bridge-readiness.js +82 -0
  23. package/dist/bridge-readiness.js.map +1 -0
  24. package/dist/bridge-records.d.ts +9 -0
  25. package/dist/bridge-records.d.ts.map +1 -0
  26. package/dist/bridge-records.js +37 -0
  27. package/dist/bridge-records.js.map +1 -0
  28. package/dist/browser-capture-hooks.d.ts +9 -0
  29. package/dist/browser-capture-hooks.d.ts.map +1 -0
  30. package/dist/browser-capture-hooks.js +15 -0
  31. package/dist/browser-capture-hooks.js.map +1 -0
  32. package/dist/browser-service.d.ts +103 -0
  33. package/dist/browser-service.d.ts.map +1 -0
  34. package/dist/browser-service.js +186 -0
  35. package/dist/browser-service.js.map +1 -0
  36. package/dist/browser-workspace-hooks.d.ts +14 -0
  37. package/dist/browser-workspace-hooks.d.ts.map +1 -0
  38. package/dist/browser-workspace-hooks.js +15 -0
  39. package/dist/browser-workspace-hooks.js.map +1 -0
  40. package/dist/companion-auth.d.ts +34 -0
  41. package/dist/companion-auth.d.ts.map +1 -0
  42. package/dist/companion-auth.js +98 -0
  43. package/dist/companion-auth.js.map +1 -0
  44. package/dist/contracts.d.ts +284 -0
  45. package/dist/contracts.d.ts.map +1 -0
  46. package/dist/contracts.js +56 -0
  47. package/dist/contracts.js.map +1 -0
  48. package/dist/index.d.ts +30 -16
  49. package/dist/index.d.ts.map +1 -1
  50. package/dist/index.js +76 -90
  51. package/dist/index.js.map +1 -1
  52. package/dist/lifeops-session-contracts.d.ts +46 -0
  53. package/dist/lifeops-session-contracts.d.ts.map +1 -0
  54. package/dist/lifeops-session-contracts.js +1 -0
  55. package/dist/lifeops-session-contracts.js.map +1 -0
  56. package/dist/message-adapter.d.ts +9 -0
  57. package/dist/message-adapter.d.ts.map +1 -0
  58. package/dist/message-adapter.js +104 -0
  59. package/dist/message-adapter.js.map +1 -0
  60. package/dist/packaging.d.ts +27 -0
  61. package/dist/packaging.d.ts.map +1 -0
  62. package/dist/packaging.js +571 -0
  63. package/dist/packaging.js.map +1 -0
  64. package/dist/password-manager-bridge.d.ts +50 -0
  65. package/dist/password-manager-bridge.d.ts.map +1 -0
  66. package/dist/password-manager-bridge.js +437 -0
  67. package/dist/password-manager-bridge.js.map +1 -0
  68. package/dist/plugin.d.ts +10 -0
  69. package/dist/plugin.d.ts.map +1 -0
  70. package/dist/plugin.js +168 -0
  71. package/dist/plugin.js.map +1 -0
  72. package/dist/providers/workspace.d.ts +13 -0
  73. package/dist/providers/workspace.d.ts.map +1 -0
  74. package/dist/providers/workspace.js +64 -0
  75. package/dist/providers/workspace.js.map +1 -0
  76. package/dist/routes/bridge.d.ts +37 -0
  77. package/dist/routes/bridge.d.ts.map +1 -0
  78. package/dist/routes/bridge.js +844 -0
  79. package/dist/routes/bridge.js.map +1 -0
  80. package/dist/routes/workspace-account-gate.d.ts +29 -0
  81. package/dist/routes/workspace-account-gate.d.ts.map +1 -0
  82. package/dist/routes/workspace-account-gate.js +147 -0
  83. package/dist/routes/workspace-account-gate.js.map +1 -0
  84. package/dist/routes/workspace-setup.d.ts +10 -0
  85. package/dist/routes/workspace-setup.d.ts.map +1 -0
  86. package/dist/routes/workspace-setup.js +65 -0
  87. package/dist/routes/workspace-setup.js.map +1 -0
  88. package/dist/routes/workspace.d.ts +20 -0
  89. package/dist/routes/workspace.d.ts.map +1 -0
  90. package/dist/routes/workspace.js +276 -0
  91. package/dist/routes/workspace.js.map +1 -0
  92. package/dist/schema.d.ts +2326 -0
  93. package/dist/schema.d.ts.map +1 -0
  94. package/dist/schema.js +133 -0
  95. package/dist/schema.js.map +1 -0
  96. package/dist/service.d.ts +30 -0
  97. package/dist/service.d.ts.map +1 -0
  98. package/dist/service.js +5 -0
  99. package/dist/service.js.map +1 -0
  100. package/dist/targets/bridge-target.d.ts +31 -0
  101. package/dist/targets/bridge-target.d.ts.map +1 -0
  102. package/dist/targets/bridge-target.js +98 -0
  103. package/dist/targets/bridge-target.js.map +1 -0
  104. package/dist/targets/stagehand-target.d.ts +3 -0
  105. package/dist/targets/stagehand-target.d.ts.map +1 -0
  106. package/dist/targets/stagehand-target.js +187 -0
  107. package/dist/targets/stagehand-target.js.map +1 -0
  108. package/dist/workspace/browser-capture.d.ts +41 -0
  109. package/dist/workspace/browser-capture.d.ts.map +1 -0
  110. package/dist/workspace/browser-capture.js +159 -0
  111. package/dist/workspace/browser-capture.js.map +1 -0
  112. package/dist/workspace/browser-workspace-desktop.d.ts +19 -0
  113. package/dist/workspace/browser-workspace-desktop.d.ts.map +1 -0
  114. package/dist/workspace/browser-workspace-desktop.js +1578 -0
  115. package/dist/workspace/browser-workspace-desktop.js.map +1 -0
  116. package/dist/workspace/browser-workspace-elements.d.ts +42 -0
  117. package/dist/workspace/browser-workspace-elements.d.ts.map +1 -0
  118. package/dist/workspace/browser-workspace-elements.js +547 -0
  119. package/dist/workspace/browser-workspace-elements.js.map +1 -0
  120. package/dist/workspace/browser-workspace-forms.d.ts +19 -0
  121. package/dist/workspace/browser-workspace-forms.d.ts.map +1 -0
  122. package/dist/workspace/browser-workspace-forms.js +277 -0
  123. package/dist/workspace/browser-workspace-forms.js.map +1 -0
  124. package/dist/workspace/browser-workspace-helpers.d.ts +32 -0
  125. package/dist/workspace/browser-workspace-helpers.d.ts.map +1 -0
  126. package/dist/workspace/browser-workspace-helpers.js +232 -0
  127. package/dist/workspace/browser-workspace-helpers.js.map +1 -0
  128. package/dist/workspace/browser-workspace-jsdom.d.ts +16 -0
  129. package/dist/workspace/browser-workspace-jsdom.d.ts.map +1 -0
  130. package/dist/workspace/browser-workspace-jsdom.js +233 -0
  131. package/dist/workspace/browser-workspace-jsdom.js.map +1 -0
  132. package/dist/workspace/browser-workspace-network.d.ts +7 -0
  133. package/dist/workspace/browser-workspace-network.d.ts.map +1 -0
  134. package/dist/workspace/browser-workspace-network.js +145 -0
  135. package/dist/workspace/browser-workspace-network.js.map +1 -0
  136. package/dist/workspace/browser-workspace-snapshots.d.ts +14 -0
  137. package/dist/workspace/browser-workspace-snapshots.d.ts.map +1 -0
  138. package/dist/workspace/browser-workspace-snapshots.js +144 -0
  139. package/dist/workspace/browser-workspace-snapshots.js.map +1 -0
  140. package/dist/workspace/browser-workspace-state.d.ts +24 -0
  141. package/dist/workspace/browser-workspace-state.d.ts.map +1 -0
  142. package/dist/workspace/browser-workspace-state.js +155 -0
  143. package/dist/workspace/browser-workspace-state.js.map +1 -0
  144. package/dist/workspace/browser-workspace-types.d.ts +345 -0
  145. package/dist/workspace/browser-workspace-types.d.ts.map +1 -0
  146. package/dist/workspace/browser-workspace-types.js +11 -0
  147. package/dist/workspace/browser-workspace-types.js.map +1 -0
  148. package/dist/workspace/browser-workspace-web.d.ts +8 -0
  149. package/dist/workspace/browser-workspace-web.d.ts.map +1 -0
  150. package/dist/workspace/browser-workspace-web.js +1342 -0
  151. package/dist/workspace/browser-workspace-web.js.map +1 -0
  152. package/dist/workspace/browser-workspace.d.ts +39 -0
  153. package/dist/workspace/browser-workspace.d.ts.map +1 -0
  154. package/dist/workspace/browser-workspace.js +958 -0
  155. package/dist/workspace/browser-workspace.js.map +1 -0
  156. package/dist/workspace/index.d.ts +26 -0
  157. package/dist/workspace/index.d.ts.map +1 -0
  158. package/dist/workspace/index.js +3 -0
  159. package/dist/workspace/index.js.map +1 -0
  160. package/dist/workspace.d.ts +2 -0
  161. package/dist/workspace.d.ts.map +1 -0
  162. package/dist/workspace.js +2 -0
  163. package/dist/workspace.js.map +1 -0
  164. package/package.json +71 -110
  165. package/dist/actions/click.d.ts +0 -3
  166. package/dist/actions/click.d.ts.map +0 -1
  167. package/dist/actions/click.js +0 -158
  168. package/dist/actions/click.js.map +0 -1
  169. package/dist/actions/extract.d.ts +0 -3
  170. package/dist/actions/extract.d.ts.map +0 -1
  171. package/dist/actions/extract.js +0 -168
  172. package/dist/actions/extract.js.map +0 -1
  173. package/dist/actions/index.d.ts +0 -7
  174. package/dist/actions/index.d.ts.map +0 -1
  175. package/dist/actions/index.js +0 -7
  176. package/dist/actions/index.js.map +0 -1
  177. package/dist/actions/navigate.d.ts +0 -3
  178. package/dist/actions/navigate.d.ts.map +0 -1
  179. package/dist/actions/navigate.js +0 -187
  180. package/dist/actions/navigate.js.map +0 -1
  181. package/dist/actions/screenshot.d.ts +0 -3
  182. package/dist/actions/screenshot.d.ts.map +0 -1
  183. package/dist/actions/screenshot.js +0 -167
  184. package/dist/actions/screenshot.js.map +0 -1
  185. package/dist/actions/select.d.ts +0 -3
  186. package/dist/actions/select.d.ts.map +0 -1
  187. package/dist/actions/select.js +0 -167
  188. package/dist/actions/select.js.map +0 -1
  189. package/dist/actions/type.d.ts +0 -3
  190. package/dist/actions/type.d.ts.map +0 -1
  191. package/dist/actions/type.js +0 -167
  192. package/dist/actions/type.js.map +0 -1
  193. package/dist/cli/index.d.ts +0 -8
  194. package/dist/cli/index.d.ts.map +0 -1
  195. package/dist/cli/index.js +0 -13
  196. package/dist/cli/index.js.map +0 -1
  197. package/dist/cli/register.d.ts +0 -20
  198. package/dist/cli/register.d.ts.map +0 -1
  199. package/dist/cli/register.js +0 -403
  200. package/dist/cli/register.js.map +0 -1
  201. package/dist/providerRelevance.d.ts +0 -4
  202. package/dist/providerRelevance.d.ts.map +0 -1
  203. package/dist/providerRelevance.js +0 -33
  204. package/dist/providerRelevance.js.map +0 -1
  205. package/dist/providers/browser-state.d.ts +0 -3
  206. package/dist/providers/browser-state.d.ts.map +0 -1
  207. package/dist/providers/browser-state.js +0 -72
  208. package/dist/providers/browser-state.js.map +0 -1
  209. package/dist/providers/index.d.ts +0 -2
  210. package/dist/providers/index.d.ts.map +0 -1
  211. package/dist/providers/index.js +0 -2
  212. package/dist/providers/index.js.map +0 -1
  213. package/dist/services/browser-service.d.ts +0 -32
  214. package/dist/services/browser-service.d.ts.map +0 -1
  215. package/dist/services/browser-service.js +0 -213
  216. package/dist/services/browser-service.js.map +0 -1
  217. package/dist/services/index.d.ts +0 -4
  218. package/dist/services/index.d.ts.map +0 -1
  219. package/dist/services/index.js +0 -4
  220. package/dist/services/index.js.map +0 -1
  221. package/dist/services/process-manager.d.ts +0 -24
  222. package/dist/services/process-manager.d.ts.map +0 -1
  223. package/dist/services/process-manager.js +0 -270
  224. package/dist/services/process-manager.js.map +0 -1
  225. package/dist/services/websocket-client.d.ts +0 -35
  226. package/dist/services/websocket-client.d.ts.map +0 -1
  227. package/dist/services/websocket-client.js +0 -221
  228. package/dist/services/websocket-client.js.map +0 -1
  229. package/dist/types.d.ts +0 -101
  230. package/dist/types.d.ts.map +0 -1
  231. package/dist/types.js +0 -2
  232. package/dist/types.js.map +0 -1
  233. package/dist/utils/captcha.d.ts +0 -33
  234. package/dist/utils/captcha.d.ts.map +0 -1
  235. package/dist/utils/captcha.js +0 -219
  236. package/dist/utils/captcha.js.map +0 -1
  237. package/dist/utils/errors.d.ts +0 -37
  238. package/dist/utils/errors.d.ts.map +0 -1
  239. package/dist/utils/errors.js +0 -81
  240. package/dist/utils/errors.js.map +0 -1
  241. package/dist/utils/index.d.ts +0 -5
  242. package/dist/utils/index.d.ts.map +0 -1
  243. package/dist/utils/index.js +0 -5
  244. package/dist/utils/index.js.map +0 -1
  245. package/dist/utils/retry.d.ts +0 -26
  246. package/dist/utils/retry.d.ts.map +0 -1
  247. package/dist/utils/retry.js +0 -55
  248. package/dist/utils/retry.js.map +0 -1
  249. package/dist/utils/security.d.ts +0 -27
  250. package/dist/utils/security.d.ts.map +0 -1
  251. package/dist/utils/security.js +0 -139
  252. package/dist/utils/security.js.map +0 -1
  253. package/dist/utils/url.d.ts +0 -12
  254. package/dist/utils/url.d.ts.map +0 -1
  255. package/dist/utils/url.js +0 -39
  256. package/dist/utils/url.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../src/schema.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;GAqBG;AAWH,eAAO,MAAM,eAAe,mDAAsB,CAAC;AAEnD,eAAO,MAAM,uBAAuB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAgCnC,CAAC;AAEF,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA0BjC,CAAC;AAEF,eAAO,MAAM,iBAAiB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAgC7B,CAAC;AAEF,eAAO,MAAM,yBAAyB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAuBrC,CAAC;AAEF,eAAO,MAAM,mBAAmB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAKtB,CAAC"}
package/dist/schema.js ADDED
@@ -0,0 +1,133 @@
1
+ import {
2
+ boolean,
3
+ index,
4
+ integer,
5
+ pgSchema,
6
+ text,
7
+ unique
8
+ } from "drizzle-orm/pg-core";
9
+ const browserPgSchema = pgSchema("browser");
10
+ const browserBridgeCompanions = browserPgSchema.table(
11
+ "browser_bridge_companions",
12
+ {
13
+ id: text("id").primaryKey(),
14
+ agentId: text("agent_id").notNull(),
15
+ browser: text("browser").notNull(),
16
+ profileId: text("profile_id").notNull(),
17
+ profileLabel: text("profile_label").notNull().default(""),
18
+ label: text("label").notNull().default(""),
19
+ extensionVersion: text("extension_version"),
20
+ connectionState: text("connection_state").notNull().default("disconnected"),
21
+ permissionsJson: text("permissions_json").notNull().default("{}"),
22
+ pairingTokenHash: text("pairing_token_hash"),
23
+ pairingTokenExpiresAt: text("pairing_token_expires_at"),
24
+ pairingTokenRevokedAt: text("pairing_token_revoked_at"),
25
+ pendingPairingTokenHashesJson: text("pending_pairing_token_hashes_json").notNull().default("[]"),
26
+ lastSeenAt: text("last_seen_at"),
27
+ pairedAt: text("paired_at"),
28
+ metadataJson: text("metadata_json").notNull().default("{}"),
29
+ createdAt: text("created_at").notNull(),
30
+ updatedAt: text("updated_at").notNull()
31
+ },
32
+ (t) => [
33
+ unique().on(t.agentId, t.browser, t.profileId),
34
+ index("idx_browser_bridge_companions_agent").on(
35
+ t.agentId,
36
+ t.browser,
37
+ t.updatedAt
38
+ )
39
+ ]
40
+ );
41
+ const browserBridgeSettings = browserPgSchema.table(
42
+ "browser_bridge_settings",
43
+ {
44
+ agentId: text("agent_id").primaryKey(),
45
+ enabled: boolean("enabled").notNull().default(false),
46
+ trackingMode: text("tracking_mode").notNull().default("current_tab"),
47
+ allowBrowserControl: boolean("allow_browser_control").notNull().default(false),
48
+ requireConfirmationForAccountAffecting: boolean(
49
+ "require_confirmation_for_account_affecting"
50
+ ).notNull().default(true),
51
+ incognitoEnabled: boolean("incognito_enabled").notNull().default(false),
52
+ siteAccessMode: text("site_access_mode").notNull().default("current_site_only"),
53
+ grantedOriginsJson: text("granted_origins_json").notNull().default("[]"),
54
+ blockedOriginsJson: text("blocked_origins_json").notNull().default("[]"),
55
+ maxRememberedTabs: integer("max_remembered_tabs").notNull().default(10),
56
+ pauseUntil: text("pause_until"),
57
+ metadataJson: text("metadata_json").notNull().default("{}"),
58
+ createdAt: text("created_at").notNull(),
59
+ updatedAt: text("updated_at").notNull()
60
+ }
61
+ );
62
+ const browserBridgeTabs = browserPgSchema.table(
63
+ "browser_bridge_tabs",
64
+ {
65
+ id: text("id").primaryKey(),
66
+ agentId: text("agent_id").notNull(),
67
+ companionId: text("companion_id"),
68
+ browser: text("browser").notNull(),
69
+ profileId: text("profile_id").notNull(),
70
+ windowId: text("window_id").notNull(),
71
+ tabId: text("tab_id").notNull(),
72
+ url: text("url").notNull().default(""),
73
+ title: text("title").notNull().default(""),
74
+ activeInWindow: boolean("active_in_window").notNull().default(false),
75
+ focusedWindow: boolean("focused_window").notNull().default(false),
76
+ focusedActive: boolean("focused_active").notNull().default(false),
77
+ incognito: boolean("incognito").notNull().default(false),
78
+ faviconUrl: text("favicon_url"),
79
+ lastSeenAt: text("last_seen_at").notNull(),
80
+ lastFocusedAt: text("last_focused_at"),
81
+ metadataJson: text("metadata_json").notNull().default("{}"),
82
+ createdAt: text("created_at").notNull(),
83
+ updatedAt: text("updated_at").notNull()
84
+ },
85
+ (t) => [
86
+ unique().on(t.agentId, t.browser, t.profileId, t.windowId, t.tabId),
87
+ index("idx_browser_bridge_tabs_agent").on(
88
+ t.agentId,
89
+ t.focusedActive,
90
+ t.activeInWindow,
91
+ t.lastSeenAt
92
+ )
93
+ ]
94
+ );
95
+ const browserBridgePageContexts = browserPgSchema.table(
96
+ "browser_bridge_page_contexts",
97
+ {
98
+ id: text("id").primaryKey(),
99
+ agentId: text("agent_id").notNull(),
100
+ browser: text("browser").notNull(),
101
+ profileId: text("profile_id").notNull(),
102
+ windowId: text("window_id").notNull(),
103
+ tabId: text("tab_id").notNull(),
104
+ url: text("url").notNull().default(""),
105
+ title: text("title").notNull().default(""),
106
+ selectionText: text("selection_text"),
107
+ mainText: text("main_text"),
108
+ headingsJson: text("headings_json").notNull().default("[]"),
109
+ linksJson: text("links_json").notNull().default("[]"),
110
+ formsJson: text("forms_json").notNull().default("[]"),
111
+ capturedAt: text("captured_at").notNull(),
112
+ metadataJson: text("metadata_json").notNull().default("{}")
113
+ },
114
+ (t) => [
115
+ unique().on(t.agentId, t.browser, t.profileId, t.windowId, t.tabId),
116
+ index("idx_browser_bridge_page_contexts_agent").on(t.agentId, t.capturedAt)
117
+ ]
118
+ );
119
+ const browserBridgeSchema = {
120
+ browserBridgeCompanions,
121
+ browserBridgeSettings,
122
+ browserBridgeTabs,
123
+ browserBridgePageContexts
124
+ };
125
+ export {
126
+ browserBridgeCompanions,
127
+ browserBridgePageContexts,
128
+ browserBridgeSchema,
129
+ browserBridgeSettings,
130
+ browserBridgeTabs,
131
+ browserPgSchema
132
+ };
133
+ //# sourceMappingURL=schema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/schema.ts"],"sourcesContent":["/**\n * Agent Browser Bridge Drizzle schema.\n *\n * The four generic browser tables (`browser_bridge_companions`,\n * `browser_bridge_settings`, `browser_bridge_tabs`,\n * `browser_bridge_page_contexts`) are owned by this plugin. The\n * workflow-bound `life_browser_sessions` table remains in LifeOps because\n * it carries `workflowId` plus LifeOps-only scoping columns.\n *\n * Tables are placed in the `browser` PostgreSQL schema (matches the\n * `deriveSchemaName(\"@elizaos/plugin-browser\")` result used by\n * plugin-sql's runtime migrator) so they no longer trip the\n * \"Plugin table is using public schema\" warning. The runtime migrator\n * issues `CREATE SCHEMA IF NOT EXISTS` automatically before applying\n * migrations.\n *\n * Migrations are applied via elizaOS plugin-sql's `runPluginMigrations`\n * when the plugin's `schema` field is populated and an appropriate\n * migration strategy is selected. Renaming the old `life_browser_*`\n * tables to `browser_bridge_*` is a destructive migration controlled by\n * plugin-sql's destructive-migration override.\n */\n\nimport {\n boolean,\n index,\n integer,\n pgSchema,\n text,\n unique,\n} from \"drizzle-orm/pg-core\";\n\nexport const browserPgSchema = pgSchema(\"browser\");\n\nexport const browserBridgeCompanions = browserPgSchema.table(\n \"browser_bridge_companions\",\n {\n id: text(\"id\").primaryKey(),\n agentId: text(\"agent_id\").notNull(),\n browser: text(\"browser\").notNull(),\n profileId: text(\"profile_id\").notNull(),\n profileLabel: text(\"profile_label\").notNull().default(\"\"),\n label: text(\"label\").notNull().default(\"\"),\n extensionVersion: text(\"extension_version\"),\n connectionState: text(\"connection_state\").notNull().default(\"disconnected\"),\n permissionsJson: text(\"permissions_json\").notNull().default(\"{}\"),\n pairingTokenHash: text(\"pairing_token_hash\"),\n pairingTokenExpiresAt: text(\"pairing_token_expires_at\"),\n pairingTokenRevokedAt: text(\"pairing_token_revoked_at\"),\n pendingPairingTokenHashesJson: text(\"pending_pairing_token_hashes_json\")\n .notNull()\n .default(\"[]\"),\n lastSeenAt: text(\"last_seen_at\"),\n pairedAt: text(\"paired_at\"),\n metadataJson: text(\"metadata_json\").notNull().default(\"{}\"),\n createdAt: text(\"created_at\").notNull(),\n updatedAt: text(\"updated_at\").notNull(),\n },\n (t) => [\n unique().on(t.agentId, t.browser, t.profileId),\n index(\"idx_browser_bridge_companions_agent\").on(\n t.agentId,\n t.browser,\n t.updatedAt,\n ),\n ],\n);\n\nexport const browserBridgeSettings = browserPgSchema.table(\n \"browser_bridge_settings\",\n {\n agentId: text(\"agent_id\").primaryKey(),\n enabled: boolean(\"enabled\").notNull().default(false),\n trackingMode: text(\"tracking_mode\").notNull().default(\"current_tab\"),\n allowBrowserControl: boolean(\"allow_browser_control\")\n .notNull()\n .default(false),\n requireConfirmationForAccountAffecting: boolean(\n \"require_confirmation_for_account_affecting\",\n )\n .notNull()\n .default(true),\n incognitoEnabled: boolean(\"incognito_enabled\").notNull().default(false),\n siteAccessMode: text(\"site_access_mode\")\n .notNull()\n .default(\"current_site_only\"),\n grantedOriginsJson: text(\"granted_origins_json\").notNull().default(\"[]\"),\n blockedOriginsJson: text(\"blocked_origins_json\").notNull().default(\"[]\"),\n maxRememberedTabs: integer(\"max_remembered_tabs\").notNull().default(10),\n pauseUntil: text(\"pause_until\"),\n metadataJson: text(\"metadata_json\").notNull().default(\"{}\"),\n createdAt: text(\"created_at\").notNull(),\n updatedAt: text(\"updated_at\").notNull(),\n },\n);\n\nexport const browserBridgeTabs = browserPgSchema.table(\n \"browser_bridge_tabs\",\n {\n id: text(\"id\").primaryKey(),\n agentId: text(\"agent_id\").notNull(),\n companionId: text(\"companion_id\"),\n browser: text(\"browser\").notNull(),\n profileId: text(\"profile_id\").notNull(),\n windowId: text(\"window_id\").notNull(),\n tabId: text(\"tab_id\").notNull(),\n url: text(\"url\").notNull().default(\"\"),\n title: text(\"title\").notNull().default(\"\"),\n activeInWindow: boolean(\"active_in_window\").notNull().default(false),\n focusedWindow: boolean(\"focused_window\").notNull().default(false),\n focusedActive: boolean(\"focused_active\").notNull().default(false),\n incognito: boolean(\"incognito\").notNull().default(false),\n faviconUrl: text(\"favicon_url\"),\n lastSeenAt: text(\"last_seen_at\").notNull(),\n lastFocusedAt: text(\"last_focused_at\"),\n metadataJson: text(\"metadata_json\").notNull().default(\"{}\"),\n createdAt: text(\"created_at\").notNull(),\n updatedAt: text(\"updated_at\").notNull(),\n },\n (t) => [\n unique().on(t.agentId, t.browser, t.profileId, t.windowId, t.tabId),\n index(\"idx_browser_bridge_tabs_agent\").on(\n t.agentId,\n t.focusedActive,\n t.activeInWindow,\n t.lastSeenAt,\n ),\n ],\n);\n\nexport const browserBridgePageContexts = browserPgSchema.table(\n \"browser_bridge_page_contexts\",\n {\n id: text(\"id\").primaryKey(),\n agentId: text(\"agent_id\").notNull(),\n browser: text(\"browser\").notNull(),\n profileId: text(\"profile_id\").notNull(),\n windowId: text(\"window_id\").notNull(),\n tabId: text(\"tab_id\").notNull(),\n url: text(\"url\").notNull().default(\"\"),\n title: text(\"title\").notNull().default(\"\"),\n selectionText: text(\"selection_text\"),\n mainText: text(\"main_text\"),\n headingsJson: text(\"headings_json\").notNull().default(\"[]\"),\n linksJson: text(\"links_json\").notNull().default(\"[]\"),\n formsJson: text(\"forms_json\").notNull().default(\"[]\"),\n capturedAt: text(\"captured_at\").notNull(),\n metadataJson: text(\"metadata_json\").notNull().default(\"{}\"),\n },\n (t) => [\n unique().on(t.agentId, t.browser, t.profileId, t.windowId, t.tabId),\n index(\"idx_browser_bridge_page_contexts_agent\").on(t.agentId, t.capturedAt),\n ],\n);\n\nexport const browserBridgeSchema = {\n browserBridgeCompanions,\n browserBridgeSettings,\n browserBridgeTabs,\n browserBridgePageContexts,\n} as const;\n"],"mappings":"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","names":[]}
@@ -0,0 +1,30 @@
1
+ import type { Service, UUID } from "@elizaos/core";
2
+ import type { BrowserBridgeCompanionAutoPairResponse, BrowserBridgeCompanionPairingResponse, BrowserBridgeCompanionRevokeResponse, BrowserBridgeCompanionStatus, BrowserBridgeCompanionSyncResponse, BrowserBridgePageContext, BrowserBridgeSettings, BrowserBridgeTabSummary, CreateBrowserBridgeCompanionAutoPairRequest, CreateBrowserBridgeCompanionPairingRequest, SyncBrowserBridgeStateRequest, UpdateBrowserBridgeSessionProgressRequest, UpdateBrowserBridgeSettingsRequest } from "./contracts.js";
3
+ import type { CompleteLifeOpsBrowserSessionRequest, ConfirmLifeOpsBrowserSessionRequest, CreateLifeOpsBrowserSessionRequest, LifeOpsBrowserSession } from "./lifeops-session-contracts.js";
4
+ export declare const BROWSER_BRIDGE_ROUTE_SERVICE_TYPE = "lifeops_browser_plugin";
5
+ export interface BrowserBridgeRouteService extends Service {
6
+ getBrowserSettings(ownerEntityId?: UUID | null): Promise<BrowserBridgeSettings>;
7
+ updateBrowserSettings(request: UpdateBrowserBridgeSettingsRequest, ownerEntityId?: UUID | null): Promise<BrowserBridgeSettings>;
8
+ listBrowserCompanions(ownerEntityId?: UUID | null): Promise<BrowserBridgeCompanionStatus[]>;
9
+ listBrowserTabs(ownerEntityId?: UUID | null): Promise<BrowserBridgeTabSummary[]>;
10
+ getCurrentBrowserPage(ownerEntityId?: UUID | null): Promise<BrowserBridgePageContext | null>;
11
+ syncBrowserState(request: SyncBrowserBridgeStateRequest, ownerEntityId?: UUID | null): Promise<{
12
+ companion: BrowserBridgeCompanionStatus;
13
+ tabs: BrowserBridgeTabSummary[];
14
+ currentPage: BrowserBridgePageContext | null;
15
+ }>;
16
+ createBrowserCompanionPairing(request: CreateBrowserBridgeCompanionPairingRequest, ownerEntityId?: UUID | null): Promise<BrowserBridgeCompanionPairingResponse>;
17
+ autoPairBrowserCompanion(request: CreateBrowserBridgeCompanionAutoPairRequest, apiBaseUrl: string, ownerEntityId?: UUID | null): Promise<BrowserBridgeCompanionAutoPairResponse>;
18
+ revokeBrowserCompanion(companionId: string, ownerEntityId?: UUID | null): Promise<BrowserBridgeCompanionRevokeResponse>;
19
+ revokeBrowserCompanionFromCompanion(companionId: string, pairingToken: string, ownerEntityId?: UUID | null): Promise<BrowserBridgeCompanionRevokeResponse>;
20
+ syncBrowserCompanion(companionId: string, pairingToken: string, request: SyncBrowserBridgeStateRequest, ownerEntityId?: UUID | null): Promise<BrowserBridgeCompanionSyncResponse>;
21
+ listBrowserSessions(ownerEntityId?: UUID | null): Promise<LifeOpsBrowserSession[]>;
22
+ getBrowserSession(sessionId: string, ownerEntityId?: UUID | null): Promise<LifeOpsBrowserSession>;
23
+ createBrowserSession(request: CreateLifeOpsBrowserSessionRequest, ownerEntityId?: UUID | null): Promise<LifeOpsBrowserSession>;
24
+ confirmBrowserSession(sessionId: string, request: ConfirmLifeOpsBrowserSessionRequest, ownerEntityId?: UUID | null): Promise<LifeOpsBrowserSession>;
25
+ updateBrowserSessionProgress(sessionId: string, request: UpdateBrowserBridgeSessionProgressRequest, ownerEntityId?: UUID | null): Promise<LifeOpsBrowserSession>;
26
+ completeBrowserSession(sessionId: string, request: CompleteLifeOpsBrowserSessionRequest, ownerEntityId?: UUID | null): Promise<LifeOpsBrowserSession>;
27
+ updateBrowserSessionProgressFromCompanion(companionId: string, pairingToken: string, sessionId: string, request: UpdateBrowserBridgeSessionProgressRequest, ownerEntityId?: UUID | null): Promise<LifeOpsBrowserSession>;
28
+ completeBrowserSessionFromCompanion(companionId: string, pairingToken: string, sessionId: string, request: CompleteLifeOpsBrowserSessionRequest, ownerEntityId?: UUID | null): Promise<LifeOpsBrowserSession>;
29
+ }
30
+ //# sourceMappingURL=service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"service.d.ts","sourceRoot":"","sources":["../src/service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,KAAK,EACV,sCAAsC,EACtC,qCAAqC,EACrC,oCAAoC,EACpC,4BAA4B,EAC5B,kCAAkC,EAClC,wBAAwB,EACxB,qBAAqB,EACrB,uBAAuB,EACvB,2CAA2C,EAC3C,0CAA0C,EAC1C,6BAA6B,EAC7B,yCAAyC,EACzC,kCAAkC,EACnC,MAAM,gBAAgB,CAAC;AACxB,OAAO,KAAK,EACV,oCAAoC,EACpC,mCAAmC,EACnC,kCAAkC,EAClC,qBAAqB,EACtB,MAAM,gCAAgC,CAAC;AAExC,eAAO,MAAM,iCAAiC,2BAA2B,CAAC;AAE1E,MAAM,WAAW,yBAA0B,SAAQ,OAAO;IACxD,kBAAkB,CAChB,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,qBAAqB,CAAC,CAAC;IAClC,qBAAqB,CACnB,OAAO,EAAE,kCAAkC,EAC3C,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,qBAAqB,CAAC,CAAC;IAClC,qBAAqB,CACnB,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,4BAA4B,EAAE,CAAC,CAAC;IAC3C,eAAe,CACb,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,uBAAuB,EAAE,CAAC,CAAC;IACtC,qBAAqB,CACnB,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,wBAAwB,GAAG,IAAI,CAAC,CAAC;IAC5C,gBAAgB,CACd,OAAO,EAAE,6BAA6B,EACtC,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC;QACT,SAAS,EAAE,4BAA4B,CAAC;QACxC,IAAI,EAAE,uBAAuB,EAAE,CAAC;QAChC,WAAW,EAAE,wBAAwB,GAAG,IAAI,CAAC;KAC9C,CAAC,CAAC;IACH,6BAA6B,CAC3B,OAAO,EAAE,0CAA0C,EACnD,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,qCAAqC,CAAC,CAAC;IAClD,wBAAwB,CACtB,OAAO,EAAE,2CAA2C,EACpD,UAAU,EAAE,MAAM,EAClB,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,sCAAsC,CAAC,CAAC;IACnD,sBAAsB,CACpB,WAAW,EAAE,MAAM,EACnB,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,oCAAoC,CAAC,CAAC;IACjD,mCAAmC,CACjC,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,EACpB,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,oCAAoC,CAAC,CAAC;IACjD,oBAAoB,CAClB,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,EACpB,OAAO,EAAE,6BAA6B,EACtC,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,kCAAkC,CAAC,CAAC;IAC/C,mBAAmB,CACjB,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,qBAAqB,EAAE,CAAC,CAAC;IACpC,iBAAiB,CACf,SAAS,EAAE,MAAM,EACjB,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,qBAAqB,CAAC,CAAC;IAClC,oBAAoB,CAClB,OAAO,EAAE,kCAAkC,EAC3C,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,qBAAqB,CAAC,CAAC;IAClC,qBAAqB,CACnB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,mCAAmC,EAC5C,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,qBAAqB,CAAC,CAAC;IAClC,4BAA4B,CAC1B,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,yCAAyC,EAClD,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,qBAAqB,CAAC,CAAC;IAClC,sBAAsB,CACpB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,oCAAoC,EAC7C,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,qBAAqB,CAAC,CAAC;IAClC,yCAAyC,CACvC,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,EACpB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,yCAAyC,EAClD,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,qBAAqB,CAAC,CAAC;IAClC,mCAAmC,CACjC,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,EACpB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,oCAAoC,EAC7C,aAAa,CAAC,EAAE,IAAI,GAAG,IAAI,GAC1B,OAAO,CAAC,qBAAqB,CAAC,CAAC;CACnC"}
@@ -0,0 +1,5 @@
1
+ const BROWSER_BRIDGE_ROUTE_SERVICE_TYPE = "lifeops_browser_plugin";
2
+ export {
3
+ BROWSER_BRIDGE_ROUTE_SERVICE_TYPE
4
+ };
5
+ //# sourceMappingURL=service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/service.ts"],"sourcesContent":["import type { Service, UUID } from \"@elizaos/core\";\nimport type {\n BrowserBridgeCompanionAutoPairResponse,\n BrowserBridgeCompanionPairingResponse,\n BrowserBridgeCompanionRevokeResponse,\n BrowserBridgeCompanionStatus,\n BrowserBridgeCompanionSyncResponse,\n BrowserBridgePageContext,\n BrowserBridgeSettings,\n BrowserBridgeTabSummary,\n CreateBrowserBridgeCompanionAutoPairRequest,\n CreateBrowserBridgeCompanionPairingRequest,\n SyncBrowserBridgeStateRequest,\n UpdateBrowserBridgeSessionProgressRequest,\n UpdateBrowserBridgeSettingsRequest,\n} from \"./contracts.js\";\nimport type {\n CompleteLifeOpsBrowserSessionRequest,\n ConfirmLifeOpsBrowserSessionRequest,\n CreateLifeOpsBrowserSessionRequest,\n LifeOpsBrowserSession,\n} from \"./lifeops-session-contracts.js\";\n\nexport const BROWSER_BRIDGE_ROUTE_SERVICE_TYPE = \"lifeops_browser_plugin\";\n\nexport interface BrowserBridgeRouteService extends Service {\n getBrowserSettings(\n ownerEntityId?: UUID | null,\n ): Promise<BrowserBridgeSettings>;\n updateBrowserSettings(\n request: UpdateBrowserBridgeSettingsRequest,\n ownerEntityId?: UUID | null,\n ): Promise<BrowserBridgeSettings>;\n listBrowserCompanions(\n ownerEntityId?: UUID | null,\n ): Promise<BrowserBridgeCompanionStatus[]>;\n listBrowserTabs(\n ownerEntityId?: UUID | null,\n ): Promise<BrowserBridgeTabSummary[]>;\n getCurrentBrowserPage(\n ownerEntityId?: UUID | null,\n ): Promise<BrowserBridgePageContext | null>;\n syncBrowserState(\n request: SyncBrowserBridgeStateRequest,\n ownerEntityId?: UUID | null,\n ): Promise<{\n companion: BrowserBridgeCompanionStatus;\n tabs: BrowserBridgeTabSummary[];\n currentPage: BrowserBridgePageContext | null;\n }>;\n createBrowserCompanionPairing(\n request: CreateBrowserBridgeCompanionPairingRequest,\n ownerEntityId?: UUID | null,\n ): Promise<BrowserBridgeCompanionPairingResponse>;\n autoPairBrowserCompanion(\n request: CreateBrowserBridgeCompanionAutoPairRequest,\n apiBaseUrl: string,\n ownerEntityId?: UUID | null,\n ): Promise<BrowserBridgeCompanionAutoPairResponse>;\n revokeBrowserCompanion(\n companionId: string,\n ownerEntityId?: UUID | null,\n ): Promise<BrowserBridgeCompanionRevokeResponse>;\n revokeBrowserCompanionFromCompanion(\n companionId: string,\n pairingToken: string,\n ownerEntityId?: UUID | null,\n ): Promise<BrowserBridgeCompanionRevokeResponse>;\n syncBrowserCompanion(\n companionId: string,\n pairingToken: string,\n request: SyncBrowserBridgeStateRequest,\n ownerEntityId?: UUID | null,\n ): Promise<BrowserBridgeCompanionSyncResponse>;\n listBrowserSessions(\n ownerEntityId?: UUID | null,\n ): Promise<LifeOpsBrowserSession[]>;\n getBrowserSession(\n sessionId: string,\n ownerEntityId?: UUID | null,\n ): Promise<LifeOpsBrowserSession>;\n createBrowserSession(\n request: CreateLifeOpsBrowserSessionRequest,\n ownerEntityId?: UUID | null,\n ): Promise<LifeOpsBrowserSession>;\n confirmBrowserSession(\n sessionId: string,\n request: ConfirmLifeOpsBrowserSessionRequest,\n ownerEntityId?: UUID | null,\n ): Promise<LifeOpsBrowserSession>;\n updateBrowserSessionProgress(\n sessionId: string,\n request: UpdateBrowserBridgeSessionProgressRequest,\n ownerEntityId?: UUID | null,\n ): Promise<LifeOpsBrowserSession>;\n completeBrowserSession(\n sessionId: string,\n request: CompleteLifeOpsBrowserSessionRequest,\n ownerEntityId?: UUID | null,\n ): Promise<LifeOpsBrowserSession>;\n updateBrowserSessionProgressFromCompanion(\n companionId: string,\n pairingToken: string,\n sessionId: string,\n request: UpdateBrowserBridgeSessionProgressRequest,\n ownerEntityId?: UUID | null,\n ): Promise<LifeOpsBrowserSession>;\n completeBrowserSessionFromCompanion(\n companionId: string,\n pairingToken: string,\n sessionId: string,\n request: CompleteLifeOpsBrowserSessionRequest,\n ownerEntityId?: UUID | null,\n ): Promise<LifeOpsBrowserSession>;\n}\n"],"mappings":"AAuBO,MAAM,oCAAoC;","names":[]}
@@ -0,0 +1,31 @@
1
+ /**
2
+ * Bridge target — routes a `BrowserWorkspaceCommand` to the Agent Browser
3
+ * Bridge companion (Chrome / Safari) via `BrowserBridgeRouteService`.
4
+ *
5
+ * The bridge surface is intentionally narrower than the workspace surface.
6
+ * It speaks at the level of paired browser tabs, not of an embedded
7
+ * BrowserView, so subactions like `eval` / `pdf` / `trace` / `profiler`
8
+ * have no clean translation. We translate the read-mostly subset that DOES
9
+ * map cleanly:
10
+ *
11
+ * list → list companion-tracked tabs
12
+ * state → snapshot of current page context
13
+ * open → ask the companion to open a URL in a new tab
14
+ * navigate → ask the companion to navigate the current/named tab
15
+ * close → ask the companion to close a tab
16
+ * show / hide → focus / unfocus a tab in the companion window
17
+ * get → return the current page text/title/url
18
+ * back / forward / reload → companion navigation history nav
19
+ *
20
+ * Anything outside that subset throws a clear error so the caller
21
+ * (typically the BROWSER action) can surface a "this isn't supported on
22
+ * the bridge target — try the workspace target" message back to the user.
23
+ *
24
+ * The bridge protocol's session-tracking semantics (`createBrowserSession`,
25
+ * `confirmBrowserSession`, etc.) are LifeOps workflow concerns and live
26
+ * in a dedicated lifeops session action, not here.
27
+ */
28
+ import type { BrowserBridgeRouteService } from "../service.js";
29
+ import type { BrowserWorkspaceCommand, BrowserWorkspaceCommandResult } from "../workspace/browser-workspace-types.js";
30
+ export declare function dispatchBridgeCommand(service: BrowserBridgeRouteService, command: BrowserWorkspaceCommand): Promise<BrowserWorkspaceCommandResult>;
31
+ //# sourceMappingURL=bridge-target.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bridge-target.d.ts","sourceRoot":"","sources":["../../src/targets/bridge-target.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AAGH,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,eAAe,CAAC;AAC/D,OAAO,KAAK,EACV,uBAAuB,EACvB,6BAA6B,EAE9B,MAAM,yCAAyC,CAAC;AAyCjD,wBAAsB,qBAAqB,CACzC,OAAO,EAAE,yBAAyB,EAClC,OAAO,EAAE,uBAAuB,GAC/B,OAAO,CAAC,6BAA6B,CAAC,CAsExC"}
@@ -0,0 +1,98 @@
1
+ const SUPPORTED_SUBACTIONS = /* @__PURE__ */ new Set([
2
+ "list",
3
+ "state",
4
+ "open",
5
+ "navigate",
6
+ "close",
7
+ "show",
8
+ "hide",
9
+ "tab",
10
+ "get",
11
+ "back",
12
+ "forward",
13
+ "reload"
14
+ ]);
15
+ function bridgeTabToWorkspaceTab(tab) {
16
+ return {
17
+ id: tab.id,
18
+ title: tab.title,
19
+ url: tab.url,
20
+ partition: `bridge:${tab.profileId}`,
21
+ kind: "standard",
22
+ visible: tab.activeInWindow,
23
+ createdAt: tab.createdAt,
24
+ updatedAt: tab.updatedAt,
25
+ lastFocusedAt: tab.lastFocusedAt
26
+ };
27
+ }
28
+ function unsupported(subaction) {
29
+ return new Error(
30
+ `Browser bridge target does not support subaction "${subaction}". Use the workspace target for embedded-browser features (eval, pdf, snapshot, trace, profiler, etc.).`
31
+ );
32
+ }
33
+ async function dispatchBridgeCommand(service, command) {
34
+ if (!SUPPORTED_SUBACTIONS.has(command.subaction)) {
35
+ throw unsupported(command.subaction);
36
+ }
37
+ switch (command.subaction) {
38
+ case "list":
39
+ case "tab":
40
+ return {
41
+ mode: "desktop",
42
+ subaction: command.subaction,
43
+ tabs: (await service.listBrowserTabs()).map(bridgeTabToWorkspaceTab)
44
+ };
45
+ case "state": {
46
+ const page = await service.getCurrentBrowserPage();
47
+ return {
48
+ mode: "desktop",
49
+ subaction: command.subaction,
50
+ value: page ? {
51
+ url: page.url,
52
+ title: page.title,
53
+ browser: page.browser,
54
+ profileId: page.profileId,
55
+ windowId: page.windowId,
56
+ tabId: page.tabId,
57
+ capturedAt: page.capturedAt
58
+ } : null
59
+ };
60
+ }
61
+ case "get": {
62
+ const page = await service.getCurrentBrowserPage();
63
+ if (!page) {
64
+ return {
65
+ mode: "desktop",
66
+ subaction: command.subaction,
67
+ value: null
68
+ };
69
+ }
70
+ const mode = command.getMode ?? "text";
71
+ const value = mode === "url" ? page.url : mode === "title" ? page.title : page.mainText ?? "";
72
+ return { mode: "desktop", subaction: command.subaction, value };
73
+ }
74
+ // open / navigate / close / show / hide / back / forward / reload are
75
+ // session-creating operations on the bridge — they require a
76
+ // LifeOpsBrowserSession to record the action and gate confirmation.
77
+ // The bridge's session APIs aren't appropriate to call from a generic
78
+ // BROWSER target, so we throw a clear error directing the caller to
79
+ // the dedicated lifeops session action.
80
+ case "open":
81
+ case "navigate":
82
+ case "close":
83
+ case "show":
84
+ case "hide":
85
+ case "back":
86
+ case "forward":
87
+ case "reload":
88
+ throw new Error(
89
+ `Bridge target subaction "${command.subaction}" requires a recorded LifeOpsBrowserSession (the bridge gates account-affecting ops behind owner confirmation). Use the lifeops browser-session action to start a session, or pin target=workspace for embedded-browser tabs.`
90
+ );
91
+ default:
92
+ throw unsupported(command.subaction);
93
+ }
94
+ }
95
+ export {
96
+ dispatchBridgeCommand
97
+ };
98
+ //# sourceMappingURL=bridge-target.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/targets/bridge-target.ts"],"sourcesContent":["/**\n * Bridge target — routes a `BrowserWorkspaceCommand` to the Agent Browser\n * Bridge companion (Chrome / Safari) via `BrowserBridgeRouteService`.\n *\n * The bridge surface is intentionally narrower than the workspace surface.\n * It speaks at the level of paired browser tabs, not of an embedded\n * BrowserView, so subactions like `eval` / `pdf` / `trace` / `profiler`\n * have no clean translation. We translate the read-mostly subset that DOES\n * map cleanly:\n *\n * list → list companion-tracked tabs\n * state → snapshot of current page context\n * open → ask the companion to open a URL in a new tab\n * navigate → ask the companion to navigate the current/named tab\n * close → ask the companion to close a tab\n * show / hide → focus / unfocus a tab in the companion window\n * get → return the current page text/title/url\n * back / forward / reload → companion navigation history nav\n *\n * Anything outside that subset throws a clear error so the caller\n * (typically the BROWSER action) can surface a \"this isn't supported on\n * the bridge target — try the workspace target\" message back to the user.\n *\n * The bridge protocol's session-tracking semantics (`createBrowserSession`,\n * `confirmBrowserSession`, etc.) are LifeOps workflow concerns and live\n * in a dedicated lifeops session action, not here.\n */\n\nimport type { BrowserBridgeTabSummary } from \"../contracts.js\";\nimport type { BrowserBridgeRouteService } from \"../service.js\";\nimport type {\n BrowserWorkspaceCommand,\n BrowserWorkspaceCommandResult,\n BrowserWorkspaceTab,\n} from \"../workspace/browser-workspace-types.js\";\n\nconst SUPPORTED_SUBACTIONS = new Set<BrowserWorkspaceCommand[\"subaction\"]>([\n \"list\",\n \"state\",\n \"open\",\n \"navigate\",\n \"close\",\n \"show\",\n \"hide\",\n \"tab\",\n \"get\",\n \"back\",\n \"forward\",\n \"reload\",\n]);\n\nfunction bridgeTabToWorkspaceTab(\n tab: BrowserBridgeTabSummary,\n): BrowserWorkspaceTab {\n // The bridge speaks BrowserBridgeTabSummary; the BROWSER action expects\n // BrowserWorkspaceTab. Map the overlapping fields and use defaults for the rest.\n return {\n id: tab.id,\n title: tab.title,\n url: tab.url,\n partition: `bridge:${tab.profileId}`,\n kind: \"standard\",\n visible: tab.activeInWindow,\n createdAt: tab.createdAt,\n updatedAt: tab.updatedAt,\n lastFocusedAt: tab.lastFocusedAt,\n };\n}\n\nfunction unsupported(subaction: BrowserWorkspaceCommand[\"subaction\"]): Error {\n return new Error(\n `Browser bridge target does not support subaction \"${subaction}\". Use the workspace target for embedded-browser features (eval, pdf, snapshot, trace, profiler, etc.).`,\n );\n}\n\nexport async function dispatchBridgeCommand(\n service: BrowserBridgeRouteService,\n command: BrowserWorkspaceCommand,\n): Promise<BrowserWorkspaceCommandResult> {\n if (!SUPPORTED_SUBACTIONS.has(command.subaction)) {\n throw unsupported(command.subaction);\n }\n switch (command.subaction) {\n case \"list\":\n case \"tab\":\n // Bridge `tab` always behaves like list; the bridge has no concept of\n // creating an internal tab via the agent — the user owns the tabs.\n return {\n mode: \"desktop\",\n subaction: command.subaction,\n tabs: (await service.listBrowserTabs()).map(bridgeTabToWorkspaceTab),\n };\n case \"state\": {\n const page = await service.getCurrentBrowserPage();\n return {\n mode: \"desktop\",\n subaction: command.subaction,\n value: page\n ? {\n url: page.url,\n title: page.title,\n browser: page.browser,\n profileId: page.profileId,\n windowId: page.windowId,\n tabId: page.tabId,\n capturedAt: page.capturedAt,\n }\n : null,\n };\n }\n case \"get\": {\n const page = await service.getCurrentBrowserPage();\n if (!page) {\n return {\n mode: \"desktop\",\n subaction: command.subaction,\n value: null,\n };\n }\n const mode = command.getMode ?? \"text\";\n const value =\n mode === \"url\"\n ? page.url\n : mode === \"title\"\n ? page.title\n : (page.mainText ?? \"\");\n return { mode: \"desktop\", subaction: command.subaction, value };\n }\n // open / navigate / close / show / hide / back / forward / reload are\n // session-creating operations on the bridge — they require a\n // LifeOpsBrowserSession to record the action and gate confirmation.\n // The bridge's session APIs aren't appropriate to call from a generic\n // BROWSER target, so we throw a clear error directing the caller to\n // the dedicated lifeops session action.\n case \"open\":\n case \"navigate\":\n case \"close\":\n case \"show\":\n case \"hide\":\n case \"back\":\n case \"forward\":\n case \"reload\":\n throw new Error(\n `Bridge target subaction \"${command.subaction}\" requires a recorded LifeOpsBrowserSession (the bridge gates account-affecting ops behind owner confirmation). Use the lifeops browser-session action to start a session, or pin target=workspace for embedded-browser tabs.`,\n );\n default:\n throw unsupported(command.subaction);\n }\n}\n"],"mappings":"AAoCA,MAAM,uBAAuB,oBAAI,IAA0C;AAAA,EACzE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,CAAC;AAED,SAAS,wBACP,KACqB;AAGrB,SAAO;AAAA,IACL,IAAI,IAAI;AAAA,IACR,OAAO,IAAI;AAAA,IACX,KAAK,IAAI;AAAA,IACT,WAAW,UAAU,IAAI,SAAS;AAAA,IAClC,MAAM;AAAA,IACN,SAAS,IAAI;AAAA,IACb,WAAW,IAAI;AAAA,IACf,WAAW,IAAI;AAAA,IACf,eAAe,IAAI;AAAA,EACrB;AACF;AAEA,SAAS,YAAY,WAAwD;AAC3E,SAAO,IAAI;AAAA,IACT,qDAAqD,SAAS;AAAA,EAChE;AACF;AAEA,eAAsB,sBACpB,SACA,SACwC;AACxC,MAAI,CAAC,qBAAqB,IAAI,QAAQ,SAAS,GAAG;AAChD,UAAM,YAAY,QAAQ,SAAS;AAAA,EACrC;AACA,UAAQ,QAAQ,WAAW;AAAA,IACzB,KAAK;AAAA,IACL,KAAK;AAGH,aAAO;AAAA,QACL,MAAM;AAAA,QACN,WAAW,QAAQ;AAAA,QACnB,OAAO,MAAM,QAAQ,gBAAgB,GAAG,IAAI,uBAAuB;AAAA,MACrE;AAAA,IACF,KAAK,SAAS;AACZ,YAAM,OAAO,MAAM,QAAQ,sBAAsB;AACjD,aAAO;AAAA,QACL,MAAM;AAAA,QACN,WAAW,QAAQ;AAAA,QACnB,OAAO,OACH;AAAA,UACE,KAAK,KAAK;AAAA,UACV,OAAO,KAAK;AAAA,UACZ,SAAS,KAAK;AAAA,UACd,WAAW,KAAK;AAAA,UAChB,UAAU,KAAK;AAAA,UACf,OAAO,KAAK;AAAA,UACZ,YAAY,KAAK;AAAA,QACnB,IACA;AAAA,MACN;AAAA,IACF;AAAA,IACA,KAAK,OAAO;AACV,YAAM,OAAO,MAAM,QAAQ,sBAAsB;AACjD,UAAI,CAAC,MAAM;AACT,eAAO;AAAA,UACL,MAAM;AAAA,UACN,WAAW,QAAQ;AAAA,UACnB,OAAO;AAAA,QACT;AAAA,MACF;AACA,YAAM,OAAO,QAAQ,WAAW;AAChC,YAAM,QACJ,SAAS,QACL,KAAK,MACL,SAAS,UACP,KAAK,QACJ,KAAK,YAAY;AAC1B,aAAO,EAAE,MAAM,WAAW,WAAW,QAAQ,WAAW,MAAM;AAAA,IAChE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AACH,YAAM,IAAI;AAAA,QACR,4BAA4B,QAAQ,SAAS;AAAA,MAC/C;AAAA,IACF;AACE,YAAM,YAAY,QAAQ,SAAS;AAAA,EACvC;AACF;","names":[]}
@@ -0,0 +1,3 @@
1
+ import type { BrowserTarget } from "../browser-service.js";
2
+ export declare function maybeCreateStagehandTarget(env?: NodeJS.ProcessEnv): Promise<BrowserTarget | null>;
3
+ //# sourceMappingURL=stagehand-target.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stagehand-target.d.ts","sourceRoot":"","sources":["../../src/targets/stagehand-target.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAuB3D,wBAAsB,0BAA0B,CAC9C,GAAG,GAAE,MAAM,CAAC,UAAwB,GACnC,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC,CAkC/B"}
@@ -0,0 +1,187 @@
1
+ import { execFileSync, execSync } from "node:child_process";
2
+ import fs from "node:fs";
3
+ import path from "node:path";
4
+ import { fileURLToPath } from "node:url";
5
+ import { logger } from "@elizaos/core";
6
+ const pluginSrcDir = path.dirname(fileURLToPath(import.meta.url));
7
+ const STAGEHAND_COMMAND_URL_ENV = [
8
+ "ELIZA_BROWSER_STAGEHAND_COMMAND_URL",
9
+ "STAGEHAND_BROWSER_COMMAND_URL",
10
+ "ELIZA_STAGEHAND_COMMAND_URL"
11
+ ];
12
+ const STAGEHAND_BASE_URL_ENV = [
13
+ "ELIZA_BROWSER_STAGEHAND_URL",
14
+ "STAGEHAND_SERVER_URL",
15
+ "ELIZA_STAGEHAND_SERVER_URL"
16
+ ];
17
+ const STAGEHAND_AUTO_SETUP_ENV = "ELIZA_BROWSER_STAGEHAND_AUTO_SETUP";
18
+ const STAGEHAND_ALLOW_MOBILE_ENV = "ELIZA_BROWSER_ALLOW_STAGEHAND_ON_MOBILE";
19
+ async function maybeCreateStagehandTarget(env = process.env) {
20
+ if (isDisabled(env.ELIZA_BROWSER_STAGEHAND_ENABLED)) return null;
21
+ const mobile = isMobileRuntime(env);
22
+ if (mobile && !isEnabled(env[STAGEHAND_ALLOW_MOBILE_ENV])) {
23
+ logger.debug(
24
+ "[BrowserService] stagehand target not registered on mobile; using the app browser surface instead"
25
+ );
26
+ return null;
27
+ }
28
+ if (!isDisabled(env[STAGEHAND_AUTO_SETUP_ENV])) {
29
+ ensureLocalStagehandServer(env);
30
+ }
31
+ const commandUrl = resolveStagehandCommandUrl(env);
32
+ if (!commandUrl) {
33
+ logger.debug(
34
+ "[BrowserService] stagehand target not registered; set ELIZA_BROWSER_STAGEHAND_COMMAND_URL or STAGEHAND_SERVER_URL to enable it"
35
+ );
36
+ return null;
37
+ }
38
+ return {
39
+ id: "stagehand",
40
+ name: "Stagehand Browser",
41
+ description: "Fallback Stagehand/Playwright browser backend reached through a local or remote stagehand command endpoint.",
42
+ kind: "stagehand",
43
+ priority: 10,
44
+ score: ({ mobile: mobileContext }) => mobileContext ? null : 10,
45
+ available: async () => probeStagehand(commandUrl, env),
46
+ execute: async (command) => executeStagehandCommand(commandUrl, command)
47
+ };
48
+ }
49
+ function resolveStagehandCommandUrl(env) {
50
+ for (const key of STAGEHAND_COMMAND_URL_ENV) {
51
+ const value = normalizeUrl(env[key]);
52
+ if (value) return value;
53
+ }
54
+ for (const key of STAGEHAND_BASE_URL_ENV) {
55
+ const value = normalizeUrl(env[key]);
56
+ if (value) return new URL("/api/browser-command", value).toString();
57
+ }
58
+ return null;
59
+ }
60
+ async function probeStagehand(_commandUrl, env) {
61
+ const healthUrl = normalizeUrl(env.ELIZA_BROWSER_STAGEHAND_HEALTH_URL);
62
+ if (!healthUrl) return true;
63
+ try {
64
+ const response = await fetch(healthUrl, { method: "GET" });
65
+ return response.ok;
66
+ } catch {
67
+ return false;
68
+ }
69
+ }
70
+ async function executeStagehandCommand(commandUrl, command) {
71
+ const response = await fetch(commandUrl, {
72
+ method: "POST",
73
+ headers: { "content-type": "application/json" },
74
+ body: JSON.stringify({ command })
75
+ });
76
+ const body = await response.json().catch(() => null);
77
+ if (!response.ok) {
78
+ const message = body && typeof body === "object" && "error" in body ? String(body.error) : `Stagehand command endpoint returned HTTP ${response.status}`;
79
+ throw new Error(message);
80
+ }
81
+ return normalizeStagehandResult(command, body);
82
+ }
83
+ function normalizeStagehandResult(command, body) {
84
+ if (body && typeof body === "object") {
85
+ const record = body;
86
+ const result = record.result && typeof record.result === "object" ? record.result : record;
87
+ return {
88
+ ...result,
89
+ mode: "cloud",
90
+ subaction: command.subaction
91
+ };
92
+ }
93
+ return {
94
+ mode: "cloud",
95
+ subaction: command.subaction,
96
+ value: body
97
+ };
98
+ }
99
+ function ensureLocalStagehandServer(env) {
100
+ const stagehandDir = findStagehandDir(env);
101
+ if (!stagehandDir) return false;
102
+ const stagehandIndex = path.join(stagehandDir, "dist", "index.js");
103
+ if (fs.existsSync(stagehandIndex)) return true;
104
+ const stagehandSrc = path.join(stagehandDir, "src", "index.ts");
105
+ if (!fs.existsSync(stagehandSrc)) return false;
106
+ try {
107
+ if (!fs.existsSync(path.join(stagehandDir, "node_modules"))) {
108
+ execSync("bun install --ignore-scripts", {
109
+ cwd: stagehandDir,
110
+ stdio: "ignore",
111
+ timeout: 6e4
112
+ });
113
+ }
114
+ const localTsc = path.join(stagehandDir, "node_modules", ".bin", "tsc");
115
+ if (fs.existsSync(localTsc)) {
116
+ execFileSync(localTsc, [], {
117
+ cwd: stagehandDir,
118
+ stdio: "ignore",
119
+ timeout: 6e4
120
+ });
121
+ } else {
122
+ execFileSync("bunx", ["tsc"], {
123
+ cwd: stagehandDir,
124
+ stdio: "ignore",
125
+ timeout: 6e4
126
+ });
127
+ }
128
+ logger.info("[BrowserService] stagehand-server built successfully");
129
+ return fs.existsSync(stagehandIndex);
130
+ } catch (err) {
131
+ const message = err instanceof Error ? err.message : String(err);
132
+ logger.debug(
133
+ `[BrowserService] stagehand-server auto-setup failed: ${message}`
134
+ );
135
+ return false;
136
+ }
137
+ }
138
+ function findStagehandDir(env) {
139
+ const configured = env.ELIZA_BROWSER_STAGEHAND_DIR?.trim();
140
+ const candidates = [
141
+ configured,
142
+ ...ancestorPaths(pluginSrcDir).flatMap((root) => [
143
+ path.join(root, "stagehand-server"),
144
+ path.join(root, "plugins", "plugin-browser", "stagehand-server"),
145
+ path.join(root, "eliza", "plugins", "plugin-browser", "stagehand-server")
146
+ ])
147
+ ].filter((candidate) => Boolean(candidate));
148
+ for (const candidate of candidates) {
149
+ const dir = path.resolve(candidate);
150
+ if (fs.existsSync(path.join(dir, "dist", "index.js")) || fs.existsSync(path.join(dir, "src", "index.ts"))) {
151
+ return dir;
152
+ }
153
+ }
154
+ return null;
155
+ }
156
+ function ancestorPaths(start) {
157
+ const ancestors = [];
158
+ let current = path.resolve(start);
159
+ while (true) {
160
+ ancestors.push(current);
161
+ const parent = path.dirname(current);
162
+ if (parent === current) return ancestors;
163
+ current = parent;
164
+ }
165
+ }
166
+ function normalizeUrl(value) {
167
+ if (!value?.trim()) return null;
168
+ try {
169
+ return new URL(value.trim()).toString();
170
+ } catch {
171
+ return null;
172
+ }
173
+ }
174
+ function isEnabled(value) {
175
+ return value === "1" || value?.toLowerCase() === "true";
176
+ }
177
+ function isDisabled(value) {
178
+ return value === "0" || value?.toLowerCase() === "false";
179
+ }
180
+ function isMobileRuntime(env) {
181
+ const platform = (env.ELIZA_MOBILE_PLATFORM ?? env.ELIZA_PLATFORM ?? env.CAPACITOR_PLATFORM ?? "").toLowerCase();
182
+ return platform === "ios" || platform === "android" || platform === "mobile";
183
+ }
184
+ export {
185
+ maybeCreateStagehandTarget
186
+ };
187
+ //# sourceMappingURL=stagehand-target.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/targets/stagehand-target.ts"],"sourcesContent":["import { execFileSync, execSync } from \"node:child_process\";\nimport fs from \"node:fs\";\nimport path from \"node:path\";\nimport { fileURLToPath } from \"node:url\";\nimport { logger } from \"@elizaos/core\";\nimport type { BrowserTarget } from \"../browser-service.js\";\nimport type {\n BrowserWorkspaceCommand,\n BrowserWorkspaceCommandResult,\n} from \"../workspace/browser-workspace-types.js\";\n\nconst pluginSrcDir = path.dirname(fileURLToPath(import.meta.url));\n\nconst STAGEHAND_COMMAND_URL_ENV = [\n \"ELIZA_BROWSER_STAGEHAND_COMMAND_URL\",\n \"STAGEHAND_BROWSER_COMMAND_URL\",\n \"ELIZA_STAGEHAND_COMMAND_URL\",\n] as const;\n\nconst STAGEHAND_BASE_URL_ENV = [\n \"ELIZA_BROWSER_STAGEHAND_URL\",\n \"STAGEHAND_SERVER_URL\",\n \"ELIZA_STAGEHAND_SERVER_URL\",\n] as const;\n\nconst STAGEHAND_AUTO_SETUP_ENV = \"ELIZA_BROWSER_STAGEHAND_AUTO_SETUP\";\nconst STAGEHAND_ALLOW_MOBILE_ENV = \"ELIZA_BROWSER_ALLOW_STAGEHAND_ON_MOBILE\";\n\nexport async function maybeCreateStagehandTarget(\n env: NodeJS.ProcessEnv = process.env,\n): Promise<BrowserTarget | null> {\n if (isDisabled(env.ELIZA_BROWSER_STAGEHAND_ENABLED)) return null;\n\n const mobile = isMobileRuntime(env);\n if (mobile && !isEnabled(env[STAGEHAND_ALLOW_MOBILE_ENV])) {\n logger.debug(\n \"[BrowserService] stagehand target not registered on mobile; using the app browser surface instead\",\n );\n return null;\n }\n\n if (!isDisabled(env[STAGEHAND_AUTO_SETUP_ENV])) {\n ensureLocalStagehandServer(env);\n }\n\n const commandUrl = resolveStagehandCommandUrl(env);\n if (!commandUrl) {\n logger.debug(\n \"[BrowserService] stagehand target not registered; set ELIZA_BROWSER_STAGEHAND_COMMAND_URL or STAGEHAND_SERVER_URL to enable it\",\n );\n return null;\n }\n\n return {\n id: \"stagehand\",\n name: \"Stagehand Browser\",\n description:\n \"Fallback Stagehand/Playwright browser backend reached through a local or remote stagehand command endpoint.\",\n kind: \"stagehand\",\n priority: 10,\n score: ({ mobile: mobileContext }) => (mobileContext ? null : 10),\n available: async () => probeStagehand(commandUrl, env),\n execute: async (command) => executeStagehandCommand(commandUrl, command),\n };\n}\n\nfunction resolveStagehandCommandUrl(env: NodeJS.ProcessEnv): string | null {\n for (const key of STAGEHAND_COMMAND_URL_ENV) {\n const value = normalizeUrl(env[key]);\n if (value) return value;\n }\n for (const key of STAGEHAND_BASE_URL_ENV) {\n const value = normalizeUrl(env[key]);\n if (value) return new URL(\"/api/browser-command\", value).toString();\n }\n return null;\n}\n\nasync function probeStagehand(\n _commandUrl: string,\n env: NodeJS.ProcessEnv,\n): Promise<boolean> {\n const healthUrl = normalizeUrl(env.ELIZA_BROWSER_STAGEHAND_HEALTH_URL);\n if (!healthUrl) return true;\n try {\n const response = await fetch(healthUrl, { method: \"GET\" });\n return response.ok;\n } catch {\n return false;\n }\n}\n\nasync function executeStagehandCommand(\n commandUrl: string,\n command: BrowserWorkspaceCommand,\n): Promise<BrowserWorkspaceCommandResult> {\n const response = await fetch(commandUrl, {\n method: \"POST\",\n headers: { \"content-type\": \"application/json\" },\n body: JSON.stringify({ command }),\n });\n const body = await response.json().catch(() => null);\n if (!response.ok) {\n const message =\n body && typeof body === \"object\" && \"error\" in body\n ? String((body as { error?: unknown }).error)\n : `Stagehand command endpoint returned HTTP ${response.status}`;\n throw new Error(message);\n }\n return normalizeStagehandResult(command, body);\n}\n\nfunction normalizeStagehandResult(\n command: BrowserWorkspaceCommand,\n body: unknown,\n): BrowserWorkspaceCommandResult {\n if (body && typeof body === \"object\") {\n const record = body as {\n result?: unknown;\n mode?: unknown;\n subaction?: unknown;\n value?: unknown;\n };\n const result =\n record.result && typeof record.result === \"object\"\n ? (record.result as BrowserWorkspaceCommandResult)\n : (record as BrowserWorkspaceCommandResult);\n return {\n ...result,\n mode: \"cloud\",\n subaction: command.subaction,\n };\n }\n return {\n mode: \"cloud\",\n subaction: command.subaction,\n value: body,\n };\n}\n\nfunction ensureLocalStagehandServer(env: NodeJS.ProcessEnv): boolean {\n const stagehandDir = findStagehandDir(env);\n if (!stagehandDir) return false;\n\n const stagehandIndex = path.join(stagehandDir, \"dist\", \"index.js\");\n if (fs.existsSync(stagehandIndex)) return true;\n\n const stagehandSrc = path.join(stagehandDir, \"src\", \"index.ts\");\n if (!fs.existsSync(stagehandSrc)) return false;\n\n try {\n if (!fs.existsSync(path.join(stagehandDir, \"node_modules\"))) {\n execSync(\"bun install --ignore-scripts\", {\n cwd: stagehandDir,\n stdio: \"ignore\",\n timeout: 60_000,\n });\n }\n const localTsc = path.join(stagehandDir, \"node_modules\", \".bin\", \"tsc\");\n if (fs.existsSync(localTsc)) {\n execFileSync(localTsc, [], {\n cwd: stagehandDir,\n stdio: \"ignore\",\n timeout: 60_000,\n });\n } else {\n execFileSync(\"bunx\", [\"tsc\"], {\n cwd: stagehandDir,\n stdio: \"ignore\",\n timeout: 60_000,\n });\n }\n logger.info(\"[BrowserService] stagehand-server built successfully\");\n return fs.existsSync(stagehandIndex);\n } catch (err) {\n const message = err instanceof Error ? err.message : String(err);\n logger.debug(\n `[BrowserService] stagehand-server auto-setup failed: ${message}`,\n );\n return false;\n }\n}\n\nfunction findStagehandDir(env: NodeJS.ProcessEnv): string | null {\n const configured = env.ELIZA_BROWSER_STAGEHAND_DIR?.trim();\n const candidates = [\n configured,\n ...ancestorPaths(pluginSrcDir).flatMap((root) => [\n path.join(root, \"stagehand-server\"),\n path.join(root, \"plugins\", \"plugin-browser\", \"stagehand-server\"),\n path.join(root, \"eliza\", \"plugins\", \"plugin-browser\", \"stagehand-server\"),\n ]),\n ].filter((candidate): candidate is string => Boolean(candidate));\n\n for (const candidate of candidates) {\n const dir = path.resolve(candidate);\n if (\n fs.existsSync(path.join(dir, \"dist\", \"index.js\")) ||\n fs.existsSync(path.join(dir, \"src\", \"index.ts\"))\n ) {\n return dir;\n }\n }\n return null;\n}\n\nfunction ancestorPaths(start: string): string[] {\n const ancestors: string[] = [];\n let current = path.resolve(start);\n while (true) {\n ancestors.push(current);\n const parent = path.dirname(current);\n if (parent === current) return ancestors;\n current = parent;\n }\n}\n\nfunction normalizeUrl(value: string | undefined): string | null {\n if (!value?.trim()) return null;\n try {\n return new URL(value.trim()).toString();\n } catch {\n return null;\n }\n}\n\nfunction isEnabled(value: string | undefined): boolean {\n return value === \"1\" || value?.toLowerCase() === \"true\";\n}\n\nfunction isDisabled(value: string | undefined): boolean {\n return value === \"0\" || value?.toLowerCase() === \"false\";\n}\n\nfunction isMobileRuntime(env: NodeJS.ProcessEnv): boolean {\n const platform = (\n env.ELIZA_MOBILE_PLATFORM ??\n env.ELIZA_PLATFORM ??\n env.CAPACITOR_PLATFORM ??\n \"\"\n ).toLowerCase();\n return platform === \"ios\" || platform === \"android\" || platform === \"mobile\";\n}\n"],"mappings":"AAAA,SAAS,cAAc,gBAAgB;AACvC,OAAO,QAAQ;AACf,OAAO,UAAU;AACjB,SAAS,qBAAqB;AAC9B,SAAS,cAAc;AAOvB,MAAM,eAAe,KAAK,QAAQ,cAAc,YAAY,GAAG,CAAC;AAEhE,MAAM,4BAA4B;AAAA,EAChC;AAAA,EACA;AAAA,EACA;AACF;AAEA,MAAM,yBAAyB;AAAA,EAC7B;AAAA,EACA;AAAA,EACA;AACF;AAEA,MAAM,2BAA2B;AACjC,MAAM,6BAA6B;AAEnC,eAAsB,2BACpB,MAAyB,QAAQ,KACF;AAC/B,MAAI,WAAW,IAAI,+BAA+B,EAAG,QAAO;AAE5D,QAAM,SAAS,gBAAgB,GAAG;AAClC,MAAI,UAAU,CAAC,UAAU,IAAI,0BAA0B,CAAC,GAAG;AACzD,WAAO;AAAA,MACL;AAAA,IACF;AACA,WAAO;AAAA,EACT;AAEA,MAAI,CAAC,WAAW,IAAI,wBAAwB,CAAC,GAAG;AAC9C,+BAA2B,GAAG;AAAA,EAChC;AAEA,QAAM,aAAa,2BAA2B,GAAG;AACjD,MAAI,CAAC,YAAY;AACf,WAAO;AAAA,MACL;AAAA,IACF;AACA,WAAO;AAAA,EACT;AAEA,SAAO;AAAA,IACL,IAAI;AAAA,IACJ,MAAM;AAAA,IACN,aACE;AAAA,IACF,MAAM;AAAA,IACN,UAAU;AAAA,IACV,OAAO,CAAC,EAAE,QAAQ,cAAc,MAAO,gBAAgB,OAAO;AAAA,IAC9D,WAAW,YAAY,eAAe,YAAY,GAAG;AAAA,IACrD,SAAS,OAAO,YAAY,wBAAwB,YAAY,OAAO;AAAA,EACzE;AACF;AAEA,SAAS,2BAA2B,KAAuC;AACzE,aAAW,OAAO,2BAA2B;AAC3C,UAAM,QAAQ,aAAa,IAAI,GAAG,CAAC;AACnC,QAAI,MAAO,QAAO;AAAA,EACpB;AACA,aAAW,OAAO,wBAAwB;AACxC,UAAM,QAAQ,aAAa,IAAI,GAAG,CAAC;AACnC,QAAI,MAAO,QAAO,IAAI,IAAI,wBAAwB,KAAK,EAAE,SAAS;AAAA,EACpE;AACA,SAAO;AACT;AAEA,eAAe,eACb,aACA,KACkB;AAClB,QAAM,YAAY,aAAa,IAAI,kCAAkC;AACrE,MAAI,CAAC,UAAW,QAAO;AACvB,MAAI;AACF,UAAM,WAAW,MAAM,MAAM,WAAW,EAAE,QAAQ,MAAM,CAAC;AACzD,WAAO,SAAS;AAAA,EAClB,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AAEA,eAAe,wBACb,YACA,SACwC;AACxC,QAAM,WAAW,MAAM,MAAM,YAAY;AAAA,IACvC,QAAQ;AAAA,IACR,SAAS,EAAE,gBAAgB,mBAAmB;AAAA,IAC9C,MAAM,KAAK,UAAU,EAAE,QAAQ,CAAC;AAAA,EAClC,CAAC;AACD,QAAM,OAAO,MAAM,SAAS,KAAK,EAAE,MAAM,MAAM,IAAI;AACnD,MAAI,CAAC,SAAS,IAAI;AAChB,UAAM,UACJ,QAAQ,OAAO,SAAS,YAAY,WAAW,OAC3C,OAAQ,KAA6B,KAAK,IAC1C,4CAA4C,SAAS,MAAM;AACjE,UAAM,IAAI,MAAM,OAAO;AAAA,EACzB;AACA,SAAO,yBAAyB,SAAS,IAAI;AAC/C;AAEA,SAAS,yBACP,SACA,MAC+B;AAC/B,MAAI,QAAQ,OAAO,SAAS,UAAU;AACpC,UAAM,SAAS;AAMf,UAAM,SACJ,OAAO,UAAU,OAAO,OAAO,WAAW,WACrC,OAAO,SACP;AACP,WAAO;AAAA,MACL,GAAG;AAAA,MACH,MAAM;AAAA,MACN,WAAW,QAAQ;AAAA,IACrB;AAAA,EACF;AACA,SAAO;AAAA,IACL,MAAM;AAAA,IACN,WAAW,QAAQ;AAAA,IACnB,OAAO;AAAA,EACT;AACF;AAEA,SAAS,2BAA2B,KAAiC;AACnE,QAAM,eAAe,iBAAiB,GAAG;AACzC,MAAI,CAAC,aAAc,QAAO;AAE1B,QAAM,iBAAiB,KAAK,KAAK,cAAc,QAAQ,UAAU;AACjE,MAAI,GAAG,WAAW,cAAc,EAAG,QAAO;AAE1C,QAAM,eAAe,KAAK,KAAK,cAAc,OAAO,UAAU;AAC9D,MAAI,CAAC,GAAG,WAAW,YAAY,EAAG,QAAO;AAEzC,MAAI;AACF,QAAI,CAAC,GAAG,WAAW,KAAK,KAAK,cAAc,cAAc,CAAC,GAAG;AAC3D,eAAS,gCAAgC;AAAA,QACvC,KAAK;AAAA,QACL,OAAO;AAAA,QACP,SAAS;AAAA,MACX,CAAC;AAAA,IACH;AACA,UAAM,WAAW,KAAK,KAAK,cAAc,gBAAgB,QAAQ,KAAK;AACtE,QAAI,GAAG,WAAW,QAAQ,GAAG;AAC3B,mBAAa,UAAU,CAAC,GAAG;AAAA,QACzB,KAAK;AAAA,QACL,OAAO;AAAA,QACP,SAAS;AAAA,MACX,CAAC;AAAA,IACH,OAAO;AACL,mBAAa,QAAQ,CAAC,KAAK,GAAG;AAAA,QAC5B,KAAK;AAAA,QACL,OAAO;AAAA,QACP,SAAS;AAAA,MACX,CAAC;AAAA,IACH;AACA,WAAO,KAAK,sDAAsD;AAClE,WAAO,GAAG,WAAW,cAAc;AAAA,EACrC,SAAS,KAAK;AACZ,UAAM,UAAU,eAAe,QAAQ,IAAI,UAAU,OAAO,GAAG;AAC/D,WAAO;AAAA,MACL,wDAAwD,OAAO;AAAA,IACjE;AACA,WAAO;AAAA,EACT;AACF;AAEA,SAAS,iBAAiB,KAAuC;AAC/D,QAAM,aAAa,IAAI,6BAA6B,KAAK;AACzD,QAAM,aAAa;AAAA,IACjB;AAAA,IACA,GAAG,cAAc,YAAY,EAAE,QAAQ,CAAC,SAAS;AAAA,MAC/C,KAAK,KAAK,MAAM,kBAAkB;AAAA,MAClC,KAAK,KAAK,MAAM,WAAW,kBAAkB,kBAAkB;AAAA,MAC/D,KAAK,KAAK,MAAM,SAAS,WAAW,kBAAkB,kBAAkB;AAAA,IAC1E,CAAC;AAAA,EACH,EAAE,OAAO,CAAC,cAAmC,QAAQ,SAAS,CAAC;AAE/D,aAAW,aAAa,YAAY;AAClC,UAAM,MAAM,KAAK,QAAQ,SAAS;AAClC,QACE,GAAG,WAAW,KAAK,KAAK,KAAK,QAAQ,UAAU,CAAC,KAChD,GAAG,WAAW,KAAK,KAAK,KAAK,OAAO,UAAU,CAAC,GAC/C;AACA,aAAO;AAAA,IACT;AAAA,EACF;AACA,SAAO;AACT;AAEA,SAAS,cAAc,OAAyB;AAC9C,QAAM,YAAsB,CAAC;AAC7B,MAAI,UAAU,KAAK,QAAQ,KAAK;AAChC,SAAO,MAAM;AACX,cAAU,KAAK,OAAO;AACtB,UAAM,SAAS,KAAK,QAAQ,OAAO;AACnC,QAAI,WAAW,QAAS,QAAO;AAC/B,cAAU;AAAA,EACZ;AACF;AAEA,SAAS,aAAa,OAA0C;AAC9D,MAAI,CAAC,OAAO,KAAK,EAAG,QAAO;AAC3B,MAAI;AACF,WAAO,IAAI,IAAI,MAAM,KAAK,CAAC,EAAE,SAAS;AAAA,EACxC,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AAEA,SAAS,UAAU,OAAoC;AACrD,SAAO,UAAU,OAAO,OAAO,YAAY,MAAM;AACnD;AAEA,SAAS,WAAW,OAAoC;AACtD,SAAO,UAAU,OAAO,OAAO,YAAY,MAAM;AACnD;AAEA,SAAS,gBAAgB,KAAiC;AACxD,QAAM,YACJ,IAAI,yBACJ,IAAI,kBACJ,IAAI,sBACJ,IACA,YAAY;AACd,SAAO,aAAa,SAAS,aAAa,aAAa,aAAa;AACtE;","names":[]}
@@ -0,0 +1,41 @@
1
+ /**
2
+ * Headless browser capture — opens the StreamView in headless Chrome and
3
+ * saves screenshots to a temp file. FFmpeg reads the temp file using
4
+ * -loop 1 to continuously re-read the latest frame.
5
+ *
6
+ * This approach avoids the pipe bottleneck — FFmpeg reads at its own
7
+ * pace while the browser updates the file independently.
8
+ *
9
+ * Visual parity with the desktop shell:
10
+ * - Appends `?popout` to the URL so the app renders StreamView directly
11
+ * (without onboarding, auth gates, or navigation chrome).
12
+ * - Enables SwiftShader for WebGL so VRM avatar renders identically.
13
+ * - Seeds localStorage with overlay layout, theme, and avatar index so
14
+ * the first rendered frame matches the configured appearance.
15
+ * - Uses `waitUntil: "networkidle0"` to ensure all assets load before capture.
16
+ * - Keeps CSS animations/transitions enabled for visual parity.
17
+ */
18
+ /** Path to the temp frame file that FFmpeg reads */
19
+ export declare const FRAME_FILE: string;
20
+ export interface BrowserCaptureConfig {
21
+ url: string;
22
+ width?: number;
23
+ height?: number;
24
+ fps?: number;
25
+ quality?: number;
26
+ /** Optional overlay layout JSON to seed into localStorage before page load. */
27
+ overlayLayout?: string;
28
+ /** Theme name to apply (e.g. "eliza", "haxor", "psycho"). */
29
+ theme?: string;
30
+ /** Avatar VRM index (1–8). */
31
+ avatarIndex?: number;
32
+ /** Destination ID — seeds the destination-specific localStorage key. */
33
+ destinationId?: string;
34
+ }
35
+ export declare function getBrowserCaptureExecutablePath(): string;
36
+ export declare function isBrowserCaptureSupported(): boolean;
37
+ export declare function startBrowserCapture(config: BrowserCaptureConfig): Promise<void>;
38
+ export declare function stopBrowserCapture(): Promise<void>;
39
+ export declare function isBrowserCaptureRunning(): boolean;
40
+ export declare function hasFrameFile(): boolean;
41
+ //# sourceMappingURL=browser-capture.d.ts.map