@intuned/runtime-dev 1.3.18-interface.2 → 1.3.18-interface.21

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 (225) hide show
  1. package/.babelrc +6 -0
  2. package/.claude/settings.local.json +7 -0
  3. package/InterfaceTemplate/__utils.ts +3 -1
  4. package/dist/commands/api/run.d.ts +6 -0
  5. package/dist/commands/api/run.js +119 -0
  6. package/dist/commands/auth-sessions/load.d.ts +2 -0
  7. package/dist/commands/auth-sessions/load.js +35 -0
  8. package/dist/commands/auth-sessions/run-check.d.ts +2 -0
  9. package/dist/commands/auth-sessions/run-check.js +74 -0
  10. package/dist/commands/auth-sessions/run-create.d.ts +2 -0
  11. package/dist/commands/auth-sessions/run-create.js +78 -0
  12. package/dist/commands/browser/save-state.d.ts +2 -0
  13. package/dist/commands/browser/save-state.js +17 -0
  14. package/dist/commands/browser/start-browser.d.ts +2 -0
  15. package/dist/commands/browser/start-browser.js +14 -0
  16. package/dist/commands/build.d.ts +1 -0
  17. package/dist/commands/build.js +83 -0
  18. package/dist/commands/common/browserUtils.d.ts +14 -0
  19. package/dist/commands/common/browserUtils.js +57 -0
  20. package/dist/commands/common/getFirstLineNumber.d.ts +9 -0
  21. package/dist/commands/common/getFirstLineNumber.js +101 -0
  22. package/dist/commands/common/getFirstLineNumber.test.js +227 -0
  23. package/dist/commands/common/projectExclusions.d.ts +2 -0
  24. package/dist/commands/common/projectExclusions.js +8 -0
  25. package/dist/commands/common/sendMessageToClient.d.ts +1 -0
  26. package/dist/commands/common/sendMessageToClient.js +10 -0
  27. package/dist/commands/common/tsNodeImport.d.ts +2 -0
  28. package/dist/commands/common/tsNodeImport.js +42 -0
  29. package/dist/commands/common/utils/fileUtils.d.ts +6 -0
  30. package/dist/commands/common/utils/fileUtils.js +32 -0
  31. package/dist/commands/common/utils/interfaceClient.d.ts +31 -0
  32. package/dist/commands/common/utils/interfaceClient.js +98 -0
  33. package/dist/commands/common/utils/settings.d.ts +2 -0
  34. package/dist/commands/common/utils/settings.js +31 -0
  35. package/dist/commands/common/utils/template.d.ts +2 -0
  36. package/dist/commands/common/utils/template.js +30 -0
  37. package/dist/commands/get-headless-user-agent.d.ts +1 -0
  38. package/dist/commands/get-headless-user-agent.js +18 -0
  39. package/dist/commands/interface/run.d.ts +1 -0
  40. package/dist/commands/interface/run.js +189 -0
  41. package/dist/commands/intuned-cli/commands/attempt.command.d.ts +1 -0
  42. package/dist/commands/intuned-cli/commands/attempt.command.js +8 -0
  43. package/dist/commands/intuned-cli/commands/attempt_api.command.d.ts +1 -0
  44. package/dist/commands/intuned-cli/commands/attempt_api.command.js +30 -0
  45. package/dist/commands/intuned-cli/commands/attempt_authsession.command.d.ts +1 -0
  46. package/dist/commands/intuned-cli/commands/attempt_authsession.command.js +8 -0
  47. package/dist/commands/intuned-cli/commands/attempt_authsession_check.command.d.ts +1 -0
  48. package/dist/commands/intuned-cli/commands/attempt_authsession_check.command.js +19 -0
  49. package/dist/commands/intuned-cli/commands/attempt_authsession_create.command.d.ts +1 -0
  50. package/dist/commands/intuned-cli/commands/attempt_authsession_create.command.js +24 -0
  51. package/dist/commands/intuned-cli/commands/authsession.command.d.ts +1 -0
  52. package/dist/commands/intuned-cli/commands/authsession.command.js +8 -0
  53. package/dist/commands/intuned-cli/commands/authsession_record.command.d.ts +1 -0
  54. package/dist/commands/intuned-cli/commands/authsession_record.command.js +32 -0
  55. package/dist/commands/intuned-cli/commands/authsession_scaffold.command.d.ts +1 -0
  56. package/dist/commands/intuned-cli/commands/authsession_scaffold.command.js +16 -0
  57. package/dist/commands/intuned-cli/commands/build.command.d.ts +1 -0
  58. package/dist/commands/intuned-cli/commands/build.command.js +12 -0
  59. package/dist/commands/intuned-cli/commands/command.d.ts +2 -0
  60. package/dist/commands/intuned-cli/commands/command.js +9 -0
  61. package/dist/commands/intuned-cli/commands/deploy.command.d.ts +1 -0
  62. package/dist/commands/intuned-cli/commands/deploy.command.js +42 -0
  63. package/dist/commands/intuned-cli/commands/index.d.ts +18 -0
  64. package/dist/commands/intuned-cli/commands/index.js +203 -0
  65. package/dist/commands/intuned-cli/commands/provision.command.d.ts +13 -0
  66. package/dist/commands/intuned-cli/commands/provision.command.js +50 -0
  67. package/dist/commands/intuned-cli/commands/run.command.d.ts +1 -0
  68. package/dist/commands/intuned-cli/commands/run.command.js +8 -0
  69. package/dist/commands/intuned-cli/commands/run_api.command.d.ts +1 -0
  70. package/dist/commands/intuned-cli/commands/run_api.command.js +46 -0
  71. package/dist/commands/intuned-cli/commands/run_authsession.command.d.ts +35 -0
  72. package/dist/commands/intuned-cli/commands/run_authsession.command.js +17 -0
  73. package/dist/commands/intuned-cli/commands/run_authsession_create.command.d.ts +1 -0
  74. package/dist/commands/intuned-cli/commands/run_authsession_create.command.js +35 -0
  75. package/dist/commands/intuned-cli/commands/run_authsession_update.command.d.ts +1 -0
  76. package/dist/commands/intuned-cli/commands/run_authsession_update.command.js +35 -0
  77. package/dist/commands/intuned-cli/commands/run_authsession_validate.command.d.ts +1 -0
  78. package/dist/commands/intuned-cli/commands/run_authsession_validate.command.js +33 -0
  79. package/dist/commands/intuned-cli/commands/types.d.ts +39 -0
  80. package/dist/commands/intuned-cli/commands/types.js +33 -0
  81. package/dist/commands/intuned-cli/constants/index.d.ts +17 -0
  82. package/dist/commands/intuned-cli/constants/index.js +25 -0
  83. package/dist/commands/intuned-cli/controller/__test__/api.test.js +399 -0
  84. package/dist/commands/intuned-cli/controller/__test__/authSession.test.js +1061 -0
  85. package/dist/commands/intuned-cli/controller/api.d.ts +42 -0
  86. package/dist/commands/intuned-cli/controller/api.js +194 -0
  87. package/dist/commands/intuned-cli/controller/authSession.d.ts +209 -0
  88. package/dist/commands/intuned-cli/controller/authSession.js +425 -0
  89. package/dist/commands/intuned-cli/controller/build.d.ts +1 -0
  90. package/dist/commands/intuned-cli/controller/build.js +35 -0
  91. package/dist/commands/intuned-cli/controller/deploy.d.ts +5 -0
  92. package/dist/commands/intuned-cli/controller/deploy.js +317 -0
  93. package/dist/commands/intuned-cli/controller/index.d.ts +1 -0
  94. package/dist/commands/intuned-cli/controller/index.js +45 -0
  95. package/dist/commands/intuned-cli/controller/provision.d.ts +21 -0
  96. package/dist/commands/intuned-cli/controller/provision.js +299 -0
  97. package/dist/commands/intuned-cli/controller/scaffold.d.ts +1 -0
  98. package/dist/commands/intuned-cli/controller/scaffold.js +77 -0
  99. package/dist/commands/intuned-cli/helpers/__test__/browser.test.js +152 -0
  100. package/dist/commands/intuned-cli/helpers/__test__/tracing.test.js +41 -0
  101. package/dist/commands/intuned-cli/helpers/api.d.ts +3 -0
  102. package/dist/commands/intuned-cli/helpers/api.js +16 -0
  103. package/dist/commands/intuned-cli/helpers/auth.d.ts +46 -0
  104. package/dist/commands/intuned-cli/helpers/auth.js +147 -0
  105. package/dist/commands/intuned-cli/helpers/backend.d.ts +8 -0
  106. package/dist/commands/intuned-cli/helpers/backend.js +35 -0
  107. package/dist/commands/intuned-cli/helpers/browser.d.ts +14 -0
  108. package/dist/commands/intuned-cli/helpers/browser.js +93 -0
  109. package/dist/commands/intuned-cli/helpers/context.d.ts +3 -0
  110. package/dist/commands/intuned-cli/helpers/context.js +33 -0
  111. package/dist/commands/intuned-cli/helpers/errors.d.ts +16 -0
  112. package/dist/commands/intuned-cli/helpers/errors.js +44 -0
  113. package/dist/commands/intuned-cli/helpers/index.d.ts +12 -0
  114. package/dist/commands/intuned-cli/helpers/index.js +137 -0
  115. package/dist/commands/intuned-cli/helpers/intunedJson.d.ts +39 -0
  116. package/dist/commands/intuned-cli/helpers/intunedJson.js +20 -0
  117. package/dist/commands/intuned-cli/helpers/prompts.d.ts +3 -0
  118. package/dist/commands/intuned-cli/helpers/prompts.js +71 -0
  119. package/dist/commands/intuned-cli/helpers/proxy.d.ts +5 -0
  120. package/dist/commands/intuned-cli/helpers/proxy.js +23 -0
  121. package/dist/commands/intuned-cli/helpers/terminal.d.ts +5 -0
  122. package/dist/commands/intuned-cli/helpers/terminal.js +13 -0
  123. package/dist/commands/intuned-cli/helpers/timeout.d.ts +1 -0
  124. package/dist/commands/intuned-cli/helpers/timeout.js +23 -0
  125. package/dist/commands/intuned-cli/helpers/traces.d.ts +2 -0
  126. package/dist/commands/intuned-cli/helpers/traces.js +32 -0
  127. package/dist/commands/intuned-cli/helpers/validation.d.ts +2 -0
  128. package/dist/commands/intuned-cli/helpers/validation.js +14 -0
  129. package/dist/commands/intuned-cli/helpers/wrapper.d.ts +2 -0
  130. package/dist/commands/intuned-cli/helpers/wrapper.js +76 -0
  131. package/dist/commands/intuned-cli/index.d.ts +1 -0
  132. package/dist/commands/intuned-cli/index.js +16 -0
  133. package/dist/commands/intuned-cli/main.d.ts +1 -0
  134. package/dist/commands/intuned-cli/main.js +35 -0
  135. package/dist/commands/intuned-cli/types.d.ts +70 -0
  136. package/dist/commands/intuned-cli/types.js +22 -0
  137. package/dist/commands/ts-check.d.ts +2 -0
  138. package/dist/commands/ts-check.js +55 -0
  139. package/dist/common/Logger/Logger/index.d.ts +12 -0
  140. package/dist/common/Logger/Logger/index.js +60 -0
  141. package/dist/common/Logger/Logger/types.d.ts +8 -0
  142. package/dist/common/Logger/Logger/types.js +5 -0
  143. package/dist/common/Logger/index.d.ts +12 -0
  144. package/dist/common/Logger/index.js +60 -0
  145. package/dist/common/Logger/types.d.ts +8 -0
  146. package/dist/common/Logger/types.js +5 -0
  147. package/dist/common/assets/browser_scripts.js +2580 -0
  148. package/dist/common/asyncLocalStorage/index.d.ts +16 -0
  149. package/dist/common/asyncLocalStorage/index.js +17 -0
  150. package/dist/common/backendFunctions/getAuthSessionParameters.d.ts +1 -0
  151. package/dist/common/backendFunctions/getAuthSessionParameters.js +38 -0
  152. package/dist/common/binStartupScript.d.ts +1 -0
  153. package/dist/common/binStartupScript.js +36 -0
  154. package/dist/common/browserTabs.d.ts +72 -0
  155. package/dist/common/browserTabs.js +74 -0
  156. package/dist/common/cleanEnvironmentVariables.d.ts +1 -0
  157. package/dist/common/cleanEnvironmentVariables.js +16 -0
  158. package/dist/common/constants.d.ts +11 -0
  159. package/dist/common/constants.js +17 -0
  160. package/dist/common/contextStorageStateHelpers.d.ts +22 -0
  161. package/dist/common/contextStorageStateHelpers.js +84 -0
  162. package/dist/common/extension/extensionsHelpers.d.ts +11 -0
  163. package/dist/common/extension/extensionsHelpers.js +147 -0
  164. package/dist/common/extension/intunedExtensionServer.d.ts +24 -0
  165. package/dist/common/extension/intunedExtensionServer.js +178 -0
  166. package/dist/common/extension/types.d.ts +219 -0
  167. package/dist/common/extension/types.js +51 -0
  168. package/dist/common/formatZodError.d.ts +2 -0
  169. package/dist/common/formatZodError.js +18 -0
  170. package/dist/common/intunedJson.d.ts +229 -0
  171. package/dist/common/intunedJson.js +132 -0
  172. package/dist/common/jwtTokenManager.d.ts +17 -0
  173. package/dist/common/jwtTokenManager.js +113 -0
  174. package/dist/common/launchBrowser.d.ts +34 -0
  175. package/dist/common/launchBrowser.js +247 -0
  176. package/dist/common/playwrightContext.d.ts +29 -0
  177. package/dist/common/playwrightContext.js +148 -0
  178. package/dist/common/runApi/importUsingImportFunction.d.ts +7 -0
  179. package/dist/common/runApi/importUsingImportFunction.js +46 -0
  180. package/dist/common/runApi/index.d.ts +8 -0
  181. package/dist/common/runApi/index.js +177 -0
  182. package/dist/common/settingsSchema.d.ts +537 -0
  183. package/dist/common/settingsSchema.js +57 -0
  184. package/dist/common/setupContextHook.d.ts +16 -0
  185. package/dist/common/setupContextHook.js +22 -0
  186. package/dist/common/telemetry.d.ts +3 -0
  187. package/dist/common/telemetry.js +31 -0
  188. package/dist/index.d.ts +4 -0
  189. package/dist/index.js +117 -0
  190. package/dist/runtime/RunError.d.ts +5 -0
  191. package/dist/runtime/RunError.js +19 -0
  192. package/dist/runtime/attemptStore.d.ts +2 -0
  193. package/dist/runtime/attemptStore.js +23 -0
  194. package/dist/runtime/captcha.d.ts +15 -0
  195. package/dist/runtime/captcha.js +191 -0
  196. package/dist/runtime/captcha.test.js +821 -0
  197. package/dist/runtime/downloadDirectory.d.ts +1 -0
  198. package/dist/runtime/downloadDirectory.js +19 -0
  199. package/dist/runtime/enums.d.js +5 -0
  200. package/dist/runtime/enums.d.ts +11 -0
  201. package/dist/runtime/enums.js +18 -0
  202. package/dist/runtime/executionHelpers.test.js +52 -0
  203. package/dist/runtime/export.d.js +5 -0
  204. package/dist/runtime/export.d.ts +284 -0
  205. package/dist/runtime/extendPayload.d.ts +2 -0
  206. package/dist/runtime/extendPayload.js +21 -0
  207. package/dist/runtime/extendTimeout.d.ts +1 -0
  208. package/dist/runtime/extendTimeout.js +23 -0
  209. package/dist/runtime/getAiGatewayConfig.d.ts +10 -0
  210. package/dist/runtime/getAiGatewayConfig.js +16 -0
  211. package/dist/runtime/getAuthSessionParameters.d.ts +1 -0
  212. package/dist/runtime/getAuthSessionParameters.js +20 -0
  213. package/dist/runtime/index.d.ts +10 -0
  214. package/dist/runtime/index.js +111 -0
  215. package/dist/runtime/persistentStore.d.ts +2 -0
  216. package/dist/runtime/persistentStore.js +37 -0
  217. package/dist/runtime/persistentStore.test.js +101 -0
  218. package/dist/runtime/runInfo.d.ts +2 -0
  219. package/dist/runtime/runInfo.js +21 -0
  220. package/dist/vendor/runtime-interface.d.ts +1 -0
  221. package/dist/vendor/runtime-interface.js +479 -0
  222. package/package.json +8 -3
  223. package/tsup.config.ts +12 -0
  224. package/WebTemplate.zip +0 -0
  225. package/api/sample.ts +0 -4
