@intuned/runtime-dev 1.3.18-interface.9 → 1.3.21-dev.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (212) hide show
  1. package/.babelrc +27 -0
  2. package/.eslintignore +10 -0
  3. package/.eslintrc.js +39 -0
  4. package/CHANGELOG.md +2 -1
  5. package/InterfaceTemplate/__utils.ts +63 -0
  6. package/InterfaceTemplate/index.playwright.ts +6 -0
  7. package/bin/intuned +20 -2
  8. package/dist/commands/api/run.d.ts +6 -0
  9. package/dist/commands/api/run.js +119 -0
  10. package/dist/commands/auth-sessions/load.d.ts +2 -0
  11. package/dist/commands/auth-sessions/load.js +38 -0
  12. package/dist/commands/auth-sessions/run-check.d.ts +2 -0
  13. package/dist/commands/auth-sessions/run-check.js +83 -0
  14. package/dist/commands/auth-sessions/run-create.d.ts +2 -0
  15. package/dist/commands/auth-sessions/run-create.js +85 -0
  16. package/dist/commands/browser/save-state.d.ts +2 -0
  17. package/dist/commands/browser/save-state.js +17 -0
  18. package/dist/commands/browser/start-browser.d.ts +2 -0
  19. package/dist/commands/browser/start-browser.js +14 -0
  20. package/dist/commands/build.d.ts +1 -0
  21. package/dist/commands/build.js +83 -0
  22. package/dist/commands/common/browserUtils.d.ts +14 -0
  23. package/dist/commands/common/browserUtils.js +66 -0
  24. package/dist/commands/common/getFirstLineNumber.d.ts +9 -0
  25. package/dist/commands/common/getFirstLineNumber.js +101 -0
  26. package/dist/commands/common/getFirstLineNumber.test.js +227 -0
  27. package/dist/commands/common/projectExclusions.d.ts +2 -0
  28. package/dist/commands/common/projectExclusions.js +8 -0
  29. package/dist/commands/common/sendMessageToClient.d.ts +1 -0
  30. package/dist/commands/common/sendMessageToClient.js +10 -0
  31. package/dist/commands/common/tsNodeImport.d.ts +2 -5
  32. package/dist/commands/common/tsNodeImport.js +15 -56
  33. package/dist/commands/common/utils/fileUtils.d.ts +6 -0
  34. package/dist/commands/common/utils/fileUtils.js +32 -0
  35. package/dist/commands/common/utils/interfaceClient.d.ts +31 -0
  36. package/dist/commands/common/utils/interfaceClient.js +98 -0
  37. package/dist/commands/common/utils/settings.d.ts +2 -0
  38. package/dist/commands/common/utils/settings.js +31 -0
  39. package/dist/commands/common/utils/template.d.ts +2 -0
  40. package/dist/commands/common/utils/template.js +30 -0
  41. package/dist/commands/get-headless-user-agent.d.ts +1 -0
  42. package/dist/commands/get-headless-user-agent.js +18 -0
  43. package/dist/commands/interface/run.d.ts +1 -3
  44. package/dist/commands/interface/run.js +139 -2047
  45. package/dist/commands/ts-check.d.ts +2 -0
  46. package/dist/commands/ts-check.js +55 -0
  47. package/dist/common/Logger/Logger/index.d.ts +12 -0
  48. package/dist/common/Logger/Logger/index.js +60 -0
  49. package/dist/common/Logger/Logger/types.d.ts +8 -0
  50. package/dist/common/Logger/Logger/types.js +5 -0
  51. package/dist/common/Logger/index.d.ts +12 -0
  52. package/dist/common/Logger/index.js +60 -0
  53. package/dist/common/Logger/types.d.ts +8 -0
  54. package/dist/common/Logger/types.js +5 -0
  55. package/dist/common/asyncLocalStorage/index.d.ts +8 -9
  56. package/dist/common/asyncLocalStorage/index.js +9 -34
  57. package/dist/common/backendFunctions/getAuthSessionParameters.d.ts +1 -0
  58. package/dist/common/backendFunctions/getAuthSessionParameters.js +38 -0
  59. package/dist/common/binStartupScript.d.ts +1 -2
  60. package/dist/common/binStartupScript.js +25 -132
  61. package/dist/common/browserTabs.d.ts +72 -0
  62. package/dist/common/browserTabs.js +74 -0
  63. package/dist/common/cleanEnvironmentVariables.d.ts +1 -3
  64. package/dist/common/cleanEnvironmentVariables.js +7 -30
  65. package/dist/common/constants.d.ts +11 -13
  66. package/dist/common/constants.js +15 -58
  67. package/dist/common/contextStorageStateHelpers.d.ts +6 -8
  68. package/dist/common/contextStorageStateHelpers.js +26 -48
  69. package/dist/common/env.d.ts +6 -0
  70. package/dist/common/env.js +17 -0
  71. package/dist/common/extension/extensionsHelpers.d.ts +11 -0
  72. package/dist/common/extension/extensionsHelpers.js +147 -0
  73. package/dist/common/extension/intunedExtensionServer.d.ts +24 -0
  74. package/dist/common/extension/intunedExtensionServer.js +178 -0
  75. package/dist/common/extension/types.d.ts +219 -0
  76. package/dist/common/extension/types.js +51 -0
  77. package/dist/common/formatZodError.d.ts +2 -0
  78. package/dist/{chunk-NDMVGENG.mjs → common/formatZodError.js} +9 -9
  79. package/dist/common/intunedJson.d.ts +249 -0
  80. package/dist/common/intunedJson.js +155 -0
  81. package/dist/common/jwtTokenManager.d.ts +4 -6
  82. package/dist/common/jwtTokenManager.js +40 -108
  83. package/dist/common/launchBrowser.d.ts +43 -0
  84. package/dist/common/launchBrowser.js +301 -0
  85. package/dist/common/playwrightContext.d.ts +31 -0
  86. package/dist/common/playwrightContext.js +154 -0
  87. package/dist/common/runApi/importUsingImportFunction.d.ts +7 -0
  88. package/dist/common/runApi/importUsingImportFunction.js +46 -0
  89. package/dist/common/runApi/index.d.ts +6 -9
  90. package/dist/common/runApi/index.js +75 -1782
  91. package/dist/common/settingsSchema.d.ts +9 -9
  92. package/dist/common/settingsSchema.js +20 -55
  93. package/dist/common/setupContextHook.d.ts +16 -0
  94. package/dist/common/setupContextHook.js +22 -0
  95. package/dist/common/telemetry.d.ts +3 -6
  96. package/dist/common/telemetry.js +8 -41
  97. package/dist/index.d.ts +4 -6
  98. package/dist/index.js +92 -784
  99. package/dist/runtime/RunError.d.ts +5 -0
  100. package/dist/runtime/RunError.js +19 -0
  101. package/dist/runtime/attemptStore.d.ts +2 -0
  102. package/dist/runtime/attemptStore.js +23 -0
  103. package/dist/runtime/captcha.d.ts +15 -0
  104. package/dist/runtime/captcha.js +191 -0
  105. package/dist/runtime/captcha.test.js +821 -0
  106. package/dist/runtime/downloadDirectory.d.ts +1 -0
  107. package/dist/runtime/downloadDirectory.js +19 -0
  108. package/dist/runtime/enums.d.js +5 -0
  109. package/dist/runtime/enums.d.ts +11 -0
  110. package/dist/runtime/enums.js +18 -0
  111. package/dist/runtime/executionHelpers.test.js +52 -0
  112. package/dist/runtime/export.d.js +5 -0
  113. package/dist/runtime/export.d.ts +284 -0
  114. package/dist/runtime/extendPayload.d.ts +2 -0
  115. package/dist/runtime/extendPayload.js +21 -0
  116. package/dist/runtime/extendTimeout.d.ts +1 -0
  117. package/dist/runtime/extendTimeout.js +23 -0
  118. package/dist/runtime/getAiGatewayConfig.d.ts +10 -0
  119. package/dist/runtime/getAiGatewayConfig.js +16 -0
  120. package/dist/runtime/getAuthSessionParameters.d.ts +1 -0
  121. package/dist/runtime/getAuthSessionParameters.js +20 -0
  122. package/dist/runtime/index.d.ts +10 -168
  123. package/dist/runtime/index.js +88 -779
  124. package/dist/runtime/persistentStore.d.ts +2 -0
  125. package/dist/runtime/persistentStore.js +37 -0
  126. package/dist/runtime/persistentStore.test.js +101 -0
  127. package/dist/runtime/runInfo.d.ts +2 -0
  128. package/dist/runtime/runInfo.js +21 -0
  129. package/dist/vendor/runtime-interface.d.ts +1 -0
  130. package/dist/vendor/runtime-interface.js +497 -0
  131. package/package.json +21 -75
  132. package/template.tsconfig.json +11 -0
  133. package/tsconfig.eslint.json +5 -0
  134. package/tsconfig.json +25 -0
  135. package/tsup.config.ts +12 -0
  136. package/typedoc.json +49 -0
  137. package/dist/chunk-3AGSY4RT.mjs +0 -1108
  138. package/dist/chunk-3AGSY4RT.mjs.map +0 -1
  139. package/dist/chunk-6ZRJOUQS.mjs +0 -16
  140. package/dist/chunk-6ZRJOUQS.mjs.map +0 -1
  141. package/dist/chunk-7YL2JUTE.mjs +0 -146
  142. package/dist/chunk-7YL2JUTE.mjs.map +0 -1
  143. package/dist/chunk-BF45RZ32.mjs +0 -13
  144. package/dist/chunk-BF45RZ32.mjs.map +0 -1
  145. package/dist/chunk-FGV5T6SI.mjs +0 -27
  146. package/dist/chunk-FGV5T6SI.mjs.map +0 -1
  147. package/dist/chunk-G4PO5RIV.mjs +0 -85
  148. package/dist/chunk-G4PO5RIV.mjs.map +0 -1
  149. package/dist/chunk-LZOMFHX3.mjs +0 -38
  150. package/dist/chunk-LZOMFHX3.mjs.map +0 -1
  151. package/dist/chunk-NDMVGENG.mjs.map +0 -1
  152. package/dist/chunk-UO2E7T7T.mjs +0 -787
  153. package/dist/chunk-UO2E7T7T.mjs.map +0 -1
  154. package/dist/chunk-W4UX6G4X.mjs +0 -17
  155. package/dist/chunk-W4UX6G4X.mjs.map +0 -1
  156. package/dist/chunk-XOAZ2MGA.mjs +0 -59
  157. package/dist/chunk-XOAZ2MGA.mjs.map +0 -1
  158. package/dist/commands/common/tsNodeImport.d.mts +0 -5
  159. package/dist/commands/common/tsNodeImport.js.map +0 -1
  160. package/dist/commands/common/tsNodeImport.mjs +0 -45
  161. package/dist/commands/common/tsNodeImport.mjs.map +0 -1
  162. package/dist/commands/interface/run.d.mts +0 -3
  163. package/dist/commands/interface/run.js.map +0 -1
  164. package/dist/commands/interface/run.mjs +0 -256
  165. package/dist/commands/interface/run.mjs.map +0 -1
  166. package/dist/common/asyncLocalStorage/index.d.mts +0 -17
  167. package/dist/common/asyncLocalStorage/index.js.map +0 -1
  168. package/dist/common/asyncLocalStorage/index.mjs +0 -12
  169. package/dist/common/asyncLocalStorage/index.mjs.map +0 -1
  170. package/dist/common/binStartupScript.d.mts +0 -2
  171. package/dist/common/binStartupScript.js.map +0 -1
  172. package/dist/common/binStartupScript.mjs +0 -135
  173. package/dist/common/binStartupScript.mjs.map +0 -1
  174. package/dist/common/cleanEnvironmentVariables.d.mts +0 -3
  175. package/dist/common/cleanEnvironmentVariables.js.map +0 -1
  176. package/dist/common/cleanEnvironmentVariables.mjs +0 -8
  177. package/dist/common/cleanEnvironmentVariables.mjs.map +0 -1
  178. package/dist/common/constants.d.mts +0 -13
  179. package/dist/common/constants.js.map +0 -1
  180. package/dist/common/constants.mjs +0 -28
  181. package/dist/common/constants.mjs.map +0 -1
  182. package/dist/common/contextStorageStateHelpers.d.mts +0 -24
  183. package/dist/common/contextStorageStateHelpers.js.map +0 -1
  184. package/dist/common/contextStorageStateHelpers.mjs +0 -10
  185. package/dist/common/contextStorageStateHelpers.mjs.map +0 -1
  186. package/dist/common/jwtTokenManager.d.mts +0 -19
  187. package/dist/common/jwtTokenManager.js.map +0 -1
  188. package/dist/common/jwtTokenManager.mjs +0 -11
  189. package/dist/common/jwtTokenManager.mjs.map +0 -1
  190. package/dist/common/runApi/index.d.mts +0 -11
  191. package/dist/common/runApi/index.js.map +0 -1
  192. package/dist/common/runApi/index.mjs +0 -19
  193. package/dist/common/runApi/index.mjs.map +0 -1
  194. package/dist/common/settingsSchema.d.mts +0 -540
  195. package/dist/common/settingsSchema.js.map +0 -1
  196. package/dist/common/settingsSchema.mjs +0 -10
  197. package/dist/common/settingsSchema.mjs.map +0 -1
  198. package/dist/common/telemetry.d.mts +0 -6
  199. package/dist/common/telemetry.js.map +0 -1
  200. package/dist/common/telemetry.mjs +0 -31
  201. package/dist/common/telemetry.mjs.map +0 -1
  202. package/dist/export.d-BAUMB-lG.d.mts +0 -140
  203. package/dist/export.d-BAUMB-lG.d.ts +0 -140
  204. package/dist/index.d.mts +0 -6
  205. package/dist/index.js.map +0 -1
  206. package/dist/index.mjs +0 -48
  207. package/dist/index.mjs.map +0 -1
  208. package/dist/runtime/index.d.mts +0 -168
  209. package/dist/runtime/index.js.map +0 -1
  210. package/dist/runtime/index.mjs +0 -43
  211. package/dist/runtime/index.mjs.map +0 -1
  212. /package/dist/common/assets/{assets/browser_scripts.js → browser_scripts.js} +0 -0
