@sylix/coworker 1.4.2 → 1.5.2
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/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +86 -18
- package/dist/cli/index.js.map +1 -1
- package/dist/commands/slash/branch.d.ts +3 -0
- package/dist/commands/slash/branch.d.ts.map +1 -0
- package/dist/commands/slash/branch.js +45 -0
- package/dist/commands/slash/branch.js.map +1 -0
- package/dist/commands/slash/config.d.ts.map +1 -1
- package/dist/commands/slash/config.js +43 -0
- package/dist/commands/slash/config.js.map +1 -1
- package/dist/commands/slash/context.d.ts.map +1 -1
- package/dist/commands/slash/context.js +71 -47
- package/dist/commands/slash/context.js.map +1 -1
- package/dist/commands/slash/core.d.ts.map +1 -1
- package/dist/commands/slash/core.js +67 -6
- package/dist/commands/slash/core.js.map +1 -1
- package/dist/commands/slash/files.js +16 -16
- package/dist/commands/slash/registry.d.ts.map +1 -1
- package/dist/commands/slash/registry.js +2 -0
- package/dist/commands/slash/registry.js.map +1 -1
- package/dist/core/CoWorkerAgent.d.ts +3 -21
- package/dist/core/CoWorkerAgent.d.ts.map +1 -1
- package/dist/core/CoWorkerAgent.js +154 -338
- package/dist/core/CoWorkerAgent.js.map +1 -1
- package/dist/core/ContextReader.d.ts +11 -0
- package/dist/core/ContextReader.d.ts.map +1 -0
- package/dist/core/ContextReader.js +126 -0
- package/dist/core/ContextReader.js.map +1 -0
- package/dist/review/CodeReviewEngine.d.ts +2 -2
- package/dist/review/CodeReviewEngine.js +3 -3
- package/dist/review/CodeReviewEngine.js.map +1 -1
- package/dist/services/BrowserService.d.ts +10 -0
- package/dist/services/BrowserService.d.ts.map +1 -0
- package/dist/services/BrowserService.js +81 -0
- package/dist/services/BrowserService.js.map +1 -0
- package/dist/services/browser/browser-manager-pages.test.d.ts +2 -0
- package/dist/services/browser/browser-manager-pages.test.d.ts.map +1 -0
- package/dist/services/browser/browser-manager-pages.test.js +102 -0
- package/dist/services/browser/browser-manager-pages.test.js.map +1 -0
- package/dist/services/browser/browser-manager-title-timeout.test.d.ts +2 -0
- package/dist/services/browser/browser-manager-title-timeout.test.d.ts.map +1 -0
- package/dist/services/browser/browser-manager-title-timeout.test.js +67 -0
- package/dist/services/browser/browser-manager-title-timeout.test.js.map +1 -0
- package/dist/services/browser/browser-manager.d.ts +84 -0
- package/dist/services/browser/browser-manager.d.ts.map +1 -0
- package/dist/services/browser/browser-manager.js +618 -0
- package/dist/services/browser/browser-manager.js.map +1 -0
- package/dist/services/browser/daemon.d.ts +2 -0
- package/dist/services/browser/daemon.d.ts.map +1 -0
- package/dist/services/browser/daemon.js +410 -0
- package/dist/services/browser/daemon.js.map +1 -0
- package/dist/services/browser/local-endpoint.d.ts +10 -0
- package/dist/services/browser/local-endpoint.d.ts.map +1 -0
- package/dist/services/browser/local-endpoint.js +57 -0
- package/dist/services/browser/local-endpoint.js.map +1 -0
- package/dist/services/browser/local-endpoint.test.d.ts +2 -0
- package/dist/services/browser/local-endpoint.test.d.ts.map +1 -0
- package/dist/services/browser/local-endpoint.test.js +27 -0
- package/dist/services/browser/local-endpoint.test.js.map +1 -0
- package/dist/services/browser/lock.d.ts +5 -0
- package/dist/services/browser/lock.d.ts.map +1 -0
- package/dist/services/browser/lock.js +34 -0
- package/dist/services/browser/lock.js.map +1 -0
- package/dist/services/browser/lock.test.d.ts +2 -0
- package/dist/services/browser/lock.test.d.ts.map +1 -0
- package/dist/services/browser/lock.test.js +64 -0
- package/dist/services/browser/lock.test.js.map +1 -0
- package/dist/services/browser/protocol.d.ts +194 -0
- package/dist/services/browser/protocol.d.ts.map +1 -0
- package/dist/services/browser/protocol.js +114 -0
- package/dist/services/browser/protocol.js.map +1 -0
- package/dist/services/browser/sandbox/__tests__/auto-connect.test.d.ts +2 -0
- package/dist/services/browser/sandbox/__tests__/auto-connect.test.d.ts.map +1 -0
- package/dist/services/browser/sandbox/__tests__/auto-connect.test.js +643 -0
- package/dist/services/browser/sandbox/__tests__/auto-connect.test.js.map +1 -0
- package/dist/services/browser/sandbox/__tests__/bundle-test-helpers.d.ts +2 -0
- package/dist/services/browser/sandbox/__tests__/bundle-test-helpers.d.ts.map +1 -0
- package/dist/services/browser/sandbox/__tests__/bundle-test-helpers.js +15 -0
- package/dist/services/browser/sandbox/__tests__/bundle-test-helpers.js.map +1 -0
- package/dist/services/browser/sandbox/__tests__/forked-client-bundle.test.d.ts +2 -0
- package/dist/services/browser/sandbox/__tests__/forked-client-bundle.test.d.ts.map +1 -0
- package/dist/services/browser/sandbox/__tests__/forked-client-bundle.test.js +39 -0
- package/dist/services/browser/sandbox/__tests__/forked-client-bundle.test.js.map +1 -0
- package/dist/services/browser/sandbox/__tests__/named-pages.test.d.ts +2 -0
- package/dist/services/browser/sandbox/__tests__/named-pages.test.d.ts.map +1 -0
- package/dist/services/browser/sandbox/__tests__/named-pages.test.js +179 -0
- package/dist/services/browser/sandbox/__tests__/named-pages.test.js.map +1 -0
- package/dist/services/browser/sandbox/__tests__/playwright-api.test.d.ts +2 -0
- package/dist/services/browser/sandbox/__tests__/playwright-api.test.d.ts.map +1 -0
- package/dist/services/browser/sandbox/__tests__/playwright-api.test.js +641 -0
- package/dist/services/browser/sandbox/__tests__/playwright-api.test.js.map +1 -0
- package/dist/services/browser/sandbox/__tests__/protocol-bridge.test.d.ts +2 -0
- package/dist/services/browser/sandbox/__tests__/protocol-bridge.test.d.ts.map +1 -0
- package/dist/services/browser/sandbox/__tests__/protocol-bridge.test.js +46 -0
- package/dist/services/browser/sandbox/__tests__/protocol-bridge.test.js.map +1 -0
- package/dist/services/browser/sandbox/__tests__/quickjs-host.test.d.ts +2 -0
- package/dist/services/browser/sandbox/__tests__/quickjs-host.test.d.ts.map +1 -0
- package/dist/services/browser/sandbox/__tests__/quickjs-host.test.js +125 -0
- package/dist/services/browser/sandbox/__tests__/quickjs-host.test.js.map +1 -0
- package/dist/services/browser/sandbox/__tests__/sandbox-file-io.test.d.ts +2 -0
- package/dist/services/browser/sandbox/__tests__/sandbox-file-io.test.d.ts.map +1 -0
- package/dist/services/browser/sandbox/__tests__/sandbox-file-io.test.js +207 -0
- package/dist/services/browser/sandbox/__tests__/sandbox-file-io.test.js.map +1 -0
- package/dist/services/browser/sandbox/__tests__/sandbox-integration.test.d.ts +2 -0
- package/dist/services/browser/sandbox/__tests__/sandbox-integration.test.d.ts.map +1 -0
- package/dist/services/browser/sandbox/__tests__/sandbox-integration.test.js +110 -0
- package/dist/services/browser/sandbox/__tests__/sandbox-integration.test.js.map +1 -0
- package/dist/services/browser/sandbox/__tests__/sandbox-security.test.d.ts +2 -0
- package/dist/services/browser/sandbox/__tests__/sandbox-security.test.d.ts.map +1 -0
- package/dist/services/browser/sandbox/__tests__/sandbox-security.test.js +137 -0
- package/dist/services/browser/sandbox/__tests__/sandbox-security.test.js.map +1 -0
- package/dist/services/browser/sandbox/bundle.d.ts +2 -0
- package/dist/services/browser/sandbox/bundle.d.ts.map +1 -0
- package/dist/services/browser/sandbox/bundle.js +30 -0
- package/dist/services/browser/sandbox/bundle.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/bundle-entry.d.ts +9 -0
- package/dist/services/browser/sandbox/forked-client/bundle-entry.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/bundle-entry.js +8 -0
- package/dist/services/browser/sandbox/forked-client/bundle-entry.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/quickjs-platform.d.ts +3 -0
- package/dist/services/browser/sandbox/forked-client/quickjs-platform.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/quickjs-platform.js +53 -0
- package/dist/services/browser/sandbox/forked-client/quickjs-platform.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/android.d.ts +16 -0
- package/dist/services/browser/sandbox/forked-client/src/client/android.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/android.js +33 -0
- package/dist/services/browser/sandbox/forked-client/src/client/android.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/api.d.ts +48 -0
- package/dist/services/browser/sandbox/forked-client/src/client/api.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/api.js +90 -0
- package/dist/services/browser/sandbox/forked-client/src/client/api.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/artifact.d.ts +12 -0
- package/dist/services/browser/sandbox/forked-client/src/client/artifact.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/artifact.js +33 -0
- package/dist/services/browser/sandbox/forked-client/src/client/artifact.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/browser.d.ts +71 -0
- package/dist/services/browser/sandbox/forked-client/src/client/browser.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/browser.js +177 -0
- package/dist/services/browser/sandbox/forked-client/src/client/browser.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/browserContext.d.ts +152 -0
- package/dist/services/browser/sandbox/forked-client/src/client/browserContext.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/browserContext.js +620 -0
- package/dist/services/browser/sandbox/forked-client/src/client/browserContext.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/browserType.d.ts +55 -0
- package/dist/services/browser/sandbox/forked-client/src/client/browserType.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/browserType.js +122 -0
- package/dist/services/browser/sandbox/forked-client/src/client/browserType.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/cdpSession.d.ts +26 -0
- package/dist/services/browser/sandbox/forked-client/src/client/cdpSession.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/cdpSession.js +49 -0
- package/dist/services/browser/sandbox/forked-client/src/client/cdpSession.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/channelOwner.d.ts +64 -0
- package/dist/services/browser/sandbox/forked-client/src/client/channelOwner.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/channelOwner.js +216 -0
- package/dist/services/browser/sandbox/forked-client/src/client/channelOwner.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/clientHelper.d.ts +27 -0
- package/dist/services/browser/sandbox/forked-client/src/client/clientHelper.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/clientHelper.js +55 -0
- package/dist/services/browser/sandbox/forked-client/src/client/clientHelper.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/clientInstrumentation.d.ts +69 -0
- package/dist/services/browser/sandbox/forked-client/src/client/clientInstrumentation.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/clientInstrumentation.js +48 -0
- package/dist/services/browser/sandbox/forked-client/src/client/clientInstrumentation.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/clientStackTrace.d.ts +22 -0
- package/dist/services/browser/sandbox/forked-client/src/client/clientStackTrace.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/clientStackTrace.js +67 -0
- package/dist/services/browser/sandbox/forked-client/src/client/clientStackTrace.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/clock.d.ts +31 -0
- package/dist/services/browser/sandbox/forked-client/src/client/clock.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/clock.js +62 -0
- package/dist/services/browser/sandbox/forked-client/src/client/clock.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/connect.d.ts +23 -0
- package/dist/services/browser/sandbox/forked-client/src/client/connect.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/connect.js +137 -0
- package/dist/services/browser/sandbox/forked-client/src/client/connect.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/connection.d.ts +60 -0
- package/dist/services/browser/sandbox/forked-client/src/client/connection.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/connection.js +332 -0
- package/dist/services/browser/sandbox/forked-client/src/client/connection.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/consoleMessage.d.ts +38 -0
- package/dist/services/browser/sandbox/forked-client/src/client/consoleMessage.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/consoleMessage.js +55 -0
- package/dist/services/browser/sandbox/forked-client/src/client/consoleMessage.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/coverage.d.ts +26 -0
- package/dist/services/browser/sandbox/forked-client/src/client/coverage.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/coverage.js +38 -0
- package/dist/services/browser/sandbox/forked-client/src/client/coverage.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/debugger.d.ts +42 -0
- package/dist/services/browser/sandbox/forked-client/src/client/debugger.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/debugger.js +51 -0
- package/dist/services/browser/sandbox/forked-client/src/client/debugger.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/dialog.d.ts +31 -0
- package/dist/services/browser/sandbox/forked-client/src/client/dialog.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/dialog.js +52 -0
- package/dist/services/browser/sandbox/forked-client/src/client/dialog.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/disposable.d.ts +33 -0
- package/dist/services/browser/sandbox/forked-client/src/client/disposable.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/disposable.js +70 -0
- package/dist/services/browser/sandbox/forked-client/src/client/disposable.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/download.d.ts +36 -0
- package/dist/services/browser/sandbox/forked-client/src/client/download.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/download.js +56 -0
- package/dist/services/browser/sandbox/forked-client/src/client/download.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/electron.d.ts +8 -0
- package/dist/services/browser/sandbox/forked-client/src/client/electron.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/electron.js +18 -0
- package/dist/services/browser/sandbox/forked-client/src/client/electron.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/elementHandle.d.ts +87 -0
- package/dist/services/browser/sandbox/forked-client/src/client/elementHandle.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/elementHandle.js +325 -0
- package/dist/services/browser/sandbox/forked-client/src/client/elementHandle.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/errors.d.ts +26 -0
- package/dist/services/browser/sandbox/forked-client/src/client/errors.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/errors.js +67 -0
- package/dist/services/browser/sandbox/forked-client/src/client/errors.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/eventEmitter.d.ts +61 -0
- package/dist/services/browser/sandbox/forked-client/src/client/eventEmitter.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/eventEmitter.js +348 -0
- package/dist/services/browser/sandbox/forked-client/src/client/eventEmitter.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/events.d.ts +88 -0
- package/dist/services/browser/sandbox/forked-client/src/client/events.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/events.js +96 -0
- package/dist/services/browser/sandbox/forked-client/src/client/events.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/fetch.d.ts +17 -0
- package/dist/services/browser/sandbox/forked-client/src/client/fetch.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/fetch.js +36 -0
- package/dist/services/browser/sandbox/forked-client/src/client/fetch.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/fileChooser.d.ts +31 -0
- package/dist/services/browser/sandbox/forked-client/src/client/fileChooser.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/fileChooser.js +40 -0
- package/dist/services/browser/sandbox/forked-client/src/client/fileChooser.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/fileUtils.d.ts +4 -0
- package/dist/services/browser/sandbox/forked-client/src/client/fileUtils.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/fileUtils.js +15 -0
- package/dist/services/browser/sandbox/forked-client/src/client/fileUtils.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/frame.d.ts +151 -0
- package/dist/services/browser/sandbox/forked-client/src/client/frame.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/frame.js +494 -0
- package/dist/services/browser/sandbox/forked-client/src/client/frame.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/harRouter.d.ts +7 -0
- package/dist/services/browser/sandbox/forked-client/src/client/harRouter.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/harRouter.js +21 -0
- package/dist/services/browser/sandbox/forked-client/src/client/harRouter.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/input.d.ts +46 -0
- package/dist/services/browser/sandbox/forked-client/src/client/input.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/input.js +77 -0
- package/dist/services/browser/sandbox/forked-client/src/client/input.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/jsHandle.d.ts +37 -0
- package/dist/services/browser/sandbox/forked-client/src/client/jsHandle.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/jsHandle.js +107 -0
- package/dist/services/browser/sandbox/forked-client/src/client/jsHandle.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/jsonPipe.d.ts +5 -0
- package/dist/services/browser/sandbox/forked-client/src/client/jsonPipe.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/jsonPipe.js +12 -0
- package/dist/services/browser/sandbox/forked-client/src/client/jsonPipe.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/localUtils.d.ts +13 -0
- package/dist/services/browser/sandbox/forked-client/src/client/localUtils.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/localUtils.js +38 -0
- package/dist/services/browser/sandbox/forked-client/src/client/localUtils.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/locator.d.ts +163 -0
- package/dist/services/browser/sandbox/forked-client/src/client/locator.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/locator.js +411 -0
- package/dist/services/browser/sandbox/forked-client/src/client/locator.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/network.d.ts +268 -0
- package/dist/services/browser/sandbox/forked-client/src/client/network.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/network.js +756 -0
- package/dist/services/browser/sandbox/forked-client/src/client/network.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/page.d.ts +291 -0
- package/dist/services/browser/sandbox/forked-client/src/client/page.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/page.js +754 -0
- package/dist/services/browser/sandbox/forked-client/src/client/page.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/platform.d.ts +57 -0
- package/dist/services/browser/sandbox/forked-client/src/client/platform.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/platform.js +71 -0
- package/dist/services/browser/sandbox/forked-client/src/client/platform.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/playwright.d.ts +48 -0
- package/dist/services/browser/sandbox/forked-client/src/client/playwright.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/playwright.js +65 -0
- package/dist/services/browser/sandbox/forked-client/src/client/playwright.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/screencast.d.ts +6 -0
- package/dist/services/browser/sandbox/forked-client/src/client/screencast.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/screencast.js +15 -0
- package/dist/services/browser/sandbox/forked-client/src/client/screencast.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/selectors.d.ts +38 -0
- package/dist/services/browser/sandbox/forked-client/src/client/selectors.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/selectors.js +56 -0
- package/dist/services/browser/sandbox/forked-client/src/client/selectors.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/stream.d.ts +6 -0
- package/dist/services/browser/sandbox/forked-client/src/client/stream.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/stream.js +15 -0
- package/dist/services/browser/sandbox/forked-client/src/client/stream.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/timeoutSettings.d.ts +38 -0
- package/dist/services/browser/sandbox/forked-client/src/client/timeoutSettings.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/timeoutSettings.js +74 -0
- package/dist/services/browser/sandbox/forked-client/src/client/timeoutSettings.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/tracing.d.ts +12 -0
- package/dist/services/browser/sandbox/forked-client/src/client/tracing.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/tracing.js +18 -0
- package/dist/services/browser/sandbox/forked-client/src/client/tracing.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/types.d.ts +161 -0
- package/dist/services/browser/sandbox/forked-client/src/client/types.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/types.js +27 -0
- package/dist/services/browser/sandbox/forked-client/src/client/types.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/video.d.ts +10 -0
- package/dist/services/browser/sandbox/forked-client/src/client/video.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/video.js +28 -0
- package/dist/services/browser/sandbox/forked-client/src/client/video.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/waiter.d.ts +39 -0
- package/dist/services/browser/sandbox/forked-client/src/client/waiter.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/waiter.js +142 -0
- package/dist/services/browser/sandbox/forked-client/src/client/waiter.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/webError.d.ts +25 -0
- package/dist/services/browser/sandbox/forked-client/src/client/webError.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/webError.js +33 -0
- package/dist/services/browser/sandbox/forked-client/src/client/webError.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/worker.d.ts +36 -0
- package/dist/services/browser/sandbox/forked-client/src/client/worker.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/worker.js +90 -0
- package/dist/services/browser/sandbox/forked-client/src/client/worker.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/writableStream.d.ts +6 -0
- package/dist/services/browser/sandbox/forked-client/src/client/writableStream.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/client/writableStream.js +15 -0
- package/dist/services/browser/sandbox/forked-client/src/client/writableStream.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/protocol/serializers.d.ts +25 -0
- package/dist/services/browser/sandbox/forked-client/src/protocol/serializers.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/protocol/serializers.js +196 -0
- package/dist/services/browser/sandbox/forked-client/src/protocol/serializers.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/protocol/validator.d.ts +18 -0
- package/dist/services/browser/sandbox/forked-client/src/protocol/validator.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/protocol/validator.js +3017 -0
- package/dist/services/browser/sandbox/forked-client/src/protocol/validator.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/protocol/validatorPrimitives.d.ts +45 -0
- package/dist/services/browser/sandbox/forked-client/src/protocol/validatorPrimitives.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/protocol/validatorPrimitives.js +170 -0
- package/dist/services/browser/sandbox/forked-client/src/protocol/validatorPrimitives.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/ariaSnapshot.d.ts +112 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/ariaSnapshot.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/ariaSnapshot.js +488 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/ariaSnapshot.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/assert.d.ts +17 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/assert.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/assert.js +24 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/assert.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/colors.d.ts +39 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/colors.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/colors.js +63 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/colors.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/cssParser.d.ts +42 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/cssParser.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/cssParser.js +299 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/cssParser.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/cssTokenizer.d.ts +172 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/cssTokenizer.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/cssTokenizer.js +1096 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/cssTokenizer.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/headers.d.ts +26 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/headers.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/headers.js +46 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/headers.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/imageUtils.d.ts +29 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/imageUtils.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/imageUtils.js +150 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/imageUtils.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/locatorGenerators.d.ts +82 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/locatorGenerators.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/locatorGenerators.js +702 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/locatorGenerators.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/locatorParser.d.ts +19 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/locatorParser.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/locatorParser.js +246 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/locatorParser.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/locatorUtils.d.ts +44 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/locatorUtils.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/locatorUtils.js +68 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/locatorUtils.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/lruCache.d.ts +26 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/lruCache.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/lruCache.js +46 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/lruCache.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/manualPromise.d.ts +41 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/manualPromise.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/manualPromise.js +108 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/manualPromise.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/mimeType.d.ts +20 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/mimeType.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/mimeType.js +454 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/mimeType.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/multimap.d.ts +31 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/multimap.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/multimap.js +74 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/multimap.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/protocolFormatter.d.ts +28 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/protocolFormatter.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/protocolFormatter.js +76 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/protocolFormatter.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/protocolMetainfo.d.ts +25 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/protocolMetainfo.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/protocolMetainfo.js +532 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/protocolMetainfo.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/rtti.d.ts +20 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/rtti.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/rtti.js +34 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/rtti.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/selectorParser.d.ts +49 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/selectorParser.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/selectorParser.js +463 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/selectorParser.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/semaphore.d.ts +26 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/semaphore.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/semaphore.js +48 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/semaphore.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/stackTrace.d.ts +41 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/stackTrace.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/stackTrace.js +178 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/stackTrace.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/stringUtils.d.ts +38 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/stringUtils.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/stringUtils.js +202 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/stringUtils.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/time.d.ts +21 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/time.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/time.js +46 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/time.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/timeoutRunner.d.ts +29 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/timeoutRunner.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/timeoutRunner.js +62 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/timeoutRunner.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/types.d.ts +31 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/types.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/types.js +19 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/types.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/urlMatch.d.ts +57 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/urlMatch.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/urlMatch.js +275 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/urlMatch.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/utilityScriptSerializers.d.ts +67 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/utilityScriptSerializers.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/utilityScriptSerializers.js +275 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/utilityScriptSerializers.js.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/yaml.d.ts +18 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/yaml.d.ts.map +1 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/yaml.js +89 -0
- package/dist/services/browser/sandbox/forked-client/src/utils/isomorphic/yaml.js.map +1 -0
- package/dist/services/browser/sandbox/host-bridge.d.ts +20 -0
- package/dist/services/browser/sandbox/host-bridge.d.ts.map +1 -0
- package/dist/services/browser/sandbox/host-bridge.js +49 -0
- package/dist/services/browser/sandbox/host-bridge.js.map +1 -0
- package/dist/services/browser/sandbox/playwright-internals.d.ts +37 -0
- package/dist/services/browser/sandbox/playwright-internals.d.ts.map +1 -0
- package/dist/services/browser/sandbox/playwright-internals.js +29 -0
- package/dist/services/browser/sandbox/playwright-internals.js.map +1 -0
- package/dist/services/browser/sandbox/protocol-bridge.d.ts +20 -0
- package/dist/services/browser/sandbox/protocol-bridge.d.ts.map +1 -0
- package/dist/services/browser/sandbox/protocol-bridge.js +58 -0
- package/dist/services/browser/sandbox/protocol-bridge.js.map +1 -0
- package/dist/services/browser/sandbox/quickjs-host.d.ts +32 -0
- package/dist/services/browser/sandbox/quickjs-host.d.ts.map +1 -0
- package/dist/services/browser/sandbox/quickjs-host.js +505 -0
- package/dist/services/browser/sandbox/quickjs-host.js.map +1 -0
- package/dist/services/browser/sandbox/quickjs-sandbox.d.ts +18 -0
- package/dist/services/browser/sandbox/quickjs-sandbox.d.ts.map +1 -0
- package/dist/services/browser/sandbox/quickjs-sandbox.js +683 -0
- package/dist/services/browser/sandbox/quickjs-sandbox.js.map +1 -0
- package/dist/services/browser/sandbox/sandbox-client.js +12390 -0
- package/dist/services/browser/sandbox/sandbox-transport.d.ts +16 -0
- package/dist/services/browser/sandbox/sandbox-transport.d.ts.map +1 -0
- package/dist/services/browser/sandbox/sandbox-transport.js +30 -0
- package/dist/services/browser/sandbox/sandbox-transport.js.map +1 -0
- package/dist/services/browser/sandbox/script-runner-quickjs.d.ts +11 -0
- package/dist/services/browser/sandbox/script-runner-quickjs.d.ts.map +1 -0
- package/dist/services/browser/sandbox/script-runner-quickjs.js +22 -0
- package/dist/services/browser/sandbox/script-runner-quickjs.js.map +1 -0
- package/dist/services/browser/temp-files.d.ts +9 -0
- package/dist/services/browser/temp-files.d.ts.map +1 -0
- package/dist/services/browser/temp-files.js +175 -0
- package/dist/services/browser/temp-files.js.map +1 -0
- package/dist/services/browser/test-cleanup.d.ts +10 -0
- package/dist/services/browser/test-cleanup.d.ts.map +1 -0
- package/dist/services/browser/test-cleanup.js +34 -0
- package/dist/services/browser/test-cleanup.js.map +1 -0
- package/dist/services/browser/test-cleanup.test.d.ts +2 -0
- package/dist/services/browser/test-cleanup.test.d.ts.map +1 -0
- package/dist/services/browser/test-cleanup.test.js +50 -0
- package/dist/services/browser/test-cleanup.test.js.map +1 -0
- package/dist/session/SessionManager.d.ts +5 -0
- package/dist/session/SessionManager.d.ts.map +1 -1
- package/dist/session/SessionManager.js +3 -4
- package/dist/session/SessionManager.js.map +1 -1
- package/dist/skills/HookAndSkillManager.d.ts +2 -2
- package/dist/skills/HookAndSkillManager.js +2 -2
- package/dist/tools/NativeTools.d.ts +20 -16
- package/dist/tools/NativeTools.d.ts.map +1 -1
- package/dist/tools/NativeTools.js +38 -20
- package/dist/tools/NativeTools.js.map +1 -1
- package/dist/tools/Schemas.d.ts +171 -1250
- package/dist/tools/Schemas.d.ts.map +1 -1
- package/dist/tools/Schemas.js +70 -374
- package/dist/tools/Schemas.js.map +1 -1
- package/dist/utils/character.d.ts +2 -0
- package/dist/utils/character.d.ts.map +1 -0
- package/dist/utils/character.js +33 -0
- package/dist/utils/character.js.map +1 -0
- package/dist/utils/contextManager.d.ts +26 -0
- package/dist/utils/contextManager.d.ts.map +1 -0
- package/dist/utils/contextManager.js +72 -0
- package/dist/utils/contextManager.js.map +1 -0
- package/dist/utils/inputbar.d.ts +3 -2
- package/dist/utils/inputbar.d.ts.map +1 -1
- package/dist/utils/inputbar.js +18 -17
- package/dist/utils/inputbar.js.map +1 -1
- package/dist/utils/memoryManager.d.ts +14 -0
- package/dist/utils/memoryManager.d.ts.map +1 -0
- package/dist/utils/memoryManager.js +96 -0
- package/dist/utils/memoryManager.js.map +1 -0
- package/dist/utils/output.d.ts +3 -2
- package/dist/utils/output.d.ts.map +1 -1
- package/dist/utils/output.js +56 -19
- package/dist/utils/output.js.map +1 -1
- package/dist/utils/string.d.ts +6 -0
- package/dist/utils/string.d.ts.map +1 -0
- package/dist/utils/string.js +18 -0
- package/dist/utils/string.js.map +1 -0
- package/dist/utils/string.test.d.ts +2 -0
- package/dist/utils/string.test.d.ts.map +1 -0
- package/dist/utils/string.test.js +19 -0
- package/dist/utils/string.test.js.map +1 -0
- package/dist/utils/systemPrompt.d.ts +3 -0
- package/dist/utils/systemPrompt.d.ts.map +1 -0
- package/dist/utils/systemPrompt.js +194 -0
- package/dist/utils/systemPrompt.js.map +1 -0
- package/dist/utils/welcome.d.ts +3 -0
- package/dist/utils/welcome.d.ts.map +1 -1
- package/dist/utils/welcome.js +133 -22
- package/dist/utils/welcome.js.map +1 -1
- package/package.json +9 -5
|
@@ -0,0 +1,683 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
36
|
+
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
37
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
38
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
39
|
+
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
40
|
+
};
|
|
41
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
42
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
43
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
44
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
45
|
+
};
|
|
46
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
47
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
48
|
+
};
|
|
49
|
+
var _QuickJSSandbox_instances, _QuickJSSandbox_options, _QuickJSSandbox_anonymousPages, _QuickJSSandbox_pendingHostOperations, _QuickJSSandbox_transportInbox, _QuickJSSandbox_asyncError, _QuickJSSandbox_host, _QuickJSSandbox_hostBridge, _QuickJSSandbox_flushPromise, _QuickJSSandbox_disposed, _QuickJSSandbox_initialized, _QuickJSSandbox_routeConsole, _QuickJSSandbox_handleTransportSend, _QuickJSSandbox_drainAsyncOps, _QuickJSSandbox_flushTransportQueue, _QuickJSSandbox_getPage, _QuickJSSandbox_newPage, _QuickJSSandbox_closePage, _QuickJSSandbox_writeTempFile, _QuickJSSandbox_readTempFile, _QuickJSSandbox_cleanupAnonymousPages, _QuickJSSandbox_throwIfAsyncError, _QuickJSSandbox_assertAlive, _QuickJSSandbox_assertInitialized;
|
|
50
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
51
|
+
exports.QuickJSSandbox = void 0;
|
|
52
|
+
const promises_1 = require("node:fs/promises");
|
|
53
|
+
const node_util_1 = __importDefault(require("node:util"));
|
|
54
|
+
const temp_files_1 = require("../temp-files");
|
|
55
|
+
const host_bridge_1 = require("./host-bridge");
|
|
56
|
+
const quickjs_host_1 = require("./quickjs-host");
|
|
57
|
+
const DEFAULT_MEMORY_LIMIT_BYTES = 512 * 1024 * 1024;
|
|
58
|
+
const WAIT_FOR_OBJECT_ATTEMPTS = 1000;
|
|
59
|
+
const node_fs_1 = require("node:fs");
|
|
60
|
+
const path = __importStar(require("node:path"));
|
|
61
|
+
// Resolve sandbox-client.js: next to the running script (production), or in dist/ (development)
|
|
62
|
+
function findBundlePath() {
|
|
63
|
+
const candidates = [
|
|
64
|
+
path.join(__dirname, "sandbox-client.js"),
|
|
65
|
+
path.join(__dirname, "..", "..", "..", "dist", "sandbox-client.js"),
|
|
66
|
+
];
|
|
67
|
+
for (const p of candidates) {
|
|
68
|
+
if ((0, node_fs_1.existsSync)(p))
|
|
69
|
+
return p;
|
|
70
|
+
}
|
|
71
|
+
throw new Error(`Failed to find sandbox-client.js. Searched:\n${candidates.map((c) => ` - ${c}`).join("\n")}`);
|
|
72
|
+
}
|
|
73
|
+
const BUNDLE_PATH = findBundlePath();
|
|
74
|
+
const TRANSPORT_RECEIVE_GLOBAL = "__transport_receive";
|
|
75
|
+
let bundleCodePromise;
|
|
76
|
+
function formatArgs(args) {
|
|
77
|
+
return args
|
|
78
|
+
.map((arg) => typeof arg === "string"
|
|
79
|
+
? arg
|
|
80
|
+
: node_util_1.default.inspect(arg, {
|
|
81
|
+
colors: false,
|
|
82
|
+
depth: 6,
|
|
83
|
+
compact: 3,
|
|
84
|
+
breakLength: Infinity,
|
|
85
|
+
}))
|
|
86
|
+
.join(" ");
|
|
87
|
+
}
|
|
88
|
+
function normalizeError(error) {
|
|
89
|
+
if (error instanceof Error) {
|
|
90
|
+
return error;
|
|
91
|
+
}
|
|
92
|
+
return new Error(String(error));
|
|
93
|
+
}
|
|
94
|
+
function getSandboxClientBundleCode() {
|
|
95
|
+
bundleCodePromise ?? (bundleCodePromise = (0, promises_1.readFile)(BUNDLE_PATH, "utf8").catch((error) => {
|
|
96
|
+
bundleCodePromise = undefined;
|
|
97
|
+
const message = error instanceof Error ? error.message : "Sandbox client bundle could not be read";
|
|
98
|
+
throw new Error(`Failed to load sandbox client bundle at ${BUNDLE_PATH}: ${message}`);
|
|
99
|
+
}));
|
|
100
|
+
return bundleCodePromise;
|
|
101
|
+
}
|
|
102
|
+
function formatTimeoutDuration(timeoutMs) {
|
|
103
|
+
if (timeoutMs % 1000 === 0) {
|
|
104
|
+
return `${timeoutMs / 1000}s`;
|
|
105
|
+
}
|
|
106
|
+
return `${timeoutMs}ms`;
|
|
107
|
+
}
|
|
108
|
+
function createScriptTimeoutError(timeoutMs) {
|
|
109
|
+
const error = new Error(`Script timed out after ${formatTimeoutDuration(timeoutMs)} and was terminated.`);
|
|
110
|
+
error.name = "ScriptTimeoutError";
|
|
111
|
+
return error;
|
|
112
|
+
}
|
|
113
|
+
function createGuestScriptTimeoutErrorSource(timeoutMs) {
|
|
114
|
+
const message = JSON.stringify(createScriptTimeoutError(timeoutMs).message);
|
|
115
|
+
return `(() => {
|
|
116
|
+
const error = new Error(${message});
|
|
117
|
+
error.name = "ScriptTimeoutError";
|
|
118
|
+
return error;
|
|
119
|
+
})()`;
|
|
120
|
+
}
|
|
121
|
+
function wrapScriptWithWallClockTimeout(script, timeoutMs) {
|
|
122
|
+
if (timeoutMs === undefined) {
|
|
123
|
+
return script;
|
|
124
|
+
}
|
|
125
|
+
return `
|
|
126
|
+
(() => {
|
|
127
|
+
return new Promise((resolve, reject) => {
|
|
128
|
+
const timeoutId = setTimeout(() => {
|
|
129
|
+
reject(${createGuestScriptTimeoutErrorSource(timeoutMs)});
|
|
130
|
+
}, ${timeoutMs});
|
|
131
|
+
|
|
132
|
+
Promise.resolve()
|
|
133
|
+
.then(() => (${script}))
|
|
134
|
+
.then(resolve, reject)
|
|
135
|
+
.finally(() => {
|
|
136
|
+
clearTimeout(timeoutId);
|
|
137
|
+
});
|
|
138
|
+
});
|
|
139
|
+
})()
|
|
140
|
+
`;
|
|
141
|
+
}
|
|
142
|
+
function requireString(value, label) {
|
|
143
|
+
if (typeof value !== "string" || value.length === 0) {
|
|
144
|
+
throw new TypeError(`${label} must be a non-empty string`);
|
|
145
|
+
}
|
|
146
|
+
return value;
|
|
147
|
+
}
|
|
148
|
+
function toServerImpl(clientObject, label) {
|
|
149
|
+
const connection = clientObject
|
|
150
|
+
._connection;
|
|
151
|
+
const toImpl = connection?.toImpl;
|
|
152
|
+
if (typeof toImpl !== "function") {
|
|
153
|
+
throw new Error(`${label} does not expose a server implementation`);
|
|
154
|
+
}
|
|
155
|
+
const impl = toImpl(clientObject);
|
|
156
|
+
if (!impl) {
|
|
157
|
+
throw new Error(`${label} could not be mapped to a server implementation`);
|
|
158
|
+
}
|
|
159
|
+
return impl;
|
|
160
|
+
}
|
|
161
|
+
function extractGuid(page) {
|
|
162
|
+
const guid = toServerImpl(page, "Playwright page").guid;
|
|
163
|
+
if (typeof guid !== "string" || guid.length === 0) {
|
|
164
|
+
throw new Error("Playwright page did not expose a guid");
|
|
165
|
+
}
|
|
166
|
+
return guid;
|
|
167
|
+
}
|
|
168
|
+
function decodeSandboxFilePayload(value, label) {
|
|
169
|
+
if (typeof value !== "object" || value === null) {
|
|
170
|
+
throw new TypeError(`${label} must be an object`);
|
|
171
|
+
}
|
|
172
|
+
const encoding = "encoding" in value ? value.encoding : undefined;
|
|
173
|
+
const data = "data" in value ? value.data : undefined;
|
|
174
|
+
if ((encoding !== "utf8" && encoding !== "base64") || typeof data !== "string") {
|
|
175
|
+
throw new TypeError(`${label} must include a valid encoding and string data`);
|
|
176
|
+
}
|
|
177
|
+
if (encoding === "utf8") {
|
|
178
|
+
return data;
|
|
179
|
+
}
|
|
180
|
+
return Buffer.from(data, "base64");
|
|
181
|
+
}
|
|
182
|
+
class QuickJSSandbox {
|
|
183
|
+
constructor(options) {
|
|
184
|
+
_QuickJSSandbox_instances.add(this);
|
|
185
|
+
_QuickJSSandbox_options.set(this, void 0);
|
|
186
|
+
_QuickJSSandbox_anonymousPages.set(this, new Set());
|
|
187
|
+
_QuickJSSandbox_pendingHostOperations.set(this, new Set());
|
|
188
|
+
_QuickJSSandbox_transportInbox.set(this, []);
|
|
189
|
+
_QuickJSSandbox_asyncError.set(this, void 0);
|
|
190
|
+
_QuickJSSandbox_host.set(this, void 0);
|
|
191
|
+
_QuickJSSandbox_hostBridge.set(this, void 0);
|
|
192
|
+
_QuickJSSandbox_flushPromise.set(this, void 0);
|
|
193
|
+
_QuickJSSandbox_disposed.set(this, false);
|
|
194
|
+
_QuickJSSandbox_initialized.set(this, false);
|
|
195
|
+
__classPrivateFieldSet(this, _QuickJSSandbox_options, options, "f");
|
|
196
|
+
}
|
|
197
|
+
async initialize() {
|
|
198
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_assertAlive).call(this);
|
|
199
|
+
if (__classPrivateFieldGet(this, _QuickJSSandbox_initialized, "f")) {
|
|
200
|
+
return;
|
|
201
|
+
}
|
|
202
|
+
try {
|
|
203
|
+
await (0, temp_files_1.ensureDevBrowserTempDir)();
|
|
204
|
+
__classPrivateFieldSet(this, _QuickJSSandbox_host, await quickjs_host_1.QuickJSHost.create({
|
|
205
|
+
memoryLimitBytes: __classPrivateFieldGet(this, _QuickJSSandbox_options, "f").memoryLimitBytes ?? DEFAULT_MEMORY_LIMIT_BYTES,
|
|
206
|
+
cpuTimeoutMs: __classPrivateFieldGet(this, _QuickJSSandbox_options, "f").timeoutMs,
|
|
207
|
+
hostFunctions: {
|
|
208
|
+
getPage: (name) => __classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_getPage).call(this, name),
|
|
209
|
+
newPage: () => __classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_newPage).call(this),
|
|
210
|
+
listPages: () => __classPrivateFieldGet(this, _QuickJSSandbox_options, "f").manager.listPages(__classPrivateFieldGet(this, _QuickJSSandbox_options, "f").browserName),
|
|
211
|
+
closePage: (name) => __classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_closePage).call(this, name),
|
|
212
|
+
saveScreenshot: (name, data) => __classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_writeTempFile).call(this, name, data),
|
|
213
|
+
writeFile: (name, data) => __classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_writeTempFile).call(this, name, data),
|
|
214
|
+
readFile: (name) => __classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_readTempFile).call(this, name),
|
|
215
|
+
},
|
|
216
|
+
onConsole: (level, args) => {
|
|
217
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_routeConsole).call(this, level, args);
|
|
218
|
+
},
|
|
219
|
+
onDrain: () => __classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_drainAsyncOps).call(this),
|
|
220
|
+
onTransportSend: (message) => {
|
|
221
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_handleTransportSend).call(this, message);
|
|
222
|
+
},
|
|
223
|
+
}), "f");
|
|
224
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_host, "f").executeScriptSync(`
|
|
225
|
+
const __performanceOrigin = Date.now();
|
|
226
|
+
const __base64Alphabet =
|
|
227
|
+
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
|
|
228
|
+
|
|
229
|
+
const __encodeBase64 = (bytes) => {
|
|
230
|
+
let result = "";
|
|
231
|
+
for (let index = 0; index < bytes.length; index += 3) {
|
|
232
|
+
const chunk =
|
|
233
|
+
(bytes[index] << 16) |
|
|
234
|
+
((bytes[index + 1] ?? 0) << 8) |
|
|
235
|
+
(bytes[index + 2] ?? 0);
|
|
236
|
+
result += __base64Alphabet[(chunk >> 18) & 63];
|
|
237
|
+
result += __base64Alphabet[(chunk >> 12) & 63];
|
|
238
|
+
result += index + 1 < bytes.length ? __base64Alphabet[(chunk >> 6) & 63] : "=";
|
|
239
|
+
result += index + 2 < bytes.length ? __base64Alphabet[chunk & 63] : "=";
|
|
240
|
+
}
|
|
241
|
+
return result;
|
|
242
|
+
};
|
|
243
|
+
|
|
244
|
+
const __decodeBase64 = (base64) => {
|
|
245
|
+
const normalized = String(base64).replace(/\\s+/g, "");
|
|
246
|
+
const output = [];
|
|
247
|
+
for (let index = 0; index < normalized.length; index += 4) {
|
|
248
|
+
const a = __base64Alphabet.indexOf(normalized[index] ?? "A");
|
|
249
|
+
const b = __base64Alphabet.indexOf(normalized[index + 1] ?? "A");
|
|
250
|
+
const c =
|
|
251
|
+
normalized[index + 2] === "="
|
|
252
|
+
? 64
|
|
253
|
+
: __base64Alphabet.indexOf(normalized[index + 2] ?? "A");
|
|
254
|
+
const d =
|
|
255
|
+
normalized[index + 3] === "="
|
|
256
|
+
? 64
|
|
257
|
+
: __base64Alphabet.indexOf(normalized[index + 3] ?? "A");
|
|
258
|
+
const chunk = (a << 18) | (b << 12) | ((c & 63) << 6) | (d & 63);
|
|
259
|
+
output.push((chunk >> 16) & 255);
|
|
260
|
+
if (c !== 64) {
|
|
261
|
+
output.push((chunk >> 8) & 255);
|
|
262
|
+
}
|
|
263
|
+
if (d !== 64) {
|
|
264
|
+
output.push(chunk & 255);
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
return new Uint8Array(output);
|
|
268
|
+
};
|
|
269
|
+
|
|
270
|
+
globalThis.URL ??= class URL {
|
|
271
|
+
constructor(value, base) {
|
|
272
|
+
this.href = base === undefined ? String(value) : String(base) + String(value);
|
|
273
|
+
}
|
|
274
|
+
|
|
275
|
+
toJSON() {
|
|
276
|
+
return this.href;
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
toString() {
|
|
280
|
+
return this.href;
|
|
281
|
+
}
|
|
282
|
+
};
|
|
283
|
+
|
|
284
|
+
globalThis.Buffer ??= class Buffer extends Uint8Array {
|
|
285
|
+
constructor(value, byteOffset, length) {
|
|
286
|
+
if (typeof value === "number") {
|
|
287
|
+
super(value);
|
|
288
|
+
return;
|
|
289
|
+
}
|
|
290
|
+
if (value instanceof ArrayBuffer) {
|
|
291
|
+
super(value, byteOffset, length);
|
|
292
|
+
return;
|
|
293
|
+
}
|
|
294
|
+
if (ArrayBuffer.isView(value)) {
|
|
295
|
+
super(value.buffer, value.byteOffset, value.byteLength);
|
|
296
|
+
return;
|
|
297
|
+
}
|
|
298
|
+
super(value);
|
|
299
|
+
}
|
|
300
|
+
|
|
301
|
+
static from(value, encodingOrOffset, length) {
|
|
302
|
+
if (typeof value === "string") {
|
|
303
|
+
if (encodingOrOffset !== undefined && encodingOrOffset !== "base64") {
|
|
304
|
+
throw new Error("QuickJS Buffer only supports base64 string input");
|
|
305
|
+
}
|
|
306
|
+
return new Buffer(__decodeBase64(value));
|
|
307
|
+
}
|
|
308
|
+
if (value instanceof ArrayBuffer) {
|
|
309
|
+
return new Buffer(value, encodingOrOffset, length);
|
|
310
|
+
}
|
|
311
|
+
if (ArrayBuffer.isView(value)) {
|
|
312
|
+
return new Buffer(
|
|
313
|
+
value.buffer.slice(
|
|
314
|
+
value.byteOffset,
|
|
315
|
+
value.byteOffset + value.byteLength,
|
|
316
|
+
),
|
|
317
|
+
);
|
|
318
|
+
}
|
|
319
|
+
if (Array.isArray(value)) {
|
|
320
|
+
return new Buffer(value);
|
|
321
|
+
}
|
|
322
|
+
throw new TypeError("Unsupported Buffer.from input");
|
|
323
|
+
}
|
|
324
|
+
|
|
325
|
+
toString(encoding) {
|
|
326
|
+
if (encoding === undefined || encoding === "utf8") {
|
|
327
|
+
return Array.from(this)
|
|
328
|
+
.map((value) => String.fromCharCode(value))
|
|
329
|
+
.join("");
|
|
330
|
+
}
|
|
331
|
+
if (encoding === "base64") {
|
|
332
|
+
return __encodeBase64(this);
|
|
333
|
+
}
|
|
334
|
+
throw new Error("QuickJS Buffer only supports utf8 and base64 output");
|
|
335
|
+
}
|
|
336
|
+
};
|
|
337
|
+
|
|
338
|
+
globalThis.performance ??= {
|
|
339
|
+
now: () => Date.now() - __performanceOrigin,
|
|
340
|
+
timeOrigin: __performanceOrigin,
|
|
341
|
+
};
|
|
342
|
+
globalThis.global = globalThis;
|
|
343
|
+
`, {
|
|
344
|
+
filename: "quickjs-runtime.js",
|
|
345
|
+
});
|
|
346
|
+
const bundleCode = await getSandboxClientBundleCode();
|
|
347
|
+
const bundleFactorySource = JSON.stringify(`${bundleCode}\nreturn __PlaywrightClient;`);
|
|
348
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_host, "f").executeScriptSync(`
|
|
349
|
+
globalThis.__createPlaywrightClient = () => {
|
|
350
|
+
return new Function(${bundleFactorySource})();
|
|
351
|
+
};
|
|
352
|
+
`, {
|
|
353
|
+
filename: "sandbox-client.js",
|
|
354
|
+
});
|
|
355
|
+
const browserEntry = __classPrivateFieldGet(this, _QuickJSSandbox_options, "f").manager.getBrowser(__classPrivateFieldGet(this, _QuickJSSandbox_options, "f").browserName);
|
|
356
|
+
if (!browserEntry) {
|
|
357
|
+
throw new Error(`Browser "${__classPrivateFieldGet(this, _QuickJSSandbox_options, "f").browserName}" not found. It should have been created before script execution.`);
|
|
358
|
+
}
|
|
359
|
+
__classPrivateFieldSet(this, _QuickJSSandbox_hostBridge, new host_bridge_1.HostBridge({
|
|
360
|
+
sendToSandbox: (json) => {
|
|
361
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_transportInbox, "f").push(json);
|
|
362
|
+
},
|
|
363
|
+
preLaunchedBrowser: toServerImpl(browserEntry.browser, "Playwright browser"),
|
|
364
|
+
sharedBrowser: true,
|
|
365
|
+
denyLaunch: true,
|
|
366
|
+
}), "f");
|
|
367
|
+
await __classPrivateFieldGet(this, _QuickJSSandbox_host, "f").executeScript(`
|
|
368
|
+
(() => {
|
|
369
|
+
const hostCall = globalThis.__hostCall;
|
|
370
|
+
const transportSend = globalThis.__transport_send;
|
|
371
|
+
const createPlaywrightClient = globalThis.__createPlaywrightClient;
|
|
372
|
+
|
|
373
|
+
if (typeof hostCall !== "function") {
|
|
374
|
+
throw new Error("Sandbox bridge did not expose a host-call function");
|
|
375
|
+
}
|
|
376
|
+
if (typeof transportSend !== "function") {
|
|
377
|
+
throw new Error("Sandbox bridge did not expose a transport sender");
|
|
378
|
+
}
|
|
379
|
+
if (typeof createPlaywrightClient !== "function") {
|
|
380
|
+
throw new Error("Sandbox client bundle did not expose a Playwright client factory");
|
|
381
|
+
}
|
|
382
|
+
|
|
383
|
+
if (!delete globalThis.__hostCall) {
|
|
384
|
+
globalThis.__hostCall = undefined;
|
|
385
|
+
}
|
|
386
|
+
if (!delete globalThis.__transport_send) {
|
|
387
|
+
globalThis.__transport_send = undefined;
|
|
388
|
+
}
|
|
389
|
+
if (!delete globalThis.__createPlaywrightClient) {
|
|
390
|
+
globalThis.__createPlaywrightClient = undefined;
|
|
391
|
+
}
|
|
392
|
+
|
|
393
|
+
const playwrightClient = createPlaywrightClient();
|
|
394
|
+
const connection = new playwrightClient.Connection(playwrightClient.quickjsPlatform);
|
|
395
|
+
connection.onmessage = (message) => {
|
|
396
|
+
transportSend(JSON.stringify(message));
|
|
397
|
+
};
|
|
398
|
+
|
|
399
|
+
Object.defineProperty(globalThis, "${TRANSPORT_RECEIVE_GLOBAL}", {
|
|
400
|
+
value: (json) => {
|
|
401
|
+
connection.dispatch(JSON.parse(json));
|
|
402
|
+
},
|
|
403
|
+
configurable: false,
|
|
404
|
+
enumerable: false,
|
|
405
|
+
writable: false,
|
|
406
|
+
});
|
|
407
|
+
|
|
408
|
+
const waitForConnectionObject = async (guid, label) => {
|
|
409
|
+
if (typeof guid !== "string" || guid.length === 0) {
|
|
410
|
+
throw new Error(\`\${label} did not return a valid guid\`);
|
|
411
|
+
}
|
|
412
|
+
|
|
413
|
+
for (let attempt = 0; attempt < ${WAIT_FOR_OBJECT_ATTEMPTS}; attempt += 1) {
|
|
414
|
+
const object = connection.getObjectWithKnownName(guid);
|
|
415
|
+
if (object) {
|
|
416
|
+
return object;
|
|
417
|
+
}
|
|
418
|
+
await new Promise((resolve) => setTimeout(resolve, 0));
|
|
419
|
+
}
|
|
420
|
+
|
|
421
|
+
throw new Error(\`Timed out waiting for \${label} (\${guid}) in the sandbox\`);
|
|
422
|
+
};
|
|
423
|
+
|
|
424
|
+
const encodeHostFilePayload = (value) => {
|
|
425
|
+
if (typeof value === "string") {
|
|
426
|
+
return { encoding: "utf8", data: value };
|
|
427
|
+
}
|
|
428
|
+
if (value instanceof ArrayBuffer || ArrayBuffer.isView(value)) {
|
|
429
|
+
return { encoding: "base64", data: Buffer.from(value).toString("base64") };
|
|
430
|
+
}
|
|
431
|
+
throw new TypeError(
|
|
432
|
+
"File data must be a string, Buffer, Uint8Array, or ArrayBuffer",
|
|
433
|
+
);
|
|
434
|
+
};
|
|
435
|
+
|
|
436
|
+
return (async () => {
|
|
437
|
+
await connection.initializePlaywright();
|
|
438
|
+
|
|
439
|
+
const browserApi = Object.create(null);
|
|
440
|
+
Object.defineProperties(browserApi, {
|
|
441
|
+
getPage: {
|
|
442
|
+
value: async (name) => {
|
|
443
|
+
const guid = await hostCall("getPage", JSON.stringify([name]));
|
|
444
|
+
return await waitForConnectionObject(guid, \`page "\${name}"\`);
|
|
445
|
+
},
|
|
446
|
+
enumerable: true,
|
|
447
|
+
},
|
|
448
|
+
newPage: {
|
|
449
|
+
value: async () => {
|
|
450
|
+
const guid = await hostCall("newPage", JSON.stringify([]));
|
|
451
|
+
return await waitForConnectionObject(guid, "anonymous page");
|
|
452
|
+
},
|
|
453
|
+
enumerable: true,
|
|
454
|
+
},
|
|
455
|
+
listPages: {
|
|
456
|
+
value: async () => {
|
|
457
|
+
return await hostCall("listPages", JSON.stringify([]));
|
|
458
|
+
},
|
|
459
|
+
enumerable: true,
|
|
460
|
+
},
|
|
461
|
+
closePage: {
|
|
462
|
+
value: async (name) => {
|
|
463
|
+
await hostCall("closePage", JSON.stringify([name]));
|
|
464
|
+
},
|
|
465
|
+
enumerable: true,
|
|
466
|
+
},
|
|
467
|
+
});
|
|
468
|
+
Object.freeze(browserApi);
|
|
469
|
+
|
|
470
|
+
Object.defineProperty(globalThis, "browser", {
|
|
471
|
+
value: browserApi,
|
|
472
|
+
configurable: false,
|
|
473
|
+
enumerable: true,
|
|
474
|
+
writable: false,
|
|
475
|
+
});
|
|
476
|
+
|
|
477
|
+
Object.defineProperties(globalThis, {
|
|
478
|
+
saveScreenshot: {
|
|
479
|
+
value: async (buffer, name) => {
|
|
480
|
+
return await hostCall(
|
|
481
|
+
"saveScreenshot",
|
|
482
|
+
JSON.stringify([name, encodeHostFilePayload(buffer)]),
|
|
483
|
+
);
|
|
484
|
+
},
|
|
485
|
+
configurable: false,
|
|
486
|
+
enumerable: true,
|
|
487
|
+
writable: false,
|
|
488
|
+
},
|
|
489
|
+
writeFile: {
|
|
490
|
+
value: async (name, data) => {
|
|
491
|
+
return await hostCall(
|
|
492
|
+
"writeFile",
|
|
493
|
+
JSON.stringify([name, encodeHostFilePayload(data)]),
|
|
494
|
+
);
|
|
495
|
+
},
|
|
496
|
+
configurable: false,
|
|
497
|
+
enumerable: true,
|
|
498
|
+
writable: false,
|
|
499
|
+
},
|
|
500
|
+
readFile: {
|
|
501
|
+
value: async (name) => {
|
|
502
|
+
return await hostCall("readFile", JSON.stringify([name]));
|
|
503
|
+
},
|
|
504
|
+
configurable: false,
|
|
505
|
+
enumerable: true,
|
|
506
|
+
writable: false,
|
|
507
|
+
},
|
|
508
|
+
});
|
|
509
|
+
})();
|
|
510
|
+
})()
|
|
511
|
+
`, {
|
|
512
|
+
filename: "sandbox-init.js",
|
|
513
|
+
});
|
|
514
|
+
await __classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_flushTransportQueue).call(this);
|
|
515
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_throwIfAsyncError).call(this);
|
|
516
|
+
__classPrivateFieldSet(this, _QuickJSSandbox_initialized, true, "f");
|
|
517
|
+
}
|
|
518
|
+
catch (error) {
|
|
519
|
+
await this.dispose();
|
|
520
|
+
throw error;
|
|
521
|
+
}
|
|
522
|
+
}
|
|
523
|
+
async executeScript(script) {
|
|
524
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_assertInitialized).call(this);
|
|
525
|
+
let executionError;
|
|
526
|
+
try {
|
|
527
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_throwIfAsyncError).call(this);
|
|
528
|
+
await __classPrivateFieldGet(this, _QuickJSSandbox_host, "f").executeScript(wrapScriptWithWallClockTimeout(script, __classPrivateFieldGet(this, _QuickJSSandbox_options, "f").timeoutMs), {
|
|
529
|
+
filename: "user-script.js",
|
|
530
|
+
});
|
|
531
|
+
await __classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_flushTransportQueue).call(this);
|
|
532
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_throwIfAsyncError).call(this);
|
|
533
|
+
}
|
|
534
|
+
catch (error) {
|
|
535
|
+
executionError = error;
|
|
536
|
+
}
|
|
537
|
+
try {
|
|
538
|
+
await __classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_cleanupAnonymousPages).call(this);
|
|
539
|
+
}
|
|
540
|
+
catch (error) {
|
|
541
|
+
executionError ?? (executionError = error);
|
|
542
|
+
}
|
|
543
|
+
if (executionError) {
|
|
544
|
+
throw executionError;
|
|
545
|
+
}
|
|
546
|
+
}
|
|
547
|
+
async dispose() {
|
|
548
|
+
if (__classPrivateFieldGet(this, _QuickJSSandbox_disposed, "f")) {
|
|
549
|
+
return;
|
|
550
|
+
}
|
|
551
|
+
__classPrivateFieldSet(this, _QuickJSSandbox_disposed, true, "f");
|
|
552
|
+
await __classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_cleanupAnonymousPages).call(this, {
|
|
553
|
+
suppressErrors: true,
|
|
554
|
+
});
|
|
555
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_transportInbox, "f").length = 0;
|
|
556
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_pendingHostOperations, "f").clear();
|
|
557
|
+
try {
|
|
558
|
+
await __classPrivateFieldGet(this, _QuickJSSandbox_hostBridge, "f")?.dispose();
|
|
559
|
+
}
|
|
560
|
+
catch {
|
|
561
|
+
// Best effort cleanup during sandbox teardown.
|
|
562
|
+
}
|
|
563
|
+
finally {
|
|
564
|
+
__classPrivateFieldSet(this, _QuickJSSandbox_hostBridge, undefined, "f");
|
|
565
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_host, "f")?.dispose();
|
|
566
|
+
__classPrivateFieldSet(this, _QuickJSSandbox_host, undefined, "f");
|
|
567
|
+
__classPrivateFieldSet(this, _QuickJSSandbox_flushPromise, undefined, "f");
|
|
568
|
+
}
|
|
569
|
+
}
|
|
570
|
+
}
|
|
571
|
+
exports.QuickJSSandbox = QuickJSSandbox;
|
|
572
|
+
_QuickJSSandbox_options = new WeakMap(), _QuickJSSandbox_anonymousPages = new WeakMap(), _QuickJSSandbox_pendingHostOperations = new WeakMap(), _QuickJSSandbox_transportInbox = new WeakMap(), _QuickJSSandbox_asyncError = new WeakMap(), _QuickJSSandbox_host = new WeakMap(), _QuickJSSandbox_hostBridge = new WeakMap(), _QuickJSSandbox_flushPromise = new WeakMap(), _QuickJSSandbox_disposed = new WeakMap(), _QuickJSSandbox_initialized = new WeakMap(), _QuickJSSandbox_instances = new WeakSet(), _QuickJSSandbox_routeConsole = function _QuickJSSandbox_routeConsole(level, args) {
|
|
573
|
+
const line = `${formatArgs(args)}\n`;
|
|
574
|
+
if (level === "warn" || level === "error") {
|
|
575
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_options, "f").onStderr(line);
|
|
576
|
+
return;
|
|
577
|
+
}
|
|
578
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_options, "f").onStdout(line);
|
|
579
|
+
}, _QuickJSSandbox_handleTransportSend = function _QuickJSSandbox_handleTransportSend(message) {
|
|
580
|
+
if (!__classPrivateFieldGet(this, _QuickJSSandbox_hostBridge, "f")) {
|
|
581
|
+
__classPrivateFieldSet(this, _QuickJSSandbox_asyncError, __classPrivateFieldGet(this, _QuickJSSandbox_asyncError, "f") ?? new Error("Sandbox transport is not initialized"), "f");
|
|
582
|
+
return;
|
|
583
|
+
}
|
|
584
|
+
const operation = __classPrivateFieldGet(this, _QuickJSSandbox_hostBridge, "f")
|
|
585
|
+
.receiveFromSandbox(message)
|
|
586
|
+
.catch((error) => {
|
|
587
|
+
__classPrivateFieldSet(this, _QuickJSSandbox_asyncError, __classPrivateFieldGet(this, _QuickJSSandbox_asyncError, "f") ?? normalizeError(error), "f");
|
|
588
|
+
})
|
|
589
|
+
.finally(() => {
|
|
590
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_pendingHostOperations, "f").delete(operation);
|
|
591
|
+
});
|
|
592
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_pendingHostOperations, "f").add(operation);
|
|
593
|
+
}, _QuickJSSandbox_drainAsyncOps = async function _QuickJSSandbox_drainAsyncOps() {
|
|
594
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_throwIfAsyncError).call(this);
|
|
595
|
+
await __classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_flushTransportQueue).call(this);
|
|
596
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_throwIfAsyncError).call(this);
|
|
597
|
+
if (__classPrivateFieldGet(this, _QuickJSSandbox_pendingHostOperations, "f").size === 0) {
|
|
598
|
+
return;
|
|
599
|
+
}
|
|
600
|
+
await Promise.race(__classPrivateFieldGet(this, _QuickJSSandbox_pendingHostOperations, "f"));
|
|
601
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_throwIfAsyncError).call(this);
|
|
602
|
+
await __classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_flushTransportQueue).call(this);
|
|
603
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_throwIfAsyncError).call(this);
|
|
604
|
+
}, _QuickJSSandbox_flushTransportQueue = async function _QuickJSSandbox_flushTransportQueue() {
|
|
605
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_throwIfAsyncError).call(this);
|
|
606
|
+
if (!__classPrivateFieldGet(this, _QuickJSSandbox_host, "f") || __classPrivateFieldGet(this, _QuickJSSandbox_transportInbox, "f").length === 0) {
|
|
607
|
+
return;
|
|
608
|
+
}
|
|
609
|
+
if (__classPrivateFieldGet(this, _QuickJSSandbox_flushPromise, "f")) {
|
|
610
|
+
await __classPrivateFieldGet(this, _QuickJSSandbox_flushPromise, "f");
|
|
611
|
+
return;
|
|
612
|
+
}
|
|
613
|
+
const flush = async () => {
|
|
614
|
+
while (__classPrivateFieldGet(this, _QuickJSSandbox_transportInbox, "f").length > 0) {
|
|
615
|
+
const message = __classPrivateFieldGet(this, _QuickJSSandbox_transportInbox, "f").shift();
|
|
616
|
+
if (message === undefined) {
|
|
617
|
+
continue;
|
|
618
|
+
}
|
|
619
|
+
await __classPrivateFieldGet(this, _QuickJSSandbox_host, "f").callFunction(TRANSPORT_RECEIVE_GLOBAL, message);
|
|
620
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_throwIfAsyncError).call(this);
|
|
621
|
+
}
|
|
622
|
+
};
|
|
623
|
+
__classPrivateFieldSet(this, _QuickJSSandbox_flushPromise, flush().finally(() => {
|
|
624
|
+
__classPrivateFieldSet(this, _QuickJSSandbox_flushPromise, undefined, "f");
|
|
625
|
+
}), "f");
|
|
626
|
+
await __classPrivateFieldGet(this, _QuickJSSandbox_flushPromise, "f");
|
|
627
|
+
}, _QuickJSSandbox_getPage = async function _QuickJSSandbox_getPage(name) {
|
|
628
|
+
const page = await __classPrivateFieldGet(this, _QuickJSSandbox_options, "f").manager.getPage(__classPrivateFieldGet(this, _QuickJSSandbox_options, "f").browserName, requireString(name, "Page name or targetId"));
|
|
629
|
+
return extractGuid(page);
|
|
630
|
+
}, _QuickJSSandbox_newPage = async function _QuickJSSandbox_newPage() {
|
|
631
|
+
const page = await __classPrivateFieldGet(this, _QuickJSSandbox_options, "f").manager.newPage(__classPrivateFieldGet(this, _QuickJSSandbox_options, "f").browserName);
|
|
632
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_anonymousPages, "f").add(page);
|
|
633
|
+
page.on("close", () => {
|
|
634
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_anonymousPages, "f").delete(page);
|
|
635
|
+
});
|
|
636
|
+
return extractGuid(page);
|
|
637
|
+
}, _QuickJSSandbox_closePage = async function _QuickJSSandbox_closePage(name) {
|
|
638
|
+
await __classPrivateFieldGet(this, _QuickJSSandbox_options, "f").manager.closePage(__classPrivateFieldGet(this, _QuickJSSandbox_options, "f").browserName, requireString(name, "Page name"));
|
|
639
|
+
}, _QuickJSSandbox_writeTempFile = async function _QuickJSSandbox_writeTempFile(name, payload) {
|
|
640
|
+
return await (0, temp_files_1.writeDevBrowserTempFile)(requireString(name, "File name"), decodeSandboxFilePayload(payload, "File data"));
|
|
641
|
+
}, _QuickJSSandbox_readTempFile = async function _QuickJSSandbox_readTempFile(name) {
|
|
642
|
+
return await (0, temp_files_1.readDevBrowserTempFile)(requireString(name, "File name"));
|
|
643
|
+
}, _QuickJSSandbox_cleanupAnonymousPages = async function _QuickJSSandbox_cleanupAnonymousPages(options = {}) {
|
|
644
|
+
const anonymousPages = [...__classPrivateFieldGet(this, _QuickJSSandbox_anonymousPages, "f")];
|
|
645
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_anonymousPages, "f").clear();
|
|
646
|
+
for (const page of anonymousPages) {
|
|
647
|
+
try {
|
|
648
|
+
if (!page.isClosed()) {
|
|
649
|
+
await page.close();
|
|
650
|
+
}
|
|
651
|
+
}
|
|
652
|
+
catch (error) {
|
|
653
|
+
if (!options.suppressErrors) {
|
|
654
|
+
throw error;
|
|
655
|
+
}
|
|
656
|
+
}
|
|
657
|
+
}
|
|
658
|
+
if (options.suppressErrors) {
|
|
659
|
+
try {
|
|
660
|
+
await __classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_flushTransportQueue).call(this);
|
|
661
|
+
}
|
|
662
|
+
catch {
|
|
663
|
+
// Best effort cleanup during sandbox teardown.
|
|
664
|
+
}
|
|
665
|
+
return;
|
|
666
|
+
}
|
|
667
|
+
await __classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_flushTransportQueue).call(this);
|
|
668
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_throwIfAsyncError).call(this);
|
|
669
|
+
}, _QuickJSSandbox_throwIfAsyncError = function _QuickJSSandbox_throwIfAsyncError() {
|
|
670
|
+
if (__classPrivateFieldGet(this, _QuickJSSandbox_asyncError, "f")) {
|
|
671
|
+
throw __classPrivateFieldGet(this, _QuickJSSandbox_asyncError, "f");
|
|
672
|
+
}
|
|
673
|
+
}, _QuickJSSandbox_assertAlive = function _QuickJSSandbox_assertAlive() {
|
|
674
|
+
if (__classPrivateFieldGet(this, _QuickJSSandbox_disposed, "f")) {
|
|
675
|
+
throw new Error("QuickJS sandbox has been disposed");
|
|
676
|
+
}
|
|
677
|
+
}, _QuickJSSandbox_assertInitialized = function _QuickJSSandbox_assertInitialized() {
|
|
678
|
+
__classPrivateFieldGet(this, _QuickJSSandbox_instances, "m", _QuickJSSandbox_assertAlive).call(this);
|
|
679
|
+
if (!__classPrivateFieldGet(this, _QuickJSSandbox_initialized, "f") || !__classPrivateFieldGet(this, _QuickJSSandbox_host, "f") || !__classPrivateFieldGet(this, _QuickJSSandbox_hostBridge, "f")) {
|
|
680
|
+
throw new Error("QuickJS sandbox has not been initialized");
|
|
681
|
+
}
|
|
682
|
+
};
|
|
683
|
+
//# sourceMappingURL=quickjs-sandbox.js.map
|