opendevbrowser 0.0.15 → 0.0.16
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.
- package/LICENSE +1 -1
- package/README.md +229 -34
- package/dist/annotate/direct-annotator.d.ts +22 -0
- package/dist/annotate/direct-annotator.d.ts.map +1 -0
- package/dist/annotate/output.d.ts +10 -0
- package/dist/annotate/output.d.ts.map +1 -0
- package/dist/browser/annotation-manager.d.ts +30 -0
- package/dist/browser/annotation-manager.d.ts.map +1 -0
- package/dist/browser/browser-manager.d.ts +397 -0
- package/dist/browser/browser-manager.d.ts.map +1 -0
- package/dist/browser/fingerprint/adapters.d.ts +26 -0
- package/dist/browser/fingerprint/adapters.d.ts.map +1 -0
- package/dist/browser/fingerprint/canary.d.ts +25 -0
- package/dist/browser/fingerprint/canary.d.ts.map +1 -0
- package/dist/browser/fingerprint/profiles.d.ts +16 -0
- package/dist/browser/fingerprint/profiles.d.ts.map +1 -0
- package/dist/browser/fingerprint/tier1-coherence.d.ts +36 -0
- package/dist/browser/fingerprint/tier1-coherence.d.ts.map +1 -0
- package/dist/browser/fingerprint/tier2-runtime.d.ts +40 -0
- package/dist/browser/fingerprint/tier2-runtime.d.ts.map +1 -0
- package/dist/browser/fingerprint/tier3-adaptive.d.ts +30 -0
- package/dist/browser/fingerprint/tier3-adaptive.d.ts.map +1 -0
- package/dist/browser/manager-types.d.ts +3 -0
- package/dist/browser/manager-types.d.ts.map +1 -0
- package/dist/browser/ops-browser-manager.d.ts +131 -0
- package/dist/browser/ops-browser-manager.d.ts.map +1 -0
- package/dist/browser/ops-client.d.ts +56 -0
- package/dist/browser/ops-client.d.ts.map +1 -0
- package/dist/browser/parallelism-governor.d.ts +31 -0
- package/dist/browser/parallelism-governor.d.ts.map +1 -0
- package/dist/browser/script-runner.d.ts +23 -0
- package/dist/browser/script-runner.d.ts.map +1 -0
- package/dist/browser/session-store.d.ts +63 -0
- package/dist/browser/session-store.d.ts.map +1 -0
- package/dist/browser/target-manager.d.ts +36 -0
- package/dist/browser/target-manager.d.ts.map +1 -0
- package/dist/cache/chrome-locator.d.ts +2 -0
- package/dist/cache/chrome-locator.d.ts.map +1 -0
- package/dist/cache/downloader.d.ts +6 -0
- package/dist/cache/downloader.d.ts.map +1 -0
- package/dist/cache/paths.d.ts +9 -0
- package/dist/cache/paths.d.ts.map +1 -0
- package/dist/chunk-7W3SPXIB.js +166 -0
- package/dist/chunk-7W3SPXIB.js.map +1 -0
- package/dist/chunk-ST7CO5FA.js +18668 -0
- package/dist/chunk-ST7CO5FA.js.map +1 -0
- package/dist/cli/args.d.ts +25 -0
- package/dist/cli/args.d.ts.map +1 -0
- package/dist/cli/client.d.ts +2 -0
- package/dist/cli/client.d.ts.map +1 -0
- package/dist/cli/commands/annotate.d.ts +27 -0
- package/dist/cli/commands/annotate.d.ts.map +1 -0
- package/dist/cli/commands/artifacts.d.ts +24 -0
- package/dist/cli/commands/artifacts.d.ts.map +1 -0
- package/dist/cli/commands/daemon.d.ts +35 -0
- package/dist/cli/commands/daemon.d.ts.map +1 -0
- package/dist/cli/commands/devtools/console-poll.d.ts +7 -0
- package/dist/cli/commands/devtools/console-poll.d.ts.map +1 -0
- package/dist/cli/commands/devtools/debug-trace-snapshot.d.ts +20 -0
- package/dist/cli/commands/devtools/debug-trace-snapshot.d.ts.map +1 -0
- package/dist/cli/commands/devtools/network-poll.d.ts +7 -0
- package/dist/cli/commands/devtools/network-poll.d.ts.map +1 -0
- package/dist/cli/commands/devtools/perf.d.ts +7 -0
- package/dist/cli/commands/devtools/perf.d.ts.map +1 -0
- package/dist/cli/commands/devtools/screenshot.d.ts +17 -0
- package/dist/cli/commands/devtools/screenshot.d.ts.map +1 -0
- package/dist/cli/commands/dom/attr.d.ts +7 -0
- package/dist/cli/commands/dom/attr.d.ts.map +1 -0
- package/dist/cli/commands/dom/checked.d.ts +7 -0
- package/dist/cli/commands/dom/checked.d.ts.map +1 -0
- package/dist/cli/commands/dom/enabled.d.ts +7 -0
- package/dist/cli/commands/dom/enabled.d.ts.map +1 -0
- package/dist/cli/commands/dom/html.d.ts +7 -0
- package/dist/cli/commands/dom/html.d.ts.map +1 -0
- package/dist/cli/commands/dom/text.d.ts +7 -0
- package/dist/cli/commands/dom/text.d.ts.map +1 -0
- package/dist/cli/commands/dom/value.d.ts +7 -0
- package/dist/cli/commands/dom/value.d.ts.map +1 -0
- package/dist/cli/commands/dom/visible.d.ts +7 -0
- package/dist/cli/commands/dom/visible.d.ts.map +1 -0
- package/dist/cli/commands/export/clone-component.d.ts +7 -0
- package/dist/cli/commands/export/clone-component.d.ts.map +1 -0
- package/dist/cli/commands/export/clone-page.d.ts +7 -0
- package/dist/cli/commands/export/clone-page.d.ts.map +1 -0
- package/dist/cli/commands/interact/check.d.ts +7 -0
- package/dist/cli/commands/interact/check.d.ts.map +1 -0
- package/dist/cli/commands/interact/click.d.ts +7 -0
- package/dist/cli/commands/interact/click.d.ts.map +1 -0
- package/dist/cli/commands/interact/hover.d.ts +7 -0
- package/dist/cli/commands/interact/hover.d.ts.map +1 -0
- package/dist/cli/commands/interact/press.d.ts +7 -0
- package/dist/cli/commands/interact/press.d.ts.map +1 -0
- package/dist/cli/commands/interact/scroll-into-view.d.ts +7 -0
- package/dist/cli/commands/interact/scroll-into-view.d.ts.map +1 -0
- package/dist/cli/commands/interact/scroll.d.ts +7 -0
- package/dist/cli/commands/interact/scroll.d.ts.map +1 -0
- package/dist/cli/commands/interact/select.d.ts +7 -0
- package/dist/cli/commands/interact/select.d.ts.map +1 -0
- package/dist/cli/commands/interact/type.d.ts +7 -0
- package/dist/cli/commands/interact/type.d.ts.map +1 -0
- package/dist/cli/commands/interact/uncheck.d.ts +7 -0
- package/dist/cli/commands/interact/uncheck.d.ts.map +1 -0
- package/dist/cli/commands/macro-resolve.d.ts +18 -0
- package/dist/cli/commands/macro-resolve.d.ts.map +1 -0
- package/dist/cli/commands/native.d.ts +82 -0
- package/dist/cli/commands/native.d.ts.map +1 -0
- package/dist/cli/commands/nav/goto.d.ts +7 -0
- package/dist/cli/commands/nav/goto.d.ts.map +1 -0
- package/dist/cli/commands/nav/snapshot.d.ts +7 -0
- package/dist/cli/commands/nav/snapshot.d.ts.map +1 -0
- package/dist/cli/commands/nav/wait.d.ts +7 -0
- package/dist/cli/commands/nav/wait.d.ts.map +1 -0
- package/dist/cli/commands/pages/close.d.ts +6 -0
- package/dist/cli/commands/pages/close.d.ts.map +1 -0
- package/dist/cli/commands/pages/list.d.ts +7 -0
- package/dist/cli/commands/pages/list.d.ts.map +1 -0
- package/dist/cli/commands/pages/open.d.ts +7 -0
- package/dist/cli/commands/pages/open.d.ts.map +1 -0
- package/dist/cli/commands/product-video.d.ts +25 -0
- package/dist/cli/commands/product-video.d.ts.map +1 -0
- package/dist/cli/commands/registry.d.ts +5 -0
- package/dist/cli/commands/registry.d.ts.map +1 -0
- package/dist/cli/commands/research.d.ts +27 -0
- package/dist/cli/commands/research.d.ts.map +1 -0
- package/dist/cli/commands/rpc.d.ts +28 -0
- package/dist/cli/commands/rpc.d.ts.map +1 -0
- package/dist/cli/commands/run.d.ts +17 -0
- package/dist/cli/commands/run.d.ts.map +1 -0
- package/dist/cli/commands/serve.d.ts +59 -0
- package/dist/cli/commands/serve.d.ts.map +1 -0
- package/dist/cli/commands/session/connect.d.ts +9 -0
- package/dist/cli/commands/session/connect.d.ts.map +1 -0
- package/dist/cli/commands/session/cookie-import.d.ts +31 -0
- package/dist/cli/commands/session/cookie-import.d.ts.map +1 -0
- package/dist/cli/commands/session/cookie-list.d.ts +17 -0
- package/dist/cli/commands/session/cookie-list.d.ts.map +1 -0
- package/dist/cli/commands/session/disconnect.d.ts +6 -0
- package/dist/cli/commands/session/disconnect.d.ts.map +1 -0
- package/dist/cli/commands/session/launch.d.ts +29 -0
- package/dist/cli/commands/session/launch.d.ts.map +1 -0
- package/dist/cli/commands/session/status.d.ts +7 -0
- package/dist/cli/commands/session/status.d.ts.map +1 -0
- package/dist/cli/commands/shopping.d.ts +25 -0
- package/dist/cli/commands/shopping.d.ts.map +1 -0
- package/dist/cli/commands/status.d.ts +19 -0
- package/dist/cli/commands/status.d.ts.map +1 -0
- package/dist/cli/commands/targets/close.d.ts +6 -0
- package/dist/cli/commands/targets/close.d.ts.map +1 -0
- package/dist/cli/commands/targets/list.d.ts +7 -0
- package/dist/cli/commands/targets/list.d.ts.map +1 -0
- package/dist/cli/commands/targets/new.d.ts +7 -0
- package/dist/cli/commands/targets/new.d.ts.map +1 -0
- package/dist/cli/commands/targets/use.d.ts +7 -0
- package/dist/cli/commands/targets/use.d.ts.map +1 -0
- package/dist/cli/commands/types.d.ts +13 -0
- package/dist/cli/commands/types.d.ts.map +1 -0
- package/dist/cli/commands/uninstall.d.ts +14 -0
- package/dist/cli/commands/uninstall.d.ts.map +1 -0
- package/dist/cli/commands/update.d.ts +7 -0
- package/dist/cli/commands/update.d.ts.map +1 -0
- package/dist/cli/daemon-autostart.d.ts +46 -0
- package/dist/cli/daemon-autostart.d.ts.map +1 -0
- package/dist/cli/daemon-client.d.ts +33 -0
- package/dist/cli/daemon-client.d.ts.map +1 -0
- package/dist/cli/daemon-commands.d.ts +7 -0
- package/dist/cli/daemon-commands.d.ts.map +1 -0
- package/dist/cli/daemon-state.d.ts +56 -0
- package/dist/cli/daemon-state.d.ts.map +1 -0
- package/dist/cli/daemon-status.d.ts +19 -0
- package/dist/cli/daemon-status.d.ts.map +1 -0
- package/dist/cli/daemon.d.ts +29 -0
- package/dist/cli/daemon.d.ts.map +1 -0
- package/dist/cli/errors.d.ts +20 -0
- package/dist/cli/errors.d.ts.map +1 -0
- package/dist/cli/help.d.ts +28 -0
- package/dist/cli/help.d.ts.map +1 -0
- package/dist/cli/index.d.ts +2 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +2205 -267
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/installers/global.d.ts +9 -0
- package/dist/cli/installers/global.d.ts.map +1 -0
- package/dist/cli/installers/local.d.ts +9 -0
- package/dist/cli/installers/local.d.ts.map +1 -0
- package/dist/cli/installers/skills.d.ts +19 -0
- package/dist/cli/installers/skills.d.ts.map +1 -0
- package/dist/cli/output.d.ts +7 -0
- package/dist/cli/output.d.ts.map +1 -0
- package/dist/cli/remote-manager.d.ts +96 -0
- package/dist/cli/remote-manager.d.ts.map +1 -0
- package/dist/cli/remote-relay.d.ts +17 -0
- package/dist/cli/remote-relay.d.ts.map +1 -0
- package/dist/cli/templates/config.d.ts +7 -0
- package/dist/cli/templates/config.d.ts.map +1 -0
- package/dist/cli/utils/config.d.ts +20 -0
- package/dist/cli/utils/config.d.ts.map +1 -0
- package/dist/cli/utils/http.d.ts +5 -0
- package/dist/cli/utils/http.d.ts.map +1 -0
- package/dist/cli/utils/parse.d.ts +8 -0
- package/dist/cli/utils/parse.d.ts.map +1 -0
- package/dist/cli/utils/skills.d.ts +12 -0
- package/dist/cli/utils/skills.d.ts.map +1 -0
- package/dist/config.d.ts +208 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/core/bootstrap.d.ts +3 -0
- package/dist/core/bootstrap.d.ts.map +1 -0
- package/dist/core/index.d.ts +3 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/logging.d.ts +34 -0
- package/dist/core/logging.d.ts.map +1 -0
- package/dist/core/types.d.ts +34 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/devtools/console-tracker.d.ts +44 -0
- package/dist/devtools/console-tracker.d.ts.map +1 -0
- package/dist/devtools/exception-tracker.d.ts +42 -0
- package/dist/devtools/exception-tracker.d.ts.map +1 -0
- package/dist/devtools/network-tracker.d.ts +34 -0
- package/dist/devtools/network-tracker.d.ts.map +1 -0
- package/dist/export/css-extract.d.ts +5 -0
- package/dist/export/css-extract.d.ts.map +1 -0
- package/dist/export/dom-capture.d.ts +15 -0
- package/dist/export/dom-capture.d.ts.map +1 -0
- package/dist/export/react-emitter.d.ts +11 -0
- package/dist/export/react-emitter.d.ts.map +1 -0
- package/dist/extension-extractor.d.ts +3 -0
- package/dist/extension-extractor.d.ts.map +1 -0
- package/dist/index.d.ts +3 -4
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +867 -87
- package/dist/index.js.map +1 -1
- package/dist/macros/execute.d.ts +44 -0
- package/dist/macros/execute.d.ts.map +1 -0
- package/dist/macros/index.d.ts +9 -0
- package/dist/macros/index.d.ts.map +1 -0
- package/dist/macros/packs/core.d.ts +3 -0
- package/dist/macros/packs/core.d.ts.map +1 -0
- package/dist/macros/registry.d.ts +48 -0
- package/dist/macros/registry.d.ts.map +1 -0
- package/dist/macros-NUBRM44Y.js +399 -0
- package/dist/macros-NUBRM44Y.js.map +1 -0
- package/dist/opendevbrowser.d.ts +3 -4
- package/dist/opendevbrowser.d.ts.map +1 -0
- package/dist/opendevbrowser.js +867 -87
- package/dist/opendevbrowser.js.map +1 -1
- package/dist/providers/adaptive-concurrency.d.ts +42 -0
- package/dist/providers/adaptive-concurrency.d.ts.map +1 -0
- package/dist/providers/artifacts.d.ts +34 -0
- package/dist/providers/artifacts.d.ts.map +1 -0
- package/dist/providers/blocker.d.ts +47 -0
- package/dist/providers/blocker.d.ts.map +1 -0
- package/dist/providers/community/index.d.ts +44 -0
- package/dist/providers/community/index.d.ts.map +1 -0
- package/dist/providers/enrichment.d.ts +33 -0
- package/dist/providers/enrichment.d.ts.map +1 -0
- package/dist/providers/errors.d.ts +41 -0
- package/dist/providers/errors.d.ts.map +1 -0
- package/dist/providers/index.d.ts +121 -0
- package/dist/providers/index.d.ts.map +1 -0
- package/dist/providers/normalize.d.ts +39 -0
- package/dist/providers/normalize.d.ts.map +1 -0
- package/dist/providers/policy.d.ts +5 -0
- package/dist/providers/policy.d.ts.map +1 -0
- package/dist/providers/registry.d.ts +22 -0
- package/dist/providers/registry.d.ts.map +1 -0
- package/dist/providers/renderer.d.ts +49 -0
- package/dist/providers/renderer.d.ts.map +1 -0
- package/dist/providers/runtime-factory.d.ts +20 -0
- package/dist/providers/runtime-factory.d.ts.map +1 -0
- package/dist/providers/safety/prompt-guard.d.ts +34 -0
- package/dist/providers/safety/prompt-guard.d.ts.map +1 -0
- package/dist/providers/shared/anti-bot-policy.d.ts +51 -0
- package/dist/providers/shared/anti-bot-policy.d.ts.map +1 -0
- package/dist/providers/shared/post-policy.d.ts +31 -0
- package/dist/providers/shared/post-policy.d.ts.map +1 -0
- package/dist/providers/shared/request-headers.d.ts +5 -0
- package/dist/providers/shared/request-headers.d.ts.map +1 -0
- package/dist/providers/shared/traversal-url.d.ts +2 -0
- package/dist/providers/shared/traversal-url.d.ts.map +1 -0
- package/dist/providers/shopping/index.d.ts +63 -0
- package/dist/providers/shopping/index.d.ts.map +1 -0
- package/dist/providers/social/bluesky.d.ts +3 -0
- package/dist/providers/social/bluesky.d.ts.map +1 -0
- package/dist/providers/social/facebook.d.ts +3 -0
- package/dist/providers/social/facebook.d.ts.map +1 -0
- package/dist/providers/social/index.d.ts +31 -0
- package/dist/providers/social/index.d.ts.map +1 -0
- package/dist/providers/social/instagram.d.ts +3 -0
- package/dist/providers/social/instagram.d.ts.map +1 -0
- package/dist/providers/social/linkedin.d.ts +3 -0
- package/dist/providers/social/linkedin.d.ts.map +1 -0
- package/dist/providers/social/platform.d.ts +40 -0
- package/dist/providers/social/platform.d.ts.map +1 -0
- package/dist/providers/social/reddit.d.ts +3 -0
- package/dist/providers/social/reddit.d.ts.map +1 -0
- package/dist/providers/social/threads.d.ts +3 -0
- package/dist/providers/social/threads.d.ts.map +1 -0
- package/dist/providers/social/tiktok.d.ts +3 -0
- package/dist/providers/social/tiktok.d.ts.map +1 -0
- package/dist/providers/social/x.d.ts +3 -0
- package/dist/providers/social/x.d.ts.map +1 -0
- package/dist/providers/social/youtube-resolver.d.ts +78 -0
- package/dist/providers/social/youtube-resolver.d.ts.map +1 -0
- package/dist/providers/social/youtube.d.ts +34 -0
- package/dist/providers/social/youtube.d.ts.map +1 -0
- package/dist/providers/tier-router.d.ts +30 -0
- package/dist/providers/tier-router.d.ts.map +1 -0
- package/dist/providers/timebox.d.ts +20 -0
- package/dist/providers/timebox.d.ts.map +1 -0
- package/dist/providers/types.d.ts +344 -0
- package/dist/providers/types.d.ts.map +1 -0
- package/dist/providers/web/crawl-worker.d.ts +36 -0
- package/dist/providers/web/crawl-worker.d.ts.map +1 -0
- package/dist/providers/web/crawler.d.ts +101 -0
- package/dist/providers/web/crawler.d.ts.map +1 -0
- package/dist/providers/web/extract.d.ts +11 -0
- package/dist/providers/web/extract.d.ts.map +1 -0
- package/dist/providers/web/index.d.ts +24 -0
- package/dist/providers/web/index.d.ts.map +1 -0
- package/dist/providers/web/policy.d.ts +14 -0
- package/dist/providers/web/policy.d.ts.map +1 -0
- package/dist/providers/workflows.d.ts +67 -0
- package/dist/providers/workflows.d.ts.map +1 -0
- package/dist/relay/protocol.d.ts +317 -0
- package/dist/relay/protocol.d.ts.map +1 -0
- package/dist/relay/relay-endpoints.d.ts +16 -0
- package/dist/relay/relay-endpoints.d.ts.map +1 -0
- package/dist/relay/relay-server.d.ts +111 -0
- package/dist/relay/relay-server.d.ts.map +1 -0
- package/dist/relay/relay-types.d.ts +9 -0
- package/dist/relay/relay-types.d.ts.map +1 -0
- package/dist/skills/continuity-nudge.d.ts +12 -0
- package/dist/skills/continuity-nudge.d.ts.map +1 -0
- package/dist/skills/skill-loader.d.ts +20 -0
- package/dist/skills/skill-loader.d.ts.map +1 -0
- package/dist/skills/skill-nudge.d.ts +18 -0
- package/dist/skills/skill-nudge.d.ts.map +1 -0
- package/dist/skills/types.d.ts +12 -0
- package/dist/skills/types.d.ts.map +1 -0
- package/dist/snapshot/ops-snapshot.d.ts +16 -0
- package/dist/snapshot/ops-snapshot.d.ts.map +1 -0
- package/dist/snapshot/refs.d.ts +23 -0
- package/dist/snapshot/refs.d.ts.map +1 -0
- package/dist/snapshot/snapshotter.d.ts +27 -0
- package/dist/snapshot/snapshotter.d.ts.map +1 -0
- package/dist/tools/annotate.d.ts +4 -0
- package/dist/tools/annotate.d.ts.map +1 -0
- package/dist/tools/check.d.ts +4 -0
- package/dist/tools/check.d.ts.map +1 -0
- package/dist/tools/click.d.ts +4 -0
- package/dist/tools/click.d.ts.map +1 -0
- package/dist/tools/clone_component.d.ts +4 -0
- package/dist/tools/clone_component.d.ts.map +1 -0
- package/dist/tools/clone_page.d.ts +4 -0
- package/dist/tools/clone_page.d.ts.map +1 -0
- package/dist/tools/close.d.ts +4 -0
- package/dist/tools/close.d.ts.map +1 -0
- package/dist/tools/connect.d.ts +4 -0
- package/dist/tools/connect.d.ts.map +1 -0
- package/dist/tools/console_poll.d.ts +4 -0
- package/dist/tools/console_poll.d.ts.map +1 -0
- package/dist/tools/cookie_import.d.ts +25 -0
- package/dist/tools/cookie_import.d.ts.map +1 -0
- package/dist/tools/cookie_list.d.ts +9 -0
- package/dist/tools/cookie_list.d.ts.map +1 -0
- package/dist/tools/debug_trace_snapshot.d.ts +4 -0
- package/dist/tools/debug_trace_snapshot.d.ts.map +1 -0
- package/dist/tools/deps.d.ts +26 -0
- package/dist/tools/deps.d.ts.map +1 -0
- package/dist/tools/disconnect.d.ts +4 -0
- package/dist/tools/disconnect.d.ts.map +1 -0
- package/dist/tools/dom_get_html.d.ts +4 -0
- package/dist/tools/dom_get_html.d.ts.map +1 -0
- package/dist/tools/dom_get_text.d.ts +4 -0
- package/dist/tools/dom_get_text.d.ts.map +1 -0
- package/dist/tools/get_attr.d.ts +4 -0
- package/dist/tools/get_attr.d.ts.map +1 -0
- package/dist/tools/get_value.d.ts +4 -0
- package/dist/tools/get_value.d.ts.map +1 -0
- package/dist/tools/goto.d.ts +4 -0
- package/dist/tools/goto.d.ts.map +1 -0
- package/dist/tools/hover.d.ts +4 -0
- package/dist/tools/hover.d.ts.map +1 -0
- package/dist/tools/index.d.ts +4 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/is_checked.d.ts +4 -0
- package/dist/tools/is_checked.d.ts.map +1 -0
- package/dist/tools/is_enabled.d.ts +4 -0
- package/dist/tools/is_enabled.d.ts.map +1 -0
- package/dist/tools/is_visible.d.ts +4 -0
- package/dist/tools/is_visible.d.ts.map +1 -0
- package/dist/tools/launch.d.ts +4 -0
- package/dist/tools/launch.d.ts.map +1 -0
- package/dist/tools/list.d.ts +4 -0
- package/dist/tools/list.d.ts.map +1 -0
- package/dist/tools/macro_resolve.d.ts +25 -0
- package/dist/tools/macro_resolve.d.ts.map +1 -0
- package/dist/tools/network_poll.d.ts +4 -0
- package/dist/tools/network_poll.d.ts.map +1 -0
- package/dist/tools/page.d.ts +4 -0
- package/dist/tools/page.d.ts.map +1 -0
- package/dist/tools/perf.d.ts +4 -0
- package/dist/tools/perf.d.ts.map +1 -0
- package/dist/tools/press.d.ts +4 -0
- package/dist/tools/press.d.ts.map +1 -0
- package/dist/tools/product_video_run.d.ts +4 -0
- package/dist/tools/product_video_run.d.ts.map +1 -0
- package/dist/tools/prompting_guide.d.ts +4 -0
- package/dist/tools/prompting_guide.d.ts.map +1 -0
- package/dist/tools/research_run.d.ts +4 -0
- package/dist/tools/research_run.d.ts.map +1 -0
- package/dist/tools/response.d.ts +16 -0
- package/dist/tools/response.d.ts.map +1 -0
- package/dist/tools/run.d.ts +4 -0
- package/dist/tools/run.d.ts.map +1 -0
- package/dist/tools/screenshot.d.ts +4 -0
- package/dist/tools/screenshot.d.ts.map +1 -0
- package/dist/tools/scroll.d.ts +4 -0
- package/dist/tools/scroll.d.ts.map +1 -0
- package/dist/tools/scroll_into_view.d.ts +4 -0
- package/dist/tools/scroll_into_view.d.ts.map +1 -0
- package/dist/tools/select.d.ts +4 -0
- package/dist/tools/select.d.ts.map +1 -0
- package/dist/tools/shopping_run.d.ts +4 -0
- package/dist/tools/shopping_run.d.ts.map +1 -0
- package/dist/tools/skill_list.d.ts +4 -0
- package/dist/tools/skill_list.d.ts.map +1 -0
- package/dist/tools/skill_load.d.ts +4 -0
- package/dist/tools/skill_load.d.ts.map +1 -0
- package/dist/tools/snapshot.d.ts +4 -0
- package/dist/tools/snapshot.d.ts.map +1 -0
- package/dist/tools/status.d.ts +4 -0
- package/dist/tools/status.d.ts.map +1 -0
- package/dist/tools/target_close.d.ts +4 -0
- package/dist/tools/target_close.d.ts.map +1 -0
- package/dist/tools/target_new.d.ts +4 -0
- package/dist/tools/target_new.d.ts.map +1 -0
- package/dist/tools/target_use.d.ts +4 -0
- package/dist/tools/target_use.d.ts.map +1 -0
- package/dist/tools/targets_list.d.ts +4 -0
- package/dist/tools/targets_list.d.ts.map +1 -0
- package/dist/tools/type.d.ts +4 -0
- package/dist/tools/type.d.ts.map +1 -0
- package/dist/tools/uncheck.d.ts +4 -0
- package/dist/tools/uncheck.d.ts.map +1 -0
- package/dist/tools/wait.d.ts +4 -0
- package/dist/tools/wait.d.ts.map +1 -0
- package/dist/tools/workflow-runtime.d.ts +4 -0
- package/dist/tools/workflow-runtime.d.ts.map +1 -0
- package/dist/utils/crypto.d.ts +2 -0
- package/dist/utils/crypto.d.ts.map +1 -0
- package/dist/utils/endpoint-validation.d.ts +2 -0
- package/dist/utils/endpoint-validation.d.ts.map +1 -0
- package/dist/utils/fs.d.ts +5 -0
- package/dist/utils/fs.d.ts.map +1 -0
- package/dist/utils/hub-enabled.d.ts +3 -0
- package/dist/utils/hub-enabled.d.ts.map +1 -0
- package/extension/dist/background.js +10 -4
- package/extension/dist/ops/ops-runtime.js +506 -4
- package/extension/dist/ops/ops-session-store.js +16 -2
- package/extension/dist/ops/parallelism-governor.js +117 -0
- package/extension/dist/ops/snapshot-shared.js +21 -5
- package/extension/dist/services/CDPRouter.js +70 -5
- package/extension/dist/services/ConnectionManager.js +5 -3
- package/extension/icons/icon128.png +0 -0
- package/extension/icons/icon16.png +0 -0
- package/extension/icons/icon32.png +0 -0
- package/extension/icons/icon48.png +0 -0
- package/extension/manifest.json +1 -1
- package/package.json +25 -16
- package/scripts/native/host.cjs +230 -0
- package/scripts/native/install.ps1 +73 -0
- package/scripts/native/install.sh +66 -0
- package/scripts/native/uninstall.ps1 +25 -0
- package/scripts/native/uninstall.sh +26 -0
- package/skills/AGENTS.md +17 -8
- package/skills/opendevbrowser-best-practices/SKILL.md +178 -72
- package/skills/opendevbrowser-best-practices/artifacts/browser-agent-known-issues-matrix.md +44 -0
- package/skills/opendevbrowser-best-practices/artifacts/command-channel-reference.md +95 -0
- package/skills/opendevbrowser-best-practices/artifacts/debug-trace-playbook.md +36 -0
- package/skills/opendevbrowser-best-practices/artifacts/fingerprint-tiers.md +36 -0
- package/skills/opendevbrowser-best-practices/artifacts/macro-workflows.md +43 -0
- package/skills/opendevbrowser-best-practices/artifacts/parity-gates.md +36 -0
- package/skills/opendevbrowser-best-practices/artifacts/provider-workflows.md +89 -0
- package/skills/opendevbrowser-best-practices/assets/templates/cdp-forward-envelope.json +11 -0
- package/skills/opendevbrowser-best-practices/assets/templates/mode-flag-matrix.json +56 -0
- package/skills/opendevbrowser-best-practices/assets/templates/ops-request-envelope.json +9 -0
- package/skills/opendevbrowser-best-practices/assets/templates/robustness-checklist.json +79 -0
- package/skills/opendevbrowser-best-practices/assets/templates/surface-audit-checklist.json +24 -0
- package/skills/opendevbrowser-best-practices/scripts/odb-workflow.sh +144 -0
- package/skills/opendevbrowser-best-practices/scripts/run-robustness-audit.sh +83 -0
- package/skills/opendevbrowser-best-practices/scripts/validate-skill-assets.sh +93 -0
- package/skills/opendevbrowser-continuity-ledger/SKILL.md +10 -0
- package/skills/opendevbrowser-data-extraction/SKILL.md +126 -0
- package/skills/opendevbrowser-data-extraction/artifacts/extraction-workflows.md +31 -0
- package/skills/opendevbrowser-data-extraction/assets/templates/compliance-checklist.md +7 -0
- package/skills/opendevbrowser-data-extraction/assets/templates/extraction-schema.json +17 -0
- package/skills/opendevbrowser-data-extraction/assets/templates/pagination-state.json +11 -0
- package/skills/opendevbrowser-data-extraction/assets/templates/quality-gates.json +10 -0
- package/skills/opendevbrowser-data-extraction/examples/sample-schema.json +19 -0
- package/skills/opendevbrowser-data-extraction/scripts/run-extraction-workflow.sh +83 -0
- package/skills/opendevbrowser-data-extraction/scripts/validate-skill-assets.sh +49 -0
- package/skills/opendevbrowser-form-testing/SKILL.md +143 -0
- package/skills/opendevbrowser-form-testing/artifacts/form-workflows.md +37 -0
- package/skills/opendevbrowser-form-testing/assets/templates/a11y-assertions.md +7 -0
- package/skills/opendevbrowser-form-testing/assets/templates/challenge-decision-tree.json +16 -0
- package/skills/opendevbrowser-form-testing/assets/templates/multi-step-state.json +11 -0
- package/skills/opendevbrowser-form-testing/assets/templates/validation-matrix.json +24 -0
- package/skills/opendevbrowser-form-testing/examples/sample-validation-matrix.json +29 -0
- package/skills/opendevbrowser-form-testing/scripts/run-form-workflow.sh +82 -0
- package/skills/opendevbrowser-form-testing/scripts/validate-skill-assets.sh +49 -0
- package/skills/opendevbrowser-login-automation/SKILL.md +159 -0
- package/skills/opendevbrowser-login-automation/artifacts/login-workflows.md +39 -0
- package/skills/opendevbrowser-login-automation/assets/templates/auth-signals.json +21 -0
- package/skills/opendevbrowser-login-automation/assets/templates/challenge-checkpoint.md +10 -0
- package/skills/opendevbrowser-login-automation/assets/templates/login-scenario-matrix.json +26 -0
- package/skills/opendevbrowser-login-automation/examples/sample-auth-signals.json +14 -0
- package/skills/opendevbrowser-login-automation/scripts/record-auth-signals.sh +18 -0
- package/skills/opendevbrowser-login-automation/scripts/run-login-workflow.sh +99 -0
- package/skills/opendevbrowser-login-automation/scripts/validate-skill-assets.sh +50 -0
- package/skills/opendevbrowser-product-presentation-asset/SKILL.md +98 -0
- package/skills/opendevbrowser-product-presentation-asset/artifacts/asset-pack-assembly.md +23 -0
- package/skills/opendevbrowser-product-presentation-asset/artifacts/ugc-creative-guide.md +21 -0
- package/skills/opendevbrowser-product-presentation-asset/assets/templates/claims-evidence-map.md +5 -0
- package/skills/opendevbrowser-product-presentation-asset/assets/templates/copy.md +5 -0
- package/skills/opendevbrowser-product-presentation-asset/assets/templates/features.md +4 -0
- package/skills/opendevbrowser-product-presentation-asset/assets/templates/manifest.schema.json +14 -0
- package/skills/opendevbrowser-product-presentation-asset/assets/templates/shot-list.md +7 -0
- package/skills/opendevbrowser-product-presentation-asset/assets/templates/ugc-concepts.md +17 -0
- package/skills/opendevbrowser-product-presentation-asset/assets/templates/user-actions.md +7 -0
- package/skills/opendevbrowser-product-presentation-asset/assets/templates/video-assembly.md +18 -0
- package/skills/opendevbrowser-product-presentation-asset/examples/sample-input.json +6 -0
- package/skills/opendevbrowser-product-presentation-asset/examples/sample-manifest.json +18 -0
- package/skills/opendevbrowser-product-presentation-asset/scripts/capture-screenshots.sh +9 -0
- package/skills/opendevbrowser-product-presentation-asset/scripts/collect-product.sh +14 -0
- package/skills/opendevbrowser-product-presentation-asset/scripts/download-images.sh +9 -0
- package/skills/opendevbrowser-product-presentation-asset/scripts/render-video-brief.sh +96 -0
- package/skills/opendevbrowser-product-presentation-asset/scripts/validate-skill-assets.sh +56 -0
- package/skills/opendevbrowser-product-presentation-asset/scripts/write-manifest.sh +43 -0
- package/skills/opendevbrowser-research/SKILL.md +73 -0
- package/skills/opendevbrowser-research/artifacts/research-workflows.md +29 -0
- package/skills/opendevbrowser-research/assets/templates/compact.md +7 -0
- package/skills/opendevbrowser-research/assets/templates/context.json +18 -0
- package/skills/opendevbrowser-research/assets/templates/report.md +9 -0
- package/skills/opendevbrowser-research/examples/sample-input.json +6 -0
- package/skills/opendevbrowser-research/examples/sample-output.md +4 -0
- package/skills/opendevbrowser-research/scripts/render-output.sh +12 -0
- package/skills/opendevbrowser-research/scripts/run-research.sh +23 -0
- package/skills/opendevbrowser-research/scripts/validate-skill-assets.sh +48 -0
- package/skills/opendevbrowser-research/scripts/write-artifacts.sh +29 -0
- package/skills/opendevbrowser-shopping/SKILL.md +118 -0
- package/skills/opendevbrowser-shopping/artifacts/deal-hunting-workflows.md +37 -0
- package/skills/opendevbrowser-shopping/assets/templates/deal-thresholds.json +8 -0
- package/skills/opendevbrowser-shopping/assets/templates/deals-context.json +9 -0
- package/skills/opendevbrowser-shopping/assets/templates/deals-table.md +4 -0
- package/skills/opendevbrowser-shopping/assets/templates/market-analysis.json +30 -0
- package/skills/opendevbrowser-shopping/examples/sample-deals.md +4 -0
- package/skills/opendevbrowser-shopping/examples/sample-query.json +5 -0
- package/skills/opendevbrowser-shopping/scripts/analyze-market.sh +307 -0
- package/skills/opendevbrowser-shopping/scripts/normalize-offers.sh +28 -0
- package/skills/opendevbrowser-shopping/scripts/render-deals.sh +13 -0
- package/skills/opendevbrowser-shopping/scripts/run-deal-hunt.sh +32 -0
- package/skills/opendevbrowser-shopping/scripts/run-shopping.sh +19 -0
- package/skills/opendevbrowser-shopping/scripts/validate-skill-assets.sh +53 -0
- package/dist/chunk-JVBMT2O5.js +0 -7173
- package/dist/chunk-JVBMT2O5.js.map +0 -1
- package/skills/data-extraction/SKILL.md +0 -128
- package/skills/form-testing/SKILL.md +0 -106
- package/skills/login-automation/SKILL.md +0 -108
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { DEFAULT_OPS_PARALLELISM_POLICY, createOpsGovernorState } from "./parallelism-governor.js";
|
|
1
2
|
export class OpsRefStore {
|
|
2
3
|
refsByTarget = new Map();
|
|
3
4
|
snapshotByTarget = new Map();
|
|
@@ -32,9 +33,10 @@ export class OpsRefStore {
|
|
|
32
33
|
export class OpsSessionStore {
|
|
33
34
|
sessions = new Map();
|
|
34
35
|
tabToSession = new Map();
|
|
35
|
-
createSession(ownerClientId, tabId, leaseId, info) {
|
|
36
|
+
createSession(ownerClientId, tabId, leaseId, info, options) {
|
|
36
37
|
const id = createId();
|
|
37
38
|
const targetId = `tab-${tabId}`;
|
|
39
|
+
const parallelismPolicy = options?.parallelismPolicy ?? DEFAULT_OPS_PARALLELISM_POLICY;
|
|
38
40
|
const target = {
|
|
39
41
|
targetId,
|
|
40
42
|
tabId,
|
|
@@ -60,7 +62,16 @@ export class OpsSessionStore {
|
|
|
60
62
|
networkRequests: new Map(),
|
|
61
63
|
consoleSeq: 0,
|
|
62
64
|
networkSeq: 0,
|
|
63
|
-
queue: Promise.resolve()
|
|
65
|
+
queue: Promise.resolve(),
|
|
66
|
+
targetQueues: new Map(),
|
|
67
|
+
targetQueueDepth: new Map(),
|
|
68
|
+
targetQueueOldestAt: new Map(),
|
|
69
|
+
parallelInFlight: 0,
|
|
70
|
+
pendingParallel: 0,
|
|
71
|
+
discardedSignals: 0,
|
|
72
|
+
frozenSignals: 0,
|
|
73
|
+
parallelismPolicy,
|
|
74
|
+
parallelismState: createOpsGovernorState(parallelismPolicy, "extensionOpsHeaded")
|
|
64
75
|
};
|
|
65
76
|
this.sessions.set(id, session);
|
|
66
77
|
this.tabToSession.set(tabId, id);
|
|
@@ -120,6 +131,9 @@ export class OpsSessionStore {
|
|
|
120
131
|
const [first] = session.targets.keys();
|
|
121
132
|
session.activeTargetId = first ?? "";
|
|
122
133
|
}
|
|
134
|
+
session.targetQueues.delete(targetId);
|
|
135
|
+
session.targetQueueDepth.delete(targetId);
|
|
136
|
+
session.targetQueueOldestAt.delete(targetId);
|
|
123
137
|
session.refStore.clearTarget(targetId);
|
|
124
138
|
return target;
|
|
125
139
|
}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
export const DEFAULT_OPS_PARALLELISM_POLICY = {
|
|
2
|
+
floor: 1,
|
|
3
|
+
backpressureTimeoutMs: 5000,
|
|
4
|
+
sampleIntervalMs: 2000,
|
|
5
|
+
recoveryStableWindows: 3,
|
|
6
|
+
hostFreeMemMediumPct: 25,
|
|
7
|
+
hostFreeMemHighPct: 18,
|
|
8
|
+
hostFreeMemCriticalPct: 10,
|
|
9
|
+
rssBudgetMb: 2048,
|
|
10
|
+
rssSoftPct: 65,
|
|
11
|
+
rssHighPct: 75,
|
|
12
|
+
rssCriticalPct: 85,
|
|
13
|
+
queueAgeHighMs: 2000,
|
|
14
|
+
queueAgeCriticalMs: 5000,
|
|
15
|
+
modeCaps: {
|
|
16
|
+
managedHeaded: 6,
|
|
17
|
+
managedHeadless: 8,
|
|
18
|
+
cdpConnectHeaded: 6,
|
|
19
|
+
cdpConnectHeadless: 8,
|
|
20
|
+
extensionOpsHeaded: 6,
|
|
21
|
+
extensionLegacyCdpHeaded: 1
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
const clamp = (value, floor, ceil) => {
|
|
25
|
+
if (value < floor)
|
|
26
|
+
return floor;
|
|
27
|
+
if (value > ceil)
|
|
28
|
+
return ceil;
|
|
29
|
+
return value;
|
|
30
|
+
};
|
|
31
|
+
const floorPercent = (value) => clamp(Number.isFinite(value) ? value : 0, 0, 100);
|
|
32
|
+
const classifyPressure = (policy, input) => {
|
|
33
|
+
const hostFreeMemPct = floorPercent(input.hostFreeMemPct);
|
|
34
|
+
const rssUsagePct = floorPercent(input.rssUsagePct);
|
|
35
|
+
const queueAgeMs = Math.max(0, Number.isFinite(input.queueAgeMs) ? input.queueAgeMs : 0);
|
|
36
|
+
const discardedSignals = Math.max(0, input.discardedSignals ?? 0);
|
|
37
|
+
const frozenSignals = Math.max(0, input.frozenSignals ?? 0);
|
|
38
|
+
const critical = hostFreeMemPct <= policy.hostFreeMemCriticalPct
|
|
39
|
+
|| rssUsagePct >= policy.rssCriticalPct
|
|
40
|
+
|| queueAgeMs >= policy.queueAgeCriticalMs;
|
|
41
|
+
if (critical)
|
|
42
|
+
return "critical";
|
|
43
|
+
const high = hostFreeMemPct <= policy.hostFreeMemHighPct
|
|
44
|
+
|| rssUsagePct >= policy.rssHighPct
|
|
45
|
+
|| queueAgeMs >= policy.queueAgeHighMs
|
|
46
|
+
|| discardedSignals > 0;
|
|
47
|
+
if (high)
|
|
48
|
+
return "high";
|
|
49
|
+
const medium = hostFreeMemPct <= policy.hostFreeMemMediumPct
|
|
50
|
+
|| rssUsagePct >= policy.rssSoftPct
|
|
51
|
+
|| frozenSignals > 0;
|
|
52
|
+
return medium ? "medium" : "healthy";
|
|
53
|
+
};
|
|
54
|
+
const pressurePenalty = (pressure) => {
|
|
55
|
+
switch (pressure) {
|
|
56
|
+
case "medium":
|
|
57
|
+
return 1;
|
|
58
|
+
case "high":
|
|
59
|
+
return 2;
|
|
60
|
+
case "critical":
|
|
61
|
+
return Number.MAX_SAFE_INTEGER;
|
|
62
|
+
default:
|
|
63
|
+
return 0;
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
export const resolveOpsStaticCap = (policy, modeVariant) => {
|
|
67
|
+
const cap = policy.modeCaps[modeVariant];
|
|
68
|
+
return clamp(cap, policy.floor, cap);
|
|
69
|
+
};
|
|
70
|
+
export const createOpsGovernorState = (policy, modeVariant) => {
|
|
71
|
+
const staticCap = resolveOpsStaticCap(policy, modeVariant);
|
|
72
|
+
return {
|
|
73
|
+
modeVariant,
|
|
74
|
+
staticCap,
|
|
75
|
+
effectiveCap: staticCap,
|
|
76
|
+
healthyWindows: 0,
|
|
77
|
+
lastSampleAt: 0,
|
|
78
|
+
lastPressure: "healthy"
|
|
79
|
+
};
|
|
80
|
+
};
|
|
81
|
+
export const evaluateOpsGovernor = (policy, current, input, sampledAt = Date.now()) => {
|
|
82
|
+
const normalizedQueueDepth = Math.max(0, Number.isFinite(input.queueDepth) ? input.queueDepth : 0);
|
|
83
|
+
const normalizedQueueAgeMs = Math.max(0, Number.isFinite(input.queueAgeMs) ? input.queueAgeMs : 0);
|
|
84
|
+
const pressure = classifyPressure(policy, input);
|
|
85
|
+
const basePenalty = pressurePenalty(pressure);
|
|
86
|
+
const lifecyclePenalty = Math.max(0, input.discardedSignals ?? 0) + Math.max(0, input.frozenSignals ?? 0);
|
|
87
|
+
const targetCap = pressure === "critical"
|
|
88
|
+
? policy.floor
|
|
89
|
+
: clamp(current.staticCap - basePenalty - lifecyclePenalty, policy.floor, current.staticCap);
|
|
90
|
+
let effectiveCap = current.effectiveCap;
|
|
91
|
+
let healthyWindows = pressure === "healthy" ? current.healthyWindows + 1 : 0;
|
|
92
|
+
if (targetCap < current.effectiveCap) {
|
|
93
|
+
effectiveCap = targetCap;
|
|
94
|
+
healthyWindows = 0;
|
|
95
|
+
}
|
|
96
|
+
else if (targetCap > current.effectiveCap) {
|
|
97
|
+
const windowsRequired = Math.max(1, policy.recoveryStableWindows);
|
|
98
|
+
if (healthyWindows >= windowsRequired) {
|
|
99
|
+
effectiveCap = clamp(current.effectiveCap + 1, policy.floor, targetCap);
|
|
100
|
+
healthyWindows = 0;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
return {
|
|
104
|
+
state: {
|
|
105
|
+
modeVariant: current.modeVariant,
|
|
106
|
+
staticCap: current.staticCap,
|
|
107
|
+
effectiveCap,
|
|
108
|
+
healthyWindows,
|
|
109
|
+
lastSampleAt: sampledAt,
|
|
110
|
+
lastPressure: pressure
|
|
111
|
+
},
|
|
112
|
+
pressure,
|
|
113
|
+
targetCap,
|
|
114
|
+
waitQueueDepth: normalizedQueueDepth,
|
|
115
|
+
waitQueueAgeMs: normalizedQueueAgeMs
|
|
116
|
+
};
|
|
117
|
+
};
|
|
@@ -49,13 +49,27 @@ export const selectorFunction = function () {
|
|
|
49
49
|
}
|
|
50
50
|
return String(value).replace(/([^\w-])/g, "\\$1");
|
|
51
51
|
};
|
|
52
|
+
const isUniqueSelector = (selector) => {
|
|
53
|
+
try {
|
|
54
|
+
return document.querySelectorAll(selector).length === 1;
|
|
55
|
+
}
|
|
56
|
+
catch {
|
|
57
|
+
return false;
|
|
58
|
+
}
|
|
59
|
+
};
|
|
52
60
|
const testId = this.getAttribute("data-testid");
|
|
53
61
|
if (testId) {
|
|
54
|
-
|
|
62
|
+
const selector = '[data-testid="' + escape(testId) + '"]';
|
|
63
|
+
if (isUniqueSelector(selector)) {
|
|
64
|
+
return selector;
|
|
65
|
+
}
|
|
55
66
|
}
|
|
56
67
|
const ariaLabel = this.getAttribute("aria-label");
|
|
57
68
|
if (ariaLabel && ariaLabel.length < 50) {
|
|
58
|
-
|
|
69
|
+
const selector = '[aria-label="' + escape(ariaLabel) + '"]';
|
|
70
|
+
if (isUniqueSelector(selector)) {
|
|
71
|
+
return selector;
|
|
72
|
+
}
|
|
59
73
|
}
|
|
60
74
|
const buildPathSelector = (start) => {
|
|
61
75
|
const parts = [];
|
|
@@ -63,9 +77,11 @@ export const selectorFunction = function () {
|
|
|
63
77
|
while (current && current.nodeType === Node.ELEMENT_NODE) {
|
|
64
78
|
let selector = current.nodeName.toLowerCase();
|
|
65
79
|
if (current.id) {
|
|
66
|
-
selector
|
|
67
|
-
|
|
68
|
-
|
|
80
|
+
const withId = selector + "#" + escape(current.id);
|
|
81
|
+
if (isUniqueSelector(withId)) {
|
|
82
|
+
parts.unshift(withId);
|
|
83
|
+
break;
|
|
84
|
+
}
|
|
69
85
|
}
|
|
70
86
|
const parentEl = current.parentElement;
|
|
71
87
|
if (!parentEl) {
|
|
@@ -64,14 +64,47 @@ export class CDPRouter {
|
|
|
64
64
|
}
|
|
65
65
|
await this.safeDetach(debuggee);
|
|
66
66
|
if (allowRetry && this.isStaleTabError(error)) {
|
|
67
|
+
const attemptedTabIds = new Set([tabId]);
|
|
68
|
+
let lastStaleError = error;
|
|
67
69
|
const activeTabId = await this.tabManager.getActiveTabId();
|
|
68
|
-
if (activeTabId && activeTabId
|
|
69
|
-
|
|
70
|
+
if (activeTabId && !attemptedTabIds.has(activeTabId)) {
|
|
71
|
+
attemptedTabIds.add(activeTabId);
|
|
72
|
+
try {
|
|
73
|
+
return await this.attachInternal(activeTabId, false);
|
|
74
|
+
}
|
|
75
|
+
catch (candidateError) {
|
|
76
|
+
if (!this.isStaleTabError(candidateError)) {
|
|
77
|
+
throw candidateError;
|
|
78
|
+
}
|
|
79
|
+
lastStaleError = candidateError;
|
|
80
|
+
}
|
|
70
81
|
}
|
|
71
82
|
const fallbackTabId = await this.tabManager.getFirstHttpTabId();
|
|
72
|
-
if (fallbackTabId && fallbackTabId
|
|
73
|
-
|
|
83
|
+
if (fallbackTabId && !attemptedTabIds.has(fallbackTabId)) {
|
|
84
|
+
attemptedTabIds.add(fallbackTabId);
|
|
85
|
+
try {
|
|
86
|
+
return await this.attachInternal(fallbackTabId, false);
|
|
87
|
+
}
|
|
88
|
+
catch (candidateError) {
|
|
89
|
+
if (!this.isStaleTabError(candidateError)) {
|
|
90
|
+
throw candidateError;
|
|
91
|
+
}
|
|
92
|
+
lastStaleError = candidateError;
|
|
93
|
+
}
|
|
74
94
|
}
|
|
95
|
+
try {
|
|
96
|
+
const createdTab = await this.tabManager.createTab("about:blank", true);
|
|
97
|
+
if (typeof createdTab.id === "number" && !attemptedTabIds.has(createdTab.id)) {
|
|
98
|
+
return await this.attachInternal(createdTab.id, false);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
catch (candidateError) {
|
|
102
|
+
if (!this.isStaleTabError(candidateError)) {
|
|
103
|
+
throw candidateError;
|
|
104
|
+
}
|
|
105
|
+
lastStaleError = candidateError;
|
|
106
|
+
}
|
|
107
|
+
throw lastStaleError;
|
|
75
108
|
}
|
|
76
109
|
throw error;
|
|
77
110
|
}
|
|
@@ -503,7 +536,23 @@ export class CDPRouter {
|
|
|
503
536
|
return sessionId;
|
|
504
537
|
}
|
|
505
538
|
async sendCommand(debuggee, method, params) {
|
|
506
|
-
|
|
539
|
+
try {
|
|
540
|
+
return await this.sendCommandOnce(debuggee, method, params);
|
|
541
|
+
}
|
|
542
|
+
catch (error) {
|
|
543
|
+
const hasChildSession = typeof debuggee.sessionId === "string";
|
|
544
|
+
if (!this.isStaleTabError(error) || hasChildSession) {
|
|
545
|
+
throw error;
|
|
546
|
+
}
|
|
547
|
+
const recovered = await this.recoverFromStaleTab(debuggee);
|
|
548
|
+
if (!recovered) {
|
|
549
|
+
throw error;
|
|
550
|
+
}
|
|
551
|
+
return await this.sendCommandOnce(recovered, method, params);
|
|
552
|
+
}
|
|
553
|
+
}
|
|
554
|
+
async sendCommandOnce(debuggee, method, params) {
|
|
555
|
+
return await new Promise((resolve, reject) => {
|
|
507
556
|
chrome.debugger.sendCommand(debuggee, method, params, (result) => {
|
|
508
557
|
const lastError = chrome.runtime.lastError;
|
|
509
558
|
if (lastError) {
|
|
@@ -514,6 +563,22 @@ export class CDPRouter {
|
|
|
514
563
|
});
|
|
515
564
|
});
|
|
516
565
|
}
|
|
566
|
+
async recoverFromStaleTab(debuggee) {
|
|
567
|
+
const staleTabId = typeof debuggee.tabId === "number" ? debuggee.tabId : null;
|
|
568
|
+
if (staleTabId === null) {
|
|
569
|
+
return null;
|
|
570
|
+
}
|
|
571
|
+
this.debuggees.delete(staleTabId);
|
|
572
|
+
this.detachTabState(staleTabId);
|
|
573
|
+
await this.safeDetach({ tabId: staleTabId });
|
|
574
|
+
try {
|
|
575
|
+
await this.attachInternal(staleTabId, true);
|
|
576
|
+
}
|
|
577
|
+
catch {
|
|
578
|
+
return null;
|
|
579
|
+
}
|
|
580
|
+
return this.getPrimaryDebuggee();
|
|
581
|
+
}
|
|
517
582
|
isStaleTabError(error) {
|
|
518
583
|
const message = error instanceof Error ? error.message : String(error);
|
|
519
584
|
return message.includes("No tab with given id");
|
|
@@ -29,6 +29,8 @@ const logInfo = (message) => {
|
|
|
29
29
|
const logWarn = (message) => {
|
|
30
30
|
console.warn(`[opendevbrowser] ${message}`);
|
|
31
31
|
};
|
|
32
|
+
const RECONNECT_INITIAL_DELAY_MS = 12_000;
|
|
33
|
+
const RECONNECT_MAX_DELAY_MS = 30_000;
|
|
32
34
|
export class ConnectionManager {
|
|
33
35
|
status = "disconnected";
|
|
34
36
|
lastError = null;
|
|
@@ -41,7 +43,7 @@ export class ConnectionManager {
|
|
|
41
43
|
shouldReconnect = false;
|
|
42
44
|
reconnectTimer = null;
|
|
43
45
|
reconnectAttempts = 0;
|
|
44
|
-
reconnectDelayMs =
|
|
46
|
+
reconnectDelayMs = RECONNECT_INITIAL_DELAY_MS;
|
|
45
47
|
pairingToken = DEFAULT_PAIRING_TOKEN;
|
|
46
48
|
pairingEnabled = DEFAULT_PAIRING_ENABLED;
|
|
47
49
|
relayPort = DEFAULT_RELAY_PORT;
|
|
@@ -49,7 +51,7 @@ export class ConnectionManager {
|
|
|
49
51
|
relayEpoch = null;
|
|
50
52
|
relayConfirmedPort = null;
|
|
51
53
|
relayNotice = null;
|
|
52
|
-
maxReconnectDelayMs =
|
|
54
|
+
maxReconnectDelayMs = RECONNECT_MAX_DELAY_MS;
|
|
53
55
|
connectPromise = null;
|
|
54
56
|
annotationHandler = null;
|
|
55
57
|
opsHandler = null;
|
|
@@ -405,7 +407,7 @@ export class ConnectionManager {
|
|
|
405
407
|
this.setStatus("connected");
|
|
406
408
|
this.startHeartbeat();
|
|
407
409
|
this.reconnectAttempts = 0;
|
|
408
|
-
this.reconnectDelayMs =
|
|
410
|
+
this.reconnectDelayMs = RECONNECT_INITIAL_DELAY_MS;
|
|
409
411
|
}
|
|
410
412
|
catch (error) {
|
|
411
413
|
const detail = error instanceof Error ? error.message : "Unknown error";
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
package/extension/manifest.json
CHANGED
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "opendevbrowser",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.16",
|
|
4
4
|
"description": "OpenCode plugin for browser automation via CDP with snapshot-refs-actions workflow",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -11,6 +11,7 @@
|
|
|
11
11
|
"files": [
|
|
12
12
|
"dist",
|
|
13
13
|
"skills",
|
|
14
|
+
"scripts/native",
|
|
14
15
|
"extension/manifest.json",
|
|
15
16
|
"extension/popup.html",
|
|
16
17
|
"extension/dist",
|
|
@@ -36,36 +37,44 @@
|
|
|
36
37
|
"node": ">=18"
|
|
37
38
|
},
|
|
38
39
|
"scripts": {
|
|
39
|
-
"build": "tsup src/index.ts src/cli/index.ts --format esm --
|
|
40
|
+
"build": "tsup src/index.ts src/cli/index.ts --format esm --clean --sourcemap && tsc --emitDeclarationOnly --declaration --declarationMap -p tsconfig.json && node --input-type=module -e \"import { copyFileSync, existsSync } from 'node:fs';\nimport { resolve } from 'node:path';\nconst dist = resolve('dist');\nconst pairs = [\n ['index.js', 'opendevbrowser.js'],\n ['index.js.map', 'opendevbrowser.js.map'],\n ['index.d.ts', 'opendevbrowser.d.ts'],\n ['index.d.ts.map', 'opendevbrowser.d.ts.map'],\n];\nfor (const [src, dst] of pairs) {\n const from = resolve(dist, src);\n const to = resolve(dist, dst);\n if (existsSync(from)) copyFileSync(from, to);\n}\"",
|
|
40
41
|
"dev": "tsup src/index.ts src/cli/index.ts --format esm --dts --watch",
|
|
41
|
-
"lint": "eslint \"
|
|
42
|
+
"lint": "eslint \"src/**/*.ts\" \"tests/**/*.ts\"",
|
|
43
|
+
"typecheck": "tsc --noEmit -p tsconfig.json",
|
|
42
44
|
"test": "vitest run --coverage",
|
|
45
|
+
"test:release-gate": "node scripts/release-gate-test-groups.mjs",
|
|
46
|
+
"test:release-gate:g1": "node scripts/release-gate-test-groups.mjs --group 1",
|
|
47
|
+
"test:release-gate:g2": "node scripts/release-gate-test-groups.mjs --group 2",
|
|
48
|
+
"test:release-gate:g3": "node scripts/release-gate-test-groups.mjs --group 3",
|
|
49
|
+
"test:release-gate:g4": "node scripts/release-gate-test-groups.mjs --group 4",
|
|
50
|
+
"test:release-gate:g5": "node scripts/release-gate-test-groups.mjs --group 5",
|
|
43
51
|
"extension:sync": "node scripts/sync-extension-version.mjs",
|
|
44
52
|
"extension:build": "npm run extension:sync && tsc -p extension/tsconfig.json && node scripts/copy-extension-assets.mjs",
|
|
45
53
|
"extension:pack": "cd extension && zip -r ../opendevbrowser-extension.zip manifest.json popup.html dist/ icons/",
|
|
54
|
+
"extension:store": "node scripts/chrome-store-publish.mjs",
|
|
46
55
|
"version:check": "node scripts/verify-versions.mjs",
|
|
47
56
|
"prepack": "npm run version:check && npm run build && npm run extension:build"
|
|
48
57
|
},
|
|
49
58
|
"dependencies": {
|
|
50
|
-
"@opencode-ai/plugin": "^1.
|
|
51
|
-
"@puppeteer/browsers": "^2.
|
|
59
|
+
"@opencode-ai/plugin": "^1.2.11",
|
|
60
|
+
"@puppeteer/browsers": "^2.13.0",
|
|
52
61
|
"async-mutex": "^0.5.0",
|
|
53
62
|
"jsonc-parser": "^3.2.0",
|
|
54
|
-
"playwright-core": "^1.
|
|
55
|
-
"ws": "^8.
|
|
56
|
-
"zod": "^3.
|
|
63
|
+
"playwright-core": "^1.58.2",
|
|
64
|
+
"ws": "^8.19.0",
|
|
65
|
+
"zod": "^3.25.76"
|
|
57
66
|
},
|
|
58
67
|
"devDependencies": {
|
|
59
|
-
"@types/chrome": "^0.
|
|
60
|
-
"@types/node": "^20.19.
|
|
68
|
+
"@types/chrome": "^0.1.37",
|
|
69
|
+
"@types/node": "^20.19.35",
|
|
61
70
|
"@types/ws": "^8.18.1",
|
|
62
|
-
"@typescript-eslint/eslint-plugin": "^8.
|
|
63
|
-
"@typescript-eslint/parser": "^8.
|
|
64
|
-
"@vitest/coverage-v8": "^4.0.
|
|
65
|
-
"eslint": "^9.
|
|
66
|
-
"happy-dom": "^20.0
|
|
71
|
+
"@typescript-eslint/eslint-plugin": "^8.56.1",
|
|
72
|
+
"@typescript-eslint/parser": "^8.56.1",
|
|
73
|
+
"@vitest/coverage-v8": "^4.0.18",
|
|
74
|
+
"eslint": "^9.39.3",
|
|
75
|
+
"happy-dom": "^20.7.0",
|
|
67
76
|
"tsup": "^8.5.1",
|
|
68
77
|
"typescript": "^5.9.3",
|
|
69
|
-
"vitest": "^4.0.
|
|
78
|
+
"vitest": "^4.0.18"
|
|
70
79
|
}
|
|
71
80
|
}
|
|
@@ -0,0 +1,230 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
"use strict";
|
|
3
|
+
|
|
4
|
+
const fs = require("fs");
|
|
5
|
+
const path = require("path");
|
|
6
|
+
const net = require("net");
|
|
7
|
+
const crypto = require("crypto");
|
|
8
|
+
const os = require("os");
|
|
9
|
+
|
|
10
|
+
const IS_WINDOWS = process.platform === "win32";
|
|
11
|
+
const DEFAULT_BASE_DIR = IS_WINDOWS ? os.tmpdir() : "/tmp";
|
|
12
|
+
const BASE_DIR = process.env.OPD_NATIVE_BASE_DIR || DEFAULT_BASE_DIR;
|
|
13
|
+
const MAX_MESSAGE_BYTES = 8 * 1024 * 1024;
|
|
14
|
+
const LOG_ROTATE_BYTES = 5 * 1024 * 1024;
|
|
15
|
+
|
|
16
|
+
const buildPaths = (baseDir, pid) => {
|
|
17
|
+
const socketPath = IS_WINDOWS
|
|
18
|
+
? `\\\\.\\pipe\\opendevbrowser-${pid}.sock`
|
|
19
|
+
: path.join(baseDir, `opendevbrowser-${pid}.sock`);
|
|
20
|
+
return {
|
|
21
|
+
tokenPath: path.join(baseDir, `opendevbrowser-${pid}.token`),
|
|
22
|
+
socketPath,
|
|
23
|
+
logPath: path.join(baseDir, "opendevbrowser-native.log")
|
|
24
|
+
};
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
const redactLogLine = (line, token) => {
|
|
28
|
+
let output = line;
|
|
29
|
+
if (token) {
|
|
30
|
+
output = output.split(token).join("[redacted]");
|
|
31
|
+
}
|
|
32
|
+
output = output.replace(/Authorization\\s*[:=]\\s*Bearer\\s+[^\\s"\']+/gi, "Authorization: Bearer [redacted]");
|
|
33
|
+
output = output.replace(/\"token\"\\s*:\\s*\"[^\"]+\"/gi, "\"token\":\"[redacted]\"");
|
|
34
|
+
return output;
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
const rotateLogIfNeeded = (logPath) => {
|
|
38
|
+
try {
|
|
39
|
+
const stat = fs.statSync(logPath);
|
|
40
|
+
if (stat.size <= LOG_ROTATE_BYTES) return false;
|
|
41
|
+
const rotated = `${logPath}.1`;
|
|
42
|
+
fs.renameSync(logPath, rotated);
|
|
43
|
+
return true;
|
|
44
|
+
} catch {
|
|
45
|
+
return false;
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
const writeLog = (logPath, message, token) => {
|
|
50
|
+
rotateLogIfNeeded(logPath);
|
|
51
|
+
const line = redactLogLine(message, token);
|
|
52
|
+
fs.appendFileSync(logPath, `${line}\\n`, { encoding: "utf8" });
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
const writeTokenFile = (tokenPath) => {
|
|
56
|
+
const token = crypto.randomBytes(32).toString("hex");
|
|
57
|
+
fs.writeFileSync(tokenPath, token, { encoding: "utf8", mode: 0o600 });
|
|
58
|
+
return token;
|
|
59
|
+
};
|
|
60
|
+
|
|
61
|
+
const parseNativeMessages = (buffer) => {
|
|
62
|
+
const messages = [];
|
|
63
|
+
let offset = 0;
|
|
64
|
+
while (buffer.length >= offset + 4) {
|
|
65
|
+
const size = buffer.readUInt32LE(offset);
|
|
66
|
+
if (size > MAX_MESSAGE_BYTES) {
|
|
67
|
+
return { error: new Error("Message exceeds size limit"), remainder: Buffer.alloc(0) };
|
|
68
|
+
}
|
|
69
|
+
if (buffer.length < offset + 4 + size) {
|
|
70
|
+
break;
|
|
71
|
+
}
|
|
72
|
+
const slice = buffer.slice(offset + 4, offset + 4 + size);
|
|
73
|
+
offset += 4 + size;
|
|
74
|
+
try {
|
|
75
|
+
messages.push(JSON.parse(slice.toString("utf8")));
|
|
76
|
+
} catch {
|
|
77
|
+
// Ignore invalid JSON.
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
return { messages, remainder: buffer.slice(offset) };
|
|
81
|
+
};
|
|
82
|
+
|
|
83
|
+
const sendNativeMessage = (payload) => {
|
|
84
|
+
const json = JSON.stringify(payload);
|
|
85
|
+
const data = Buffer.from(json, "utf8");
|
|
86
|
+
if (data.length > MAX_MESSAGE_BYTES) {
|
|
87
|
+
return false;
|
|
88
|
+
}
|
|
89
|
+
const header = Buffer.alloc(4);
|
|
90
|
+
header.writeUInt32LE(data.length, 0);
|
|
91
|
+
process.stdout.write(Buffer.concat([header, data]));
|
|
92
|
+
return true;
|
|
93
|
+
};
|
|
94
|
+
|
|
95
|
+
const runHost = () => {
|
|
96
|
+
fs.mkdirSync(BASE_DIR, { recursive: true });
|
|
97
|
+
const { tokenPath, socketPath, logPath } = buildPaths(BASE_DIR, process.pid);
|
|
98
|
+
const token = writeTokenFile(tokenPath);
|
|
99
|
+
|
|
100
|
+
let socketClient = null;
|
|
101
|
+
let socketAuthorized = false;
|
|
102
|
+
let socketBuffer = "";
|
|
103
|
+
|
|
104
|
+
const cleanup = () => {
|
|
105
|
+
try {
|
|
106
|
+
if (socketClient) {
|
|
107
|
+
socketClient.destroy();
|
|
108
|
+
}
|
|
109
|
+
} catch {}
|
|
110
|
+
if (!IS_WINDOWS) {
|
|
111
|
+
try {
|
|
112
|
+
if (fs.existsSync(socketPath)) {
|
|
113
|
+
fs.unlinkSync(socketPath);
|
|
114
|
+
}
|
|
115
|
+
} catch {}
|
|
116
|
+
}
|
|
117
|
+
try {
|
|
118
|
+
if (fs.existsSync(tokenPath)) {
|
|
119
|
+
fs.unlinkSync(tokenPath);
|
|
120
|
+
}
|
|
121
|
+
} catch {}
|
|
122
|
+
};
|
|
123
|
+
|
|
124
|
+
process.on("SIGINT", () => {
|
|
125
|
+
cleanup();
|
|
126
|
+
process.exit(0);
|
|
127
|
+
});
|
|
128
|
+
process.on("SIGTERM", () => {
|
|
129
|
+
cleanup();
|
|
130
|
+
process.exit(0);
|
|
131
|
+
});
|
|
132
|
+
process.on("exit", () => {
|
|
133
|
+
cleanup();
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
const server = net.createServer((socket) => {
|
|
137
|
+
if (socketClient) {
|
|
138
|
+
socketClient.destroy();
|
|
139
|
+
}
|
|
140
|
+
socketClient = socket;
|
|
141
|
+
socketAuthorized = false;
|
|
142
|
+
socketBuffer = "";
|
|
143
|
+
socket.setEncoding("utf8");
|
|
144
|
+
socket.on("data", (chunk) => {
|
|
145
|
+
socketBuffer += chunk;
|
|
146
|
+
const lines = socketBuffer.split("\\n");
|
|
147
|
+
socketBuffer = lines.pop() ?? "";
|
|
148
|
+
for (const line of lines) {
|
|
149
|
+
const trimmed = line.trim();
|
|
150
|
+
if (!trimmed) continue;
|
|
151
|
+
let message = null;
|
|
152
|
+
try {
|
|
153
|
+
message = JSON.parse(trimmed);
|
|
154
|
+
} catch {
|
|
155
|
+
socket.write(JSON.stringify({ type: "error", code: "invalid_json", message: "Invalid JSON" }) + "\\n");
|
|
156
|
+
continue;
|
|
157
|
+
}
|
|
158
|
+
if (!socketAuthorized) {
|
|
159
|
+
if (message?.type === "auth" && message?.token === token) {
|
|
160
|
+
socketAuthorized = true;
|
|
161
|
+
socket.write(JSON.stringify({ type: "auth_ok" }) + "\\n");
|
|
162
|
+
continue;
|
|
163
|
+
}
|
|
164
|
+
socket.write(JSON.stringify({ type: "error", code: "unauthorized", message: "Unauthorized" }) + "\\n");
|
|
165
|
+
socket.destroy();
|
|
166
|
+
return;
|
|
167
|
+
}
|
|
168
|
+
const encoded = Buffer.from(JSON.stringify(message), "utf8");
|
|
169
|
+
if (encoded.length > MAX_MESSAGE_BYTES) {
|
|
170
|
+
socket.write(JSON.stringify({ type: "error", code: "host_message_too_large", message: "Message too large" }) + "\\n");
|
|
171
|
+
continue;
|
|
172
|
+
}
|
|
173
|
+
sendNativeMessage(message);
|
|
174
|
+
}
|
|
175
|
+
});
|
|
176
|
+
socket.on("error", () => {});
|
|
177
|
+
socket.on("close", () => {
|
|
178
|
+
if (socketClient === socket) {
|
|
179
|
+
socketClient = null;
|
|
180
|
+
socketAuthorized = false;
|
|
181
|
+
}
|
|
182
|
+
});
|
|
183
|
+
});
|
|
184
|
+
|
|
185
|
+
server.listen(socketPath, () => {
|
|
186
|
+
if (!IS_WINDOWS) {
|
|
187
|
+
try {
|
|
188
|
+
fs.chmodSync(socketPath, 0o600);
|
|
189
|
+
} catch {}
|
|
190
|
+
}
|
|
191
|
+
writeLog(logPath, "Native host ready", token);
|
|
192
|
+
});
|
|
193
|
+
|
|
194
|
+
let nativeBuffer = Buffer.alloc(0);
|
|
195
|
+
process.stdin.on("data", (chunk) => {
|
|
196
|
+
nativeBuffer = Buffer.concat([nativeBuffer, chunk]);
|
|
197
|
+
const result = parseNativeMessages(nativeBuffer);
|
|
198
|
+
if (result.error) {
|
|
199
|
+
sendNativeMessage({ type: "error", code: "host_message_too_large", message: result.error.message });
|
|
200
|
+
nativeBuffer = Buffer.alloc(0);
|
|
201
|
+
return;
|
|
202
|
+
}
|
|
203
|
+
nativeBuffer = result.remainder;
|
|
204
|
+
for (const message of result.messages ?? []) {
|
|
205
|
+
if (message?.type === "ping" && typeof message.id === "string") {
|
|
206
|
+
sendNativeMessage({ type: "pong", id: message.id });
|
|
207
|
+
continue;
|
|
208
|
+
}
|
|
209
|
+
if (socketClient && socketAuthorized) {
|
|
210
|
+
const line = JSON.stringify(message);
|
|
211
|
+
socketClient.write(line + "\\n");
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
});
|
|
215
|
+
};
|
|
216
|
+
|
|
217
|
+
if (require.main === module) {
|
|
218
|
+
runHost();
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
module.exports = {
|
|
222
|
+
runHost,
|
|
223
|
+
__test__: {
|
|
224
|
+
buildPaths,
|
|
225
|
+
redactLogLine,
|
|
226
|
+
rotateLogIfNeeded,
|
|
227
|
+
writeTokenFile,
|
|
228
|
+
parseNativeMessages
|
|
229
|
+
}
|
|
230
|
+
};
|