@@ -0,0 +1,301 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.getBrowserExecutablePath = getBrowserExecutablePath;
7
+ exports.getCdpWebSocketUrl = getCdpWebSocketUrl;
8
+ exports.getHeadlessUserAgent = getHeadlessUserAgent;
9
+ exports.getIgnoreHttpErrorsFromConfig = getIgnoreHttpErrorsFromConfig;
10
+ exports.getLocalCdpAddress = getLocalCdpAddress;
11
+ exports.launchBrowser = launchBrowser;
12
+ exports.launchChromium = launchChromium;
13
+ var playwright = _interopRequireWildcard(require("playwright"));
14
+ var _fsExtra = _interopRequireWildcard(require("fs-extra"));
15
+ var fs = _fsExtra;
16
+ var _path = require("path");
17
+ var _waitOn = _interopRequireDefault(require("wait-on"));
18
+ var _child_process = require("child_process");
19
+ var _extensionsHelpers = require("./extension/extensionsHelpers");
20
+ var _intunedExtensionServer = require("./extension/intunedExtensionServer");
21
+ var _util = require("util");
22
+ var _neverthrow = require("neverthrow");
23
+ var _zod = require("zod");
24
+ var _intunedJson = require("./intunedJson");
25
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
26
+ function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
27
+ const execAsync = (0, _util.promisify)(_child_process.exec);
28
+ function getMacKeychainBypassArgs() {
29
+ if (process.platform !== "darwin") {
30
+ return [];
31
+ }
32
+ if (process.env.INTUNED_MAC_DISABLE_KEYCHAIN_PROMPTS === "0") {
33
+ return [];
34
+ }
35
+ return ["--use-mock-keychain", "--password-store=basic"];
36
+ }
37
+ async function createUserDirWithPreferences() {
38
+ const playwrightTempDir = await (0, _fsExtra.mkdtemp)("/tmp/pw-");
39
+ const userDir = (0, _path.join)(playwrightTempDir, "userdir");
40
+ const defaultDir = (0, _path.join)(userDir, "Default");
41
+ await (0, _fsExtra.mkdir)(defaultDir, {
42
+ recursive: true
43
+ });
44
+ const preferences = {
45
+ plugins: {
46
+ always_open_pdf_externally: true
47
+ }
48
+ };
49
+ await (0, _fsExtra.writeFile)((0, _path.join)(defaultDir, "Preferences"), JSON.stringify(preferences));
50
+ return userDir;
51
+ }
52
+ async function getIgnoreHttpErrorsFromConfig(cliOption) {
53
+ if (cliOption !== undefined) {
54
+ return cliOption;
55
+ }
56
+ try {
57
+ const intunedJsonResult = await (0, _intunedJson.loadIntunedJson)();
58
+ if (intunedJsonResult.isOk() && intunedJsonResult.value.ignoreHttpErrors !== undefined) {
59
+ return intunedJsonResult.value.ignoreHttpErrors;
60
+ }
61
+ } catch (error) {}
62
+ const envValue = process.env.IGNORE_HTTP_ERRORS;
63
+ if (envValue !== undefined) {
64
+ return envValue.toLowerCase() === "true" || envValue === "1" || envValue.toLowerCase() === "yes";
65
+ }
66
+ return false;
67
+ }
68
+ async function launchChromium(options) {
69
+ if ("cdpAddress" in options) {
70
+ if (await (0, _extensionsHelpers.isIntunedExtensionEnabled)()) {
71
+ await (0, _intunedExtensionServer.setupIntunedExtensionServer)();
72
+ }
73
+ const browser = await playwright.chromium.connectOverCDP(options.cdpAddress);
74
+ if (browser.contexts().length === 0) {
75
+ throw new Error("No browser contexts found in the connected browser");
76
+ }
77
+ const context = browser.contexts()[0];
78
+ let page = context.pages().at(0) ?? (await context.newPage());
79
+ const targetId = options.cdpTargetId;
80
+ if (targetId) {
81
+ for (const p of context.pages()) {
82
+ let cdp = null;
83
+ try {
84
+ cdp = await context.newCDPSession(p);
85
+ const result = await cdp.send("Target.getTargetInfo");
86
+ if (result.targetInfo.targetId === targetId) {
87
+ page = p;
88
+ break;
89
+ }
90
+ } catch (error) {} finally {
91
+ await cdp?.detach();
92
+ }
93
+ }
94
+ }
95
+ if (options.timeout !== undefined) {
96
+ context.setDefaultTimeout(options.timeout * 1000);
97
+ }
98
+ return {
99
+ page,
100
+ context
101
+ };
102
+ }
103
+ const {
104
+ headless,
105
+ appModeInitialUrl,
106
+ cdpPort,
107
+ proxy,
108
+ downloadsPath,
109
+ ignoreHttpErrors: ignoreHttpErrorsParam,
110
+ timeout
111
+ } = options;
112
+ let {
113
+ executablePath
114
+ } = options;
115
+ const ignoreHttpErrors = await getIgnoreHttpErrorsFromConfig(ignoreHttpErrorsParam);
116
+ const defaultArgsToIgnore = ["--disable-extensions", "--disable-component-extensions-with-background-pages", "--disable-background-networking", "--disable-backgrounding-occluded-windows", "--disable-background-timer-throttling"];
117
+ const extraArgs = [];
118
+ const macKeychainBypassArgs = getMacKeychainBypassArgs();
119
+ extraArgs.push(...macKeychainBypassArgs);
120
+ const stealthConfig = await (0, _intunedJson.getStealthModeConfig)();
121
+ if (stealthConfig.enabled && stealthConfig.type === "intunedBrowser") {
122
+ extraArgs.push("--stealth-mode");
123
+ }
124
+ const userDataDir = await createUserDirWithPreferences();
125
+ if ((0, _extensionsHelpers.isIntunedExtensionLoaded)()) {
126
+ const extensionsList = (0, _extensionsHelpers.buildExtensionsList)();
127
+ const extensions = extensionsList.join(",");
128
+ extraArgs.push(`--disable-extensions-except=${extensions}`);
129
+ extraArgs.push(`--load-extension=${extensions}`);
130
+ }
131
+ if (await (0, _extensionsHelpers.isIntunedExtensionEnabled)()) {
132
+ await (0, _extensionsHelpers.setupIntunedExtension)();
133
+ if (proxy) {
134
+ extraArgs.push('--proxy-bypass-list="<-loopback>"');
135
+ }
136
+ }
137
+ if (cdpPort) {
138
+ extraArgs.push(`--remote-debugging-port=${cdpPort}`);
139
+ }
140
+ if (headless) {
141
+ defaultArgsToIgnore.push("--headless=old");
142
+ extraArgs.push("--headless=new");
143
+ }
144
+ if (appModeInitialUrl) {
145
+ extraArgs.push(`--app=${appModeInitialUrl}`);
146
+ }
147
+ if (stealthConfig.enabled && stealthConfig.type === "intunedBrowser") {
148
+ const stealthExecutablePath = await getIntunedBrowserExecutablePath();
149
+ executablePath = stealthExecutablePath;
150
+ } else if (executablePath) {
151
+ executablePath = await fs.realpath(executablePath);
152
+ if (!(await fs.exists(executablePath))) {
153
+ console.log(`Warning: Executable path ${executablePath} does not exist. Falling back to default.`);
154
+ executablePath = undefined;
155
+ }
156
+ }
157
+ const viewport = null;
158
+ const userAgent = process.env.__PLAYWRIGHT_USER_AGENT_OVERRIDE ?? (await getHeadlessUserAgent({
159
+ executablePath,
160
+ args: macKeychainBypassArgs
161
+ }));
162
+ const context = await playwright.chromium.launchPersistentContext(userDataDir, {
163
+ userAgent,
164
+ executablePath,
165
+ headless,
166
+ viewport,
167
+ proxy,
168
+ downloadsPath,
169
+ args: extraArgs,
170
+ ignoreDefaultArgs: defaultArgsToIgnore,
171
+ ignoreHTTPSErrors: ignoreHttpErrors
172
+ });
173
+ if (timeout !== undefined) {
174
+ context.setDefaultTimeout(timeout * 1000);
175
+ }
176
+ context.once("close", async () => {
177
+ try {
178
+ await (0, _fsExtra.rm)(userDataDir, {
179
+ recursive: true,
180
+ force: true,
181
+ retryDelay: 1000,
182
+ maxRetries: 5
183
+ });
184
+ if (await (0, _extensionsHelpers.isIntunedExtensionEnabled)()) {
185
+ await (0, _intunedExtensionServer.cleanIntunedExtensionServer)();
186
+ }
187
+ } catch (error) {
188
+ console.error("Failed to remove user data dir", error);
189
+ }
190
+ });
191
+ if (cdpPort) {
192
+ const createdCdpAddress = getLocalCdpAddress(cdpPort);
193
+ await waitOnCdpAddress(createdCdpAddress);
194
+ }
195
+ const page = context.pages().at(0) ?? (await context.newPage());
196
+ if (await (0, _extensionsHelpers.isIntunedExtensionEnabled)()) {
197
+ await (0, _extensionsHelpers.getIntunedExtensionWorker)(context);
198
+ }
199
+ return {
200
+ page,
201
+ context
202
+ };
203
+ }
204
+ async function getIntunedBrowserExecutablePath() {
205
+ const intunedPath = process.env.INTUNED_STEALTH_CHROMIUM_PATH;
206
+ if (intunedPath && (await fs.exists(intunedPath))) {
207
+ return intunedPath;
208
+ }
209
+ return undefined;
210
+ }
211
+ async function getBrowserExecutablePath() {
212
+ const browserType = getBrowserType();
213
+ if (browserType === "brave") {
214
+ return await getBraveExecutablePath();
215
+ }
216
+ }
217
+ async function launchBrowser(options) {
218
+ if ("cdpAddress" in options) {
219
+ return launchChromium(options);
220
+ }
221
+ return launchChromium({
222
+ ...options,
223
+ executablePath: await getBrowserExecutablePath()
224
+ });
225
+ }
226
+ function getBrowserType() {
227
+ if (process.env.BROWSER_TYPE === "brave") {
228
+ return "brave";
229
+ }
230
+ return "chromium";
231
+ }
232
+ async function getBraveExecutablePath() {
233
+ const {
234
+ stdout
235
+ } = await execAsync("which brave-browser-stable");
236
+ const bravePath = stdout.trim();
237
+ if (bravePath.length === 0) {
238
+ throw new Error("Brave browser not found");
239
+ }
240
+ return bravePath;
241
+ }
242
+ function getLocalCdpAddress(port) {
243
+ return `http://localhost:${port}`;
244
+ }
245
+ async function getCdpWebSocketUrl(cdpAddress) {
246
+ let response;
247
+ try {
248
+ response = await fetch(`${cdpAddress}/json/version`);
249
+ } catch (error) {
250
+ return (0, _neverthrow.err)(`Failed to fetch CDP version from ${cdpAddress}: ${error instanceof Error ? error.message : String(error)}`);
251
+ }
252
+ if (!response.ok) {
253
+ return (0, _neverthrow.err)(`Failed to get CDP WebSocket URL from ${cdpAddress}: ${response.status} ${response.statusText}`);
254
+ }
255
+ let data;
256
+ try {
257
+ data = await response.json();
258
+ } catch (error) {
259
+ return (0, _neverthrow.err)(`Invalid CDP version response from ${cdpAddress}: ${error instanceof Error ? error.message : String(error)}`);
260
+ }
261
+ const cdpJsonVersionResponseSchema = _zod.z.object({
262
+ webSocketDebuggerUrl: _zod.z.string().url()
263
+ });
264
+ const parseResult = cdpJsonVersionResponseSchema.safeParse(data);
265
+ if (!parseResult.success) {
266
+ return (0, _neverthrow.err)(`Invalid CDP version response from ${cdpAddress}: ${JSON.stringify(parseResult.error.format())}`);
267
+ }
268
+ return (0, _neverthrow.ok)(parseResult.data.webSocketDebuggerUrl);
269
+ }
270
+ async function waitOnCdpAddress(cdpAddress) {
271
+ const cdpAddressWithoutProtocol = cdpAddress.replace("http://", "").replace("https://", "").replace("localhost", "127.0.0.1");
272
+ await (0, _waitOn.default)({
273
+ resources: [`http-get://${cdpAddressWithoutProtocol}/json/version`],
274
+ delay: 100,
275
+ interval: 100,
276
+ timeout: 5000,
277
+ tcpTimeout: 1000,
278
+ window: 1000
279
+ });
280
+ }
281
+ async function getHeadlessUserAgent({
282
+ executablePath,
283
+ args,
284
+ ignoreDefaultArgs
285
+ }) {
286
+ const browser = await playwright.chromium.launch({
287
+ headless: true,
288
+ executablePath,
289
+ args,
290
+ ignoreDefaultArgs
291
+ });
292
+ const context = await browser.newContext();
293
+ const page = await context.newPage();
294
+ let userAgent = await page.evaluate(() => navigator.userAgent);
295
+ await browser.close();
296
+ if (!userAgent || typeof userAgent !== "string") {
297
+ return undefined;
298
+ }
299
+ userAgent = userAgent.replace("HeadlessChrome", "Chrome");
300
+ return userAgent;
301
+ }
@@ -0,0 +1,31 @@
1
+ import type * as playwright from "playwright";
2
+ import { Err, Ok } from "neverthrow";
3
+ import { type Proxy } from "./launchBrowser";
4
+ import { ImportFunction, RunAutomationError, RunApiSession } from "@intuned/runtime-interface";
5
+ type WithPlaywrightContextParameters = {
6
+ importFunction: ImportFunction;
7
+ apiName: string;
8
+ apiParameters: any;
9
+ } | {
10
+ importFunction?: undefined;
11
+ apiName?: undefined;
12
+ apiParameters?: undefined;
13
+ };
14
+ type WithPlaywrightContextWrappedFunctionReturn<R> = Ok<R, any> | Err<any, RunAutomationError>;
15
+ export type WithPlaywrightContextWrappedFunction<R> = (context: playwright.BrowserContext, page: playwright.Page) => Promise<WithPlaywrightContextWrappedFunctionReturn<R>>;
16
+ export declare function withPlaywrightContext<R>(options: {
17
+ proxy?: Proxy;
18
+ headless: boolean;
19
+ downloadsPath: string;
20
+ ignoreHttpErrors?: boolean;
21
+ } & WithPlaywrightContextParameters, fn: WithPlaywrightContextWrappedFunction<R>): Promise<Ok<R, any> | Err<any, RunAutomationError>>;
22
+ export declare function withPlaywrightContext<R>(options: {
23
+ cdpAddress: string;
24
+ cdpTargetId?: string;
25
+ ignoreHttpErrors?: boolean;
26
+ } & WithPlaywrightContextParameters, fn: WithPlaywrightContextWrappedFunction<R>): Promise<Ok<R, any> | Err<any, RunAutomationError>>;
27
+ export declare function loadSessionToContext({ context, session, }: {
28
+ context: playwright.BrowserContext;
29
+ session: RunApiSession;
30
+ }): Promise<void>;
31
+ export {};
@@ -0,0 +1,154 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.loadSessionToContext = loadSessionToContext;
7
+ exports.withPlaywrightContext = withPlaywrightContext;
8
+ var _contextStorageStateHelpers = require("./contextStorageStateHelpers");
9
+ var fs = _interopRequireWildcard(require("fs-extra"));
10
+ var _fileUtils = require("../commands/common/utils/fileUtils");
11
+ var _neverthrow = require("neverthrow");
12
+ var _setupContextHook = require("./setupContextHook");
13
+ var _portfinder = require("portfinder");
14
+ var _launchBrowser = require("./launchBrowser");
15
+ var _runtimeInterface = require("../vendor/runtime-interface");
16
+ function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
17
+ async function withPlaywrightContext({
18
+ cdpAddress,
19
+ cdpTargetId,
20
+ proxy,
21
+ headless = true,
22
+ downloadsPath,
23
+ ignoreHttpErrors: cliIgnoreHttpErrors,
24
+ importFunction,
25
+ apiName,
26
+ apiParameters
27
+ }, fn) {
28
+ let context;
29
+ let page;
30
+ try {
31
+ const ignoreHttpErrors = await (0, _launchBrowser.getIgnoreHttpErrorsFromConfig)(cliIgnoreHttpErrors);
32
+ const setupContextHookResult = importFunction ? await (0, _setupContextHook.loadSetupContextHook)({
33
+ importFunction
34
+ }) : (0, _neverthrow.ok)(null);
35
+ if (setupContextHookResult.isErr()) {
36
+ return setupContextHookResult;
37
+ }
38
+ const setupContextHook = setupContextHookResult.value;
39
+ if (setupContextHook === null) {
40
+ if (cdpAddress !== undefined) {
41
+ ({
42
+ page,
43
+ context
44
+ } = await (0, _launchBrowser.launchBrowser)({
45
+ cdpAddress,
46
+ cdpTargetId,
47
+ ignoreHttpErrors
48
+ }));
49
+ } else {
50
+ ({
51
+ page,
52
+ context
53
+ } = await (0, _launchBrowser.launchBrowser)({
54
+ proxy,
55
+ headless,
56
+ downloadsPath,
57
+ ignoreHttpErrors
58
+ }));
59
+ }
60
+ return await fn(context, page);
61
+ }
62
+ let hookCdpUrl = null;
63
+ if (cdpAddress) {
64
+ hookCdpUrl = cdpAddress;
65
+ ({
66
+ context,
67
+ page
68
+ } = await (0, _launchBrowser.launchBrowser)({
69
+ cdpAddress,
70
+ cdpTargetId,
71
+ ignoreHttpErrors
72
+ }));
73
+ } else {
74
+ const port = await (0, _portfinder.getPort)({
75
+ port: 9222
76
+ });
77
+ ({
78
+ context,
79
+ page
80
+ } = await (0, _launchBrowser.launchBrowser)({
81
+ proxy,
82
+ headless,
83
+ downloadsPath,
84
+ cdpPort: port,
85
+ ignoreHttpErrors
86
+ }));
87
+ hookCdpUrl = (0, _launchBrowser.getLocalCdpAddress)(port);
88
+ }
89
+ let hookResult;
90
+ try {
91
+ const wsUrlResult = await (0, _launchBrowser.getCdpWebSocketUrl)(hookCdpUrl);
92
+ if (wsUrlResult.isOk()) {
93
+ hookCdpUrl = wsUrlResult.value;
94
+ } else {
95
+ throw new Error(wsUrlResult.error);
96
+ }
97
+ hookResult = await setupContextHook({
98
+ apiName: apiName,
99
+ apiParameters: apiParameters,
100
+ cdpUrl: hookCdpUrl
101
+ });
102
+ } catch (error) {
103
+ return (0, _neverthrow.err)(new _runtimeInterface.AutomationError(error));
104
+ }
105
+ if (!hookResult) {
106
+ return await fn(context, page);
107
+ }
108
+ const {
109
+ page: newPage,
110
+ context: newContext,
111
+ cleanup
112
+ } = hookResult;
113
+ let result;
114
+ try {
115
+ result = {
116
+ return: await fn(newContext, newPage ?? page)
117
+ };
118
+ } catch (e) {
119
+ result = {
120
+ throw: e
121
+ };
122
+ }
123
+ try {
124
+ await cleanup?.();
125
+ } catch (e) {
126
+ result = {
127
+ return: (0, _neverthrow.err)(new _runtimeInterface.AutomationError(e))
128
+ };
129
+ }
130
+ if ("throw" in result) {
131
+ throw result.throw;
132
+ }
133
+ return result.return;
134
+ } finally {
135
+ await context?.close();
136
+ }
137
+ }
138
+ async function loadSessionToContext({
139
+ context,
140
+ session
141
+ }) {
142
+ let sessionToLoad;
143
+ if (session.type === "state") {
144
+ const state = session.state;
145
+ if (state === undefined || state === null) {
146
+ return;
147
+ }
148
+ sessionToLoad = state;
149
+ } else {
150
+ const fullPath = (0, _fileUtils.getFullPathInProject)(session.path);
151
+ sessionToLoad = await fs.readJson(fullPath);
152
+ }
153
+ await (0, _contextStorageStateHelpers.setStorageState)(context, sessionToLoad);
154
+ }
@@ -0,0 +1,7 @@
1
+ import { Result } from "neverthrow";
2
+ import { ImportFunction, RunAutomationError } from "@intuned/runtime-interface";
3
+ export declare function importUsingImportFunction<_ReturnType = any>({ path, allowGenerators, importFunction, }: {
4
+ path: string;
5
+ importFunction: ImportFunction;
6
+ allowGenerators?: boolean;
7
+ }): Promise<Result<(..._: any) => Promise<_ReturnType>, RunAutomationError>>;
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.importUsingImportFunction = importUsingImportFunction;
7
+ var _neverthrow = require("neverthrow");
8
+ var _runtimeInterface = require("../../vendor/runtime-interface");
9
+ async function importUsingImportFunction({
10
+ path,
11
+ allowGenerators = true,
12
+ importFunction
13
+ }) {
14
+ try {
15
+ const importedResult = await importFunction(path);
16
+ if (importedResult.isErr()) {
17
+ if (importedResult.error.type === "not_found") {
18
+ return (0, _neverthrow.err)(new _runtimeInterface.ApiNotFoundError(path));
19
+ }
20
+ return (0, _neverthrow.err)(new _runtimeInterface.AutomationError(importedResult.error.error));
21
+ }
22
+ const imported = importedResult.value;
23
+ if (!imported || !imported.default || !imported.default.constructor) {
24
+ return (0, _neverthrow.err)(new _runtimeInterface.InvalidApiError(`${path} does not have a default export`));
25
+ }
26
+ if (imported.default.constructor.name === "AsyncGeneratorFunction") {
27
+ if (!allowGenerators) {
28
+ return (0, _neverthrow.err)(new _runtimeInterface.InvalidApiError(`${path} default export must be an async function`));
29
+ }
30
+ return (0, _neverthrow.ok)(async (...args) => {
31
+ const generator = imported.default(...args);
32
+ const result = await generator.next();
33
+ if (!result.done) {
34
+ throw new Error("Yield is not supported");
35
+ }
36
+ return result.value;
37
+ });
38
+ }
39
+ if (imported.default.constructor.name === "AsyncFunction") {
40
+ return (0, _neverthrow.ok)(imported.default);
41
+ }
42
+ return (0, _neverthrow.err)(new _runtimeInterface.InvalidApiError(`${path} default export must be an async function`));
43
+ } catch (error) {
44
+ return (0, _neverthrow.err)(new _runtimeInterface.AutomationError(error));
45
+ }
46
+ }
@@ -1,11 +1,8 @@
1
- import { Result } from 'neverthrow';
2
- import { Page, BrowserContext } from 'playwright';
3
- import { ExtendedRunApiParameters, RunApiResult, RunApiResultWithSessionOk, RunAutomationError } from '@intuned/runtime-interface';
4
-
5
- declare function runApi<ResultType = any>(input: ExtendedRunApiParameters & {
1
+ import { Result } from "neverthrow";
2
+ import type { Page, BrowserContext } from "playwright";
3
+ import { ExtendedRunApiParameters, RunApiResult, RunApiResultWithSessionOk, RunAutomationError } from "@intuned/runtime-interface";
4
+ export declare function runApi<ResultType = any>(input: ExtendedRunApiParameters & {
6
5
  retrieveSession: true;
7
6
  }): Promise<RunApiResult<ResultType, RunApiResultWithSessionOk<ResultType>>>;
8
- declare function runApi<ResultType = any>(input: ExtendedRunApiParameters): Promise<RunApiResult<ResultType>>;
9
- declare function checkAuthSessionWithRetries(page: Page, context: BrowserContext, checkFn: (..._: any) => Promise<boolean>, retries?: number): Promise<Result<boolean, RunAutomationError>>;
10
-
11
- export { checkAuthSessionWithRetries, runApi };
7
+ export declare function runApi<ResultType = any>(input: ExtendedRunApiParameters): Promise<RunApiResult<ResultType>>;
8
+ export declare function checkAuthSessionWithRetries(page: Page, context: BrowserContext, checkFn: (..._: any) => Promise<boolean>, retries?: number): Promise<Result<boolean, RunAutomationError>>;