@@ -0,0 +1,16 @@
1
+ /// <reference types="node" />
2
+ import { AsyncLocalStorage } from "node:async_hooks";
3
+ import { Payload, RunInfo } from "../../runtime/export";
4
+ export declare const asyncLocalStorage: AsyncLocalStorage<InternalRunInfo>;
5
+ export 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
+ export interface InternalRunInfo extends RunInfo {
10
+ extendedPayloads: Payload[];
11
+ timeoutInfo?: TimeoutInfo;
12
+ store?: Record<string, any>;
13
+ getAuthSessionParameters?: () => Promise<any>;
14
+ }
15
+ export declare function getExecutionContext(): InternalRunInfo | undefined;
16
+ export {};
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.asyncLocalStorage = void 0;
7
+ exports.getExecutionContext = getExecutionContext;
8
+ exports.runWithContext = runWithContext;
9
+ var _nodeAsync_hooks = require("node:async_hooks");
10
+ const asyncLocalStorage = exports.asyncLocalStorage = new _nodeAsync_hooks.AsyncLocalStorage();
11
+ function runWithContext(contextData, callback, ...args) {
12
+ return asyncLocalStorage.run(contextData, callback, ...args);
13
+ }
14
+ function getExecutionContext() {
15
+ const contextData = asyncLocalStorage.getStore();
16
+ return contextData;
17
+ }
@@ -0,0 +1 @@
1
+ export declare function getAuthSessionParameters(): Promise<any>;
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.getAuthSessionParameters = getAuthSessionParameters;
7
+ var _isNil = _interopRequireDefault(require("lodash/isNil"));
8
+ var _asyncLocalStorage = require("../asyncLocalStorage");
9
+ var _zod = require("zod");
10
+ var _jwtTokenManager = require("../jwtTokenManager");
11
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
12
+ const authSessionParametersResponseSchema = _zod.z.object({
13
+ parameters: _zod.z.any().refine(v => v !== undefined)
14
+ });
15
+ async function getAuthSessionParameters() {
16
+ const context = (0, _asyncLocalStorage.getExecutionContext)();
17
+ if (!context) {
18
+ throw new Error("getAuthSessionParameters failed due to an internal error (context was not found).");
19
+ }
20
+ const authSessionId = context.authSessionId;
21
+ if ((0, _isNil.default)(authSessionId)) {
22
+ throw new Error("AuthSessions are not enabled");
23
+ }
24
+ const response = await (0, _jwtTokenManager.callBackendFunctionWithToken)(`auth-session/${authSessionId}/parameters`, {
25
+ method: "GET"
26
+ });
27
+ const body = await response.text();
28
+ if (!response.ok) {
29
+ throw new Error(`getAuthSessionParameters failed with status ${response.status}: ${body}`);
30
+ }
31
+ let json;
32
+ try {
33
+ json = JSON.parse(body);
34
+ } catch (e) {
35
+ throw new Error(`Expected JSON response, but got ${body}`);
36
+ }
37
+ return authSessionParametersResponseSchema.parse(json).parameters;
38
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+
3
+ var _dotenv = _interopRequireDefault(require("dotenv"));
4
+ var path = _interopRequireWildcard(require("path"));
5
+ var _intunedJson = require("./intunedJson");
6
+ 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); }
7
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
8
+ _dotenv.default.config({
9
+ path: `.env`
10
+ });
11
+ function isStealthModeEnabled() {
12
+ try {
13
+ const settingsResult = (0, _intunedJson.loadIntunedJsonSync)();
14
+ if (settingsResult.isErr()) {
15
+ console.error(`Warning: Failed to load Intuned settings: ${settingsResult.error}
16
+ Stealth mode will not be enabled.`);
17
+ return false;
18
+ }
19
+ return settingsResult.value.stealthMode?.enabled === true;
20
+ } catch (error) {
21
+ console.error("Error reading Intuned.json:", error.message);
22
+ return false;
23
+ }
24
+ }
25
+ try {
26
+ if (isStealthModeEnabled()) {
27
+ const currentNodeModules = path.resolve(process.cwd(), "node_modules");
28
+ process.env.NODE_PATH = process.env.NODE_PATH ? `${process.env.NODE_PATH}:${currentNodeModules}` : currentNodeModules;
29
+ require("module").Module._initPaths();
30
+ if (process.env.PLAYWRIGHT_PATCH_SCRIPT_PATH) {
31
+ require(process.env.PLAYWRIGHT_PATCH_SCRIPT_PATH);
32
+ }
33
+ }
34
+ } catch (e) {
35
+ console.error("Failed to apply stealth mode");
36
+ }
@@ -0,0 +1,72 @@
1
+ /**
2
+ * Tab management utilities using CDP HTTP API.
3
+ *
4
+ * Provides functions to interact with browser tabs via Chrome DevTools Protocol HTTP endpoints.
5
+ * Refer to https://chromedevtools.github.io/devtools-protocol/ for the endpoints documentation.
6
+ * This approach is simpler than using the playwright API because it doesn't require us to create a playwright context.
7
+ */
8
+ export interface CDPTabInfo {
9
+ id: string;
10
+ type: string;
11
+ title: string;
12
+ url: string;
13
+ webSocketDebuggerUrl?: string;
14
+ devtoolsFrontendUrl?: string;
15
+ faviconUrl?: string;
16
+ description?: string;
17
+ }
18
+ /**
19
+ * Fetch current tabs from CDP /json endpoint.
20
+ *
21
+ * @param cdpAddress - CDP address (e.g., "http://localhost:9222")
22
+ * @returns List of tab info dictionaries from CDP (filtered to only "page" type)
23
+ *
24
+ * @example
25
+ * const tabs = await getCDPTabs("http://localhost:9222");
26
+ * // Returns:
27
+ * // [
28
+ * // {
29
+ * // "id": "1234",
30
+ * // "type": "page",
31
+ * // "title": "Google",
32
+ * // "url": "https://google.com",
33
+ * // ...
34
+ * // }
35
+ * // ]
36
+ */
37
+ export declare function getCDPTabs(cdpAddress: string): Promise<CDPTabInfo[]>;
38
+ /**
39
+ * Create new tab via CDP /json/new endpoint with optional URL.
40
+ *
41
+ * @param cdpAddress - CDP address (e.g., "http://localhost:9222")
42
+ * @param url - Initial URL for the tab (default: "about:blank")
43
+ * @returns Tab info dictionary from CDP
44
+ *
45
+ * @example
46
+ * const tab = await createCDPTab("http://localhost:9222", "https://google.com");
47
+ * // Returns:
48
+ * // {
49
+ * // "id": "1234",
50
+ * // "type": "page",
51
+ * // "title": "New Tab",
52
+ * // "url": "about:blank",
53
+ * // ...
54
+ * // }
55
+ */
56
+ export declare function createCDPTab(cdpAddress: string, url?: string): Promise<CDPTabInfo>;
57
+ /**
58
+ * Close tab via CDP /json/close/{id} endpoint.
59
+ *
60
+ * @param cdpAddress - CDP address (e.g., "http://localhost:9222")
61
+ * @param cdpTargetId - Full CDP target ID to close
62
+ * @returns True if successful, False otherwise
63
+ */
64
+ export declare function closeCDPTab(cdpAddress: string, cdpTargetId: string): Promise<boolean>;
65
+ /**
66
+ * Activate/bring to front a tab via CDP /json/activate/{id} endpoint.
67
+ *
68
+ * @param cdpAddress - CDP address (e.g., "http://localhost:9222")
69
+ * @param cdpTargetId - Full CDP target ID to activate
70
+ * @returns True if successful, False otherwise
71
+ */
72
+ export declare function activateCDPTab(cdpAddress: string, cdpTargetId: string): Promise<boolean>;
@@ -0,0 +1,74 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.activateCDPTab = activateCDPTab;
7
+ exports.closeCDPTab = closeCDPTab;
8
+ exports.createCDPTab = createCDPTab;
9
+ exports.getCDPTabs = getCDPTabs;
10
+ const DEFAULT_TIMEOUT = 5000;
11
+ async function getCDPTabs(cdpAddress) {
12
+ const controller = new AbortController();
13
+ const timeoutId = setTimeout(() => controller.abort(), DEFAULT_TIMEOUT);
14
+ try {
15
+ const response = await fetch(`${cdpAddress}/json`, {
16
+ signal: controller.signal
17
+ });
18
+ if (!response.ok) {
19
+ throw new Error(`HTTP error! status: ${response.status}`);
20
+ }
21
+ const tabs = await response.json();
22
+ return tabs.filter(tab => tab.type === "page");
23
+ } finally {
24
+ clearTimeout(timeoutId);
25
+ }
26
+ }
27
+ async function createCDPTab(cdpAddress, url = "about:blank") {
28
+ const controller = new AbortController();
29
+ const timeoutId = setTimeout(() => controller.abort(), DEFAULT_TIMEOUT);
30
+ try {
31
+ let endpoint = `${cdpAddress}/json/new`;
32
+ if (url && url !== "about:blank") {
33
+ endpoint = `${endpoint}?${url}`;
34
+ }
35
+ const response = await fetch(endpoint, {
36
+ method: "PUT",
37
+ signal: controller.signal
38
+ });
39
+ if (!response.ok) {
40
+ throw new Error(`HTTP error! status: ${response.status}`);
41
+ }
42
+ return await response.json();
43
+ } finally {
44
+ clearTimeout(timeoutId);
45
+ }
46
+ }
47
+ async function closeCDPTab(cdpAddress, cdpTargetId) {
48
+ const controller = new AbortController();
49
+ const timeoutId = setTimeout(() => controller.abort(), DEFAULT_TIMEOUT);
50
+ try {
51
+ const response = await fetch(`${cdpAddress}/json/close/${cdpTargetId}`, {
52
+ signal: controller.signal
53
+ });
54
+ return response.status === 200;
55
+ } catch {
56
+ return false;
57
+ } finally {
58
+ clearTimeout(timeoutId);
59
+ }
60
+ }
61
+ async function activateCDPTab(cdpAddress, cdpTargetId) {
62
+ const controller = new AbortController();
63
+ const timeoutId = setTimeout(() => controller.abort(), DEFAULT_TIMEOUT);
64
+ try {
65
+ const response = await fetch(`${cdpAddress}/json/activate/${cdpTargetId}`, {
66
+ signal: controller.signal
67
+ });
68
+ return response.status === 200;
69
+ } catch {
70
+ return false;
71
+ } finally {
72
+ clearTimeout(timeoutId);
73
+ }
74
+ }
@@ -0,0 +1 @@
1
+ export declare function cleanEnvironmentVariables(): void;
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.cleanEnvironmentVariables = cleanEnvironmentVariables;
7
+ function cleanEnvironmentVariables() {
8
+ Object.keys(process.env).filter(i => {
9
+ if (i.toLocaleLowerCase().startsWith("npm")) {
10
+ return true;
11
+ }
12
+ if (i.toLocaleLowerCase().startsWith("fly") && i !== "FLY_ALLOC_ID") {
13
+ return true;
14
+ }
15
+ }).forEach(i => delete process.env[i]);
16
+ }
@@ -0,0 +1,11 @@
1
+ export declare const API_FOLDER_NAME = "api";
2
+ export declare const AUTH_SESSIONS_FOLDER_NAME = "auth-sessions";
3
+ export declare const AUTH_SESSIONS_INSTANCES_FOLDER_NAME = "auth-sessions-instances";
4
+ export declare const WORKSPACE_ID_ENV_VAR_KEY = "INTUNED_WORKSPACE_ID";
5
+ export declare const EXTENSION_PATH_ENV_VAR_KEY = "INTUNED_EXTENSION_PATH";
6
+ export declare const PROJECT_ID_ENV_VAR_KEY = "INTUNED_PROJECT_ID";
7
+ export declare const API_KEY_ENV_VAR_KEY = "INTUNED_API_KEY";
8
+ export declare const AUTH_TOKEN_ENV_VAR_KEY = "INTUNED_AUTH_TOKEN";
9
+ export declare const API_KEY_HEADER_NAME = "x-api-key";
10
+ export declare const API_BASE_URL_ENV_VAR_KEY = "INTUNED_API_BASE_URL";
11
+ export declare const CLI_ENV_VAR_KEY = "INTUNED_CLI";
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.WORKSPACE_ID_ENV_VAR_KEY = exports.PROJECT_ID_ENV_VAR_KEY = exports.EXTENSION_PATH_ENV_VAR_KEY = exports.CLI_ENV_VAR_KEY = exports.AUTH_TOKEN_ENV_VAR_KEY = exports.AUTH_SESSIONS_INSTANCES_FOLDER_NAME = exports.AUTH_SESSIONS_FOLDER_NAME = exports.API_KEY_HEADER_NAME = exports.API_KEY_ENV_VAR_KEY = exports.API_FOLDER_NAME = exports.API_BASE_URL_ENV_VAR_KEY = void 0;
7
+ const API_FOLDER_NAME = exports.API_FOLDER_NAME = "api";
8
+ const AUTH_SESSIONS_FOLDER_NAME = exports.AUTH_SESSIONS_FOLDER_NAME = "auth-sessions";
9
+ const AUTH_SESSIONS_INSTANCES_FOLDER_NAME = exports.AUTH_SESSIONS_INSTANCES_FOLDER_NAME = "auth-sessions-instances";
10
+ const WORKSPACE_ID_ENV_VAR_KEY = exports.WORKSPACE_ID_ENV_VAR_KEY = "INTUNED_WORKSPACE_ID";
11
+ const EXTENSION_PATH_ENV_VAR_KEY = exports.EXTENSION_PATH_ENV_VAR_KEY = "INTUNED_EXTENSION_PATH";
12
+ const PROJECT_ID_ENV_VAR_KEY = exports.PROJECT_ID_ENV_VAR_KEY = "INTUNED_PROJECT_ID";
13
+ const API_KEY_ENV_VAR_KEY = exports.API_KEY_ENV_VAR_KEY = "INTUNED_API_KEY";
14
+ const AUTH_TOKEN_ENV_VAR_KEY = exports.AUTH_TOKEN_ENV_VAR_KEY = "INTUNED_AUTH_TOKEN";
15
+ const API_KEY_HEADER_NAME = exports.API_KEY_HEADER_NAME = "x-api-key";
16
+ const API_BASE_URL_ENV_VAR_KEY = exports.API_BASE_URL_ENV_VAR_KEY = "INTUNED_API_BASE_URL";
17
+ const CLI_ENV_VAR_KEY = exports.CLI_ENV_VAR_KEY = "INTUNED_CLI";
@@ -0,0 +1,22 @@
1
+ import type * as playwright from "playwright";
2
+ import type { RunApiStorageState } from "@intuned/runtime-interface";
3
+ interface StorageEntry {
4
+ name: string;
5
+ value: string;
6
+ }
7
+ interface LocalStorageState {
8
+ origin: string;
9
+ localStorage: StorageEntry[];
10
+ }
11
+ interface SessionStorageState {
12
+ origin: string;
13
+ sessionStorage: StorageEntry[];
14
+ }
15
+ export interface StorageState {
16
+ cookies?: playwright.Cookie[] | null;
17
+ origins?: LocalStorageState[] | null;
18
+ sessionStorage?: SessionStorageState[] | null;
19
+ }
20
+ export declare function setStorageState(context: playwright.BrowserContext, state: RunApiStorageState): Promise<void>;
21
+ export declare function getStorageState(context: playwright.BrowserContext): Promise<RunApiStorageState>;
22
+ export {};
@@ -0,0 +1,84 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.getStorageState = getStorageState;
7
+ exports.setStorageState = setStorageState;
8
+ async function setStorageState(context, state) {
9
+ if ("cookies" in state && state.cookies) {
10
+ await context.addCookies(state.cookies);
11
+ }
12
+ const page = await context.newPage();
13
+ if ("origins" in state && state.origins) {
14
+ for (const originData of state.origins || []) {
15
+ const origin = originData.origin;
16
+ await page.route(`${origin}/*`, route => route.fulfill({
17
+ body: "<html><head><title>Set Storage</title></head><body><h1>Set Storage</h1></body></html>",
18
+ contentType: "text/html",
19
+ status: 200
20
+ }));
21
+ try {
22
+ await page.goto(origin);
23
+ for (const item of originData.localStorage) {
24
+ await page.evaluate(([key, value]) => {
25
+ window.localStorage.setItem(key, value);
26
+ }, [item.name, item.value]);
27
+ }
28
+ } finally {
29
+ await page.unroute(`${origin}/*`);
30
+ }
31
+ }
32
+ }
33
+ if ("sessionStorage" in state && state.sessionStorage) {
34
+ await context.addInitScript(storage => {
35
+ for (const {
36
+ origin,
37
+ sessionStorage
38
+ } of storage) {
39
+ if (window.location.origin === origin) {
40
+ for (const item of sessionStorage) {
41
+ const value = window.sessionStorage.getItem(item.name);
42
+ if (!value) {
43
+ window.sessionStorage.setItem(item.name, item.value);
44
+ }
45
+ }
46
+ }
47
+ }
48
+ }, state.sessionStorage);
49
+ }
50
+ await page.close();
51
+ }
52
+ async function getStorageState(context) {
53
+ const result = {
54
+ cookies: [],
55
+ origins: []
56
+ };
57
+ const storageState = await context.storageState();
58
+ result.cookies = storageState.cookies;
59
+ result.origins = storageState.origins;
60
+ const sessionDataList = [];
61
+ const pages = await context.pages();
62
+ for (const page of pages) {
63
+ if (page.isClosed()) continue;
64
+ try {
65
+ const sessionData = await page.evaluate(() => {
66
+ const items = {
67
+ ...window.sessionStorage
68
+ };
69
+ return {
70
+ origin: window.location.origin,
71
+ sessionStorage: Object.entries(items).map(([name, value]) => ({
72
+ name,
73
+ value
74
+ }))
75
+ };
76
+ });
77
+ sessionDataList.push(sessionData);
78
+ } catch (error) {
79
+ console.error("Error getting sessionStorage:", error);
80
+ }
81
+ }
82
+ result["sessionStorage"] = sessionDataList;
83
+ return result;
84
+ }
@@ -0,0 +1,11 @@
1
+ import type * as playwright from "playwright";
2
+ import { CaptchaSolverSettings, CaptchaSolverSettingsWithRunContext } from "../settingsSchema";
3
+ export declare function resolveCaptchaSolverSettings(input?: unknown): Promise<CaptchaSolverSettings>;
4
+ export declare function isIntunedExtensionLoaded(): boolean;
5
+ export declare function buildExtensionsList(): string[];
6
+ export declare function getIntunedExtensionPath(): string;
7
+ export declare function isIntunedExtensionEnabled(): Promise<boolean>;
8
+ export declare function getIntunedExtensionWorker(context: playwright.BrowserContext): Promise<playwright.Worker | null>;
9
+ export declare function getIntunedExtensionSettings(captchaSolverSettings: CaptchaSolverSettings): Promise<CaptchaSolverSettingsWithRunContext>;
10
+ export declare function getIntunedCaptchaSolverSettings(): Promise<CaptchaSolverSettings>;
11
+ export declare function setupIntunedExtension(): Promise<void>;
@@ -0,0 +1,147 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.buildExtensionsList = buildExtensionsList;
7
+ exports.getIntunedCaptchaSolverSettings = getIntunedCaptchaSolverSettings;
8
+ exports.getIntunedExtensionPath = getIntunedExtensionPath;
9
+ exports.getIntunedExtensionSettings = getIntunedExtensionSettings;
10
+ exports.getIntunedExtensionWorker = getIntunedExtensionWorker;
11
+ exports.isIntunedExtensionEnabled = isIntunedExtensionEnabled;
12
+ exports.isIntunedExtensionLoaded = isIntunedExtensionLoaded;
13
+ exports.resolveCaptchaSolverSettings = resolveCaptchaSolverSettings;
14
+ exports.setupIntunedExtension = setupIntunedExtension;
15
+ var _settings = require("../../commands/common/utils/settings");
16
+ var _settingsSchema = require("../settingsSchema");
17
+ var _constants = require("../constants");
18
+ var _jwtTokenManager = require("../jwtTokenManager");
19
+ var _path = _interopRequireDefault(require("path"));
20
+ var _promises = require("fs/promises");
21
+ var _intunedExtensionServer = require("./intunedExtensionServer");
22
+ var _portfinder = require("portfinder");
23
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
24
+ const INTUNED_WORKER = "intunedWorker.js";
25
+ const INTUNED_EXTENSION_SETTINGS_FILE_NAME = "intunedSettings.json";
26
+ const INTUNED_CAPTCHA_EXTENSION_PORT_ENV_VAR = "INTUNED_CAPTCHA_EXTENSION_PORT";
27
+ let captchaSolverSettings = null;
28
+ async function getIntunedCaptchaExtensionPort() {
29
+ if (process.env.INTUNED_CAPTCHA_EXTENSION_PORT) {
30
+ return parseInt(process.env.INTUNED_CAPTCHA_EXTENSION_PORT, 10);
31
+ }
32
+ return await (0, _portfinder.getPort)({});
33
+ }
34
+ async function resolveCaptchaSolverSettings(input) {
35
+ const parsed = _settingsSchema.captchaSolverSettingsSchema.parse(input || {});
36
+ if (!parsed.port) {
37
+ parsed.port = await getIntunedCaptchaExtensionPort();
38
+ }
39
+ return parsed;
40
+ }
41
+ function getIntunedCaptchaExtensionPortFromEnv() {
42
+ const raw = process.env[INTUNED_CAPTCHA_EXTENSION_PORT_ENV_VAR];
43
+ if (!raw) return null;
44
+ const parsed = Number(raw);
45
+ if (!Number.isFinite(parsed) || parsed <= 0 || parsed > 65535) {
46
+ throw new Error(`Invalid ${INTUNED_CAPTCHA_EXTENSION_PORT_ENV_VAR}: ${raw}`);
47
+ }
48
+ return parsed;
49
+ }
50
+ function isIntunedExtensionLoaded() {
51
+ return !!getIntunedExtensionPath();
52
+ }
53
+ function buildExtensionsList() {
54
+ const extensionsList = [];
55
+ if (isIntunedExtensionLoaded()) {
56
+ const intunedExtensionPath = getIntunedExtensionPath();
57
+ extensionsList.push(intunedExtensionPath);
58
+ }
59
+ return extensionsList;
60
+ }
61
+ function getIntunedExtensionPath() {
62
+ return process.env.INTUNED_EXTENSION_PATH;
63
+ }
64
+ async function isIntunedExtensionEnabled() {
65
+ const path = getIntunedExtensionPath();
66
+ if (!path) {
67
+ return false;
68
+ }
69
+ const captchaSolverSettings = await getIntunedCaptchaSolverSettings();
70
+ return captchaSolverSettings.enabled;
71
+ }
72
+ async function getIntunedExtensionWorker(context) {
73
+ if (!(await isIntunedExtensionEnabled())) {
74
+ return null;
75
+ }
76
+ let attemptCount = 0;
77
+ while (attemptCount < 4) {
78
+ const intunedServiceWorker = context.serviceWorkers().find(serviceWorker => serviceWorker.url().includes(INTUNED_WORKER));
79
+ if (intunedServiceWorker) {
80
+ return intunedServiceWorker;
81
+ }
82
+ try {
83
+ await context.waitForEvent("serviceworker", {
84
+ timeout: 3000
85
+ });
86
+ } catch (err) {
87
+ console.log(`Error accessing service workers (attempt ${attemptCount})`);
88
+ }
89
+ attemptCount++;
90
+ }
91
+ console.error("Failed to get intuned worker after 5 attmepts");
92
+ return null;
93
+ }
94
+ async function getIntunedExtensionSettings(captchaSolverSettings) {
95
+ const [domain, workspaceId, projectId] = [process.env.FUNCTIONS_DOMAIN, process.env[_constants.WORKSPACE_ID_ENV_VAR_KEY], process.env.INTUNED_INTEGRATION_ID ?? process.env[_constants.PROJECT_ID_ENV_VAR_KEY]];
96
+ if (!domain || !workspaceId || !projectId) {
97
+ const missingEnvVars = [domain && "FUNCTIONS_DOMAIN", workspaceId && _constants.WORKSPACE_ID_ENV_VAR_KEY, projectId && `INTUNED_INTEGRATION_ID OR ${_constants.PROJECT_ID_ENV_VAR_KEY}`];
98
+ throw new Error(`Missing required environment variables: ${missingEnvVars}`);
99
+ }
100
+ const authentication = (() => {
101
+ if (process.env.INTUNED_API_KEY) {
102
+ return {
103
+ type: "apiKey",
104
+ apiKey: process.env.INTUNED_API_KEY
105
+ };
106
+ }
107
+ if (process.env.INTUNED_BASIC_AUTH_USERNAME && process.env.INTUNED_BASIC_AUTH_PASSWORD) {
108
+ const credentials = `${process.env.INTUNED_BASIC_AUTH_USERNAME}:${process.env.INTUNED_BASIC_AUTH_PASSWORD}`;
109
+ const token = Buffer.from(credentials, "utf-8").toString("base64");
110
+ return {
111
+ type: "basic",
112
+ token
113
+ };
114
+ }
115
+ return {
116
+ type: "bearer",
117
+ token: _jwtTokenManager.backendFunctionsTokenManager.token
118
+ };
119
+ })();
120
+ const baseUrl = process.env.INTUNED_API_BASE_URL ?? domain;
121
+ return {
122
+ ...captchaSolverSettings,
123
+ workspaceId,
124
+ projectId,
125
+ baseUrl,
126
+ authentication
127
+ };
128
+ }
129
+ async function getIntunedCaptchaSolverSettings() {
130
+ if (captchaSolverSettings) {
131
+ return captchaSolverSettings;
132
+ }
133
+ const settings = await (0, _settings.getSettings)();
134
+ captchaSolverSettings = await resolveCaptchaSolverSettings(settings.captchaSolver);
135
+ return captchaSolverSettings;
136
+ }
137
+ async function setupIntunedExtension() {
138
+ if (!(await isIntunedExtensionEnabled())) {
139
+ return;
140
+ }
141
+ const intunedExtensionPath = getIntunedExtensionPath();
142
+ const intunedExtensionSettingsPath = _path.default.join(intunedExtensionPath, INTUNED_EXTENSION_SETTINGS_FILE_NAME);
143
+ const captchaSolverSettings = await getIntunedCaptchaSolverSettings();
144
+ await (0, _intunedExtensionServer.setupIntunedExtensionServer)(captchaSolverSettings);
145
+ const captchaSolverSettingsWithRunContext = await getIntunedExtensionSettings(captchaSolverSettings);
146
+ await (0, _promises.writeFile)(intunedExtensionSettingsPath, JSON.stringify(captchaSolverSettingsWithRunContext));
147
+ }
@@ -0,0 +1,24 @@
1
+ import type * as playwright from "playwright";
2
+ import { Captcha, CaptchaCallback, CaptchaStatus } from "./types";
3
+ import { CaptchaSolverSettings } from "../settingsSchema";
4
+ export declare class ExtensionServer {
5
+ private tabs;
6
+ private app;
7
+ constructor();
8
+ private getOrCreateTab;
9
+ handleUpsertCaptcha(captcha: Captcha): Promise<void>;
10
+ start({ port, host, }: {
11
+ port: number;
12
+ host?: string;
13
+ }): Promise<void>;
14
+ stop(): Promise<void>;
15
+ getCaptchas(page: playwright.Page, status?: CaptchaStatus): Promise<Captcha[]>;
16
+ subscribe(page: playwright.Page, handler: CaptchaCallback, status?: CaptchaStatus): Promise<void>;
17
+ unsubscribe(page: playwright.Page, handler: CaptchaCallback, status?: CaptchaStatus): Promise<void>;
18
+ removeTab(tabId: number): void;
19
+ getTabId(page: playwright.Page): Promise<number>;
20
+ }
21
+ export declare function getIntunedExtensionServer(): ExtensionServer;
22
+ export declare function setupIntunedExtensionServer(captchaSolverSettings?: CaptchaSolverSettings): Promise<void>;
23
+ export declare function cleanIntunedExtensionServer(): Promise<void>;
24
+ export declare function getTabId(page: playwright.Page): Promise<number>;