@intuned/runtime 1.3.17 → 1.3.18-interface.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bin/intuned +0 -0
- package/bin/intuned-interface +7 -0
- package/dist/chunk-6ZRJOUQS.mjs +16 -0
- package/dist/chunk-6ZRJOUQS.mjs.map +1 -0
- package/dist/chunk-7YL2JUTE.mjs +146 -0
- package/dist/chunk-7YL2JUTE.mjs.map +1 -0
- package/dist/chunk-B3T6RXPC.mjs +794 -0
- package/dist/chunk-B3T6RXPC.mjs.map +1 -0
- package/dist/chunk-FGV5T6SI.mjs +27 -0
- package/dist/chunk-FGV5T6SI.mjs.map +1 -0
- package/dist/chunk-G4PO5RIV.mjs +85 -0
- package/dist/chunk-G4PO5RIV.mjs.map +1 -0
- package/dist/chunk-LZOMFHX3.mjs +38 -0
- package/dist/chunk-LZOMFHX3.mjs.map +1 -0
- package/dist/{common/formatZodError.js → chunk-NDMVGENG.mjs} +9 -9
- package/dist/chunk-NDMVGENG.mjs.map +1 -0
- package/dist/chunk-W4UX6G4X.mjs +17 -0
- package/dist/chunk-W4UX6G4X.mjs.map +1 -0
- package/dist/chunk-XC75QGFG.mjs +1106 -0
- package/dist/chunk-XC75QGFG.mjs.map +1 -0
- package/dist/chunk-XOAZ2MGA.mjs +59 -0
- package/dist/chunk-XOAZ2MGA.mjs.map +1 -0
- package/dist/commands/interface/run.d.mts +3 -0
- package/dist/commands/interface/run.d.ts +3 -1
- package/dist/commands/interface/run.js +2060 -178
- package/dist/commands/interface/run.js.map +1 -0
- package/dist/commands/interface/run.mjs +255 -0
- package/dist/commands/interface/run.mjs.map +1 -0
- package/dist/common/asyncLocalStorage/index.d.mts +17 -0
- package/dist/common/asyncLocalStorage/index.d.ts +9 -8
- package/dist/common/asyncLocalStorage/index.js +34 -9
- package/dist/common/asyncLocalStorage/index.js.map +1 -0
- package/dist/common/asyncLocalStorage/index.mjs +12 -0
- package/dist/common/asyncLocalStorage/index.mjs.map +1 -0
- package/dist/common/binStartupScript.d.mts +2 -0
- package/dist/common/binStartupScript.d.ts +2 -1
- package/dist/common/binStartupScript.js +127 -11
- package/dist/common/binStartupScript.js.map +1 -0
- package/dist/common/binStartupScript.mjs +135 -0
- package/dist/common/binStartupScript.mjs.map +1 -0
- package/dist/common/cleanEnvironmentVariables.d.mts +3 -0
- package/dist/common/cleanEnvironmentVariables.d.ts +3 -1
- package/dist/common/cleanEnvironmentVariables.js +30 -7
- package/dist/common/cleanEnvironmentVariables.js.map +1 -0
- package/dist/common/cleanEnvironmentVariables.mjs +8 -0
- package/dist/common/cleanEnvironmentVariables.mjs.map +1 -0
- package/dist/common/constants.d.mts +13 -0
- package/dist/common/constants.d.ts +13 -10
- package/dist/common/constants.js +58 -14
- package/dist/common/constants.js.map +1 -0
- package/dist/common/constants.mjs +28 -0
- package/dist/common/constants.mjs.map +1 -0
- package/dist/common/contextStorageStateHelpers.d.mts +24 -0
- package/dist/common/contextStorageStateHelpers.d.ts +8 -5
- package/dist/common/contextStorageStateHelpers.js +51 -23
- package/dist/common/contextStorageStateHelpers.js.map +1 -0
- package/dist/common/contextStorageStateHelpers.mjs +10 -0
- package/dist/common/contextStorageStateHelpers.mjs.map +1 -0
- package/dist/common/jwtTokenManager.d.mts +19 -0
- package/dist/common/jwtTokenManager.d.ts +6 -4
- package/dist/common/jwtTokenManager.js +112 -40
- package/dist/common/jwtTokenManager.js.map +1 -0
- package/dist/common/jwtTokenManager.mjs +11 -0
- package/dist/common/jwtTokenManager.mjs.map +1 -0
- package/dist/common/runApi/index.d.mts +11 -0
- package/dist/common/runApi/index.d.ts +10 -10
- package/dist/common/runApi/index.js +1776 -93
- package/dist/common/runApi/index.js.map +1 -0
- package/dist/common/runApi/index.mjs +18 -0
- package/dist/common/runApi/index.mjs.map +1 -0
- package/dist/common/settingsSchema.d.mts +540 -0
- package/dist/common/settingsSchema.d.ts +58 -51
- package/dist/common/settingsSchema.js +55 -20
- package/dist/common/settingsSchema.js.map +1 -0
- package/dist/common/settingsSchema.mjs +10 -0
- package/dist/common/settingsSchema.mjs.map +1 -0
- package/dist/common/telemetry.d.mts +6 -0
- package/dist/common/telemetry.d.ts +6 -3
- package/dist/common/telemetry.js +41 -9
- package/dist/common/telemetry.js.map +1 -0
- package/dist/common/telemetry.mjs +31 -0
- package/dist/common/telemetry.mjs.map +1 -0
- package/dist/export.d-BAUMB-lG.d.mts +140 -0
- package/dist/export.d-BAUMB-lG.d.ts +140 -0
- package/dist/index.d.mts +6 -0
- package/dist/index.d.ts +6 -5
- package/dist/index.js +783 -98
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +47 -0
- package/dist/index.mjs.map +1 -0
- package/dist/runtime/index.d.mts +168 -0
- package/dist/runtime/index.d.ts +168 -10
- package/dist/runtime/index.js +779 -88
- package/dist/runtime/index.js.map +1 -0
- package/dist/runtime/index.mjs +42 -0
- package/dist/runtime/index.mjs.map +1 -0
- package/package.json +78 -23
- package/.babelrc +0 -21
- package/.eslintignore +0 -10
- package/.eslintrc.js +0 -39
- package/InterfaceTemplate/__utils.ts +0 -61
- package/InterfaceTemplate/index.playwright.ts +0 -6
- package/WebTemplate.zip +0 -0
- package/dist/commands/api/run.d.ts +0 -6
- package/dist/commands/api/run.js +0 -119
- package/dist/commands/auth-sessions/load.d.ts +0 -2
- package/dist/commands/auth-sessions/load.js +0 -35
- package/dist/commands/auth-sessions/run-check.d.ts +0 -2
- package/dist/commands/auth-sessions/run-check.js +0 -74
- package/dist/commands/auth-sessions/run-create.d.ts +0 -2
- package/dist/commands/auth-sessions/run-create.js +0 -78
- package/dist/commands/browser/save-state.d.ts +0 -2
- package/dist/commands/browser/save-state.js +0 -17
- package/dist/commands/browser/start-browser.d.ts +0 -2
- package/dist/commands/browser/start-browser.js +0 -14
- package/dist/commands/build.d.ts +0 -1
- package/dist/commands/build.js +0 -84
- package/dist/commands/common/browserUtils.d.ts +0 -14
- package/dist/commands/common/browserUtils.js +0 -58
- package/dist/commands/common/getFirstLineNumber.d.ts +0 -9
- package/dist/commands/common/getFirstLineNumber.js +0 -101
- package/dist/commands/common/getFirstLineNumber.test.js +0 -228
- package/dist/commands/common/projectExclusions.d.ts +0 -2
- package/dist/commands/common/projectExclusions.js +0 -8
- package/dist/commands/common/sendMessageToClient.d.ts +0 -1
- package/dist/commands/common/sendMessageToClient.js +0 -10
- package/dist/commands/common/tsNodeImport.d.ts +0 -2
- package/dist/commands/common/tsNodeImport.js +0 -43
- package/dist/commands/common/utils/fileUtils.d.ts +0 -6
- package/dist/commands/common/utils/fileUtils.js +0 -33
- package/dist/commands/common/utils/settings.d.ts +0 -2
- package/dist/commands/common/utils/settings.js +0 -31
- package/dist/commands/common/utils/template.d.ts +0 -2
- package/dist/commands/common/utils/template.js +0 -31
- package/dist/commands/common/utils/unixSocket.d.ts +0 -23
- package/dist/commands/common/utils/unixSocket.js +0 -87
- package/dist/commands/get-headless-user-agent.d.ts +0 -1
- package/dist/commands/get-headless-user-agent.js +0 -18
- package/dist/commands/intuned-cli/commands/attempt.command.d.ts +0 -1
- package/dist/commands/intuned-cli/commands/attempt.command.js +0 -8
- package/dist/commands/intuned-cli/commands/attempt_api.command.d.ts +0 -1
- package/dist/commands/intuned-cli/commands/attempt_api.command.js +0 -30
- package/dist/commands/intuned-cli/commands/attempt_authsession.command.d.ts +0 -1
- package/dist/commands/intuned-cli/commands/attempt_authsession.command.js +0 -8
- package/dist/commands/intuned-cli/commands/attempt_authsession_check.command.d.ts +0 -1
- package/dist/commands/intuned-cli/commands/attempt_authsession_check.command.js +0 -19
- package/dist/commands/intuned-cli/commands/attempt_authsession_create.command.d.ts +0 -1
- package/dist/commands/intuned-cli/commands/attempt_authsession_create.command.js +0 -24
- package/dist/commands/intuned-cli/commands/authsession.command.d.ts +0 -1
- package/dist/commands/intuned-cli/commands/authsession.command.js +0 -8
- package/dist/commands/intuned-cli/commands/authsession_record.command.d.ts +0 -1
- package/dist/commands/intuned-cli/commands/authsession_record.command.js +0 -32
- package/dist/commands/intuned-cli/commands/authsession_scaffold.command.d.ts +0 -1
- package/dist/commands/intuned-cli/commands/authsession_scaffold.command.js +0 -16
- package/dist/commands/intuned-cli/commands/build.command.d.ts +0 -1
- package/dist/commands/intuned-cli/commands/build.command.js +0 -12
- package/dist/commands/intuned-cli/commands/command.d.ts +0 -2
- package/dist/commands/intuned-cli/commands/command.js +0 -9
- package/dist/commands/intuned-cli/commands/deploy.command.d.ts +0 -1
- package/dist/commands/intuned-cli/commands/deploy.command.js +0 -42
- package/dist/commands/intuned-cli/commands/index.d.ts +0 -18
- package/dist/commands/intuned-cli/commands/index.js +0 -203
- package/dist/commands/intuned-cli/commands/provision.command.d.ts +0 -13
- package/dist/commands/intuned-cli/commands/provision.command.js +0 -50
- package/dist/commands/intuned-cli/commands/run.command.d.ts +0 -1
- package/dist/commands/intuned-cli/commands/run.command.js +0 -8
- package/dist/commands/intuned-cli/commands/run_api.command.d.ts +0 -1
- package/dist/commands/intuned-cli/commands/run_api.command.js +0 -46
- package/dist/commands/intuned-cli/commands/run_authsession.command.d.ts +0 -31
- package/dist/commands/intuned-cli/commands/run_authsession.command.js +0 -17
- package/dist/commands/intuned-cli/commands/run_authsession_create.command.d.ts +0 -1
- package/dist/commands/intuned-cli/commands/run_authsession_create.command.js +0 -35
- package/dist/commands/intuned-cli/commands/run_authsession_update.command.d.ts +0 -1
- package/dist/commands/intuned-cli/commands/run_authsession_update.command.js +0 -35
- package/dist/commands/intuned-cli/commands/run_authsession_validate.command.d.ts +0 -1
- package/dist/commands/intuned-cli/commands/run_authsession_validate.command.js +0 -33
- package/dist/commands/intuned-cli/commands/types.d.ts +0 -35
- package/dist/commands/intuned-cli/commands/types.js +0 -31
- package/dist/commands/intuned-cli/constants/index.d.ts +0 -17
- package/dist/commands/intuned-cli/constants/index.js +0 -25
- package/dist/commands/intuned-cli/controller/__test__/api.test.js +0 -398
- package/dist/commands/intuned-cli/controller/__test__/authSession.test.js +0 -1060
- package/dist/commands/intuned-cli/controller/api.d.ts +0 -42
- package/dist/commands/intuned-cli/controller/api.js +0 -194
- package/dist/commands/intuned-cli/controller/authSession.d.ts +0 -209
- package/dist/commands/intuned-cli/controller/authSession.js +0 -424
- package/dist/commands/intuned-cli/controller/build.d.ts +0 -1
- package/dist/commands/intuned-cli/controller/build.js +0 -36
- package/dist/commands/intuned-cli/controller/deploy.d.ts +0 -5
- package/dist/commands/intuned-cli/controller/deploy.js +0 -318
- package/dist/commands/intuned-cli/controller/index.d.ts +0 -1
- package/dist/commands/intuned-cli/controller/index.js +0 -46
- package/dist/commands/intuned-cli/controller/provision.d.ts +0 -21
- package/dist/commands/intuned-cli/controller/provision.js +0 -300
- package/dist/commands/intuned-cli/controller/scaffold.d.ts +0 -1
- package/dist/commands/intuned-cli/controller/scaffold.js +0 -77
- package/dist/commands/intuned-cli/helpers/__test__/browser.test.js +0 -115
- package/dist/commands/intuned-cli/helpers/__test__/tracing.test.js +0 -41
- package/dist/commands/intuned-cli/helpers/api.d.ts +0 -3
- package/dist/commands/intuned-cli/helpers/api.js +0 -16
- package/dist/commands/intuned-cli/helpers/auth.d.ts +0 -46
- package/dist/commands/intuned-cli/helpers/auth.js +0 -147
- package/dist/commands/intuned-cli/helpers/backend.d.ts +0 -8
- package/dist/commands/intuned-cli/helpers/backend.js +0 -35
- package/dist/commands/intuned-cli/helpers/browser.d.ts +0 -15
- package/dist/commands/intuned-cli/helpers/browser.js +0 -64
- package/dist/commands/intuned-cli/helpers/context.d.ts +0 -3
- package/dist/commands/intuned-cli/helpers/context.js +0 -33
- package/dist/commands/intuned-cli/helpers/errors.d.ts +0 -16
- package/dist/commands/intuned-cli/helpers/errors.js +0 -44
- package/dist/commands/intuned-cli/helpers/index.d.ts +0 -12
- package/dist/commands/intuned-cli/helpers/index.js +0 -137
- package/dist/commands/intuned-cli/helpers/intunedJson.d.ts +0 -39
- package/dist/commands/intuned-cli/helpers/intunedJson.js +0 -20
- package/dist/commands/intuned-cli/helpers/prompts.d.ts +0 -3
- package/dist/commands/intuned-cli/helpers/prompts.js +0 -71
- package/dist/commands/intuned-cli/helpers/proxy.d.ts +0 -5
- package/dist/commands/intuned-cli/helpers/proxy.js +0 -23
- package/dist/commands/intuned-cli/helpers/terminal.d.ts +0 -5
- package/dist/commands/intuned-cli/helpers/terminal.js +0 -13
- package/dist/commands/intuned-cli/helpers/timeout.d.ts +0 -1
- package/dist/commands/intuned-cli/helpers/timeout.js +0 -23
- package/dist/commands/intuned-cli/helpers/traces.d.ts +0 -2
- package/dist/commands/intuned-cli/helpers/traces.js +0 -32
- package/dist/commands/intuned-cli/helpers/validation.d.ts +0 -2
- package/dist/commands/intuned-cli/helpers/validation.js +0 -14
- package/dist/commands/intuned-cli/helpers/wrapper.d.ts +0 -2
- package/dist/commands/intuned-cli/helpers/wrapper.js +0 -76
- package/dist/commands/intuned-cli/index.d.ts +0 -1
- package/dist/commands/intuned-cli/index.js +0 -16
- package/dist/commands/intuned-cli/main.d.ts +0 -1
- package/dist/commands/intuned-cli/main.js +0 -36
- package/dist/commands/intuned-cli/types.d.ts +0 -70
- package/dist/commands/intuned-cli/types.js +0 -22
- package/dist/commands/ts-check.d.ts +0 -2
- package/dist/commands/ts-check.js +0 -56
- package/dist/common/Logger/Logger/index.d.ts +0 -12
- package/dist/common/Logger/Logger/index.js +0 -60
- package/dist/common/Logger/Logger/types.d.ts +0 -8
- package/dist/common/Logger/Logger/types.js +0 -5
- package/dist/common/Logger/index.d.ts +0 -12
- package/dist/common/Logger/index.js +0 -60
- package/dist/common/Logger/types.d.ts +0 -8
- package/dist/common/Logger/types.js +0 -5
- package/dist/common/backendFunctions/getAuthSessionParameters.d.ts +0 -1
- package/dist/common/backendFunctions/getAuthSessionParameters.js +0 -38
- package/dist/common/extension/extensionsHelpers.d.ts +0 -11
- package/dist/common/extension/extensionsHelpers.js +0 -147
- package/dist/common/extension/intunedExtensionServer.d.ts +0 -24
- package/dist/common/extension/intunedExtensionServer.js +0 -178
- package/dist/common/extension/types.d.ts +0 -212
- package/dist/common/extension/types.js +0 -51
- package/dist/common/formatZodError.d.ts +0 -2
- package/dist/common/intunedJson.d.ts +0 -229
- package/dist/common/intunedJson.js +0 -133
- package/dist/common/launchBrowser.d.ts +0 -33
- package/dist/common/launchBrowser.js +0 -235
- package/dist/common/playwrightContext.d.ts +0 -31
- package/dist/common/playwrightContext.js +0 -150
- package/dist/common/runApi/errors.d.ts +0 -72
- package/dist/common/runApi/errors.js +0 -169
- package/dist/common/runApi/importUsingImportFunction.d.ts +0 -9
- package/dist/common/runApi/importUsingImportFunction.js +0 -46
- package/dist/common/runApi/types.d.ts +0 -830
- package/dist/common/runApi/types.js +0 -73
- package/dist/common/setupContextHook.d.ts +0 -17
- package/dist/common/setupContextHook.js +0 -22
- package/dist/runtime/RunError.d.ts +0 -5
- package/dist/runtime/RunError.js +0 -19
- package/dist/runtime/attemptStore.d.ts +0 -2
- package/dist/runtime/attemptStore.js +0 -23
- package/dist/runtime/captcha.d.ts +0 -15
- package/dist/runtime/captcha.js +0 -191
- package/dist/runtime/captcha.test.js +0 -821
- package/dist/runtime/downloadDirectory.d.ts +0 -1
- package/dist/runtime/downloadDirectory.js +0 -19
- package/dist/runtime/enums.d.js +0 -5
- package/dist/runtime/enums.d.ts +0 -11
- package/dist/runtime/enums.js +0 -18
- package/dist/runtime/executionHelpers.test.js +0 -52
- package/dist/runtime/export.d.js +0 -5
- package/dist/runtime/export.d.ts +0 -284
- package/dist/runtime/extendPayload.d.ts +0 -2
- package/dist/runtime/extendPayload.js +0 -21
- package/dist/runtime/extendTimeout.d.ts +0 -1
- package/dist/runtime/extendTimeout.js +0 -23
- package/dist/runtime/getAiGatewayConfig.d.ts +0 -10
- package/dist/runtime/getAiGatewayConfig.js +0 -16
- package/dist/runtime/getAuthSessionParameters.d.ts +0 -1
- package/dist/runtime/getAuthSessionParameters.js +0 -20
- package/dist/runtime/persistentStore.d.ts +0 -2
- package/dist/runtime/persistentStore.js +0 -37
- package/dist/runtime/persistentStore.test.js +0 -101
- package/dist/runtime/runInfo.d.ts +0 -2
- package/dist/runtime/runInfo.js +0 -21
- package/template.tsconfig.json +0 -11
- package/tsconfig.eslint.json +0 -5
- package/tsconfig.json +0 -25
- package/typedoc.json +0 -49
- /package/dist/common/assets/{browser_scripts.js → assets/browser_scripts.js} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../packages/runtime-interface/src/errors.ts","../../../../packages/runtime-interface/src/types.ts","../../../../packages/runtime-interface/src/interfaceClient.ts","../../../../packages/runtime-interface/src/index.ts","../../../src/commands/interface/run.ts","../../../src/common/asyncLocalStorage/index.ts","../../../src/runtime/attemptStore.ts","../../../src/runtime/persistentStore.ts","../../../src/common/jwtTokenManager.ts","../../../src/common/constants.ts","../../../src/runtime/RunError.ts","../../../src/common/extension/intunedExtensionServer.ts","../../../src/common/extension/types.ts","../../../src/commands/common/utils/fileUtils.ts","../../../src/common/settingsSchema.ts","../../../src/commands/common/utils/settings.ts","../../../src/common/extension/extensionsHelpers.ts","../../../src/runtime/downloadDirectory.ts","../../../src/common/runApi/index.ts","../../../src/common/contextStorageStateHelpers.ts","../../../src/common/playwrightContext.ts","../../../src/common/setupContextHook.ts","../../../src/common/runApi/importUsingImportFunction.ts","../../../src/common/launchBrowser.ts","../../../src/common/formatZodError.ts","../../../src/common/cleanEnvironmentVariables.ts","../../../src/common/backendFunctions/getAuthSessionParameters.ts"],"sourcesContent":["// import { RunError } from \"../../runtime\";\n// import { RunErrorOptions } from \"../../runtime/export\";\n\nexport const apiNotFoundErrorCode = \"APINotFoundError\";\nexport const invalidApiErrorCode = \"InvalidAPIError\";\nexport const invalidCheckErrorCode = \"InvalidCheckError\";\nexport const abortedErrorCode = \"AbortedError\";\nexport const authRequiredErrorCode = \"AuthRequiredError\";\nexport const authCheckNotFoundErrorCode = \"AuthCheckNotFoundError\";\nexport const authCheckFailedErrorCode = \"AuthCheckFailedError\";\nexport const maxLevelsExceededErrorCode = \"MaxLevelsExceededError\";\nexport const automationError = \"AutomationError\";\nexport const internalInvalidInputErrorCode = \"InternalInvalidInputError\";\nexport const resultTooBigErrorCode = \"ResultTooBigError\";\n\nexport const runAutomationErrorCodes = [\n apiNotFoundErrorCode,\n invalidApiErrorCode,\n invalidCheckErrorCode,\n abortedErrorCode,\n authRequiredErrorCode,\n authCheckNotFoundErrorCode,\n authCheckFailedErrorCode,\n maxLevelsExceededErrorCode,\n automationError,\n internalInvalidInputErrorCode,\n resultTooBigErrorCode,\n] as const;\n\nexport type RunAutomationErrorCode = (typeof runAutomationErrorCodes)[number];\n\nexport type RunAutomationErrorJSON = {\n code: RunAutomationErrorCode;\n details?: any;\n cause?: RunAutomationErrorJSON;\n [key: string]: any;\n};\n\nexport abstract class RunAutomationError<T = any> {\n cause?: RunAutomationError;\n details?: T;\n\n constructor(public code: RunAutomationErrorCode, public message: string) {}\n\n get json(): RunAutomationErrorJSON {\n return {\n code: this.code,\n details: this.details,\n cause: this.cause?.json,\n };\n }\n}\n\nexport class ApiNotFoundError extends RunAutomationError {\n constructor(apiName: string) {\n super(apiNotFoundErrorCode, `API ${apiName} not found`);\n }\n}\n\nexport class InvalidApiError extends RunAutomationError {\n constructor(message: string) {\n super(invalidApiErrorCode, `API is invalid: ${message}`);\n\n this.details = {\n message,\n };\n }\n}\n\nexport class InvalidCheckError extends RunAutomationError {\n constructor(message: string, cause?: RunAutomationError) {\n super(invalidCheckErrorCode, message);\n this.cause = cause;\n }\n}\n\nexport class AbortedError extends RunAutomationError {\n constructor() {\n super(abortedErrorCode, \"Operation was aborted\");\n }\n}\n\nexport class AuthRequiredError extends RunAutomationError {\n constructor() {\n super(authRequiredErrorCode, \"AuthSessions are required\");\n }\n}\n\nexport class AuthCheckNotFoundError extends RunAutomationError {\n constructor() {\n super(authCheckNotFoundErrorCode, \"AuthSession check not found\");\n }\n}\n\nexport class AuthCheckFailedError extends RunAutomationError {\n constructor() {\n super(authCheckFailedErrorCode, \"AuthSession check failed\");\n }\n}\n\nexport class MaxLevelsExceededError extends RunAutomationError<{\n levels: number;\n}> {\n constructor(levels: number) {\n super(\n maxLevelsExceededErrorCode,\n `Max levels exceeded. Only ${levels} levels are supported`\n );\n this.details = { levels };\n }\n}\n\nexport class AutomationError extends RunAutomationError<{\n name?: string;\n message?: string;\n statusCode?: number;\n errorCode?: string;\n}> {\n error: any;\n\n constructor(error: any) {\n super(automationError, `[${error?.name ?? error}] ${error?.message}`);\n this.details = {\n ...error,\n };\n }\n}\n\nexport class InternalInvalidInputError extends RunAutomationError {\n constructor(message: string, details?: any) {\n super(internalInvalidInputErrorCode, message);\n this.details = details;\n }\n}\n\nexport class ResultTooBigError extends RunAutomationError<{\n sizeInBytes: number;\n maxSizeInBytes: number;\n}> {\n constructor(sizeInBytes: number, maxSizeInBytes: number) {\n super(\n resultTooBigErrorCode,\n `Automation result is too big. Size: ${\n Math.round((sizeInBytes / 1024 / 1024) * 100) / 100\n }MB, Max allowed: ${\n Math.round((maxSizeInBytes / 1024 / 1024) * 100) / 100\n }MB`\n );\n this.details = { sizeInBytes, maxSizeInBytes };\n }\n}\n","import type { Result } from \"neverthrow\";\nimport type { RunAutomationError } from \"./errors\";\nimport z from \"zod\";\n\nexport type Payload = {\n api: string;\n parameters: any;\n};\nexport interface PayloadToAppend {\n apiName: string;\n parameters: Record<string, any>;\n}\n\nexport interface RunAutomationSuccessResult {\n result: any;\n status: number;\n payloadToAppend: PayloadToAppend[] | null;\n session?: RunApiStorageState;\n}\n\nexport interface RunAutomationErrorResult {\n error: string;\n message: string;\n status?: number;\n details?: any;\n [key: string]: any;\n}\n\nexport type RunAutomationResult =\n | RunAutomationSuccessResult\n | RunAutomationErrorResult;\n\nexport interface RunAutomationResponse {\n status: number;\n body: RunAutomationResult;\n}\n\nexport const runApiStorageStateSchema = z.object({\n cookies: z.array(\n z.object({\n name: z.string(),\n value: z.string(),\n domain: z.string(),\n path: z.string(),\n expires: z.number(),\n httpOnly: z.boolean(),\n secure: z.boolean(),\n sameSite: z.enum([\"Strict\", \"Lax\", \"None\"]),\n })\n ),\n origins: z.array(\n z.object({\n origin: z.string(),\n localStorage: z.array(\n z.object({\n name: z.string(),\n value: z.string(),\n })\n ),\n })\n ),\n sessionStorage: z\n .array(\n z.object({\n origin: z.string(),\n sessionStorage: z.array(\n z.object({\n name: z.string(),\n value: z.string(),\n })\n ),\n })\n )\n .optional(),\n});\n\nexport type RunApiStorageState = z.input<typeof runApiStorageStateSchema>;\n\nexport const runApiSessionSchema = z.discriminatedUnion(\"type\", [\n z.object({\n type: z.literal(\"file\"),\n path: z.string(),\n }),\n z.object({\n type: z.literal(\"state\"),\n state: runApiStorageStateSchema.nullable().optional(),\n }),\n]);\n\nexport const runApiAutomationFunctionSchema = z.object({\n name: z.string(),\n params: z.any().optional(),\n});\n\nexport type RunApiAutomationFunction = z.infer<\n typeof runApiAutomationFunctionSchema\n>;\n\nexport const runApiTracingSchema = z\n .discriminatedUnion(\"enabled\", [\n z.object({ enabled: z.literal(false) }),\n z.object({ enabled: z.literal(true), filePath: z.string() }),\n ])\n .optional()\n .default({ enabled: false });\n\nexport type RunApiTracing = z.infer<typeof runApiTracingSchema>;\n\nexport const runApiAuthSchema = z\n .object({\n session: runApiSessionSchema,\n parameters: z.record(z.any()).optional(),\n })\n .optional();\n\nexport type RunApiAuth = z.infer<typeof runApiAuthSchema>;\n\nexport const runApiStandaloneRunOptionsSchema = z.object({\n environment: z.literal(\"standalone\"),\n headless: z.boolean().default(true),\n proxy: z\n .object({\n server: z.string(),\n username: z.string(),\n password: z.string(),\n })\n .optional(),\n});\n\nexport type RunApiStandaloneRunOptions = z.infer<\n typeof runApiStandaloneRunOptionsSchema\n>;\n\nexport const runApiCdpRunOptionsSchema = z.object({\n environment: z.literal(\"cdp\"),\n cdpAddress: z.string(),\n cdpTargetId: z.string().optional(),\n});\n\nexport type RunApiCdpRunOptions = z.infer<typeof runApiCdpRunOptionsSchema>;\n\nexport const runApiRunOptionsSchema = z\n .discriminatedUnion(\"environment\", [\n runApiStandaloneRunOptionsSchema,\n runApiCdpRunOptionsSchema,\n ])\n .default({ environment: \"standalone\", headless: true });\n\nexport type RunApiRunOptions = z.infer<typeof runApiRunOptionsSchema>;\n\nexport const runApiParametersSchema = z.object({\n automationFunction: runApiAutomationFunctionSchema,\n tracing: runApiTracingSchema,\n auth: runApiAuthSchema,\n runOptions: runApiRunOptionsSchema,\n retrieveSession: z.boolean().default(false),\n});\n\nexport type RunApiSession = z.infer<typeof runApiSessionSchema>;\n\nexport type RunApiParameters = z.input<typeof runApiParametersSchema>;\n\nexport type ImportFunctionError =\n | {\n type: \"not_found\";\n }\n | {\n type: \"other\";\n error: any;\n };\n\nexport type ImportFunction = (\n name: string\n) => Promise<Result<any, ImportFunctionError>>;\n\nexport type ExtendedRunApiParameters = RunApiParameters & {\n abortSignal?: AbortSignal;\n importFunction: ImportFunction;\n};\n\nexport function runApiResultOkSchema<R extends any>(\n resultSchema: z.ZodType<R>\n) {\n return z.object({\n result: resultSchema,\n extendedPayloads: z\n .array(\n z.object({\n api: z.string(),\n parameters: z.record(z.any()),\n })\n )\n .optional(),\n });\n}\n\nexport type RunApiResultOk<R = any> = {\n result: R;\n extendedPayloads: Payload[] | undefined;\n};\n\nexport function runApiResultWithSessionOkSchema<R extends any>(\n resultSchema: z.ZodType<R>\n) {\n return runApiResultOkSchema(resultSchema).extend({\n session: runApiStorageStateSchema,\n });\n}\n\nexport type RunApiResultWithSessionOk<R = any> = RunApiResultOk<R> & {\n session: RunApiStorageState;\n};\n\nexport type RunApiResult<\n R = any,\n FullResult extends RunApiResultOk<R> = RunApiResultOk<R>\n> = Result<FullResult, RunAutomationError>;\n\n// incoming messages\n\nexport const startRunApiParametersSchema = runApiParametersSchema.extend({\n retrieveSession: z.boolean(),\n functionsToken: z.string().optional(),\n context: z\n .object({\n jobId: z.string().optional(),\n jobRunId: z.string().optional(),\n runId: z.string().optional(),\n queueId: z.string().optional(),\n authSessionId: z.string().optional(),\n })\n .optional(),\n});\n\nexport type StartRunApiParameters = z.infer<typeof startRunApiParametersSchema>;\n\nexport const startRunApiSchema = z.object({\n type: z.literal(\"start\"),\n parameters: startRunApiParametersSchema,\n});\n\nexport type StartRunApiMessage = z.infer<typeof startRunApiSchema>;\n\nexport const abortRunApiSchema = z.object({\n type: z.literal(\"abort\"),\n parameters: z.object({}).optional(),\n});\n\nexport type AbortRunApiMessage = z.infer<typeof abortRunApiSchema>;\n\nexport const tokenUpdateSchema = z.object({\n type: z.literal(\"tokenUpdate\"),\n parameters: z.object({\n functionsToken: z.string(),\n }),\n});\n\nexport type TokenUpdateMessage = z.infer<typeof tokenUpdateSchema>;\n\nexport const pingSchema = z.object({\n type: z.literal(\"ping\"),\n parameters: z.object({}).optional(),\n});\n\nexport type PingMessage = z.infer<typeof pingSchema>;\n\nexport const runApiInputSchema = z.union([\n startRunApiSchema,\n abortRunApiSchema,\n tokenUpdateSchema,\n pingSchema,\n]);\n\nexport type RunApiInputMessage = z.infer<typeof runApiInputSchema>;\n\n// outgoing messages\n\nexport const extendMessageSchema = z.object({ type: z.literal(\"extend\") });\n\nexport type ExtendMessage = z.infer<typeof extendMessageSchema>;\n\nexport const doneMessageSchema = z.object({\n type: z.literal(\"done\"),\n result: z.any(),\n success: z.boolean(),\n});\n\nexport type DoneMessage = z.infer<typeof doneMessageSchema>;\n\nexport const pongMessageSchema = z.object({\n type: z.literal(\"pong\"),\n});\n\nexport type PongMessage = z.infer<typeof pongMessageSchema>;\n\nexport const outputRunApiSchema = z.union([\n extendMessageSchema,\n doneMessageSchema,\n pongMessageSchema,\n]);\n\nexport type RunApiOutputMessage = z.infer<typeof outputRunApiSchema>;\n","import * as net from \"net\";\nimport * as fs from \"fs-extra\";\nimport { createInterface } from \"readline\";\nimport { setTimeout } from \"timers/promises\";\n\nexport interface InterfaceClient {\n sendJSON(data: any): void;\n receiveJSON(): AsyncGenerator<any, void, unknown>;\n close(): void;\n get closed(): boolean;\n}\n\nexport class SocketClient implements InterfaceClient {\n static readonly LENGTH_HEADER_LENGTH = 4;\n protected readonly socket: net.Socket;\n\n constructor(socket: net.Socket) {\n this.socket = socket;\n }\n\n sendJSON(data: any) {\n const dataToSend = JSON.stringify(data);\n // calculate length\n const length = Buffer.byteLength(dataToSend);\n // create buffer\n const buffer = Buffer.alloc(SocketClient.LENGTH_HEADER_LENGTH + length);\n\n // write length in big endian\n buffer.writeUInt32BE(length, 0);\n // write data\n buffer.write(dataToSend, SocketClient.LENGTH_HEADER_LENGTH);\n\n this.socket.write(buffer);\n }\n\n async *receiveJSON() {\n let buffer = Buffer.alloc(0);\n const endPromise = new Promise<void>((resolve, reject) => {\n this.socket.once(\"end\", () => {\n resolve();\n });\n this.socket.once(\"error\", reject);\n });\n\n while (true) {\n const chunk = await Promise.race([\n new Promise<Buffer>((resolve) =>\n this.socket.once(\"data\", (data) => {\n if(typeof data === \"string\") {\n return resolve(Buffer.from(data));\n }\n resolve(data);\n })\n ),\n endPromise,\n ]);\n\n if (!(chunk instanceof Buffer)) {\n break;\n }\n\n buffer = Buffer.concat([buffer, chunk]);\n\n const length = buffer.readUInt32BE(0);\n if (buffer.length < length + SocketClient.LENGTH_HEADER_LENGTH) {\n continue;\n }\n\n const data = buffer.subarray(\n SocketClient.LENGTH_HEADER_LENGTH,\n length + SocketClient.LENGTH_HEADER_LENGTH\n );\n buffer = buffer.subarray(length + SocketClient.LENGTH_HEADER_LENGTH);\n\n yield JSON.parse(data.toString());\n }\n }\n\n async close() {\n this.socket.end();\n\n await Promise.race([\n new Promise((resolve) => this.socket.once(\"close\", resolve)),\n new Promise((resolve) => this.socket.once(\"error\", resolve)),\n setTimeout(3000),\n ]);\n }\n\n get closed(): boolean {\n return this.socket.closed;\n }\n}\n\nexport class UnixSocketClient extends SocketClient {\n constructor(path: string) {\n super(net.createConnection(path));\n }\n}\n\nexport class TCPSocketClient extends SocketClient {\n constructor(host: string, port: number) {\n super(net.createConnection(port, host));\n }\n}\n\nexport class JSONLFileClient implements InterfaceClient {\n private readonly fileStream: fs.ReadStream;\n constructor(filePath: string) {\n this.fileStream = fs.createReadStream(filePath, { encoding: \"utf-8\" });\n }\n\n sendJSON(data: any) {\n console.log(\"Sending message\", data);\n }\n\n async *receiveJSON() {\n const rl = createInterface({\n input: this.fileStream,\n crlfDelay: Infinity,\n });\n\n for await (const line of rl) {\n if (line.trim() === \"\") {\n continue;\n }\n yield JSON.parse(line);\n }\n }\n\n async close() {\n this.fileStream.close();\n\n await Promise.race([\n new Promise((resolve) => this.fileStream.once(\"close\", resolve)),\n new Promise((resolve) => this.fileStream.once(\"error\", resolve)),\n setTimeout(3000),\n ]);\n }\n\n get closed(): boolean {\n return this.fileStream.closed;\n }\n}\n","export * from \"./errors\";\nexport * from \"./types\";\nexport * from \"./interfaceClient\";","import { program } from \"commander\";\nimport dotenv from \"dotenv\";\nimport {\n runWithContext,\n InternalRunInfo,\n} from \"../../common/asyncLocalStorage\";\nimport { runApi } from \"../../common/runApi\";\nimport { RunEnvironment } from \"../../runtime/enums\";\nimport { setTimeout } from \"timers/promises\";\nimport { backendFunctionsTokenManager } from \"../../common/jwtTokenManager\";\nimport { formatZodError } from \"../../common/formatZodError\";\nimport { err, ok } from \"neverthrow\";\nimport { getAuthSessionParameters } from \"../../common/backendFunctions/getAuthSessionParameters\";\nimport {\n RunApiParameters,\n InternalInvalidInputError,\n RunApiInputMessage,\n runApiInputSchema,\n JSONLFileClient,\n TCPSocketClient,\n UnixSocketClient,\n ImportFunction,\n} from \"@intuned/runtime-interface\";\n\ndotenv.config({\n path: `.env`,\n});\n\nexport function runAutomationCLI<ResultType = any>(\n importFunction?: (path: string) => Promise<any>\n) {\n program\n .description(\"run user automation and communicate using unix socket\")\n .argument(\n \"<input>\",\n \"In unix socket mode: path to the unix socket. In jsonl mode: path to the jsonl file. In tcp socket mode: host:port\"\n )\n .option(\"--mode [mode]\", \"Communication mode: unix, jsonl, or tcp\")\n .action(\n async (\n input: string,\n {\n mode = \"unix\",\n }: {\n mode: \"unix\" | \"jsonl\" | \"tcp\";\n }\n ) => {\n let context: InternalRunInfo;\n const throttleTime = 60 * 1000; // 1 minute\n let timeoutTimestamp = Date.now();\n\n const client = createClient(mode, input);\n\n const abortController = new AbortController();\n\n const interruptSignalHandler = async () => {\n abortController.abort();\n // wait for the script to finish gracefully\n await setTimeout(60_000);\n await client.close();\n process.exit(1);\n };\n\n process.on(\"SIGINT\", interruptSignalHandler);\n process.on(\"SIGTERM\", interruptSignalHandler);\n\n const messagesGenerator = client.receiveJSON();\n\n async function receiveMessages() {\n const data = await messagesGenerator.next();\n if (data.done) {\n return;\n }\n const inputParseResult = runApiInputSchema.safeParse(data.value);\n if (!inputParseResult.success) {\n console.error(\n \"Validation error:\",\n formatZodError(inputParseResult.error)\n );\n return {\n type: \"error\" as const,\n error: new InternalInvalidInputError(\n \"Invalid input\",\n formatZodError(inputParseResult.error)\n ),\n };\n }\n const input = inputParseResult.data;\n return input;\n }\n\n let resultPromise: ReturnType<typeof runApi<ResultType>> | null =\n null as any;\n\n async function handleMessage(message: RunApiInputMessage) {\n if (message.type === \"abort\") {\n abortController.abort();\n return;\n }\n if (message.type === \"tokenUpdate\") {\n backendFunctionsTokenManager.token =\n message.parameters.functionsToken;\n return;\n }\n if (message.type === \"start\") {\n context = {\n extendedPayloads: [],\n runEnvironment:\n message.parameters.runOptions.environment === \"standalone\"\n ? RunEnvironment.DEPLOYED\n : RunEnvironment.IDE,\n timeoutInfo: {\n extendTimeoutCallback: async () => {\n if (Date.now() - timeoutTimestamp < throttleTime) return;\n timeoutTimestamp = Date.now();\n client.sendJSON({ type: \"extend\" });\n },\n },\n getAuthSessionParameters,\n\n ...(message.parameters.context ?? {}),\n proxy: getProxyUrlFromRunOptions(message.parameters.runOptions),\n };\n backendFunctionsTokenManager.token =\n message.parameters.functionsToken;\n resultPromise = runWithContext(context, async () => {\n return await runApi<ResultType>({\n ...message.parameters,\n abortSignal: abortController.signal,\n importFunction: importFunction ?? _defaultImport,\n });\n });\n return;\n }\n }\n\n let receiveMessagesPromise = receiveMessages();\n\n while (true as boolean) {\n const messageOrResult = await Promise.race([\n receiveMessagesPromise.then((message) => ({\n type: \"message\" as const,\n message,\n })),\n ...(resultPromise\n ? [\n resultPromise.then((result) => ({\n type: \"result\" as const,\n result,\n })),\n ]\n : []),\n ]);\n if (messageOrResult.type === \"message\") {\n const { message } = messageOrResult;\n if (message === undefined) {\n break;\n }\n if (message.type === \"error\") {\n client.sendJSON({\n type: \"done\",\n result: message.error.json,\n success: false,\n });\n break;\n }\n if (message.type === \"ping\") {\n client.sendJSON({\n type: \"pong\",\n });\n break;\n }\n await handleMessage(message);\n receiveMessagesPromise = receiveMessages();\n continue;\n }\n const { result } = messageOrResult;\n const success = result.isOk();\n const resultToSend = success ? result.value : result.error.json;\n client.sendJSON({\n type: \"done\",\n result: resultToSend,\n success,\n });\n break;\n }\n\n if (!client.closed) {\n await client.close();\n }\n\n process.exit(0);\n }\n );\n\n program.parse(process.argv);\n}\n\nfunction getProxyUrlFromRunOptions(runOptions: RunApiParameters[\"runOptions\"]) {\n if (runOptions?.environment !== \"standalone\") return undefined;\n const proxy = runOptions.proxy;\n if (!proxy) return undefined;\n const url = new URL(proxy.server);\n url.username = proxy.username;\n url.password = proxy.password;\n return url.toString();\n}\n\n// this is only for debugging purposes\nconst _defaultImport: ImportFunction = async (path) => {\n try {\n const imported = await import(`${process.cwd()}/${path}`);\n return ok(imported);\n } catch (e: any) {\n if (\n (\"code\" in e && e.code === \"MODULE_NOT_FOUND\") ||\n e.code === \"ERR_MODULE_NOT_FOUND\"\n ) {\n return err({\n type: \"not_found\",\n });\n }\n return err({\n type: \"other\",\n error: e,\n });\n }\n};\n\nfunction createClient(mode: \"unix\" | \"jsonl\" | \"tcp\", input: string) {\n if (mode === \"jsonl\") {\n return new JSONLFileClient(input);\n }\n if (mode === \"tcp\") {\n const [host, portString] = input.split(\":\");\n const port = Number(portString);\n if (!host || isNaN(port)) {\n throw new Error(\"Invalid tcp input, expected format host:port\");\n }\n return new TCPSocketClient(host, port);\n }\n return new UnixSocketClient(input);\n}\n\nif (require.main === module) {\n runAutomationCLI();\n}\n","import { AsyncLocalStorage } from \"node:async_hooks\";\nimport { Payload, RunInfo } from \"../../runtime/export\";\n\nexport const asyncLocalStorage = new AsyncLocalStorage<InternalRunInfo>();\n\nexport function runWithContext<R, TArgs extends any[]>(\n contextData: InternalRunInfo,\n callback: (...args: TArgs) => R,\n ...args: TArgs\n): R {\n return asyncLocalStorage.run(contextData, callback, ...args);\n}\n\ninterface TimeoutInfo {\n extendTimeoutCallback?: () => Promise<void>;\n}\n\nexport interface InternalRunInfo extends RunInfo {\n extendedPayloads: Payload[];\n timeoutInfo?: TimeoutInfo;\n store?: Record<string, any>;\n getAuthSessionParameters?: () => Promise<any>;\n}\n\nexport function getExecutionContext() {\n const contextData = asyncLocalStorage.getStore();\n\n return contextData;\n}\n","import { getExecutionContext } from \"../common/asyncLocalStorage\";\nimport { AttemptStore } from \"./export\";\n\nexport const attemptStore: AttemptStore = Object.freeze({\n get: (key: string) => {\n const context = getExecutionContext();\n return context?.store ? context.store[key] : undefined;\n },\n set: (key: string, value: any) => {\n const context = getExecutionContext();\n if (!context) {\n throw new Error(\"store.set failed due to an internal error.\");\n }\n if (!context.store) {\n context.store = {};\n }\n context.store[key] = value;\n },\n});\n","import { z } from \"zod\";\nimport { callBackendFunctionWithToken } from \"../common/jwtTokenManager\";\nimport type { PersistentStore } from \"./export\";\n\nconst forbiddenCharacters = /[:#]/g;\n\nconst keySchema = z\n .string()\n .min(1, \"Key must be at least 1 character long\")\n .refine(\n (key) => (key.match(forbiddenCharacters)?.length ?? 0) === 0,\n 'Key cannot contain the following characters: \":\" or \"#\"'\n );\n\nexport const persistentStore: PersistentStore = Object.freeze({\n get: async (key: string) => {\n const parsedKey = keySchema.parse(key);\n const response = await callBackendFunctionWithToken(\n `kv-store/${parsedKey}`,\n {\n method: \"GET\",\n }\n );\n const json = await response.json();\n if (!response.ok) {\n throw new Error(json.message);\n }\n return json.value;\n },\n set: async (key: string, value: any) => {\n const keyResult = keySchema.parse(key);\n const response = await callBackendFunctionWithToken(\n `kv-store/${keyResult}`,\n {\n method: \"PUT\",\n body: JSON.stringify(value),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n }\n );\n const json = await response.json();\n if (!response.ok) {\n throw new Error(json.message);\n }\n },\n});\n","import fetch from \"cross-fetch\";\nimport * as jwt from \"jsonwebtoken\";\nimport { err, ResultAsync } from \"neverthrow\";\nimport {\n API_KEY_ENV_VAR_KEY,\n API_KEY_HEADER_NAME,\n PROJECT_ID_ENV_VAR_KEY,\n CLI_ENV_VAR_KEY,\n WORKSPACE_ID_ENV_VAR_KEY,\n AUTH_TOKEN_ENV_VAR_KEY,\n} from \"./constants\";\n\n// Manages JWT token with renewal\nclass JwtTokenManager {\n private _token: string | undefined;\n private tokenRefreshTimeout: NodeJS.Timeout | undefined;\n private refreshTokenPath: string;\n\n constructor(refreshTokenPath: string) {\n this.refreshTokenPath = refreshTokenPath;\n this._token = undefined;\n }\n\n public get token() {\n return this._token;\n }\n\n // When the token is set, the schedule for renewal is issued automatically\n // This is currently being set it two places:\n // 1. Whenever the runner starts, initializes it from the environment variable (set whenever the api is run from the authoring IDE)\n // 2. Whenever a published api is called to run (/api/run/*), it is set to the token received in the run request.\n public set token(newToken: string | undefined) {\n if (this._token != newToken) {\n this._token = newToken;\n void this.scheduleTokenRefresh();\n }\n }\n\n private get timeToRefresh() {\n if (!this._token) return;\n\n const payload = jwt.decode(this._token);\n\n if (!payload || typeof payload == \"string\") return;\n\n const expiry = payload.expiry;\n if (!expiry || typeof expiry !== \"number\") return;\n\n const timeWindow = 60 * 1000; // 1 minute\n\n const timeToRefresh = expiry - Date.now() - timeWindow;\n return Math.max(timeToRefresh, timeWindow);\n }\n\n private async scheduleTokenRefresh() {\n if (process.env.RUN_ENVIRONMENT?.toLowerCase() !== \"authoring\") return;\n const timeToRefresh = this.timeToRefresh;\n if (timeToRefresh === undefined) return;\n\n if (this.tokenRefreshTimeout) clearTimeout(this.tokenRefreshTimeout);\n\n this.tokenRefreshTimeout = setTimeout(async () => {\n const result = await this.refreshToken();\n if (result && result.isErr()) {\n console.error(`[Internal Error] ${result.error}`);\n return;\n }\n await this.scheduleTokenRefresh();\n }, timeToRefresh);\n }\n\n private async refreshToken() {\n if (process.env.RUN_ENVIRONMENT?.toLowerCase() !== \"authoring\") return;\n const res = await this.fetchWithToken(\n `${this.backendFunctionsBaseUrl}/${this.refreshTokenPath}`,\n {\n method: \"GET\",\n }\n );\n\n if (res.status === 401) {\n return err(\"Unauthorized\");\n }\n\n const jsonResult = await ResultAsync.fromPromise(\n res.json(),\n () => \"not json\"\n );\n\n if (jsonResult.isErr()) return;\n\n const newToken = jsonResult.value.token;\n if (newToken) this._token = newToken;\n }\n\n public async fetchWithToken(...[input, init]: Parameters<typeof fetch>) {\n const headers = new Headers(init?.headers);\n const apiKey = process.env[API_KEY_ENV_VAR_KEY];\n if (apiKey) {\n headers.set(API_KEY_HEADER_NAME, apiKey);\n }\n const token = process.env[AUTH_TOKEN_ENV_VAR_KEY];\n if (token) {\n headers.set(\"Authorization\", `Bearer ${token}`);\n }\n if (this.token !== undefined) {\n headers.set(\"Authorization\", `Bearer ${this.token}`);\n }\n const result = await fetch(input, {\n ...init,\n headers,\n });\n if (result.status === 401 && process.env[CLI_ENV_VAR_KEY] === \"true\") {\n console.warn(\n \"Unauthorized backend function call - make sure to provision your project to Intuned to set up the correct API credentials.\\n\" +\n \"Run 'intuned provision' or see https://docs.intunedhq.com/docs/05-references/cli#provision-project for more information.\"\n );\n }\n return result;\n }\n\n get backendFunctionsBaseUrl() {\n try {\n if (!process.env.FUNCTIONS_DOMAIN) {\n throw new Error(\n `Cannot call backend function - FUNCTIONS_DOMAIN not set`\n );\n }\n const domain = process.env.FUNCTIONS_DOMAIN;\n if (!process.env[WORKSPACE_ID_ENV_VAR_KEY]) {\n throw new Error(\n `Cannot call backend function - ${WORKSPACE_ID_ENV_VAR_KEY} not set`\n );\n }\n const workspaceId = process.env[WORKSPACE_ID_ENV_VAR_KEY];\n if (\n !process.env[PROJECT_ID_ENV_VAR_KEY] &&\n !process.env.INTUNED_INTEGRATION_ID\n ) {\n throw new Error(\n `Cannot call backend function - ${PROJECT_ID_ENV_VAR_KEY} or INTUNED_INTEGRATION_ID not set`\n );\n }\n\n const projectId =\n process.env.INTUNED_INTEGRATION_ID ??\n process.env[PROJECT_ID_ENV_VAR_KEY];\n return `${domain}/api/${workspaceId}/functions/${projectId}`;\n } catch (e) {\n if (process.env[CLI_ENV_VAR_KEY] === \"true\") {\n throw new Error(\n `API credentials not set - make sure to provision your project to Intuned to set up the correct API credentials.\\n` +\n `Run 'intuned provision' or see https://docs.intunedhq.com/docs/05-references/cli#provision-project for more information.\\n` +\n `Original error: ${e.message}`\n );\n }\n }\n }\n}\n\nexport const backendFunctionsTokenManager = new JwtTokenManager(\n `refreshBackendFunctionsToken`\n);\nbackendFunctionsTokenManager.token =\n process.env.INTUNED_AUTHORING_SESSION_BACKEND_FUNCTIONS_TOKEN;\n\nexport function callBackendFunctionWithToken(\n path: string,\n init?: Parameters<typeof fetch>[1]\n) {\n return backendFunctionsTokenManager.fetchWithToken(\n `${backendFunctionsTokenManager.backendFunctionsBaseUrl}/${path}`,\n init\n );\n}\n","export const API_FOLDER_NAME = \"api\";\nexport const AUTH_SESSIONS_FOLDER_NAME = \"auth-sessions\";\nexport const AUTH_SESSIONS_INSTANCES_FOLDER_NAME = \"auth-sessions-instances\";\nexport const WORKSPACE_ID_ENV_VAR_KEY = \"INTUNED_WORKSPACE_ID\";\nexport const EXTENSION_PATH_ENV_VAR_KEY = \"INTUNED_EXTENSION_PATH\";\nexport const PROJECT_ID_ENV_VAR_KEY = \"INTUNED_PROJECT_ID\";\nexport const API_KEY_ENV_VAR_KEY = \"INTUNED_API_KEY\";\nexport const AUTH_TOKEN_ENV_VAR_KEY = \"INTUNED_AUTH_TOKEN\";\nexport const API_KEY_HEADER_NAME = \"x-api-key\";\nexport const API_BASE_URL_ENV_VAR_KEY = \"INTUNED_API_BASE_URL\";\nexport const CLI_ENV_VAR_KEY = \"INTUNED_CLI\";\n","import { RunErrorOptions } from \"./export\";\n\nexport class RunError extends Error {\n options: RunErrorOptions;\n constructor(message: string, options?: RunErrorOptions) {\n super(message);\n this.message = message;\n this.name = \"USER_GENERATED_ERROR\";\n this.options = options ?? {\n retryable: false,\n };\n Object.setPrototypeOf(this, RunError.prototype);\n }\n}\n\nnew RunError(\"\", {});\n","import type * as playwright from \"playwright\";\nimport fastify, { type FastifyInstance } from \"fastify\";\nimport {\n Captcha,\n CaptchaCallback,\n CaptchaStatus,\n captchaSchema,\n} from \"./types\";\nimport { CaptchaSolverSettings } from \"../settingsSchema\";\nimport { resolveCaptchaSolverSettings } from \"./extensionsHelpers\";\n\ntype CaptchaSubscriber = {\n handler: CaptchaCallback;\n status?: CaptchaStatus;\n};\n\nclass TabCaptchaState {\n public readonly tabId: number;\n private captchasById: Map<string, Captcha>;\n private subscribers: Array<CaptchaSubscriber>;\n\n constructor(tabId: number) {\n this.tabId = tabId;\n this.captchasById = new Map();\n this.subscribers = new Array<CaptchaSubscriber>();\n }\n\n subscribe(handler: CaptchaSubscriber) {\n this.subscribers.push(handler);\n }\n\n unsubscribe(handler: CaptchaCallback, status?: CaptchaStatus) {\n const index = this.subscribers.findIndex(\n (subscriber) =>\n subscriber.handler === handler &&\n (subscriber.status === status || !status)\n );\n if (index !== -1) {\n this.subscribers.splice(index, 1);\n }\n }\n\n getCaptchas(): Captcha[] {\n return [...this.captchasById.values()];\n }\n\n async upsertCaptcha(captcha: Captcha) {\n this.captchasById.set(captcha.id, captcha);\n for (const subscriber of this.subscribers) {\n // Only call handler if no status filter specified or status matches\n if (!subscriber.status || subscriber.status === captcha.status) {\n await subscriber.handler(captcha);\n }\n }\n }\n}\n\nexport class ExtensionServer {\n private tabs: Map<number, TabCaptchaState>;\n private app: FastifyInstance | null = null;\n\n constructor() {\n this.tabs = new Map();\n }\n\n private getOrCreateTab(tabId: number): TabCaptchaState {\n const existing = this.tabs.get(tabId);\n if (existing) return existing;\n const created = new TabCaptchaState(tabId);\n this.tabs.set(tabId, created);\n return created;\n }\n\n public async handleUpsertCaptcha(captcha: Captcha) {\n const tab = this.getOrCreateTab(captcha.tabId);\n await tab.upsertCaptcha(captcha);\n }\n\n async start({\n port,\n host = \"0.0.0.0\",\n }: {\n port: number;\n host?: string;\n }): Promise<void> {\n if (this.app) {\n return;\n }\n this.app = fastify({\n logger: false,\n bodyLimit: 1_000_000,\n });\n\n this.app.post(\"/state\", async (request, reply) => {\n try {\n const result = captchaSchema.safeParse(request.body);\n if (!result.success) {\n return reply.code(400).send({\n error: \"Invalid captcha payload\",\n details: result.error.flatten().fieldErrors,\n });\n }\n\n await this.handleUpsertCaptcha(result.data);\n return reply.code(200).send({});\n } catch (error: any) {\n console.error(\"Error processing captcha state update:\", error);\n return reply.code(500).send({\n error: \"Internal server error\",\n message: error?.message ?? String(error),\n });\n }\n });\n\n this.app.setNotFoundHandler((_request, reply) => {\n return reply.code(404).send({ error: \"Not found\" });\n });\n\n await this.app.listen({\n port,\n host,\n });\n }\n\n async stop(): Promise<void> {\n if (!this.app) return;\n const toClose = this.app;\n this.app = null;\n await toClose.close();\n }\n\n async getCaptchas(\n page: playwright.Page,\n status?: CaptchaStatus\n ): Promise<Captcha[]> {\n const tabId = await getTabId(page);\n const tab = this.tabs.get(tabId);\n if (!tab) return [];\n const captchas = tab.getCaptchas();\n if (!status) return captchas;\n return captchas.filter((c) => c.status === status && c.tabId === tabId);\n }\n\n async subscribe(\n page: playwright.Page,\n handler: CaptchaCallback,\n status?: CaptchaStatus\n ) {\n const tabId = await getTabId(page);\n const tab = this.getOrCreateTab(tabId);\n tab.subscribe({ handler, status });\n }\n\n async unsubscribe(\n page: playwright.Page,\n handler: CaptchaCallback,\n status?: CaptchaStatus\n ) {\n const tabId = await getTabId(page);\n const tab = this.tabs.get(tabId);\n if (!tab) return;\n tab.unsubscribe(handler, status);\n }\n\n removeTab(tabId: number) {\n this.tabs.delete(tabId);\n }\n\n async getTabId(page: playwright.Page): Promise<number> {\n return await getTabId(page);\n }\n}\n\nlet extensionServerSingleton: ExtensionServer | null = null;\n\nexport function getIntunedExtensionServer(): ExtensionServer {\n if (!extensionServerSingleton) {\n throw new Error(\"Intuned Extension Server is not initialized.\");\n }\n return extensionServerSingleton;\n}\n\nexport async function setupIntunedExtensionServer(\n captchaSolverSettings?: CaptchaSolverSettings\n) {\n if (!captchaSolverSettings) {\n captchaSolverSettings = await resolveCaptchaSolverSettings();\n }\n if (!extensionServerSingleton) {\n extensionServerSingleton = new ExtensionServer();\n }\n await extensionServerSingleton.start({\n port: captchaSolverSettings.port ?? 9000,\n });\n}\n\nexport async function cleanIntunedExtensionServer() {\n if (extensionServerSingleton) {\n await extensionServerSingleton.stop();\n extensionServerSingleton = null;\n }\n}\n\n// Cache tab IDs on the page object to avoid repeated expensive lookups\nconst TAB_ID_CACHE_KEY = \"__INTUNED_CACHED_TAB_ID__\";\n\nexport async function getTabId(page: playwright.Page): Promise<number> {\n // Check if we have a cached tab ID\n const cached = (page as any)[TAB_ID_CACHE_KEY];\n if (cached !== undefined && typeof cached === \"number\") {\n return cached;\n }\n\n // Try to get tab ID with a quick check first\n let tabId: number | undefined;\n try {\n tabId = await page.evaluate(\"window.__INTUNED_TAB_ID__\", { timeout: 100 });\n } catch {\n // If quick check fails, wait for it to be available\n await page.waitForFunction(\"window.__INTUNED_TAB_ID__ !== undefined\", {\n timeout: 15_000,\n });\n tabId = await page.evaluate(\"window.__INTUNED_TAB_ID__\");\n }\n\n const numericTabId = Number(tabId);\n // Cache the result on the page object\n (page as any)[TAB_ID_CACHE_KEY] = numericTabId;\n return numericTabId;\n}\n","import { z } from \"zod\";\n\nexport const captchaTypeSchema = z.enum([\n \"aws\",\n \"cloudflare\",\n \"customcaptcha\",\n \"funcaptcha\",\n \"geetest\",\n \"hcaptcha\",\n \"lemincaptcha\",\n \"recaptcha\",\n \"textcaptcha\",\n]);\n\nexport type CaptchaType = z.infer<typeof captchaTypeSchema>;\n\nexport const captchaStatusSchema = z.enum([\n \"attached\",\n \"solving\",\n \"solved\",\n \"error\",\n \"detached\",\n]);\n\nexport type CaptchaStatus = z.infer<typeof captchaStatusSchema>;\n\nexport const captchaErrorCodeSchema = z.enum([\n \"HIT_LIMIT\",\n \"MAX_RETRIES\",\n \"UNEXPECTED_SERVER_RESPONSE\",\n \"UNEXPECTED_ERROR\",\n]);\n\nexport type CaptchaErrorCode = z.infer<typeof captchaErrorCodeSchema>;\n\nexport const captchaErrorSchema = z.object({\n code: captchaErrorCodeSchema,\n error: z.unknown().optional(),\n});\n\nexport type CaptchaError = z.infer<typeof captchaErrorSchema>;\n\nconst captchaBaseSchema = z.object({\n id: z.string().min(1),\n tabId: z.number().int().positive(),\n type: captchaTypeSchema,\n retryCount: z.number().int().nonnegative().optional(),\n});\n\nexport type CaptchaBase = z.infer<typeof captchaBaseSchema>;\n\nconst captchaNonErrorSchema = captchaBaseSchema.extend({\n status: captchaStatusSchema.exclude([\"error\"]),\n});\n\nexport type CaptchaNonError = z.infer<typeof captchaNonErrorSchema>;\n\nconst captchaErrorStatusSchema = captchaBaseSchema.extend({\n status: z.literal(\"error\"),\n error: captchaErrorSchema,\n});\n\nexport type CaptchaErrorStatus = z.infer<typeof captchaErrorStatusSchema>;\n\nexport const captchaSchema = z.discriminatedUnion(\"status\", [\n captchaBaseSchema.extend({\n status: z.literal(\"attached\"),\n }),\n captchaBaseSchema.extend({\n status: z.literal(\"solving\"),\n }),\n captchaBaseSchema.extend({\n status: z.literal(\"solved\"),\n }),\n captchaBaseSchema.extend({\n status: z.literal(\"detached\"),\n }),\n captchaErrorStatusSchema,\n]);\n\nexport type Captcha = z.infer<typeof captchaSchema>;\n\nexport type CaptchaCallback = (captcha: Captcha) => Promise<void> | void;\n\nexport class CaptchaSolveError extends Error {\n constructor(message: string, public error: CaptchaError) {\n super(message);\n this.name = \"CaptchaSolveError\";\n }\n}\n\nexport class TimeoutError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"TimeoutError\";\n }\n}\n","import * as path from \"path\";\nimport * as fs from \"fs-extra\";\nimport dotenv from \"dotenv\";\n\ndotenv.config();\n\n// TODO: todo-identity handle identity instances\nexport function getFullPathInProject(...paths: string[]) {\n return path.resolve(process.cwd(), process.env.ROOT || \"./\", ...paths);\n}\n\nexport async function listProjectFilesAndFolders() {\n const projectPath = path.resolve(process.cwd(), process.env.ROOT || \"./\");\n try {\n const files = await fs.readdir(projectPath, { withFileTypes: true });\n return files.map((file) => ({\n type: file.isDirectory() ? (\"Folder\" as const) : (\"File\" as const),\n fullPath: path.join(projectPath, file.name),\n name: file.name,\n }));\n } catch (err) {\n console.error(\"Error reading the directory:\", err);\n throw err;\n }\n}\n","import * as z from \"zod\";\n\nconst baseCaptchaSchema = z.object({\n enabled: z.boolean(),\n});\n\nconst customCaptchaSchema = baseCaptchaSchema.extend({\n imageLocators: z\n .array(z.string())\n .min(1, \"At least one image locator is required\"),\n submitLocators: z\n .array(z.string())\n .min(1, \"At least one submit locator is required\"),\n inputLocators: z\n .array(z.string())\n .min(1, \"At least one input locator is required\"),\n});\n\nconst textCaptchaSchema = baseCaptchaSchema.extend({\n labelLocators: z\n .array(z.string())\n .min(1, \"At least one image locator is required\"),\n submitLocators: z\n .array(z.string())\n .min(1, \"At least one submit locator is required\"),\n inputLocators: z\n .array(z.string())\n .min(1, \"At least one input locator is required\"),\n});\n\nconst captchaSolverSolveSettingsSchema = z.object({\n autoSolve: z.boolean().default(true),\n solveDelay: z.number().min(0).default(2000),\n maxRetries: z.number().min(0).default(3),\n timeout: z.number().min(0).default(30000),\n});\n\nexport const captchaSolverSettingsSchema = z\n .object({\n enabled: z.boolean().default(false),\n port: z.number().int().min(1).max(65535).optional(),\n cloudflare: baseCaptchaSchema.optional(),\n googleRecaptchaV2: baseCaptchaSchema.optional(),\n googleRecaptchaV3: baseCaptchaSchema.optional(),\n awscaptcha: baseCaptchaSchema.optional(),\n hcaptcha: baseCaptchaSchema.optional(),\n funcaptcha: baseCaptchaSchema.optional(),\n geetest: baseCaptchaSchema.optional(),\n lemin: baseCaptchaSchema.optional(),\n customCaptcha: customCaptchaSchema.optional(),\n text: textCaptchaSchema.optional(),\n settings: captchaSolverSolveSettingsSchema.default(\n captchaSolverSolveSettingsSchema.parse({})\n ),\n })\n .default({});\n\nexport type CaptchaSolverSettings = z.infer<typeof captchaSolverSettingsSchema>;\n\nexport type CaptchaSolverSettingsWithRunContext = CaptchaSolverSettings & {\n workspaceId: string;\n projectId: string;\n baseUrl: string;\n authentication:\n | { type: \"apiKey\"; apiKey: string }\n | { type: \"basic\" | \"bearer\"; token?: string };\n};\n\nconst authSessionsSchema = z\n .object({\n enabled: z.boolean(),\n })\n .optional()\n .default({\n enabled: false,\n });\n\nconst stealthModeSchema = z\n .object({\n enabled: z.boolean(),\n })\n .optional()\n .default({\n enabled: false,\n });\n\nexport const settingsSchema = z.object({\n authSessions: authSessionsSchema,\n stealthMode: stealthModeSchema,\n captchaSolver: captchaSolverSettingsSchema.optional(),\n});\n\nexport type IntunedSettings = z.infer<typeof settingsSchema>;\n","import { getFullPathInProject } from \"./fileUtils\";\nimport {\n IntunedSettings,\n settingsSchema,\n} from \"../../../common/settingsSchema\";\nimport { readFile } from \"fs/promises\";\n\nexport async function getSettings(): Promise<IntunedSettings> {\n const settingsFilePath = getFullPathInProject(\"Intuned.json\");\n\n const settings = await readFile(settingsFilePath, { encoding: \"utf-8\" });\n if (settings) {\n const parsed = settingsSchema.safeParse(JSON.parse(settings));\n if (parsed.success) {\n return parsed.data;\n } else {\n // ToDo: why does the type not work here?\n throw new Error((parsed as any).error.message);\n }\n }\n\n return {\n authSessions: { enabled: false },\n stealthMode: { enabled: false },\n };\n}\n","import type * as playwright from \"playwright\";\nimport { getSettings } from \"../../commands/common/utils/settings\";\nimport {\n CaptchaSolverSettings,\n captchaSolverSettingsSchema,\n CaptchaSolverSettingsWithRunContext,\n} from \"../settingsSchema\";\nimport { PROJECT_ID_ENV_VAR_KEY, WORKSPACE_ID_ENV_VAR_KEY } from \"../constants\";\nimport { backendFunctionsTokenManager } from \"../jwtTokenManager\";\nimport path from \"path\";\nimport { writeFile } from \"fs/promises\";\nimport { setupIntunedExtensionServer } from \"./intunedExtensionServer\";\nimport { getPort } from \"portfinder\";\n\nconst INTUNED_WORKER = \"intunedWorker.js\";\nconst INTUNED_EXTENSION_SETTINGS_FILE_NAME = \"intunedSettings.json\";\nconst INTUNED_CAPTCHA_EXTENSION_PORT_ENV_VAR = \"INTUNED_CAPTCHA_EXTENSION_PORT\";\n\nlet captchaSolverSettings: CaptchaSolverSettings | null = null;\n\nasync function getIntunedCaptchaExtensionPort(): Promise<number> {\n if (process.env.INTUNED_CAPTCHA_EXTENSION_PORT) {\n return parseInt(process.env.INTUNED_CAPTCHA_EXTENSION_PORT, 10);\n }\n return await getPort({});\n}\n\nexport async function resolveCaptchaSolverSettings(\n input?: unknown\n): Promise<CaptchaSolverSettings> {\n const parsed = captchaSolverSettingsSchema.parse(input || {});\n\n if (!parsed.port) {\n parsed.port = await getIntunedCaptchaExtensionPort();\n }\n\n return parsed;\n}\n\nfunction getIntunedCaptchaExtensionPortFromEnv(): number | null {\n const raw = process.env[INTUNED_CAPTCHA_EXTENSION_PORT_ENV_VAR];\n if (!raw) return null;\n const parsed = Number(raw);\n if (!Number.isFinite(parsed) || parsed <= 0 || parsed > 65535) {\n throw new Error(\n `Invalid ${INTUNED_CAPTCHA_EXTENSION_PORT_ENV_VAR}: ${raw}`\n );\n }\n return parsed;\n}\n\nexport function isIntunedExtensionLoaded() {\n return !!getIntunedExtensionPath();\n}\n\nexport function buildExtensionsList(): string[] {\n const extensionsList: string[] = [];\n if (isIntunedExtensionLoaded()) {\n const intunedExtensionPath = getIntunedExtensionPath();\n extensionsList.push(intunedExtensionPath);\n }\n return extensionsList;\n}\n\nexport function getIntunedExtensionPath() {\n return process.env.INTUNED_EXTENSION_PATH as string;\n}\n\nexport async function isIntunedExtensionEnabled() {\n const path = getIntunedExtensionPath();\n if (!path) {\n return false;\n }\n\n const captchaSolverSettings = await getIntunedCaptchaSolverSettings();\n return captchaSolverSettings.enabled;\n}\n\nexport async function getIntunedExtensionWorker(\n context: playwright.BrowserContext\n): Promise<playwright.Worker | null> {\n if (!(await isIntunedExtensionEnabled())) {\n return null;\n }\n let attemptCount = 0;\n while (attemptCount < 4) {\n const intunedServiceWorker = context\n .serviceWorkers()\n .find((serviceWorker) => serviceWorker.url().includes(INTUNED_WORKER));\n if (intunedServiceWorker) {\n return intunedServiceWorker;\n }\n try {\n await context.waitForEvent(\"serviceworker\", { timeout: 3000 });\n } catch (err: any) {\n console.log(`Error accessing service workers (attempt ${attemptCount})`);\n }\n attemptCount++;\n }\n console.error(\"Failed to get intuned worker after 5 attmepts\");\n return null;\n}\n\nexport async function getIntunedExtensionSettings(\n captchaSolverSettings: CaptchaSolverSettings\n): Promise<CaptchaSolverSettingsWithRunContext> {\n const [domain, workspaceId, projectId] = [\n process.env.FUNCTIONS_DOMAIN,\n process.env[WORKSPACE_ID_ENV_VAR_KEY],\n process.env.INTUNED_INTEGRATION_ID ?? process.env[PROJECT_ID_ENV_VAR_KEY],\n ];\n if (!domain || !workspaceId || !projectId) {\n const missingEnvVars = [\n domain && \"FUNCTIONS_DOMAIN\",\n workspaceId && WORKSPACE_ID_ENV_VAR_KEY,\n projectId && `INTUNED_INTEGRATION_ID OR ${PROJECT_ID_ENV_VAR_KEY}`,\n ];\n throw new Error(\n `Missing required environment variables: ${missingEnvVars}`\n );\n }\n\n const authentication = (() => {\n if (process.env.INTUNED_API_KEY) {\n return { type: \"apiKey\" as const, apiKey: process.env.INTUNED_API_KEY };\n }\n if (\n process.env.INTUNED_BASIC_AUTH_USERNAME &&\n process.env.INTUNED_BASIC_AUTH_PASSWORD\n ) {\n const credentials = `${process.env.INTUNED_BASIC_AUTH_USERNAME}:${process.env.INTUNED_BASIC_AUTH_PASSWORD}`;\n const token = Buffer.from(credentials, \"utf-8\").toString(\"base64\");\n return { type: \"basic\" as const, token };\n }\n return {\n type: \"bearer\" as const,\n token: backendFunctionsTokenManager.token,\n };\n })();\n\n const baseUrl = process.env.INTUNED_API_BASE_URL ?? domain;\n\n return {\n ...captchaSolverSettings,\n workspaceId,\n projectId,\n baseUrl,\n authentication,\n };\n}\n\nexport async function getIntunedCaptchaSolverSettings(): Promise<CaptchaSolverSettings> {\n if (captchaSolverSettings) {\n return captchaSolverSettings;\n }\n const settings = await getSettings();\n captchaSolverSettings = await resolveCaptchaSolverSettings(\n settings.captchaSolver\n );\n return captchaSolverSettings;\n}\n\nexport async function setupIntunedExtension() {\n if (!(await isIntunedExtensionEnabled())) {\n return;\n }\n const intunedExtensionPath = getIntunedExtensionPath();\n const intunedExtensionSettingsPath = path.join(\n intunedExtensionPath,\n INTUNED_EXTENSION_SETTINGS_FILE_NAME\n );\n const captchaSolverSettings = await getIntunedCaptchaSolverSettings();\n await setupIntunedExtensionServer(captchaSolverSettings);\n const captchaSolverSettingsWithRunContext = await getIntunedExtensionSettings(\n captchaSolverSettings\n );\n\n await writeFile(\n intunedExtensionSettingsPath,\n JSON.stringify(captchaSolverSettingsWithRunContext)\n );\n}\n","import { getExecutionContext } from \"..\";\nimport { ensureDirSync } from \"fs-extra\";\n\nexport function getDownloadDirectoryPath() {\n const context = getExecutionContext();\n if (!context) {\n throw new Error(\"ExecutionContext not found\");\n }\n const path = `/tmp/downloads/${context.runId}`;\n ensureDirSync(path, {\n mode: 0o2775,\n });\n return path;\n}\n","import { getDownloadDirectoryPath } from \"../../runtime/downloadDirectory\";\nimport { getExecutionContext } from \"../asyncLocalStorage\";\nimport * as fs from \"fs-extra\";\nimport { remove } from \"fs-extra\";\nimport { ok, err, Result } from \"neverthrow\";\nimport type { Page, BrowserContext } from \"playwright\";\nimport { AUTH_SESSIONS_FOLDER_NAME } from \"../constants\";\nimport {\n browserScriptsFile,\n loadSessionToContext,\n withPlaywrightContext,\n WithPlaywrightContextWrappedFunction,\n} from \"../playwrightContext\";\nimport { formatZodError } from \"../formatZodError\";\nimport { cleanEnvironmentVariables } from \"../cleanEnvironmentVariables\";\nimport { importUsingImportFunction } from \"./importUsingImportFunction\";\nimport {\n ExtendedRunApiParameters,\n runApiParametersSchema,\n RunApiResult,\n RunApiResultOk,\n RunApiResultWithSessionOk,\n AbortedError,\n AuthRequiredError,\n AutomationError,\n InternalInvalidInputError,\n ResultTooBigError,\n RunAutomationError,\n} from \"@intuned/runtime-interface\";\nimport { getStorageState } from \"../contextStorageStateHelpers\";\n\n// Helper function to calculate the approximate size of an object in bytes\nfunction getObjectSizeInBytes(obj: any): number {\n try {\n return new TextEncoder().encode(JSON.stringify(obj)).length;\n } catch (error) {\n // If JSON.stringify fails (e.g., circular references), return a conservative estimate\n return new TextEncoder().encode(String(obj)).length;\n }\n}\n\nexport async function runApi<ResultType = any>(\n input: ExtendedRunApiParameters & {\n retrieveSession: true;\n }\n): Promise<RunApiResult<ResultType, RunApiResultWithSessionOk<ResultType>>>;\nexport async function runApi<ResultType = any>(\n input: ExtendedRunApiParameters\n): Promise<RunApiResult<ResultType>>;\nexport async function runApi<ResultType = any>({\n abortSignal,\n importFunction,\n retrieveSession = false,\n ...input\n}: ExtendedRunApiParameters): Promise<\n | RunApiResult<ResultType>\n | RunApiResult<ResultType, RunApiResultWithSessionOk<ResultType>>\n> {\n let traceStarted = false;\n const inputParseResult = runApiParametersSchema.safeParse(input);\n if (!inputParseResult.success) {\n return err(\n new InternalInvalidInputError(\n \"Input validation failed\",\n formatZodError(inputParseResult.error)\n )\n );\n }\n const {\n automationFunction: { name, params },\n runOptions,\n tracing,\n auth,\n } = inputParseResult.data;\n\n const abortSymbol = Symbol(\"abort\");\n\n const abortPromise = new Promise<typeof abortSymbol>((resolve) => {\n if (!abortSignal) return;\n abortSignal.addEventListener(\"abort\", () => {\n resolve(abortSymbol);\n });\n });\n\n async function runAutomation() {\n const validatedModuleResult = await importUsingImportFunction<ResultType>({\n path: name,\n importFunction,\n });\n if (validatedModuleResult.isErr()) {\n return err(validatedModuleResult.error);\n }\n\n const automationFunction = validatedModuleResult.value;\n\n if (auth && auth.session.type === \"state\") {\n const state = auth.session.state;\n if (state === undefined || state === null) {\n return err(new AuthRequiredError());\n }\n }\n\n const playwrightContextParameters = {\n apiName: name,\n apiParameters: params,\n importFunction,\n };\n\n const intunedContext = getExecutionContext();\n\n const runAutomationWithContext: WithPlaywrightContextWrappedFunction<\n RunApiResultOk<ResultType> | RunApiResultWithSessionOk<ResultType>\n > = async (context, page) => {\n async function saveTraceIfNeeded({\n errorMessage,\n }: {\n errorMessage: string;\n }) {\n if (!tracing.enabled || !traceStarted) {\n return;\n }\n try {\n await context?.tracing.stop({ path: tracing.filePath });\n } catch (error: any) {\n console.log(errorMessage, error?.message);\n await remove(tracing.filePath);\n }\n }\n\n if (auth) {\n await loadSessionToContext({\n context,\n session: auth.session,\n });\n if (intunedContext && auth.parameters) {\n intunedContext.getAuthSessionParameters = async () =>\n auth.parameters!;\n }\n }\n\n const scriptContent = await fs.readFile(browserScriptsFile, \"utf-8\");\n await context.addInitScript({\n content: scriptContent,\n });\n\n for (const page of context.pages()) {\n await page.evaluate(scriptContent);\n }\n\n if (tracing.enabled) {\n await context.tracing.start({\n screenshots: true,\n snapshots: true,\n sources: true,\n });\n traceStarted = true;\n }\n\n cleanEnvironmentVariables();\n\n const automationFunctionParameters = [\n ...(params !== undefined ? [params] : []),\n page,\n context,\n ];\n\n try {\n const [automationFunctionResult] = await Promise.all([\n automationFunction(...automationFunctionParameters),\n ]);\n const MAX_RESULT_SIZE_BYTES = 2 * 1024 * 1024; // 2MB\n const resultSizeInBytes = getObjectSizeInBytes(\n automationFunctionResult\n );\n if (resultSizeInBytes > MAX_RESULT_SIZE_BYTES) {\n return err(\n new ResultTooBigError(resultSizeInBytes, MAX_RESULT_SIZE_BYTES)\n );\n }\n\n if (retrieveSession) {\n return ok({\n result: automationFunctionResult as ResultType,\n extendedPayloads: intunedContext?.extendedPayloads,\n session: await getStorageState(context),\n });\n }\n return ok({\n result: automationFunctionResult as ResultType,\n extendedPayloads: intunedContext?.extendedPayloads,\n });\n } catch (error) {\n return err(new AutomationError(error));\n } finally {\n await saveTraceIfNeeded({ errorMessage: \"failed to save trace\" });\n }\n };\n\n if (intunedContext?.store) {\n intunedContext.store = {};\n }\n\n if (runOptions.environment === \"standalone\") {\n const downloadsPath = getDownloadDirectoryPath();\n try {\n return await withPlaywrightContext(\n {\n headless: runOptions.headless,\n proxy: runOptions.proxy,\n downloadsPath,\n ...playwrightContextParameters,\n },\n runAutomationWithContext\n );\n } finally {\n await fs.remove(downloadsPath);\n }\n } else {\n return await withPlaywrightContext(\n {\n cdpAddress: runOptions.cdpAddress,\n cdpTargetId: runOptions.cdpTargetId,\n ...playwrightContextParameters,\n },\n runAutomationWithContext\n );\n }\n }\n\n const result = await Promise.race([await runAutomation(), abortPromise]);\n\n if (result === abortSymbol) {\n return err(new AbortedError());\n }\n\n return result;\n}\n\nexport async function checkAuthSessionWithRetries(\n page: Page,\n context: BrowserContext,\n checkFn: (..._: any) => Promise<boolean>,\n retries = 3\n): Promise<Result<boolean, RunAutomationError>> {\n if (retries === 0) {\n return ok(false);\n }\n\n let tryNumber = 0;\n\n console.log(\n \"Checking AuthSession with retries\",\n `${AUTH_SESSIONS_FOLDER_NAME}/check`\n );\n\n while (retries > tryNumber) {\n const result = await checkFn(page, context);\n if (result) return ok(true);\n\n tryNumber++;\n }\n\n return ok(false);\n}\n","import type * as playwright from \"playwright\";\nimport type { RunApiStorageState } from \"@intuned/runtime-interface\";\n\ninterface StorageEntry {\n name: string;\n value: string;\n}\n\ninterface LocalStorageState {\n origin: string;\n localStorage: StorageEntry[];\n}\n\ninterface SessionStorageState {\n origin: string;\n sessionStorage: StorageEntry[];\n}\n\nexport interface StorageState {\n cookies?: playwright.Cookie[] | null;\n origins?: LocalStorageState[] | null;\n sessionStorage?: SessionStorageState[] | null;\n}\n\nexport async function setStorageState(\n context: playwright.BrowserContext,\n state: RunApiStorageState\n): Promise<void> {\n if (\"cookies\" in state && state.cookies) {\n await context.addCookies(state.cookies);\n }\n const page = await context.newPage();\n if (\"origins\" in state && state.origins) {\n for (const originData of state.origins || []) {\n const origin = originData.origin;\n await page.route(`${origin}/*`, (route) =>\n route.fulfill({\n body: \"<html><head><title>Set Storage</title></head><body><h1>Set Storage</h1></body></html>\",\n contentType: \"text/html\",\n status: 200,\n })\n );\n\n try {\n await page.goto(origin);\n\n for (const item of originData.localStorage) {\n await page.evaluate(\n ([key, value]) => {\n window.localStorage.setItem(key, value);\n },\n [item.name, item.value]\n );\n }\n } finally {\n await page.unroute(`${origin}/*`);\n }\n }\n }\n\n if (\"sessionStorage\" in state && state.sessionStorage) {\n await context.addInitScript((storage) => {\n for (const { origin, sessionStorage } of storage) {\n if (window.location.origin === origin) {\n for (const item of sessionStorage) {\n const value = window.sessionStorage.getItem(item.name);\n if (!value) {\n window.sessionStorage.setItem(item.name, item.value);\n }\n }\n }\n }\n }, state.sessionStorage);\n }\n\n await page.close();\n}\n\nexport async function getStorageState(\n context: playwright.BrowserContext\n): Promise<RunApiStorageState> {\n const result: RunApiStorageState = {\n cookies: [],\n origins: [],\n };\n const storageState = await context.storageState();\n result.cookies = storageState.cookies as playwright.Cookie[];\n result.origins = storageState.origins as LocalStorageState[];\n\n const sessionDataList: SessionStorageState[] = [];\n const pages = await context.pages();\n\n for (const page of pages) {\n if (page.isClosed()) continue;\n\n try {\n const sessionData: SessionStorageState = await page.evaluate(() => {\n const items = { ...window.sessionStorage };\n return {\n origin: window.location.origin,\n sessionStorage: Object.entries(items).map(([name, value]) => ({\n name,\n value,\n })),\n };\n });\n\n sessionDataList.push(sessionData);\n } catch (error) {\n console.error(\"Error getting sessionStorage:\", error);\n }\n }\n\n result[\"sessionStorage\"] = sessionDataList;\n\n return result;\n}\n","import type * as playwright from \"playwright\";\nimport { setStorageState } from \"./contextStorageStateHelpers\";\nimport path from \"path\";\nimport * as fs from \"fs-extra\";\nimport { getFullPathInProject } from \"../commands/common/utils/fileUtils\";\nimport { err, Err, ok, Ok } from \"neverthrow\";\nimport { SetupContextHook, loadSetupContextHook } from \"./setupContextHook\";\nimport { getPort } from \"portfinder\";\nimport {\n getLocalCdpAddress,\n launchBrowser,\n type Proxy,\n getCdpWebSocketUrl,\n} from \"./launchBrowser\";\nimport {\n RunApiStorageState,\n ImportFunction,\n AutomationError,\n RunAutomationError,\n RunApiSession,\n} from \"@intuned/runtime-interface\";\n\nexport const browserScriptsFile = path.join(\n __dirname,\n \"./assets/browser_scripts.js\"\n);\n\ntype WithPlaywrightContextParameters =\n | {\n importFunction: ImportFunction;\n apiName: string;\n apiParameters: any;\n }\n | {\n importFunction?: undefined;\n apiName?: undefined;\n apiParameters?: undefined;\n };\n\ntype WithPlaywrightContextWrappedFunctionReturn<R> =\n | Ok<R, any>\n | Err<any, RunAutomationError>;\n\nexport type WithPlaywrightContextWrappedFunction<R> = (\n context: playwright.BrowserContext,\n page: playwright.Page\n) => Promise<WithPlaywrightContextWrappedFunctionReturn<R>>;\n\nexport async function withPlaywrightContext<R>(\n options: {\n proxy?: Proxy;\n headless: boolean;\n downloadsPath: string;\n } & WithPlaywrightContextParameters,\n fn: WithPlaywrightContextWrappedFunction<R>\n): Promise<Ok<R, any> | Err<any, RunAutomationError>>;\n\nexport async function withPlaywrightContext<R>(\n options: {\n cdpAddress: string;\n cdpTargetId?: string;\n } & WithPlaywrightContextParameters,\n fn: WithPlaywrightContextWrappedFunction<R>\n): Promise<Ok<R, any> | Err<any, RunAutomationError>>;\n\nexport async function withPlaywrightContext<R>(\n {\n cdpAddress,\n cdpTargetId,\n proxy,\n headless = true,\n downloadsPath,\n importFunction,\n apiName,\n apiParameters,\n }: {\n cdpAddress?: string;\n cdpTargetId?: string;\n proxy?: Proxy;\n headless?: boolean;\n downloadsPath?: string;\n } & WithPlaywrightContextParameters,\n fn: WithPlaywrightContextWrappedFunction<R>\n): Promise<Ok<R, any> | Err<any, RunAutomationError>> {\n let context: playwright.BrowserContext | undefined;\n let page: playwright.Page;\n\n try {\n const setupContextHookResult = importFunction\n ? await loadSetupContextHook({\n importFunction,\n })\n : ok(null);\n if (setupContextHookResult.isErr()) {\n return setupContextHookResult;\n }\n const setupContextHook = setupContextHookResult.value;\n\n if (setupContextHook === null) {\n if (cdpAddress !== undefined) {\n ({ page, context } = await launchBrowser({ cdpAddress, cdpTargetId }));\n } else {\n ({ page, context } = await launchBrowser({\n proxy,\n headless,\n downloadsPath,\n }));\n }\n return await fn(context, page);\n }\n\n let hookCdpUrl: string | null = null;\n if (cdpAddress) {\n hookCdpUrl = cdpAddress;\n ({ context, page } = await launchBrowser({ cdpAddress, cdpTargetId }));\n } else {\n const port = await getPort({\n port: 9222,\n });\n ({ context, page } = await launchBrowser({\n proxy,\n headless,\n downloadsPath,\n cdpPort: port,\n }));\n\n hookCdpUrl = getLocalCdpAddress(port);\n }\n\n let hookResult: Awaited<ReturnType<SetupContextHook>>;\n try {\n const wsUrlResult = await getCdpWebSocketUrl(hookCdpUrl);\n if (wsUrlResult.isOk()) {\n hookCdpUrl = wsUrlResult.value;\n } else {\n throw new Error(wsUrlResult.error);\n }\n hookResult = await setupContextHook({\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n apiName: apiName!,\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n apiParameters: apiParameters!,\n cdpUrl: hookCdpUrl,\n });\n } catch (error) {\n return err(new AutomationError(error));\n }\n if (!hookResult) {\n return await fn(context, page);\n }\n const { page: newPage, context: newContext, cleanup } = hookResult;\n\n let result:\n | {\n return: WithPlaywrightContextWrappedFunctionReturn<R>;\n }\n | {\n throw: Error;\n };\n\n try {\n result = { return: await fn(newContext, newPage ?? page) };\n } catch (e) {\n result = { throw: e };\n }\n try {\n await cleanup?.();\n } catch (e) {\n result = { return: err(new AutomationError(e)) };\n }\n\n if (\"throw\" in result) {\n throw result.throw;\n }\n return result.return;\n } finally {\n await context?.close();\n }\n}\n\nexport async function loadSessionToContext({\n context,\n session,\n}: {\n context: playwright.BrowserContext;\n session: RunApiSession;\n}) {\n let sessionToLoad: RunApiStorageState;\n if (session.type === \"state\") {\n const state = session.state;\n if (state === undefined || state === null) {\n return;\n }\n sessionToLoad = state;\n } else {\n const fullPath = getFullPathInProject(session.path);\n sessionToLoad = await fs.readJson(fullPath);\n }\n\n await setStorageState(context, sessionToLoad);\n}\n","import type * as playwright from \"playwright\";\nimport { ok, type Err, type Ok } from \"neverthrow\";\nimport { importUsingImportFunction } from \"./runApi/importUsingImportFunction\";\nimport {\n ImportFunction,\n ApiNotFoundError,\n type RunAutomationError,\n} from \"@intuned/runtime-interface\";\n\nexport type InitializeContextHookOptions = {\n apiName: string;\n apiParameters: any;\n cdpUrl: string;\n};\n\nexport type SetupContextHook = (\n options: InitializeContextHookOptions\n) => Promise<{\n page: playwright.Page | null;\n context: playwright.BrowserContext;\n cleanup?: () => Promise<void>;\n} | null>;\n\nconst setupContextHookPath = \"hooks/setupContext\";\n\nexport async function loadSetupContextHook({\n importFunction,\n}: {\n importFunction: ImportFunction;\n}): Promise<Ok<SetupContextHook | null, any> | Err<any, RunAutomationError>> {\n const importedFunctionResult = await importUsingImportFunction({\n path: setupContextHookPath,\n importFunction,\n });\n if (\n importedFunctionResult.isErr() &&\n importedFunctionResult.error instanceof ApiNotFoundError\n ) {\n return ok(null);\n }\n return importedFunctionResult;\n}\n","import { ok, err, Result } from \"neverthrow\";\nimport {\n ImportFunction,\n ApiNotFoundError,\n AutomationError,\n InvalidApiError,\n RunAutomationError,\n} from \"@intuned/runtime-interface\";\n\nexport async function importUsingImportFunction<_ReturnType = any>({\n path,\n allowGenerators = true,\n importFunction,\n}: {\n path: string;\n importFunction: ImportFunction;\n allowGenerators?: boolean;\n}): Promise<Result<(..._: any) => Promise<_ReturnType>, RunAutomationError>> {\n try {\n const importedResult = await importFunction(path);\n if (importedResult.isErr()) {\n if (importedResult.error.type === \"not_found\") {\n return err(new ApiNotFoundError(path));\n }\n return err(new AutomationError(importedResult.error.error));\n }\n const imported = importedResult.value;\n if (!imported || !imported.default || !imported.default.constructor) {\n return err(new InvalidApiError(`${path} does not have a default export`));\n }\n if (imported.default.constructor.name === \"AsyncGeneratorFunction\") {\n if (!allowGenerators) {\n return err(\n new InvalidApiError(\n `${path} default export must be an async function`\n )\n );\n }\n return ok(async (...args) => {\n const generator = imported.default(\n ...args\n ) as AsyncGenerator<_ReturnType>;\n const result = await generator.next();\n if (!result.done) {\n throw new Error(\"Yield is not supported\");\n }\n return result.value;\n });\n }\n if (imported.default.constructor.name === \"AsyncFunction\") {\n return ok(imported.default);\n }\n return err(\n new InvalidApiError(`${path} default export must be an async function`)\n );\n } catch (error: any) {\n return err(new AutomationError(error));\n }\n}\n","import * as playwright from \"playwright\";\nimport { mkdir, mkdtemp, rm, writeFile } from \"fs-extra\";\nimport { join } from \"path\";\nimport * as fs from \"fs-extra\";\nimport waitOn from \"wait-on\";\nimport { exec } from \"child_process\";\nimport {\n buildExtensionsList,\n getIntunedExtensionWorker,\n isIntunedExtensionEnabled,\n isIntunedExtensionLoaded,\n setupIntunedExtension,\n} from \"./extension/extensionsHelpers\";\nimport {\n cleanIntunedExtensionServer,\n setupIntunedExtensionServer,\n} from \"./extension/intunedExtensionServer\";\nimport { promisify } from \"util\";\nimport { Result, err, ok } from \"neverthrow\";\nimport { z } from \"zod\";\n\nconst execAsync = promisify(exec);\n\nexport interface Proxy {\n server: string;\n username: string;\n password: string;\n}\n\nasync function createUserDirWithPreferences() {\n const playwrightTempDir = await mkdtemp(\"/tmp/pw-\");\n const userDir = join(playwrightTempDir, \"userdir\");\n const defaultDir = join(userDir, \"Default\");\n await mkdir(defaultDir, {\n recursive: true,\n });\n const preferences = {\n plugins: {\n always_open_pdf_externally: true,\n },\n };\n await writeFile(join(defaultDir, \"Preferences\"), JSON.stringify(preferences));\n\n return userDir;\n}\n\nexport type LaunchBrowserResult = {\n page: playwright.Page;\n context: playwright.BrowserContext;\n};\n\nexport type LaunchChromiumStandaloneOptions = {\n proxy?: Proxy;\n headless: boolean;\n downloadsPath?: string;\n cdpPort?: number;\n appModeInitialUrl?: string;\n executablePath?: string;\n};\n\nexport type LaunchChromiumCdpOptions = {\n cdpAddress: string;\n cdpTargetId?: string;\n};\n\nexport async function launchChromium(\n options: LaunchChromiumStandaloneOptions\n): Promise<LaunchBrowserResult>;\n\nexport async function launchChromium(\n options: LaunchChromiumCdpOptions\n): Promise<LaunchBrowserResult>;\n\nexport async function launchChromium(\n options: LaunchChromiumStandaloneOptions | LaunchChromiumCdpOptions\n): Promise<LaunchBrowserResult> {\n if (\"cdpAddress\" in options) {\n if (await isIntunedExtensionEnabled()) {\n await setupIntunedExtensionServer();\n }\n\n const browser = await playwright.chromium.connectOverCDP(\n options.cdpAddress\n );\n if (browser.contexts().length === 0) {\n throw new Error(\"No browser contexts found in the connected browser\");\n }\n const context = browser.contexts()[0];\n let page = context.pages().at(0) ?? (await context.newPage());\n const targetId = options.cdpTargetId;\n if (targetId) {\n for (const p of context.pages()) {\n let cdp: playwright.CDPSession | null = null;\n try {\n cdp = await context.newCDPSession(p);\n const result = await cdp.send(\"Target.getTargetInfo\");\n if (result.targetInfo.targetId === targetId) {\n page = p;\n break;\n }\n } catch (error) {\n } finally {\n await cdp?.detach();\n }\n }\n }\n\n return { page, context };\n }\n const { headless, appModeInitialUrl, cdpPort, proxy, downloadsPath } =\n options;\n\n let { executablePath } = options;\n\n const defaultArgsToIgnore: string[] = [\n \"--disable-extensions\",\n \"--disable-component-extensions-with-background-pages\",\n \"--disable-background-networking\",\n \"--disable-backgrounding-occluded-windows\",\n \"--disable-background-timer-throttling\",\n ];\n const extraArgs: string[] = [];\n\n const userDataDir = await createUserDirWithPreferences();\n\n if (isIntunedExtensionLoaded()) {\n const extensionsList = buildExtensionsList();\n const extensions = extensionsList.join(\",\");\n extraArgs.push(`--disable-extensions-except=${extensions}`);\n extraArgs.push(`--load-extension=${extensions}`);\n }\n\n if (await isIntunedExtensionEnabled()) {\n await setupIntunedExtension();\n if (proxy) {\n extraArgs.push('--proxy-bypass-list=\"<-loopback>\"'); // This is added to bypass proxy for localhost traffic because some proxy providers block localhost traffic, and localhost traffic doesn't need proxying\n }\n }\n\n if (cdpPort) {\n extraArgs.push(`--remote-debugging-port=${cdpPort}`);\n }\n if (headless) {\n defaultArgsToIgnore.push(\"--headless=old\");\n extraArgs.push(\"--headless=new\");\n }\n\n if (appModeInitialUrl) {\n extraArgs.push(`--app=${appModeInitialUrl}`);\n }\n\n if (executablePath) {\n executablePath = await fs.realpath(executablePath);\n if (!(await fs.exists(executablePath))) {\n console.log(\n `Warning: Executable path ${executablePath} does not exist. Falling back to default.`\n );\n executablePath = undefined;\n }\n }\n\n const viewport = null;\n const userAgent =\n process.env.__PLAYWRIGHT_USER_AGENT_OVERRIDE ??\n (await getHeadlessUserAgent({\n executablePath,\n }));\n\n const context = await playwright.chromium.launchPersistentContext(\n userDataDir,\n {\n userAgent,\n executablePath,\n headless,\n viewport,\n proxy,\n downloadsPath,\n args: extraArgs,\n ignoreDefaultArgs: defaultArgsToIgnore,\n }\n );\n\n context.once(\"close\", async () => {\n try {\n await rm(userDataDir, {\n recursive: true,\n force: true,\n retryDelay: 1000,\n maxRetries: 5,\n });\n if (await isIntunedExtensionEnabled()) {\n await cleanIntunedExtensionServer();\n }\n } catch (error) {\n console.error(\"Failed to remove user data dir\", error);\n }\n });\n\n if (cdpPort) {\n const createdCdpAddress = getLocalCdpAddress(cdpPort);\n await waitOnCdpAddress(createdCdpAddress);\n }\n\n const page = context.pages().at(0) ?? (await context.newPage());\n\n if (await isIntunedExtensionEnabled()) {\n await getIntunedExtensionWorker(context);\n }\n\n return {\n page,\n context,\n };\n}\n\nexport async function getBrowserExecutablePath(): Promise<string | undefined> {\n const browserType = getBrowserType();\n if (browserType === \"brave\") {\n return await getBraveExecutablePath();\n }\n}\n\nexport async function launchBrowser(\n options:\n | Omit<LaunchChromiumStandaloneOptions, \"executablePath\">\n | LaunchChromiumCdpOptions\n): Promise<LaunchBrowserResult> {\n if (\"cdpAddress\" in options) {\n return launchChromium(options);\n }\n\n return launchChromium({\n ...options,\n executablePath: await getBrowserExecutablePath(),\n });\n}\n\nfunction getBrowserType() {\n if (process.env.BROWSER_TYPE === \"brave\") {\n return \"brave\";\n }\n return \"chromium\";\n}\n\nasync function getBraveExecutablePath() {\n const { stdout } = await execAsync(\"which brave-browser-stable\");\n const bravePath = stdout.trim();\n if (bravePath.length === 0) {\n throw new Error(\"Brave browser not found\");\n }\n return bravePath;\n}\n\nexport function getLocalCdpAddress(port: number): string {\n return `http://localhost:${port}`;\n}\n\nexport async function getCdpWebSocketUrl(\n cdpAddress: string\n): Promise<Result<string, string>> {\n let response: Response;\n try {\n response = await fetch(`${cdpAddress}/json/version`);\n } catch (error) {\n return err(\n `Failed to fetch CDP version from ${cdpAddress}: ${\n error instanceof Error ? error.message : String(error)\n }`\n );\n }\n if (!response.ok) {\n return err(\n `Failed to get CDP WebSocket URL from ${cdpAddress}: ${response.status} ${response.statusText}`\n );\n }\n let data: any;\n try {\n data = await response.json();\n } catch (error) {\n return err(\n `Invalid CDP version response from ${cdpAddress}: ${\n error instanceof Error ? error.message : String(error)\n }`\n );\n }\n const cdpJsonVersionResponseSchema = z.object({\n webSocketDebuggerUrl: z.string().url(),\n });\n const parseResult = cdpJsonVersionResponseSchema.safeParse(data);\n if (!parseResult.success) {\n return err(\n `Invalid CDP version response from ${cdpAddress}: ${JSON.stringify(\n parseResult.error.format()\n )}`\n );\n }\n return ok(parseResult.data.webSocketDebuggerUrl);\n}\n\nasync function waitOnCdpAddress(cdpAddress: string) {\n const cdpAddressWithoutProtocol = cdpAddress\n .replace(\"http://\", \"\")\n .replace(\"https://\", \"\")\n .replace(\"localhost\", \"127.0.0.1\");\n\n await waitOn({\n resources: [`http-get://${cdpAddressWithoutProtocol}/json/version`],\n delay: 100,\n interval: 100,\n timeout: 5000,\n tcpTimeout: 1000,\n window: 1000,\n });\n}\n\nexport async function getHeadlessUserAgent({\n executablePath,\n args,\n ignoreDefaultArgs,\n}: {\n executablePath?: string;\n args?: string[];\n ignoreDefaultArgs?: string[];\n}) {\n const browser = await playwright.chromium.launch({\n headless: true,\n executablePath,\n args,\n ignoreDefaultArgs,\n });\n const context = await browser.newContext();\n const page = await context.newPage();\n let userAgent = await page.evaluate(() => navigator.userAgent);\n await browser.close();\n if (!userAgent || typeof userAgent !== \"string\") {\n return undefined;\n }\n userAgent = userAgent.replace(\"HeadlessChrome\", \"Chrome\");\n return userAgent;\n}\n","import { ZodError } from \"zod/v3\";\n\nexport function formatZodError(zodError: ZodError): string[] {\n const formattedErrors = zodError.errors.map((error) => {\n const path = error.path\n .map((segment) => {\n return typeof segment === \"number\" ? `[${segment}]` : segment;\n })\n .join(\".\");\n\n if (path) {\n return `${path} is invalid - ${error.message}`;\n }\n\n return error.message;\n });\n\n return formattedErrors;\n}\n","export function cleanEnvironmentVariables() {\n Object.keys(process.env)\n .filter((i) => {\n if (i.toLocaleLowerCase().startsWith(\"npm\")) {\n return true;\n }\n\n if (i.toLocaleLowerCase().startsWith(\"fly\") && i !== \"FLY_ALLOC_ID\") {\n return true;\n }\n })\n .forEach((i) => delete process.env[i]);\n}\n","import isNil from \"lodash/isNil\";\nimport { getExecutionContext } from \"../asyncLocalStorage\";\nimport { z } from \"zod\";\nimport { callBackendFunctionWithToken } from \"../jwtTokenManager\";\n\nconst authSessionParametersResponseSchema = z.object({\n parameters: z.any().refine((v) => v !== undefined),\n});\n\nexport async function getAuthSessionParameters() {\n const context = getExecutionContext();\n\n if (!context) {\n throw new Error(\n \"getAuthSessionParameters failed due to an internal error (context was not found).\"\n );\n }\n\n const authSessionId = context.authSessionId;\n\n if (isNil(authSessionId)) {\n throw new Error(\"AuthSessions are not enabled\");\n }\n\n const response = await callBackendFunctionWithToken(\n `auth-session/${authSessionId}/parameters`,\n {\n method: \"GET\",\n }\n );\n\n const body = await response.text();\n if (!response.ok) {\n throw new Error(\n `getAuthSessionParameters failed with status ${response.status}: ${body}`\n );\n }\n\n let json: unknown;\n try {\n json = JSON.parse(body);\n } catch (e) {\n throw new Error(`Expected JSON response, but got ${body}`);\n }\n\n return authSessionParametersResponseSchema.parse(json).parameters as any;\n}\n"],"mappings":"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","names":["exports","RunAutomationError","ApiNotFoundError","InvalidApiError","AbortedError","AuthRequiredError","AutomationError","InternalInvalidInputError","ResultTooBigError","exports","fs","resolve","data","exports","UnixSocketClient","path","TCPSocketClient","JSONLFileClient","exports","import_dotenv","fetch","path","import_zod","dotenv","z","import_promises","path","captchaSolverSettings","err","fastify","captchaSolverSettings","path","fs","import_fs_extra","import_neverthrow","import_path","fs","import_neverthrow","import_neverthrow","import_neverthrow","path","import_runtime_interface","import_portfinder","import_fs_extra","import_path","fs","import_neverthrow","import_zod","context","page","waitOn","import_runtime_interface","path","path","import_runtime_interface","resolve","page","import_promises","import_neverthrow","import_zod","getAuthSessionParameters","isNil","import_runtime_interface","dotenv","input","getAuthSessionParameters","result","path"]}
|
|
@@ -0,0 +1,255 @@
|
|
|
1
|
+
import {
|
|
2
|
+
require_dist,
|
|
3
|
+
runApi
|
|
4
|
+
} from "../../chunk-XC75QGFG.mjs";
|
|
5
|
+
import "../../chunk-B3T6RXPC.mjs";
|
|
6
|
+
import {
|
|
7
|
+
getExecutionContext,
|
|
8
|
+
runWithContext
|
|
9
|
+
} from "../../chunk-W4UX6G4X.mjs";
|
|
10
|
+
import {
|
|
11
|
+
formatZodError
|
|
12
|
+
} from "../../chunk-NDMVGENG.mjs";
|
|
13
|
+
import "../../chunk-6ZRJOUQS.mjs";
|
|
14
|
+
import "../../chunk-G4PO5RIV.mjs";
|
|
15
|
+
import {
|
|
16
|
+
backendFunctionsTokenManager,
|
|
17
|
+
callBackendFunctionWithToken
|
|
18
|
+
} from "../../chunk-7YL2JUTE.mjs";
|
|
19
|
+
import "../../chunk-FGV5T6SI.mjs";
|
|
20
|
+
import "../../chunk-XOAZ2MGA.mjs";
|
|
21
|
+
import {
|
|
22
|
+
__require,
|
|
23
|
+
__toESM
|
|
24
|
+
} from "../../chunk-LZOMFHX3.mjs";
|
|
25
|
+
|
|
26
|
+
// src/commands/interface/run.ts
|
|
27
|
+
import { program } from "commander";
|
|
28
|
+
import dotenv from "dotenv";
|
|
29
|
+
import { setTimeout } from "timers/promises";
|
|
30
|
+
import { err, ok } from "neverthrow";
|
|
31
|
+
|
|
32
|
+
// src/common/backendFunctions/getAuthSessionParameters.ts
|
|
33
|
+
import isNil from "lodash/isNil";
|
|
34
|
+
import { z } from "zod";
|
|
35
|
+
var authSessionParametersResponseSchema = z.object({
|
|
36
|
+
parameters: z.any().refine((v) => v !== void 0)
|
|
37
|
+
});
|
|
38
|
+
async function getAuthSessionParameters() {
|
|
39
|
+
const context = getExecutionContext();
|
|
40
|
+
if (!context) {
|
|
41
|
+
throw new Error(
|
|
42
|
+
"getAuthSessionParameters failed due to an internal error (context was not found)."
|
|
43
|
+
);
|
|
44
|
+
}
|
|
45
|
+
const authSessionId = context.authSessionId;
|
|
46
|
+
if (isNil(authSessionId)) {
|
|
47
|
+
throw new Error("AuthSessions are not enabled");
|
|
48
|
+
}
|
|
49
|
+
const response = await callBackendFunctionWithToken(
|
|
50
|
+
`auth-session/${authSessionId}/parameters`,
|
|
51
|
+
{
|
|
52
|
+
method: "GET"
|
|
53
|
+
}
|
|
54
|
+
);
|
|
55
|
+
const body = await response.text();
|
|
56
|
+
if (!response.ok) {
|
|
57
|
+
throw new Error(
|
|
58
|
+
`getAuthSessionParameters failed with status ${response.status}: ${body}`
|
|
59
|
+
);
|
|
60
|
+
}
|
|
61
|
+
let json;
|
|
62
|
+
try {
|
|
63
|
+
json = JSON.parse(body);
|
|
64
|
+
} catch (e) {
|
|
65
|
+
throw new Error(`Expected JSON response, but got ${body}`);
|
|
66
|
+
}
|
|
67
|
+
return authSessionParametersResponseSchema.parse(json).parameters;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
// src/commands/interface/run.ts
|
|
71
|
+
var import_runtime_interface = __toESM(require_dist());
|
|
72
|
+
dotenv.config({
|
|
73
|
+
path: `.env`
|
|
74
|
+
});
|
|
75
|
+
function runAutomationCLI(importFunction) {
|
|
76
|
+
program.description("run user automation and communicate using unix socket").argument(
|
|
77
|
+
"<input>",
|
|
78
|
+
"In unix socket mode: path to the unix socket. In jsonl mode: path to the jsonl file. In tcp socket mode: host:port"
|
|
79
|
+
).option("--mode [mode]", "Communication mode: unix, jsonl, or tcp").action(
|
|
80
|
+
async (input, {
|
|
81
|
+
mode = "unix"
|
|
82
|
+
}) => {
|
|
83
|
+
let context;
|
|
84
|
+
const throttleTime = 60 * 1e3;
|
|
85
|
+
let timeoutTimestamp = Date.now();
|
|
86
|
+
const client = createClient(mode, input);
|
|
87
|
+
const abortController = new AbortController();
|
|
88
|
+
const interruptSignalHandler = async () => {
|
|
89
|
+
abortController.abort();
|
|
90
|
+
await setTimeout(6e4);
|
|
91
|
+
await client.close();
|
|
92
|
+
process.exit(1);
|
|
93
|
+
};
|
|
94
|
+
process.on("SIGINT", interruptSignalHandler);
|
|
95
|
+
process.on("SIGTERM", interruptSignalHandler);
|
|
96
|
+
const messagesGenerator = client.receiveJSON();
|
|
97
|
+
async function receiveMessages() {
|
|
98
|
+
const data = await messagesGenerator.next();
|
|
99
|
+
if (data.done) {
|
|
100
|
+
return;
|
|
101
|
+
}
|
|
102
|
+
const inputParseResult = import_runtime_interface.runApiInputSchema.safeParse(data.value);
|
|
103
|
+
if (!inputParseResult.success) {
|
|
104
|
+
console.error(
|
|
105
|
+
"Validation error:",
|
|
106
|
+
formatZodError(inputParseResult.error)
|
|
107
|
+
);
|
|
108
|
+
return {
|
|
109
|
+
type: "error",
|
|
110
|
+
error: new import_runtime_interface.InternalInvalidInputError(
|
|
111
|
+
"Invalid input",
|
|
112
|
+
formatZodError(inputParseResult.error)
|
|
113
|
+
)
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
const input2 = inputParseResult.data;
|
|
117
|
+
return input2;
|
|
118
|
+
}
|
|
119
|
+
let resultPromise = null;
|
|
120
|
+
async function handleMessage(message) {
|
|
121
|
+
if (message.type === "abort") {
|
|
122
|
+
abortController.abort();
|
|
123
|
+
return;
|
|
124
|
+
}
|
|
125
|
+
if (message.type === "tokenUpdate") {
|
|
126
|
+
backendFunctionsTokenManager.token = message.parameters.functionsToken;
|
|
127
|
+
return;
|
|
128
|
+
}
|
|
129
|
+
if (message.type === "start") {
|
|
130
|
+
context = {
|
|
131
|
+
extendedPayloads: [],
|
|
132
|
+
runEnvironment: message.parameters.runOptions.environment === "standalone" ? "DEPLOYED" /* DEPLOYED */ : "IDE" /* IDE */,
|
|
133
|
+
timeoutInfo: {
|
|
134
|
+
extendTimeoutCallback: async () => {
|
|
135
|
+
if (Date.now() - timeoutTimestamp < throttleTime) return;
|
|
136
|
+
timeoutTimestamp = Date.now();
|
|
137
|
+
client.sendJSON({ type: "extend" });
|
|
138
|
+
}
|
|
139
|
+
},
|
|
140
|
+
getAuthSessionParameters,
|
|
141
|
+
...message.parameters.context ?? {},
|
|
142
|
+
proxy: getProxyUrlFromRunOptions(message.parameters.runOptions)
|
|
143
|
+
};
|
|
144
|
+
backendFunctionsTokenManager.token = message.parameters.functionsToken;
|
|
145
|
+
resultPromise = runWithContext(context, async () => {
|
|
146
|
+
return await runApi({
|
|
147
|
+
...message.parameters,
|
|
148
|
+
abortSignal: abortController.signal,
|
|
149
|
+
importFunction: importFunction ?? _defaultImport
|
|
150
|
+
});
|
|
151
|
+
});
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
let receiveMessagesPromise = receiveMessages();
|
|
156
|
+
while (true) {
|
|
157
|
+
const messageOrResult = await Promise.race([
|
|
158
|
+
receiveMessagesPromise.then((message) => ({
|
|
159
|
+
type: "message",
|
|
160
|
+
message
|
|
161
|
+
})),
|
|
162
|
+
...resultPromise ? [
|
|
163
|
+
resultPromise.then((result2) => ({
|
|
164
|
+
type: "result",
|
|
165
|
+
result: result2
|
|
166
|
+
}))
|
|
167
|
+
] : []
|
|
168
|
+
]);
|
|
169
|
+
if (messageOrResult.type === "message") {
|
|
170
|
+
const { message } = messageOrResult;
|
|
171
|
+
if (message === void 0) {
|
|
172
|
+
break;
|
|
173
|
+
}
|
|
174
|
+
if (message.type === "error") {
|
|
175
|
+
client.sendJSON({
|
|
176
|
+
type: "done",
|
|
177
|
+
result: message.error.json,
|
|
178
|
+
success: false
|
|
179
|
+
});
|
|
180
|
+
break;
|
|
181
|
+
}
|
|
182
|
+
if (message.type === "ping") {
|
|
183
|
+
client.sendJSON({
|
|
184
|
+
type: "pong"
|
|
185
|
+
});
|
|
186
|
+
break;
|
|
187
|
+
}
|
|
188
|
+
await handleMessage(message);
|
|
189
|
+
receiveMessagesPromise = receiveMessages();
|
|
190
|
+
continue;
|
|
191
|
+
}
|
|
192
|
+
const { result } = messageOrResult;
|
|
193
|
+
const success = result.isOk();
|
|
194
|
+
const resultToSend = success ? result.value : result.error.json;
|
|
195
|
+
client.sendJSON({
|
|
196
|
+
type: "done",
|
|
197
|
+
result: resultToSend,
|
|
198
|
+
success
|
|
199
|
+
});
|
|
200
|
+
break;
|
|
201
|
+
}
|
|
202
|
+
if (!client.closed) {
|
|
203
|
+
await client.close();
|
|
204
|
+
}
|
|
205
|
+
process.exit(0);
|
|
206
|
+
}
|
|
207
|
+
);
|
|
208
|
+
program.parse(process.argv);
|
|
209
|
+
}
|
|
210
|
+
function getProxyUrlFromRunOptions(runOptions) {
|
|
211
|
+
if (runOptions?.environment !== "standalone") return void 0;
|
|
212
|
+
const proxy = runOptions.proxy;
|
|
213
|
+
if (!proxy) return void 0;
|
|
214
|
+
const url = new URL(proxy.server);
|
|
215
|
+
url.username = proxy.username;
|
|
216
|
+
url.password = proxy.password;
|
|
217
|
+
return url.toString();
|
|
218
|
+
}
|
|
219
|
+
var _defaultImport = async (path) => {
|
|
220
|
+
try {
|
|
221
|
+
const imported = await import(`${process.cwd()}/${path}`);
|
|
222
|
+
return ok(imported);
|
|
223
|
+
} catch (e) {
|
|
224
|
+
if ("code" in e && e.code === "MODULE_NOT_FOUND" || e.code === "ERR_MODULE_NOT_FOUND") {
|
|
225
|
+
return err({
|
|
226
|
+
type: "not_found"
|
|
227
|
+
});
|
|
228
|
+
}
|
|
229
|
+
return err({
|
|
230
|
+
type: "other",
|
|
231
|
+
error: e
|
|
232
|
+
});
|
|
233
|
+
}
|
|
234
|
+
};
|
|
235
|
+
function createClient(mode, input) {
|
|
236
|
+
if (mode === "jsonl") {
|
|
237
|
+
return new import_runtime_interface.JSONLFileClient(input);
|
|
238
|
+
}
|
|
239
|
+
if (mode === "tcp") {
|
|
240
|
+
const [host, portString] = input.split(":");
|
|
241
|
+
const port = Number(portString);
|
|
242
|
+
if (!host || isNaN(port)) {
|
|
243
|
+
throw new Error("Invalid tcp input, expected format host:port");
|
|
244
|
+
}
|
|
245
|
+
return new import_runtime_interface.TCPSocketClient(host, port);
|
|
246
|
+
}
|
|
247
|
+
return new import_runtime_interface.UnixSocketClient(input);
|
|
248
|
+
}
|
|
249
|
+
if (__require.main === module) {
|
|
250
|
+
runAutomationCLI();
|
|
251
|
+
}
|
|
252
|
+
export {
|
|
253
|
+
runAutomationCLI
|
|
254
|
+
};
|
|
255
|
+
//# sourceMappingURL=run.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/commands/interface/run.ts","../../../src/common/backendFunctions/getAuthSessionParameters.ts"],"sourcesContent":["import { program } from \"commander\";\nimport dotenv from \"dotenv\";\nimport {\n runWithContext,\n InternalRunInfo,\n} from \"../../common/asyncLocalStorage\";\nimport { runApi } from \"../../common/runApi\";\nimport { RunEnvironment } from \"../../runtime/enums\";\nimport { setTimeout } from \"timers/promises\";\nimport { backendFunctionsTokenManager } from \"../../common/jwtTokenManager\";\nimport { formatZodError } from \"../../common/formatZodError\";\nimport { err, ok } from \"neverthrow\";\nimport { getAuthSessionParameters } from \"../../common/backendFunctions/getAuthSessionParameters\";\nimport {\n RunApiParameters,\n InternalInvalidInputError,\n RunApiInputMessage,\n runApiInputSchema,\n JSONLFileClient,\n TCPSocketClient,\n UnixSocketClient,\n ImportFunction,\n} from \"@intuned/runtime-interface\";\n\ndotenv.config({\n path: `.env`,\n});\n\nexport function runAutomationCLI<ResultType = any>(\n importFunction?: (path: string) => Promise<any>\n) {\n program\n .description(\"run user automation and communicate using unix socket\")\n .argument(\n \"<input>\",\n \"In unix socket mode: path to the unix socket. In jsonl mode: path to the jsonl file. In tcp socket mode: host:port\"\n )\n .option(\"--mode [mode]\", \"Communication mode: unix, jsonl, or tcp\")\n .action(\n async (\n input: string,\n {\n mode = \"unix\",\n }: {\n mode: \"unix\" | \"jsonl\" | \"tcp\";\n }\n ) => {\n let context: InternalRunInfo;\n const throttleTime = 60 * 1000; // 1 minute\n let timeoutTimestamp = Date.now();\n\n const client = createClient(mode, input);\n\n const abortController = new AbortController();\n\n const interruptSignalHandler = async () => {\n abortController.abort();\n // wait for the script to finish gracefully\n await setTimeout(60_000);\n await client.close();\n process.exit(1);\n };\n\n process.on(\"SIGINT\", interruptSignalHandler);\n process.on(\"SIGTERM\", interruptSignalHandler);\n\n const messagesGenerator = client.receiveJSON();\n\n async function receiveMessages() {\n const data = await messagesGenerator.next();\n if (data.done) {\n return;\n }\n const inputParseResult = runApiInputSchema.safeParse(data.value);\n if (!inputParseResult.success) {\n console.error(\n \"Validation error:\",\n formatZodError(inputParseResult.error)\n );\n return {\n type: \"error\" as const,\n error: new InternalInvalidInputError(\n \"Invalid input\",\n formatZodError(inputParseResult.error)\n ),\n };\n }\n const input = inputParseResult.data;\n return input;\n }\n\n let resultPromise: ReturnType<typeof runApi<ResultType>> | null =\n null as any;\n\n async function handleMessage(message: RunApiInputMessage) {\n if (message.type === \"abort\") {\n abortController.abort();\n return;\n }\n if (message.type === \"tokenUpdate\") {\n backendFunctionsTokenManager.token =\n message.parameters.functionsToken;\n return;\n }\n if (message.type === \"start\") {\n context = {\n extendedPayloads: [],\n runEnvironment:\n message.parameters.runOptions.environment === \"standalone\"\n ? RunEnvironment.DEPLOYED\n : RunEnvironment.IDE,\n timeoutInfo: {\n extendTimeoutCallback: async () => {\n if (Date.now() - timeoutTimestamp < throttleTime) return;\n timeoutTimestamp = Date.now();\n client.sendJSON({ type: \"extend\" });\n },\n },\n getAuthSessionParameters,\n\n ...(message.parameters.context ?? {}),\n proxy: getProxyUrlFromRunOptions(message.parameters.runOptions),\n };\n backendFunctionsTokenManager.token =\n message.parameters.functionsToken;\n resultPromise = runWithContext(context, async () => {\n return await runApi<ResultType>({\n ...message.parameters,\n abortSignal: abortController.signal,\n importFunction: importFunction ?? _defaultImport,\n });\n });\n return;\n }\n }\n\n let receiveMessagesPromise = receiveMessages();\n\n while (true as boolean) {\n const messageOrResult = await Promise.race([\n receiveMessagesPromise.then((message) => ({\n type: \"message\" as const,\n message,\n })),\n ...(resultPromise\n ? [\n resultPromise.then((result) => ({\n type: \"result\" as const,\n result,\n })),\n ]\n : []),\n ]);\n if (messageOrResult.type === \"message\") {\n const { message } = messageOrResult;\n if (message === undefined) {\n break;\n }\n if (message.type === \"error\") {\n client.sendJSON({\n type: \"done\",\n result: message.error.json,\n success: false,\n });\n break;\n }\n if (message.type === \"ping\") {\n client.sendJSON({\n type: \"pong\",\n });\n break;\n }\n await handleMessage(message);\n receiveMessagesPromise = receiveMessages();\n continue;\n }\n const { result } = messageOrResult;\n const success = result.isOk();\n const resultToSend = success ? result.value : result.error.json;\n client.sendJSON({\n type: \"done\",\n result: resultToSend,\n success,\n });\n break;\n }\n\n if (!client.closed) {\n await client.close();\n }\n\n process.exit(0);\n }\n );\n\n program.parse(process.argv);\n}\n\nfunction getProxyUrlFromRunOptions(runOptions: RunApiParameters[\"runOptions\"]) {\n if (runOptions?.environment !== \"standalone\") return undefined;\n const proxy = runOptions.proxy;\n if (!proxy) return undefined;\n const url = new URL(proxy.server);\n url.username = proxy.username;\n url.password = proxy.password;\n return url.toString();\n}\n\n// this is only for debugging purposes\nconst _defaultImport: ImportFunction = async (path) => {\n try {\n const imported = await import(`${process.cwd()}/${path}`);\n return ok(imported);\n } catch (e: any) {\n if (\n (\"code\" in e && e.code === \"MODULE_NOT_FOUND\") ||\n e.code === \"ERR_MODULE_NOT_FOUND\"\n ) {\n return err({\n type: \"not_found\",\n });\n }\n return err({\n type: \"other\",\n error: e,\n });\n }\n};\n\nfunction createClient(mode: \"unix\" | \"jsonl\" | \"tcp\", input: string) {\n if (mode === \"jsonl\") {\n return new JSONLFileClient(input);\n }\n if (mode === \"tcp\") {\n const [host, portString] = input.split(\":\");\n const port = Number(portString);\n if (!host || isNaN(port)) {\n throw new Error(\"Invalid tcp input, expected format host:port\");\n }\n return new TCPSocketClient(host, port);\n }\n return new UnixSocketClient(input);\n}\n\nif (require.main === module) {\n runAutomationCLI();\n}\n","import isNil from \"lodash/isNil\";\nimport { getExecutionContext } from \"../asyncLocalStorage\";\nimport { z } from \"zod\";\nimport { callBackendFunctionWithToken } from \"../jwtTokenManager\";\n\nconst authSessionParametersResponseSchema = z.object({\n parameters: z.any().refine((v) => v !== undefined),\n});\n\nexport async function getAuthSessionParameters() {\n const context = getExecutionContext();\n\n if (!context) {\n throw new Error(\n \"getAuthSessionParameters failed due to an internal error (context was not found).\"\n );\n }\n\n const authSessionId = context.authSessionId;\n\n if (isNil(authSessionId)) {\n throw new Error(\"AuthSessions are not enabled\");\n }\n\n const response = await callBackendFunctionWithToken(\n `auth-session/${authSessionId}/parameters`,\n {\n method: \"GET\",\n }\n );\n\n const body = await response.text();\n if (!response.ok) {\n throw new Error(\n `getAuthSessionParameters failed with status ${response.status}: ${body}`\n );\n }\n\n let json: unknown;\n try {\n json = JSON.parse(body);\n } catch (e) {\n throw new Error(`Expected JSON response, but got ${body}`);\n }\n\n return authSessionParametersResponseSchema.parse(json).parameters as any;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,SAAS,eAAe;AACxB,OAAO,YAAY;AAOnB,SAAS,kBAAkB;AAG3B,SAAS,KAAK,UAAU;;;ACXxB,OAAO,WAAW;AAElB,SAAS,SAAS;AAGlB,IAAM,sCAAsC,EAAE,OAAO;AAAA,EACnD,YAAY,EAAE,IAAI,EAAE,OAAO,CAAC,MAAM,MAAM,MAAS;AACnD,CAAC;AAED,eAAsB,2BAA2B;AAC/C,QAAM,UAAU,oBAAoB;AAEpC,MAAI,CAAC,SAAS;AACZ,UAAM,IAAI;AAAA,MACR;AAAA,IACF;AAAA,EACF;AAEA,QAAM,gBAAgB,QAAQ;AAE9B,MAAI,MAAM,aAAa,GAAG;AACxB,UAAM,IAAI,MAAM,8BAA8B;AAAA,EAChD;AAEA,QAAM,WAAW,MAAM;AAAA,IACrB,gBAAgB,aAAa;AAAA,IAC7B;AAAA,MACE,QAAQ;AAAA,IACV;AAAA,EACF;AAEA,QAAM,OAAO,MAAM,SAAS,KAAK;AACjC,MAAI,CAAC,SAAS,IAAI;AAChB,UAAM,IAAI;AAAA,MACR,+CAA+C,SAAS,MAAM,KAAK,IAAI;AAAA,IACzE;AAAA,EACF;AAEA,MAAI;AACJ,MAAI;AACF,WAAO,KAAK,MAAM,IAAI;AAAA,EACxB,SAAS,GAAG;AACV,UAAM,IAAI,MAAM,mCAAmC,IAAI,EAAE;AAAA,EAC3D;AAEA,SAAO,oCAAoC,MAAM,IAAI,EAAE;AACzD;;;ADjCA,+BASO;AAEP,OAAO,OAAO;AAAA,EACZ,MAAM;AACR,CAAC;AAEM,SAAS,iBACd,gBACA;AACA,UACG,YAAY,uDAAuD,EACnE;AAAA,IACC;AAAA,IACA;AAAA,EACF,EACC,OAAO,iBAAiB,yCAAyC,EACjE;AAAA,IACC,OACE,OACA;AAAA,MACE,OAAO;AAAA,IACT,MAGG;AACH,UAAI;AACJ,YAAM,eAAe,KAAK;AAC1B,UAAI,mBAAmB,KAAK,IAAI;AAEhC,YAAM,SAAS,aAAa,MAAM,KAAK;AAEvC,YAAM,kBAAkB,IAAI,gBAAgB;AAE5C,YAAM,yBAAyB,YAAY;AACzC,wBAAgB,MAAM;AAEtB,cAAM,WAAW,GAAM;AACvB,cAAM,OAAO,MAAM;AACnB,gBAAQ,KAAK,CAAC;AAAA,MAChB;AAEA,cAAQ,GAAG,UAAU,sBAAsB;AAC3C,cAAQ,GAAG,WAAW,sBAAsB;AAE5C,YAAM,oBAAoB,OAAO,YAAY;AAE7C,qBAAe,kBAAkB;AAC/B,cAAM,OAAO,MAAM,kBAAkB,KAAK;AAC1C,YAAI,KAAK,MAAM;AACb;AAAA,QACF;AACA,cAAM,mBAAmB,2CAAkB,UAAU,KAAK,KAAK;AAC/D,YAAI,CAAC,iBAAiB,SAAS;AAC7B,kBAAQ;AAAA,YACN;AAAA,YACA,eAAe,iBAAiB,KAAK;AAAA,UACvC;AACA,iBAAO;AAAA,YACL,MAAM;AAAA,YACN,OAAO,IAAI;AAAA,cACT;AAAA,cACA,eAAe,iBAAiB,KAAK;AAAA,YACvC;AAAA,UACF;AAAA,QACF;AACA,cAAMA,SAAQ,iBAAiB;AAC/B,eAAOA;AAAA,MACT;AAEA,UAAI,gBACF;AAEF,qBAAe,cAAc,SAA6B;AACxD,YAAI,QAAQ,SAAS,SAAS;AAC5B,0BAAgB,MAAM;AACtB;AAAA,QACF;AACA,YAAI,QAAQ,SAAS,eAAe;AAClC,uCAA6B,QAC3B,QAAQ,WAAW;AACrB;AAAA,QACF;AACA,YAAI,QAAQ,SAAS,SAAS;AAC5B,oBAAU;AAAA,YACR,kBAAkB,CAAC;AAAA,YACnB,gBACE,QAAQ,WAAW,WAAW,gBAAgB;AAAA,YAGhD,aAAa;AAAA,cACX,uBAAuB,YAAY;AACjC,oBAAI,KAAK,IAAI,IAAI,mBAAmB,aAAc;AAClD,mCAAmB,KAAK,IAAI;AAC5B,uBAAO,SAAS,EAAE,MAAM,SAAS,CAAC;AAAA,cACpC;AAAA,YACF;AAAA,YACA;AAAA,YAEA,GAAI,QAAQ,WAAW,WAAW,CAAC;AAAA,YACnC,OAAO,0BAA0B,QAAQ,WAAW,UAAU;AAAA,UAChE;AACA,uCAA6B,QAC3B,QAAQ,WAAW;AACrB,0BAAgB,eAAe,SAAS,YAAY;AAClD,mBAAO,MAAM,OAAmB;AAAA,cAC9B,GAAG,QAAQ;AAAA,cACX,aAAa,gBAAgB;AAAA,cAC7B,gBAAgB,kBAAkB;AAAA,YACpC,CAAC;AAAA,UACH,CAAC;AACD;AAAA,QACF;AAAA,MACF;AAEA,UAAI,yBAAyB,gBAAgB;AAE7C,aAAO,MAAiB;AACtB,cAAM,kBAAkB,MAAM,QAAQ,KAAK;AAAA,UACzC,uBAAuB,KAAK,CAAC,aAAa;AAAA,YACxC,MAAM;AAAA,YACN;AAAA,UACF,EAAE;AAAA,UACF,GAAI,gBACA;AAAA,YACE,cAAc,KAAK,CAACC,aAAY;AAAA,cAC9B,MAAM;AAAA,cACN,QAAAA;AAAA,YACF,EAAE;AAAA,UACJ,IACA,CAAC;AAAA,QACP,CAAC;AACD,YAAI,gBAAgB,SAAS,WAAW;AACtC,gBAAM,EAAE,QAAQ,IAAI;AACpB,cAAI,YAAY,QAAW;AACzB;AAAA,UACF;AACA,cAAI,QAAQ,SAAS,SAAS;AAC5B,mBAAO,SAAS;AAAA,cACd,MAAM;AAAA,cACN,QAAQ,QAAQ,MAAM;AAAA,cACtB,SAAS;AAAA,YACX,CAAC;AACD;AAAA,UACF;AACA,cAAI,QAAQ,SAAS,QAAQ;AAC3B,mBAAO,SAAS;AAAA,cACd,MAAM;AAAA,YACR,CAAC;AACD;AAAA,UACF;AACA,gBAAM,cAAc,OAAO;AAC3B,mCAAyB,gBAAgB;AACzC;AAAA,QACF;AACA,cAAM,EAAE,OAAO,IAAI;AACnB,cAAM,UAAU,OAAO,KAAK;AAC5B,cAAM,eAAe,UAAU,OAAO,QAAQ,OAAO,MAAM;AAC3D,eAAO,SAAS;AAAA,UACd,MAAM;AAAA,UACN,QAAQ;AAAA,UACR;AAAA,QACF,CAAC;AACD;AAAA,MACF;AAEA,UAAI,CAAC,OAAO,QAAQ;AAClB,cAAM,OAAO,MAAM;AAAA,MACrB;AAEA,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF;AAEF,UAAQ,MAAM,QAAQ,IAAI;AAC5B;AAEA,SAAS,0BAA0B,YAA4C;AAC7E,MAAI,YAAY,gBAAgB,aAAc,QAAO;AACrD,QAAM,QAAQ,WAAW;AACzB,MAAI,CAAC,MAAO,QAAO;AACnB,QAAM,MAAM,IAAI,IAAI,MAAM,MAAM;AAChC,MAAI,WAAW,MAAM;AACrB,MAAI,WAAW,MAAM;AACrB,SAAO,IAAI,SAAS;AACtB;AAGA,IAAM,iBAAiC,OAAO,SAAS;AACrD,MAAI;AACF,UAAM,WAAW,MAAM,OAAO,GAAG,QAAQ,IAAI,CAAC,IAAI,IAAI;AACtD,WAAO,GAAG,QAAQ;AAAA,EACpB,SAAS,GAAQ;AACf,QACG,UAAU,KAAK,EAAE,SAAS,sBAC3B,EAAE,SAAS,wBACX;AACA,aAAO,IAAI;AAAA,QACT,MAAM;AAAA,MACR,CAAC;AAAA,IACH;AACA,WAAO,IAAI;AAAA,MACT,MAAM;AAAA,MACN,OAAO;AAAA,IACT,CAAC;AAAA,EACH;AACF;AAEA,SAAS,aAAa,MAAgC,OAAe;AACnE,MAAI,SAAS,SAAS;AACpB,WAAO,IAAI,yCAAgB,KAAK;AAAA,EAClC;AACA,MAAI,SAAS,OAAO;AAClB,UAAM,CAAC,MAAM,UAAU,IAAI,MAAM,MAAM,GAAG;AAC1C,UAAM,OAAO,OAAO,UAAU;AAC9B,QAAI,CAAC,QAAQ,MAAM,IAAI,GAAG;AACxB,YAAM,IAAI,MAAM,8CAA8C;AAAA,IAChE;AACA,WAAO,IAAI,yCAAgB,MAAM,IAAI;AAAA,EACvC;AACA,SAAO,IAAI,0CAAiB,KAAK;AACnC;AAEA,IAAI,UAAQ,SAAS,QAAQ;AAC3B,mBAAiB;AACnB;","names":["input","result"]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { AsyncLocalStorage } from 'node:async_hooks';
|
|
2
|
+
import { R as RunInfo, P as Payload } from '../../export.d-BAUMB-lG.mjs';
|
|
3
|
+
|
|
4
|
+
declare const asyncLocalStorage: AsyncLocalStorage<InternalRunInfo>;
|
|
5
|
+
declare function runWithContext<R, TArgs extends any[]>(contextData: InternalRunInfo, callback: (...args: TArgs) => R, ...args: TArgs): R;
|
|
6
|
+
interface TimeoutInfo {
|
|
7
|
+
extendTimeoutCallback?: () => Promise<void>;
|
|
8
|
+
}
|
|
9
|
+
interface InternalRunInfo extends RunInfo {
|
|
10
|
+
extendedPayloads: Payload[];
|
|
11
|
+
timeoutInfo?: TimeoutInfo;
|
|
12
|
+
store?: Record<string, any>;
|
|
13
|
+
getAuthSessionParameters?: () => Promise<any>;
|
|
14
|
+
}
|
|
15
|
+
declare function getExecutionContext(): InternalRunInfo | undefined;
|
|
16
|
+
|
|
17
|
+
export { type InternalRunInfo, asyncLocalStorage, getExecutionContext, runWithContext };
|