@shiplightai/sdk 0.1.1 → 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +18 -10
- package/dist/agentHelpers-MRG6DCNX.js +4 -0
- package/dist/agentHelpers-MRG6DCNX.js.map +1 -0
- package/dist/agentLogin-QZDVIJMB.js +4 -0
- package/dist/agentLogin-QZDVIJMB.js.map +1 -0
- package/dist/chunk-DIRPNR2B.js +195 -0
- package/dist/chunk-DIRPNR2B.js.map +1 -0
- package/dist/chunk-FWACDSD6.js +17 -0
- package/dist/chunk-FWACDSD6.js.map +1 -0
- package/dist/chunk-GVEDIII4.js +25 -0
- package/dist/chunk-GVEDIII4.js.map +1 -0
- package/dist/{chunk-UHZTPBZ3.js → chunk-N54UPO3H.js} +95 -92
- package/dist/chunk-N54UPO3H.js.map +1 -0
- package/dist/chunk-ODNKMWXO.js +6 -0
- package/dist/chunk-ODNKMWXO.js.map +1 -0
- package/dist/{chunk-GPZJYXUG.js → chunk-SSPF674P.js} +19 -6
- package/dist/chunk-SSPF674P.js.map +1 -0
- package/dist/chunk-USNFIQN5.js +4 -0
- package/dist/chunk-USNFIQN5.js.map +1 -0
- package/dist/chunk-W6S73J4I.js +4 -0
- package/dist/chunk-W6S73J4I.js.map +1 -0
- package/dist/handler-O7GYRDNA.js +4 -0
- package/dist/handler-O7GYRDNA.js.map +1 -0
- package/dist/index.js +12 -9
- package/dist/index.js.map +1 -0
- package/dist/task-E5YOHPFW.js +193 -0
- package/dist/task-E5YOHPFW.js.map +1 -0
- package/package.json +13 -13
- package/dist/agentHelpers-UCLT5EKK.js +0 -1
- package/dist/agentLogin-ARB3NEO4.js +0 -1
- package/dist/chunk-6H2NJBNL.js +0 -1
- package/dist/chunk-GDTCZALZ.js +0 -192
- package/dist/chunk-KFC5I6R5.js +0 -14
- package/dist/chunk-QIBDXB3J.js +0 -22
- package/dist/chunk-UFLZ3URR.js +0 -1
- package/dist/chunk-YR4E7JSB.js +0 -3
- package/dist/handler-TPOFKKIB.js +0 -1
- package/dist/task-57MAWXLN.js +0 -190
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { createRequire as __createRequire } from "module";
|
|
2
|
+
const require = __createRequire(import.meta.url);
|
|
3
|
+
var m=.5*1e3,h=30*1e3,g=1*1e3;async function y(s,c){let i=new Set,a=Date.now(),d=new Set(["document","stylesheet","image","font","script","iframe"]),l=new Set(["text/html","text/css","application/javascript","image/","font/","application/json"]),o=["analytics","tracking","telemetry","beacon","metrics","doubleclick","adsystem","adserver","advertising","facebook.com/plugins","platform.twitter","linkedin.com/embed","livechat","zendesk","intercom","crisp.chat","hotjar","push-notifications","onesignal","pushwoosh","heartbeat","ping","alive","webrtc","rtmp://","wss://","cloudfront.net","fastly.net"],f=t=>{let e=t.toLowerCase();return e.startsWith("data:")||e.startsWith("blob:")?!0:o.some(n=>e.includes(n))},p=t=>{let e=t.resourceType(),n=t.url();if(!d.has(e)||["websocket","media","eventsource","manifest","other"].includes(e)||f(n))return;let r=t.headers();r.purpose==="prefetch"||["video","audio"].includes(r["sec-fetch-dest"])||(i.add(t),a=Date.now())},u=async t=>{let e=t.request();if(!i.has(e))return;let n=(t.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(w=>n.includes(w))){i.delete(e);return}if(![...l].some(w=>n.startsWith(w))){i.delete(e);return}let r=t.headers()["content-length"];if(r)try{if(parseInt(r,10)>5*1024*1024){i.delete(e);return}}catch{}i.delete(e),a=Date.now()};s.on("request",p),s.on("response",u);try{let t=Date.now(),e=g;for(;;){await new Promise(r=>setTimeout(r,100));let n=Date.now();if(i.size===0&&n-a>=e||n-t>c)break}}finally{s.removeListener("request",p),s.removeListener("response",u)}}async function P(s,c=h,i=m){let a=Date.now();try{await y(s,c)}catch(o){throw o instanceof Error?new Error(`Failed during network stabilization: ${o.message}`):new Error("An unknown error occurred during network stabilization.")}let d=Date.now()-a,l=Math.max(i-d,0);l>0&&await new Promise(o=>setTimeout(o,l))}export{P as a};
|
|
4
|
+
//# sourceMappingURL=chunk-USNFIQN5.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../sdk-core/src/browser/browserUtils.ts"],"sourcesContent":["import { Browser, BrowserContext, Page } from \"playwright\";\nimport { INIT_SCRIPT } from \"./constants\";\n\n/**\n * Get common Chromium args for browser launch\n * @param debugPort - Optional debug port. If not provided, no remote debugging port will be set.\n * @param disableSecurity - Whether to disable web security (CORS, etc). Default: true\n * @param isHeadless - Whether to run in headless mode. Default: false\n */\nexport function getCommonChromiumArgs(\n debugPort?: number | string,\n disableSecurity: boolean = true,\n isHeadless: boolean = false\n): string[] {\n return [\n ...(debugPort !== undefined ? [\n `--remote-debugging-port=${debugPort}`,\n '--remote-allow-origins=*',\n ] : []),\n '--no-sandbox',\n '--disable-blink-features=AutomationControlled',\n '--timezone=America/Los_Angeles',\n ...(isHeadless ? ['--headless'] : []),\n ...(disableSecurity ? [\n '--disable-web-security',\n '--disable-site-isolation-trials',\n '--disable-features=IsolateOrigins,site-per-process',\n '--allow-running-insecure-content',\n '--ignore-certificate-errors',\n '--ignore-ssl-errors',\n '--ignore-certificate-errors-spki-list'\n ] : []),\n ];\n}\n\n/**\n * Create browser context with init script\n */\nexport async function newBrowserContext(browser: Browser, options?: any): Promise<BrowserContext> {\n const context = await browser.newContext(options);\n context.addInitScript(INIT_SCRIPT);\n return context;\n}\n\n/**\n * Get browser CDP URL from debug port\n * This matches packages/common/browser/browserUtils.ts::getLocalCdpUrl\n */\nexport async function getBrowserCdpUrl(debugPort: number): Promise<string> {\n const wsEndpointResponse = await fetch(\n `http://127.0.0.1:${debugPort}/json/version`\n );\n const wsEndpointData: any = await wsEndpointResponse.json();\n // Replace localhost with 127.0.0.1 to avoid IPv6 issues\n const cdpUrl = wsEndpointData.webSocketDebuggerUrl;\n return cdpUrl.replace('localhost', '127.0.0.1');\n}\n\nexport async function getPageWsUrl(debugPort: number, pageId: string): Promise<string> {\n const wsEndpointResponse = await fetch(\n `http://localhost:${debugPort}/json/list`\n );\n const wsEndpointData: any = await wsEndpointResponse.json();\n for (const target of wsEndpointData) {\n if (target.type === \"page\" && target.id === pageId) {\n return target.webSocketDebuggerUrl;\n }\n }\n throw new Error(`No page found for id: ${pageId}`);\n}\n\nexport async function getPageInfo(page: Page): Promise<any> {\n const session = await page.context().newCDPSession(page);\n const targetInfo = await session.send(\"Target.getTargetInfo\");\n await session.detach();\n return targetInfo.targetInfo;\n}\n\n// Set window bounds using CDP (copied from @loggia/common/browser/browserUtils)\nexport const setWindowBounds = async (page: Page, width: number, height: number): Promise<void> => {\n // Set window bounds using CDP\n const cdpSession = await page.context().newCDPSession(page);\n const windowIdResult = await cdpSession.send('Browser.getWindowForTarget');\n await cdpSession.send('Browser.setWindowBounds', {\n windowId: windowIdResult.windowId,\n bounds: {\n width: width,\n height: height,\n windowState: 'normal', // Ensure window is not minimized/maximized\n },\n });\n try {\n await Promise.race([\n cdpSession.detach(),\n new Promise((_, reject) => setTimeout(() => reject(new Error('CDP detach timeout')), 1000))\n ]);\n } catch (error) {\n // Ignore timeout errors for CDP detach\n }\n};\n\n// Page load stabilization constants\nconst MINIMUM_WAIT_PAGE_LOAD_TIME_MS = 0.5 * 1000;\nconst MAXIMUM_WAIT_PAGE_LOAD_TIME_MS = 30.0 * 1000;\nconst WAIT_FOR_NETWORK_IDLE_PAGE_LOAD_TIME_MS = 1.0 * 1000;\n\n/**\n * Wait for stable network (no pending requests for idle timeout)\n * Filters out irrelevant requests like analytics, ads, streaming, etc.\n */\nasync function waitForStableNetwork(page: Page, maxWaitTimeMs: number): Promise<void> {\n const pendingRequests = new Set<any>();\n let lastActivity = Date.now();\n\n const RELEVANT_RESOURCE_TYPES = new Set([\n 'document',\n 'stylesheet',\n 'image',\n 'font',\n 'script',\n 'iframe',\n ]);\n\n const RELEVANT_CONTENT_TYPES = new Set([\n 'text/html',\n 'text/css',\n 'application/javascript',\n 'image/',\n 'font/',\n 'application/json',\n ]);\n\n const IGNORED_URL_PATTERNS = [\n // Analytics and tracking\n 'analytics', 'tracking', 'telemetry', 'beacon', 'metrics',\n // Ad-related\n 'doubleclick', 'adsystem', 'adserver', 'advertising',\n // Social media widgets\n 'facebook.com/plugins', 'platform.twitter', 'linkedin.com/embed',\n // Live chat and support\n 'livechat', 'zendesk', 'intercom', 'crisp.chat', 'hotjar',\n // Push notifications\n 'push-notifications', 'onesignal', 'pushwoosh',\n // Background sync/heartbeat\n 'heartbeat', 'ping', 'alive',\n // WebRTC and streaming\n 'webrtc', 'rtmp://', 'wss://',\n // Common CDNs for dynamic content\n 'cloudfront.net', 'fastly.net',\n ];\n\n const isIgnoredUrl = (url: string): boolean => {\n const lowerUrl = url.toLowerCase();\n if (lowerUrl.startsWith('data:') || lowerUrl.startsWith('blob:')) {\n return true;\n }\n return IGNORED_URL_PATTERNS.some(pattern => lowerUrl.includes(pattern));\n };\n\n const onRequest = (request: any) => {\n const resourceType = request.resourceType();\n const url = request.url();\n\n if (!RELEVANT_RESOURCE_TYPES.has(resourceType)) return;\n if (['websocket', 'media', 'eventsource', 'manifest', 'other'].includes(resourceType)) return;\n if (isIgnoredUrl(url)) return;\n\n const headers = request.headers();\n if (headers['purpose'] === 'prefetch' || ['video', 'audio'].includes(headers['sec-fetch-dest'])) {\n return;\n }\n\n pendingRequests.add(request);\n lastActivity = Date.now();\n };\n\n const onResponse = async (response: any) => {\n const request = response.request();\n if (!pendingRequests.has(request)) return;\n\n const contentType = (response.headers()['content-type'] || '').toLowerCase();\n\n // Skip if content type indicates streaming or real-time data\n const isStreaming = [\n 'streaming', 'video', 'audio', 'webm', 'mp4',\n 'event-stream', 'websocket', 'protobuf'\n ].some(t => contentType.includes(t));\n\n if (isStreaming) {\n pendingRequests.delete(request);\n return;\n }\n\n // Only process relevant content types\n const isRelevantContentType = [...RELEVANT_CONTENT_TYPES].some(ct => contentType.startsWith(ct));\n if (!isRelevantContentType) {\n pendingRequests.delete(request);\n return;\n }\n\n // Skip if response is too large\n const contentLengthHeader = response.headers()['content-length'];\n if (contentLengthHeader) {\n try {\n const contentLength = parseInt(contentLengthHeader, 10);\n if (contentLength > 5 * 1024 * 1024) { // 5MB\n pendingRequests.delete(request);\n return;\n }\n } catch (e) {\n // Ignore parse errors\n }\n }\n\n pendingRequests.delete(request);\n lastActivity = Date.now();\n };\n\n page.on('request', onRequest);\n page.on('response', onResponse);\n\n try {\n const startTime = Date.now();\n const idleTimeoutMs = WAIT_FOR_NETWORK_IDLE_PAGE_LOAD_TIME_MS;\n\n while (true) {\n await new Promise(resolve => setTimeout(resolve, 100)); // Sleep 100ms\n const now = Date.now();\n\n if (pendingRequests.size === 0 && (now - lastActivity) >= idleTimeoutMs) {\n break; // Network is idle\n }\n\n if (now - startTime > maxWaitTimeMs) {\n break; // Max wait time exceeded\n }\n }\n } finally {\n // Clean up event listeners\n page.removeListener('request', onRequest);\n page.removeListener('response', onResponse);\n }\n}\n\n/**\n * Wait for page and frames to fully load\n * Ensures page is fully loaded before continuing by waiting for network to be idle\n * @param page - The page to wait for\n * @param maxWaitTimeMs - Maximum time to wait for network to stabilize\n * @param minWaitTimeMs - Minimum time to wait before returning (ensures page has time to render)\n */\nexport async function waitForPageAndFramesLoad(\n page: Page,\n maxWaitTimeMs: number = MAXIMUM_WAIT_PAGE_LOAD_TIME_MS,\n minWaitTimeMs: number = MINIMUM_WAIT_PAGE_LOAD_TIME_MS\n): Promise<void> {\n const startTime = Date.now();\n\n try {\n await waitForStableNetwork(page, maxWaitTimeMs);\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(`Failed during network stabilization: ${error.message}`);\n } else {\n throw new Error(`An unknown error occurred during network stabilization.`);\n }\n }\n\n const elapsedMs = Date.now() - startTime;\n const remainingMs = Math.max(minWaitTimeMs - elapsedMs, 0);\n\n if (remainingMs > 0) {\n await new Promise(resolve => setTimeout(resolve, remainingMs));\n }\n}"],"mappings":";;AA+EO,IAuBDA,EAAiC,GAAM,IACvCC,EAAiC,GAAO,IACxCC,EAA0C,EAAM,IAMtD,eAAeC,EAAqBC,EAAYC,EAAsC,CACpF,IAAMC,EAAkB,IAAI,IACxBC,EAAe,KAAK,IAAI,EAEtBC,EAA0B,IAAI,IAAI,CACtC,WACA,aACA,QACA,OACA,SACA,QACF,CAAC,EAEKC,EAAyB,IAAI,IAAI,CACrC,YACA,WACA,yBACA,SACA,QACA,kBACF,CAAC,EAEKC,EAAuB,CAE3B,YAAa,WAAY,YAAa,SAAU,UAEhD,cAAe,WAAY,WAAY,cAEvC,uBAAwB,mBAAoB,qBAE5C,WAAY,UAAW,WAAY,aAAc,SAEjD,qBAAsB,YAAa,YAEnC,YAAa,OAAQ,QAErB,SAAU,UAAW,SAErB,iBAAkB,YACpB,EAEMC,EAAgBC,GAAyB,CAC7C,IAAMC,EAAWD,EAAI,YAAY,EACjC,OAAIC,EAAS,WAAW,OAAO,GAAKA,EAAS,WAAW,OAAO,EACtD,GAEFH,EAAqB,KAAKI,GAAWD,EAAS,SAASC,CAAO,CAAC,CACxE,EAEMC,EAAaC,GAAiB,CAClC,IAAMC,EAAeD,EAAQ,aAAa,EACpCJ,EAAMI,EAAQ,IAAI,EAIxB,GAFI,CAACR,EAAwB,IAAIS,CAAY,GACzC,CAAC,YAAa,QAAS,cAAe,WAAY,OAAO,EAAE,SAASA,CAAY,GAChFN,EAAaC,CAAG,EAAG,OAEvB,IAAMM,EAAUF,EAAQ,QAAQ,EAC5BE,EAAQ,UAAe,YAAc,CAAC,QAAS,OAAO,EAAE,SAASA,EAAQ,gBAAgB,CAAC,IAI9FZ,EAAgB,IAAIU,CAAO,EAC3BT,EAAe,KAAK,IAAI,EAC1B,EAEMY,EAAa,MAAOC,GAAkB,CAC1C,IAAMJ,EAAUI,EAAS,QAAQ,EACjC,GAAI,CAACd,EAAgB,IAAIU,CAAO,EAAG,OAEnC,IAAMK,GAAeD,EAAS,QAAQ,EAAE,cAAc,GAAK,IAAI,YAAY,EAQ3E,GALoB,CAClB,YAAa,QAAS,QAAS,OAAQ,MACvC,eAAgB,YAAa,UAC/B,EAAE,KAAKE,GAAKD,EAAY,SAASC,CAAC,CAAC,EAElB,CACfhB,EAAgB,OAAOU,CAAO,EAC9B,MACF,CAIA,GAAI,CAD0B,CAAC,GAAGP,CAAsB,EAAE,KAAKc,GAAMF,EAAY,WAAWE,CAAE,CAAC,EACnE,CAC1BjB,EAAgB,OAAOU,CAAO,EAC9B,MACF,CAGA,IAAMQ,EAAsBJ,EAAS,QAAQ,EAAE,gBAAgB,EAC/D,GAAII,EACF,GAAI,CAEF,GADsB,SAASA,EAAqB,EAAE,EAClC,EAAI,KAAO,KAAM,CACnClB,EAAgB,OAAOU,CAAO,EAC9B,MACF,CACF,MAAY,CAEZ,CAGFV,EAAgB,OAAOU,CAAO,EAC9BT,EAAe,KAAK,IAAI,CAC1B,EAEAH,EAAK,GAAG,UAAWW,CAAS,EAC5BX,EAAK,GAAG,WAAYe,CAAU,EAE9B,GAAI,CACF,IAAMM,EAAY,KAAK,IAAI,EACrBC,EAAgBxB,EAEtB,OAAa,CACX,MAAM,IAAI,QAAQyB,GAAW,WAAWA,EAAS,GAAG,CAAC,EACrD,IAAMC,EAAM,KAAK,IAAI,EAMrB,GAJItB,EAAgB,OAAS,GAAMsB,EAAMrB,GAAiBmB,GAItDE,EAAMH,EAAYpB,EACpB,KAEJ,CACF,QAAA,CAEED,EAAK,eAAe,UAAWW,CAAS,EACxCX,EAAK,eAAe,WAAYe,CAAU,CAC5C,CACF,CASA,eAAsBU,EACpBzB,EACAC,EAAwBJ,EACxB6B,EAAwB9B,EACT,CACf,IAAMyB,EAAY,KAAK,IAAI,EAE3B,GAAI,CACF,MAAMtB,EAAqBC,EAAMC,CAAa,CAChD,OAAS0B,EAAO,CACd,MAAIA,aAAiB,MACb,IAAI,MAAM,wCAAwCA,EAAM,OAAO,EAAE,EAEjE,IAAI,MAAM,yDAAyD,CAE7E,CAEA,IAAMC,EAAY,KAAK,IAAI,EAAIP,EACzBQ,EAAc,KAAK,IAAIH,EAAgBE,EAAW,CAAC,EAErDC,EAAc,GAChB,MAAM,IAAI,QAAQN,GAAW,WAAWA,EAASM,CAAW,CAAC,CAEjE","names":["MINIMUM_WAIT_PAGE_LOAD_TIME_MS","MAXIMUM_WAIT_PAGE_LOAD_TIME_MS","WAIT_FOR_NETWORK_IDLE_PAGE_LOAD_TIME_MS","waitForStableNetwork","page","maxWaitTimeMs","pendingRequests","lastActivity","RELEVANT_RESOURCE_TYPES","RELEVANT_CONTENT_TYPES","IGNORED_URL_PATTERNS","isIgnoredUrl","url","lowerUrl","pattern","onRequest","request","resourceType","headers","onResponse","response","contentType","t","ct","contentLengthHeader","startTime","idleTimeoutMs","resolve","now","waitForPageAndFramesLoad","minWaitTimeMs","error","elapsedMs","remainingMs"]}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { createRequire as __createRequire } from "module";
|
|
2
|
+
const require = __createRequire(import.meta.url);
|
|
3
|
+
var g=Object.create;var i=Object.defineProperty;var u=Object.getOwnPropertyDescriptor;var l=Object.getOwnPropertyNames;var c=Object.getPrototypeOf,v=Object.prototype.hasOwnProperty;var p=(e,t,o)=>t in e?i(e,t,{enumerable:!0,configurable:!0,writable:!0,value:o}):e[t]=o;var m=(e=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(e,{get:(t,o)=>(typeof require<"u"?require:t)[o]}):e)(function(e){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+e+'" is not supported')});var E=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var h=(e,t,o,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of l(t))!v.call(e,r)&&r!==o&&i(e,r,{get:()=>t[r],enumerable:!(n=u(t,r))||n.enumerable});return e};var N=(e,t,o)=>(o=e!=null?g(c(e)):{},h(t||!e||!e.__esModule?i(o,"default",{value:e,enumerable:!0}):o,e));var j=(e,t,o)=>p(e,typeof t!="symbol"?t+"":t,o);var d=class{constructor(){this.config=this.getDefaultConfig()}getDefaultConfig(){return{logLevel:1,debugAgent:!1,testResultsJsonPath:void 0,consoleLogsPath:void 0}}getConfig(){return{...this.config}}updateConfig(e){this.config={...this.config,...e}}resetConfig(){this.config=this.getDefaultConfig()}get(e){return this.config[e]}set(e,t){this.config[e]=t}},s=new d,P=s;function w(e){s.updateConfig(e)}function I(){return s.getConfig()}var f=Object.defineProperty,O=Object.getOwnPropertyDescriptor,b=Object.getOwnPropertyNames,y=Object.prototype.hasOwnProperty;var A=(e,t)=>()=>(e&&(t=e(e=0)),t),B=(e,t)=>{for(var o in t)f(e,o,{get:t[o],enumerable:!0})},a=(e,t,o,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of b(t))!y.call(e,r)&&r!==o&&f(e,r,{get:()=>t[r],enumerable:!(n=O(t,r))||n.enumerable});return e},F=(e,t,o)=>(a(e,t,"default"),o&&a(o,t,"default")),G=e=>a(f({},"__esModule",{value:!0}),e);var C=(e=>(e[e.DEBUG=0]="DEBUG",e[e.INFO=1]="INFO",e[e.WARN=2]="WARN",e[e.ERROR=3]="ERROR",e[e.SILENT=4]="SILENT",e))(C||{});export{m as a,E as b,N as c,j as d,P as e,w as f,I as g,A as h,B as i,F as j,G as k,C as l};
|
|
4
|
+
//# sourceMappingURL=chunk-W6S73J4I.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../sdk-core/src/config.ts","../../sdk-core/dist/chunk-T34MSF5W.js","../../sdk-core/src/utils/logLevel.ts"],"sourcesContent":["/**\n * SDK Configuration\n *\n * Centralized configuration for the SDK.\n * Config must be set programmatically using configureSdk().\n */\n\nimport { LogLevel } from './utils/logLevel';\n\nexport interface SdkConfig {\n /** Log level for SDK operations */\n logLevel: LogLevel;\n /** Enable debug mode for agent operations */\n debugAgent: boolean;\n /** Path to write test results JSON */\n testResultsJsonPath?: string;\n /** Path to write console logs */\n consoleLogsPath?: string;\n /** Path to write agent execution logs (prompts, LLM thinking, internal state) */\n agentLogPath?: string;\n /**\n * Internal environment variables (API keys, secrets, etc.)\n * Not accessible via process.env in test code.\n * Use getSdkConfig().env?.KEY_NAME to access.\n */\n env?: Record<string, string>;\n}\n\nclass SdkConfigManager {\n private config: SdkConfig;\n\n constructor() {\n // Initialize with defaults\n this.config = this.getDefaultConfig();\n }\n\n private getDefaultConfig(): SdkConfig {\n return {\n logLevel: LogLevel.INFO,\n debugAgent: false,\n testResultsJsonPath: undefined,\n consoleLogsPath: undefined,\n };\n }\n\n /**\n * Get current configuration\n */\n getConfig(): SdkConfig {\n return { ...this.config };\n }\n\n /**\n * Update configuration (partial update)\n */\n updateConfig(updates: Partial<SdkConfig>): void {\n this.config = {\n ...this.config,\n ...updates,\n };\n }\n\n /**\n * Reset configuration to defaults\n */\n resetConfig(): void {\n this.config = this.getDefaultConfig();\n }\n\n /**\n * Get specific config value\n */\n get<K extends keyof SdkConfig>(key: K): SdkConfig[K] {\n return this.config[key];\n }\n\n /**\n * Set specific config value\n */\n set<K extends keyof SdkConfig>(key: K, value: SdkConfig[K]): void {\n this.config[key] = value;\n }\n}\n\n// Export singleton instance\nconst sdkConfig = new SdkConfigManager();\nexport default sdkConfig;\n\n/**\n * Configure the SDK\n * @param config - Partial configuration to update\n */\nexport function configureSdk(config: Partial<SdkConfig>): void {\n sdkConfig.updateConfig(config);\n}\n\n/**\n * Get SDK configuration\n */\nexport function getSdkConfig(): SdkConfig {\n return sdkConfig.getConfig();\n}\n","var e=Object.defineProperty;var h=Object.getOwnPropertyDescriptor;var i=Object.getOwnPropertyNames;var j=Object.prototype.hasOwnProperty;var k=(b,a,c)=>a in b?e(b,a,{enumerable:!0,configurable:!0,writable:!0,value:c}):b[a]=c;var l=(b,a)=>()=>(b&&(a=b(b=0)),a);var m=(b,a)=>{for(var c in a)e(b,c,{get:a[c],enumerable:!0})},f=(b,a,c,g)=>{if(a&&typeof a==\"object\"||typeof a==\"function\")for(let d of i(a))!j.call(b,d)&&d!==c&&e(b,d,{get:()=>a[d],enumerable:!(g=h(a,d))||g.enumerable});return b},n=(b,a,c)=>(f(b,a,\"default\"),c&&f(c,a,\"default\"));var o=b=>f(e({},\"__esModule\",{value:!0}),b);var p=(b,a,c)=>k(b,typeof a!=\"symbol\"?a+\"\":a,c);export{l as a,m as b,n as c,o as d,p as e};\n//# sourceMappingURL=chunk-T34MSF5W.js.map","/**\n * Log levels for the SDK\n */\n\nexport enum LogLevel {\n DEBUG = 0,\n INFO = 1,\n WARN = 2,\n ERROR = 3,\n SILENT = 4\n}\n"],"mappings":";;04BA4BA,IAAMA,EAAN,KAAuB,CAGrB,aAAc,CAEZ,KAAK,OAAS,KAAK,iBAAiB,CACtC,CAEQ,kBAA8B,CACpC,MAAO,CACL,SAAA,EACA,WAAY,GACZ,oBAAqB,OACrB,gBAAiB,MACnB,CACF,CAKA,WAAuB,CACrB,MAAO,CAAE,GAAG,KAAK,MAAO,CAC1B,CAKA,aAAaC,EAAmC,CAC9C,KAAK,OAAS,CACZ,GAAG,KAAK,OACR,GAAGA,CACL,CACF,CAKA,aAAoB,CAClB,KAAK,OAAS,KAAK,iBAAiB,CACtC,CAKA,IAA+BC,EAAsB,CACnD,OAAO,KAAK,OAAOA,CAAG,CACxB,CAKA,IAA+BA,EAAQC,EAA2B,CAChE,KAAK,OAAOD,CAAG,EAAIC,CACrB,CACF,EAGMC,EAAY,IAAIJ,EACfK,EAAQD,EAMR,SAASE,EAAaC,EAAkC,CAC7DH,EAAU,aAAaG,CAAM,CAC/B,CAKO,SAASC,GAA0B,CACxC,OAAOJ,EAAU,UAAU,CAC7B,CCrGA,IAAIK,EAAE,OAAO,eAAmBC,EAAE,OAAO,yBAA6BC,EAAE,OAAO,oBAAwBC,EAAE,OAAO,UAAU,eAAuG,IAAIC,EAAE,CAACC,EAAEC,IAAI,KAAKD,IAAIC,EAAED,EAAEA,EAAE,CAAC,GAAGC,GAAOC,EAAE,CAACF,EAAEC,IAAI,CAAC,QAAQE,KAAKF,EAAEG,EAAEJ,EAAEG,EAAE,CAAC,IAAIF,EAAEE,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC,EAAEE,EAAE,CAACL,EAAEC,EAAEE,EAAEG,IAAI,CAAC,GAAGL,GAAG,OAAOA,GAAG,UAAU,OAAOA,GAAG,WAAW,QAAQM,KAAKC,EAAEP,CAAC,EAAE,CAACQ,EAAE,KAAKT,EAAEO,CAAC,GAAGA,IAAIJ,GAAGC,EAAEJ,EAAEO,EAAE,CAAC,IAAI,IAAIN,EAAEM,CAAC,EAAE,WAAW,EAAED,EAAEI,EAAET,EAAEM,CAAC,IAAID,EAAE,UAAU,CAAC,EAAE,OAAON,CAAC,EAAEW,EAAE,CAACX,EAAEC,EAAEE,KAAKE,EAAEL,EAAEC,EAAE,SAAS,EAAEE,GAAGE,EAAEF,EAAEF,EAAE,SAAS,GAAOW,EAAEZ,GAAGK,EAAED,EAAE,CAAC,EAAE,aAAa,CAAC,MAAM,EAAE,CAAC,EAAEJ,CAAC,ECIhkB,IAAKa,GAAAA,IACVA,EAAAA,EAAA,MAAQ,CAAA,EAAR,QACAA,EAAAA,EAAA,KAAO,CAAA,EAAP,OACAA,EAAAA,EAAA,KAAO,CAAA,EAAP,OACAA,EAAAA,EAAA,MAAQ,CAAA,EAAR,QACAA,EAAAA,EAAA,OAAS,CAAA,EAAT,SALUA,IAAAA,GAAA,CAAA,CAAA","names":["SdkConfigManager","updates","key","value","sdkConfig","config_default","configureSdk","config","getSdkConfig","e","h","i","j","l","b","a","m","c","e","f","g","d","i","j","h","n","o","LogLevel"]}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { createRequire as __createRequire } from "module";
|
|
2
|
+
const require = __createRequire(import.meta.url);
|
|
3
|
+
import{C as o,D as r}from"./chunk-GVEDIII4.js";import"./chunk-ODNKMWXO.js";import"./chunk-W6S73J4I.js";export{o as ActionHandler,r as default};
|
|
4
|
+
//# sourceMappingURL=handler-O7GYRDNA.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
package/dist/index.js
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
|
-
import{a as te,b as Ce,c as z,d as N,e as W,f as R}from"./chunk-GDTCZALZ.js";import{A as Ee,B as De,a as oe,b as re,c as ne,d as ae,e as se,f as ce,g as le,h as ue,i as he,j as de,k as ge,l as pe,m as fe,n as me,o as we,p as Se,q as Te,r as ve,s as ye,t as xe,u as be,v as Ae,w as ke,x as Pe,y as Me,z as _e}from"./chunk-QIBDXB3J.js";import{a as y,d as $}from"./chunk-GPZJYXUG.js";import{a}from"./chunk-YR4E7JSB.js";import{a as ht,b as V,c as X,f as j,i as Le}from"./chunk-UHZTPBZ3.js";import{a as H}from"./chunk-6H2NJBNL.js";import{a as u}from"./chunk-KFC5I6R5.js";import{c as ut,d as I,f as Q,g as ee,l as ie}from"./chunk-UFLZ3URR.js";import{z as l}from"zod";var Oe=l.enum(["JS_CODE","AI_MODE"]),J=l.object({type:Oe,expression:l.string()}),Fe=l.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),_=l.object({uid:l.string(),type:Fe}),Ie=l.object({action_data:l.object({action_name:l.string(),kwargs:l.record(l.any()).optional(),args:l.array(l.any()).optional()}),action_description:l.string().optional(),url:l.string().optional(),xpath:l.string().nullable().optional(),locator:l.string().nullable().optional(),css_selector:l.string().nullable().optional(),unique_selector:l.string().nullable().optional(),element_index:l.number().nullable().optional(),frame_path:l.array(l.any()).optional(),artifacts:l.record(l.any()).optional(),feedback:l.string().optional(),original_browser_use_action:l.any().optional()}).passthrough(),$e=_.extend({type:l.literal("DRAFT"),description:l.string()}),He=_.extend({type:l.literal("ACTION"),description:l.string(),action_entity:Ie.optional(),locator:l.string().optional(),use_pure_vision:l.boolean().optional()}),M=l.lazy(()=>l.union([$e,He,_.extend({type:l.literal("STEP"),description:l.string().optional().default(""),statements:l.array(M),reference_id:l.number().optional()}),_.extend({type:l.literal("IF_ELSE"),description:l.string().optional(),condition:J,then:l.array(M),else:l.array(M).optional()}),_.extend({type:l.literal("WHILE_LOOP"),description:l.string().optional(),condition:J,body:l.array(M),timeout_ms:l.number().optional()})])),Ne=l.object({version:l.string().optional(),goal:l.string(),url:l.string(),final_feedback:l.string().optional(),completed:l.boolean().optional(),success:l.boolean().optional(),statements:l.array(M),teardown:l.array(M).optional(),last_modified_at:l.string().optional()});var We=ut(ht(),1);import{v4 as $t}from"uuid";var Re=112;var pt=1080-Re;var Be={"Blackberry PlayBook":{name:"Blackberry PlayBook",userAgent:"Mozilla/5.0 (PlayBook; U; RIM Tablet OS 2.1.0; en-US) AppleWebKit/536.2+ (KHTML like Gecko) Version/26.0 Safari/536.2+",screen:{width:600,height:1024},viewport:{width:600,height:1024},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"BlackBerry Z30":{name:"BlackBerry Z30",userAgent:"Mozilla/5.0 (BB10; Touch) AppleWebKit/537.10+ (KHTML, like Gecko) Version/26.0 Mobile Safari/537.10+",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note 3":{name:"Galaxy Note 3",userAgent:"Mozilla/5.0 (Linux; U; Android 4.3; en-us; SM-N900T Build/JSS15J) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note II":{name:"Galaxy Note II",userAgent:"Mozilla/5.0 (Linux; U; Android 4.1; en-us; GT-N7100 Build/JRO03C) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S III":{name:"Galaxy S III",userAgent:"Mozilla/5.0 (Linux; U; Android 4.0; en-us; GT-I9300 Build/IMM76D) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S5":{name:"Galaxy S5",userAgent:"Mozilla/5.0 (Linux; Android 5.0; SM-G900P Build/LRX21T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S8":{name:"Galaxy S8",userAgent:"Mozilla/5.0 (Linux; Android 7.0; SM-G950U Build/NRD90M) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:740},viewport:{width:360,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S9+":{name:"Galaxy S9+",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; SM-G965U Build/R16NW) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:320,height:658},viewport:{width:320,height:658},deviceScaleFactor:4.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S24":{name:"Galaxy S24",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-S921U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:780},viewport:{width:360,height:780},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy A55":{name:"Galaxy A55",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-A556B) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:480,height:1040},viewport:{width:480,height:1040},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S4":{name:"Galaxy Tab S4",userAgent:"Mozilla/5.0 (Linux; Android 8.1.0; SM-T837A) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:712,height:1138},viewport:{width:712,height:1138},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S9":{name:"Galaxy Tab S9",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-X710) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:640,height:1024},viewport:{width:640,height:1024},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"iPad (gen 5)":{name:"iPad (gen 5)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 6)":{name:"iPad (gen 6)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 7)":{name:"iPad (gen 7)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:810,height:1080},viewport:{width:810,height:1080},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 11)":{name:"iPad (gen 11)",userAgent:"Mozilla/5.0 (iPad; CPU OS 18_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/604.1",screen:{width:656,height:944},viewport:{width:656,height:944},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Mini":{name:"iPad Mini",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Pro 11":{name:"iPad Pro 11",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:834,height:1194},viewport:{width:834,height:1194},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6":{name:"iPhone 6",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6 Plus":{name:"iPhone 6 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7":{name:"iPhone 7",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7 Plus":{name:"iPhone 7 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8":{name:"iPhone 8",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8 Plus":{name:"iPhone 8 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE":{name:"iPhone SE",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 10_3_1 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/14E304 Safari/602.1",screen:{width:320,height:568},viewport:{width:320,height:568},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE (3rd gen)":{name:"iPhone SE (3rd gen)",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 18_5 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/602.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone X":{name:"iPhone X",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:812},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone XR":{name:"iPhone XR",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:896},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11":{name:"iPhone 11",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro":{name:"iPhone 11 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:635},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro Max":{name:"iPhone 11 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12":{name:"iPhone 12",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro":{name:"iPhone 12 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro Max":{name:"iPhone 12 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Mini":{name:"iPhone 12 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13":{name:"iPhone 13",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro":{name:"iPhone 13 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro Max":{name:"iPhone 13 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Mini":{name:"iPhone 13 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14":{name:"iPhone 14",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Plus":{name:"iPhone 14 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro":{name:"iPhone 14 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:660},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro Max":{name:"iPhone 14 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15":{name:"iPhone 15",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Plus":{name:"iPhone 15 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro":{name:"iPhone 15 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro Max":{name:"iPhone 15 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Kindle Fire HDX":{name:"Kindle Fire HDX",userAgent:"Mozilla/5.0 (Linux; U; en-us; KFAPWI Build/JDQ39) AppleWebKit/535.19 (KHTML, like Gecko) Silk/3.13 Safari/535.19 Silk-Accelerated=true",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"LG Optimus L70":{name:"LG Optimus L70",userAgent:"Mozilla/5.0 (Linux; U; Android 4.4.2; en-us; LGMS323 Build/KOT49I.MS32310c) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:1.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 550":{name:"Microsoft Lumia 550",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 550) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 950":{name:"Microsoft Lumia 950",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 950) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:4,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 10":{name:"Nexus 10",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 10 Build/MOB31T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 4":{name:"Nexus 4",userAgent:"Mozilla/5.0 (Linux; Android 4.4.2; Nexus 4 Build/KOT49H) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5":{name:"Nexus 5",userAgent:"Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5X":{name:"Nexus 5X",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 5X Build/OPR4.170623.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6":{name:"Nexus 6",userAgent:"Mozilla/5.0 (Linux; Android 7.1.1; Nexus 6 Build/N6F26U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6P":{name:"Nexus 6P",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 6P Build/OPP3.170518.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 7":{name:"Nexus 7",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 7 Build/MOB30X) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:600,height:960},viewport:{width:600,height:960},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia Lumia 520":{name:"Nokia Lumia 520",userAgent:"Mozilla/5.0 (compatible; MSIE 10.0; Windows Phone 8.0; Trident/6.0; IEMobile/10.0; ARM; Touch; NOKIA; Lumia 520)",screen:{width:320,height:533},viewport:{width:320,height:533},deviceScaleFactor:1.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia N9":{name:"Nokia N9",userAgent:"Mozilla/5.0 (MeeGo; NokiaN9) AppleWebKit/534.13 (KHTML, like Gecko) NokiaBrowser/8.5.0 Mobile Safari/534.13",screen:{width:480,height:854},viewport:{width:480,height:854},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Pixel 2":{name:"Pixel 2",userAgent:"Mozilla/5.0 (Linux; Android 8.0; Pixel 2 Build/OPD3.170816.012) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:731},viewport:{width:411,height:731},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 2 XL":{name:"Pixel 2 XL",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Pixel 2 XL Build/OPD1.170816.004) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:823},viewport:{width:411,height:823},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 3":{name:"Pixel 3",userAgent:"Mozilla/5.0 (Linux; Android 9; Pixel 3 Build/PQ1A.181105.017.A1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:786},viewport:{width:393,height:786},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4":{name:"Pixel 4",userAgent:"Mozilla/5.0 (Linux; Android 10; Pixel 4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:353,height:745},viewport:{width:353,height:745},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4a (5G)":{name:"Pixel 4a (5G)",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 4a (5G)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:892},viewport:{width:412,height:765},deviceScaleFactor:2.63,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 5":{name:"Pixel 5",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:851},viewport:{width:393,height:727},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 7":{name:"Pixel 7",userAgent:"Mozilla/5.0 (Linux; Android 14; Pixel 7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:915},viewport:{width:412,height:839},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Moto G4":{name:"Moto G4",userAgent:"Mozilla/5.0 (Linux; Android 7.0; Moto G (4)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Desktop Chrome HiDPI":{name:"Desktop Chrome HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge HiDPI":{name:"Desktop Edge HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Firefox HiDPI":{name:"Desktop Firefox HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"},"Desktop Safari":{name:"Desktop Safari",userAgent:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Safari/605.1.15",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"webkit"},"Desktop Chrome":{name:"Desktop Chrome",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome Medium Resolution":{name:"Desktop Chrome Medium Resolution",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome (Branded)":{name:"Desktop Chrome (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Chrome Medium Resolution (Branded)":{name:"Desktop Chrome Medium Resolution (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Edge":{name:"Desktop Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge (Branded)":{name:"Desktop Edge (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Edge Medium Resolution (Branded)":{name:"Desktop Edge Medium Resolution (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Firefox":{name:"Desktop Firefox",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"}};var Ke={desktop:["Desktop Chrome","Desktop Chrome Medium Resolution","Desktop Chrome (Branded)","Desktop Chrome Medium Resolution (Branded)","Desktop Edge (Branded)","Desktop Edge Medium Resolution (Branded)","Desktop Safari"],mobile:["iPhone 15 Pro Max","iPhone 15 Pro","iPhone 15 Plus","iPhone 15","iPhone 14 Pro Max","iPhone 14 Pro","iPhone 14 Plus","iPhone 14","iPhone 13 Pro Max","iPhone 13 Pro","iPhone 13","iPhone 13 Mini","iPhone 12 Pro Max","iPhone 12 Pro","iPhone 12","iPhone 12 Mini","iPhone 11 Pro Max","iPhone 11 Pro","iPhone 11","iPhone XR","iPhone X","iPhone SE (3rd gen)","iPhone SE","iPhone 8 Plus","iPhone 8","iPhone 7 Plus","iPhone 7","iPhone 6 Plus","iPhone 6","Galaxy S24","Galaxy A55","Galaxy S9+","Galaxy S8","Galaxy S5","Galaxy Note 3","Galaxy Note II","Galaxy S III","Pixel 7","Pixel 5","Pixel 4a (5G)","Pixel 4","Pixel 3","Pixel 2 XL","Pixel 2","Nexus 6P","Nexus 6","Nexus 5X","Nexus 5","Nexus 4","Moto G4","LG Optimus L70","Microsoft Lumia 950","Microsoft Lumia 550","Nokia Lumia 520","Nokia N9","BlackBerry Z30"]},L=(t,e=!1)=>{let i=["chromium"];return e&&i.push("webkit"),Ke[t].map(o=>Be[o]).filter(o=>o.defaultBrowserType&&i.includes(o.defaultBrowserType))};var ft={desktop:{label:"Desktop",type:"desktop",devices:L("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:L("mobile")}},mt={desktop:{label:"Desktop",type:"desktop",devices:L("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:L("mobile",!0)}};var B=(t=>(t.SMS="sms",t.EMAIL="email",t.TOTP="totp",t))(B||{});var K=class Ge{constructor(){I(this,"data",{});I(this,"sensitive",new Set)}get(e){return this.data[e]}set(e,i,o=!1){this.data[e]=i,o?this.sensitive.add(e):this.sensitive.has(e)&&this.sensitive.delete(e)}getAll(){return{...this.data}}isSensitive(e){return this.sensitive.has(e)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(e){return this.sensitive.delete(e),delete this.data[e]}clear(){this.data={},this.sensitive.clear()}has(e){return e in this.data}get size(){return Object.keys(this.data).length}merge(e){for(let[i,o]of Object.entries(e.getAll()))this.set(i,o,e.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(e){let i=new Ge;if(e.data){let o=new Set(e.sensitiveKeys||[]);for(let[n,r]of Object.entries(e.data))i.set(n,r,o.has(n))}return i}};import{z as Ue}from"zod";var St=Ue.object({instruction:Ue.string().describe('The instruction of the operation to perform. Can only include one operation. Do not inlcude element indexes just describe the element, e.g. "select the text "Hello, world!" in "Hello, world!""')});function ze(t){t.register({name:"perform_accurate_operation",description:"Perform an operation that requires accurate interaction like dragging or interacting with a specific area of an element. Only use this action when neccecary.",schema:St,usesElementIndex:!1,async execute(e,i){let{instruction:o}=e,n={page:i.page,agentServices:i.agentServices,domService:i.domService},r=await te(o,n,{});if(r.status==="error"||!r.actionEntity)return{success:!1,actionEntity:{action_description:o,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:o}}},error:r.error||"Failed to generate action"};let{actionEntity:c}=r,s=await Ce(c,n);return{success:s.success,actionEntity:c,message:s.success?`Successfully executed action: ${c.action_data?.action_name}`:void 0,error:s.error}}})}var G=null;async function k(){if(G)return G;let t=(await import("./handler-TPOFKKIB.js")).default;return G=new t,G}async function Ve(t){let e=await k(),i=e.getAction("click"),o=e.getAction("hover"),n=e.getAction("right_click"),r=e.getAction("double_click");return Ee(t,i),me(t,o),ve(t,n),xe(t,r),"Click, hover, double-click, right-click, or drag elements"}async function Xe(t){let e=await k(),i=e.getAction("go_to_url"),o=e.getAction("go_back"),n=e.getAction("reload_page");return fe(t,i),ke(t,o),Te(t,n),"Navigate to URLs, go back, or reload the page"}async function je(t){let e=await k(),i=e.getAction("clear_text"),o=e.getAction("input_text"),n=e.getAction("press");return _e(t,i),we(t,o),Se(t,n),"Type text into inputs, clear input values, or press keyboard keys"}async function Je(t){let e=await k(),i=e.getAction("scroll_on_element"),o=e.getAction("scroll_to_text"),n=e.getAction("scroll");return he(t,i),de(t,o),ue(t,n),"Scroll the page or scroll to specific text/elements"}async function Ye(t){let e=await k(),i=e.getAction("close_tab"),o=e.getAction("switch_tab");return De(t,i),oe(t,o),"Switch between browser tabs or close tabs"}async function qe(t){let e=await k(),i=e.getAction("upload_file"),o=e.getAction("wait_for_download_complete");return ne(t,i),se(t,o),"Upload files or wait for downloads to complete"}async function Ze(t){let e=await k(),i=e.getAction("get_dropdown_options"),o=e.getAction("select_dropdown_option"),n=e.getAction("set_date_for_native_date_picker");return Ae(t,i),ge(t,o),pe(t,n),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function Qe(t){let e=await k(),i=e.getAction("wait"),o=e.getAction("save_variable"),n=e.getAction("done");return ae(t,i),le(t,o),ye(t,n),ze(t),"Wait for conditions, save variables, or complete tasks"}async function et(t){let i=(await k()).getAction("generate_2fa_code");return be(t,i),"Generate 2FA codes"}async function tt(t){let e=await k(),i=e.getAction("verify"),o=e.getAction("ai_extract"),n=e.getAction("ai_wait_until");return Pe(t,i),Me(t,o),ce(t,n),"Perform AI-powered assertions, extractions, or wait conditions"}var vt=[Ve(y),Xe(y),je(y),Je(y),Ye(y),qe(y),Ze(y),Qe(y),tt(y),et(y)],Tr=Promise.all(vt);import{chromium as Hr,firefox as Nr,webkit as Wr}from"playwright";var it=class{constructor(t){this.currentPage=null,this.currentIndex=-1,this.context=t,this.initialize()}initialize(){this.context.on("page",async e=>{await this.handleNewPage(e)});let t=this.context.pages();t.length>0&&(this.currentPage=t[0],this.currentIndex=0);for(let e of t)this.setupPageListeners(e)}async handleNewPage(t){try{this.setupPageListeners(t);let e=this.context.pages().indexOf(t);await this.setCurrentPage(t,e)}catch{}}setupPageListeners(t){t.on("close",async()=>{await this.handlePageClose(t)})}async handlePageClose(t){try{if(this.currentPage===t){let e=this.context.pages(),i=e.slice().reverse().find(o=>!o.isClosed());i&&await this.setCurrentPage(i,e.indexOf(i))}}catch{}}async setCurrentPage(t,e){let i=this.currentPage!==t;this.currentPage=t,this.currentIndex=e,i&&await t.bringToFront()}async switchToPage(t){let e=this.context.pages();if(t<0||t>=e.length)throw new Error(`Invalid page index: ${t}. Available pages: 0-${e.length-1}`);let i=e[t];if(i.isClosed())throw new Error(`Page at index ${t} is closed`);return await this.setCurrentPage(i,t),i}async closePage(t){let e=this.context.pages();if(t<0||t>=e.length)throw new Error(`Invalid page index: ${t}. Available pages: 0-${e.length-1}`);let i=e[t];if(i.isClosed())throw new Error(`Page at index ${t} is already closed`);await i.close()}getCurrentPage(){return this.currentPage}getCurrentIndex(){return this.currentIndex}getAllPages(){return this.context.pages()}getPageCount(){return this.context.pages().length}};async function ot(t,e=3e3,i=1e3){try{await H(t,e,i)}catch{}}async function rt(t,e,i){let o=i*1e3,n=100,r=Date.now();for(;!e.downloadStatus||e.downloadStatus.status==="inProgress";){if(Date.now()-r>o){let c;throw e.downloadStatus?c=`Timed out after ${o}ms waiting for download to complete`:c="No download in progress or completed",a.error(c),new Error(c)}await t.waitForTimeout(n)}if(e.downloadStatus.status==="failed"){let c=`Download failed: ${e.downloadStatus.error||"Unknown error"}`;throw a.error(c),new Error(c)}e.agentNote=`Download completed: ${e.downloadStatus.filename}`}async function nt(t,e,i,o=60,n){let r=Math.min(o,280),s=Math.max(10,r/10)*1e3,h=Date.now()+r*1e3;for(a.info(`Waiting for condition: "${e}" (timeout: ${r}s)`);;){let d=Date.now();try{if(await i(t,e,n))return a.info(`Condition met: "${e}"`),!0}catch(f){a.warn(`Error evaluating condition: ${f.message}`)}if(Date.now()>h)return a.warn(`Timeout waiting for condition: "${e}"`),!1;let w=s-(Date.now()-d);w>0&&await t.waitForTimeout(w)}}import*as at from"fs";import*as O from"path";var Y=class{constructor(t){this.context=t,this.testDataFileNames=[]}setTestDataDownloader(t,e){this.testDataDownloader=t,this.testDataFileNames=e??[]}setupPageTracking(t){this.tabManager=new it(t)}async switchTab(t){if(!this.tabManager)throw new Error("Tab manager not initialized");return await this.tabManager.switchToPage(t)}async closeTab(t){if(!this.tabManager)throw new Error("Tab manager not initialized");await this.tabManager.closePage(t)}getCurrentPage(){return this.tabManager?this.tabManager.getCurrentPage():null}validatePage(t){let e=this.getCurrentPage();if(e&&e!==t&&!e.isClosed())return a.info(`[validatePage] Page changed, switching to ${e.url()}`),e;if(t.isClosed()){let i=t.context().pages().filter(o=>!o.isClosed());if(i.length>0){let o=i[i.length-1];return a.info(`[validatePage] Page closed, switching to ${o.url()}`),o}a.error("[validatePage] No valid pages found")}return t}replaceVariables(t){return X(t,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(t){let e=this.context.testDataDir||process.cwd();return O.join(e,t)}async downloadTestDataFiles(t){if(t.length===0){a.debug("[AgentServices] No file paths provided for download");return}let e=this.context.testDataDir||process.cwd(),i=t.filter(o=>{let n=O.basename(o),r=O.join(e,n),c=at.existsSync(r);return c&&a.debug(`[AgentServices] File already exists locally: ${n}`),!c});if(i.length===0){a.debug("[AgentServices] All files exist locally, no download needed");return}if(!this.testDataDownloader){a.debug("[AgentServices] No test data downloader configured, assuming files are pre-populated");return}a.info(`[AgentServices] Downloading ${i.length} test data files: ${i.join(", ")}`),await this.testDataDownloader(i,e)}async waitForDownloadComplete(t,e){return rt(t,this.context,e)}getRecentDownloadedFilePath(){return this.context.downloadStatus?this.context.downloadStatus.status!=="completed"?(a.debug(`Download is ${this.context.downloadStatus.status}, not completed`),null):this.context.downloadStatus.filePath?(a.info(`Retrieved recent download path: ${this.context.downloadStatus.filePath}`),this.context.downloadStatus.filePath):(a.warn("Download completed but file path is missing"),null):(a.debug("No download found"),null)}addSensitive(t,e){this.context.variableStore.set(t,e,!0)}saveVariable(t,e){let i=t.startsWith("$")?t.slice(1):t;this.context.variableStore.set(i,e),a.debug(`Saved variable: ${i} = ${JSON.stringify(e)}`),this.context.agentNote=`A new value is saved to the variable "${i}".`}addNote(t){!t||t.trim()===""||(this.context.agentNote?this.context.agentNote+=`
|
|
2
|
-
|
|
1
|
+
import { createRequire as __createRequire } from "module";
|
|
2
|
+
const require = __createRequire(import.meta.url);
|
|
3
|
+
import{a as te,b as Ie,c as z,d as H,e as N,f as K}from"./chunk-DIRPNR2B.js";import{A as Ee,B as De,a as oe,b as re,c as ae,d as ne,e as se,f as ce,g as le,h as ue,i as he,j as de,k as pe,l as ge,m as me,n as fe,o as we,p as Se,q as ye,r as be,s as ve,t as xe,u as Te,v as ke,w as Ae,x as Pe,y as Me,z as _e}from"./chunk-GVEDIII4.js";import{a as b,d as F}from"./chunk-SSPF674P.js";import{a as n}from"./chunk-ODNKMWXO.js";import{a as dt,b as V,c as X,f as j,i as Ce}from"./chunk-N54UPO3H.js";import{a as W}from"./chunk-USNFIQN5.js";import{a as u}from"./chunk-FWACDSD6.js";import{c as ht,d as $,f as Q,g as ee,l as ie}from"./chunk-W6S73J4I.js";var Oe=112;var gt=1080-Oe;var Le={"Blackberry PlayBook":{name:"Blackberry PlayBook",userAgent:"Mozilla/5.0 (PlayBook; U; RIM Tablet OS 2.1.0; en-US) AppleWebKit/536.2+ (KHTML like Gecko) Version/26.0 Safari/536.2+",screen:{width:600,height:1024},viewport:{width:600,height:1024},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"BlackBerry Z30":{name:"BlackBerry Z30",userAgent:"Mozilla/5.0 (BB10; Touch) AppleWebKit/537.10+ (KHTML, like Gecko) Version/26.0 Mobile Safari/537.10+",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note 3":{name:"Galaxy Note 3",userAgent:"Mozilla/5.0 (Linux; U; Android 4.3; en-us; SM-N900T Build/JSS15J) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note II":{name:"Galaxy Note II",userAgent:"Mozilla/5.0 (Linux; U; Android 4.1; en-us; GT-N7100 Build/JRO03C) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S III":{name:"Galaxy S III",userAgent:"Mozilla/5.0 (Linux; U; Android 4.0; en-us; GT-I9300 Build/IMM76D) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S5":{name:"Galaxy S5",userAgent:"Mozilla/5.0 (Linux; Android 5.0; SM-G900P Build/LRX21T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S8":{name:"Galaxy S8",userAgent:"Mozilla/5.0 (Linux; Android 7.0; SM-G950U Build/NRD90M) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:740},viewport:{width:360,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S9+":{name:"Galaxy S9+",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; SM-G965U Build/R16NW) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:320,height:658},viewport:{width:320,height:658},deviceScaleFactor:4.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S24":{name:"Galaxy S24",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-S921U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:780},viewport:{width:360,height:780},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy A55":{name:"Galaxy A55",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-A556B) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:480,height:1040},viewport:{width:480,height:1040},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S4":{name:"Galaxy Tab S4",userAgent:"Mozilla/5.0 (Linux; Android 8.1.0; SM-T837A) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:712,height:1138},viewport:{width:712,height:1138},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S9":{name:"Galaxy Tab S9",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-X710) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:640,height:1024},viewport:{width:640,height:1024},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"iPad (gen 5)":{name:"iPad (gen 5)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 6)":{name:"iPad (gen 6)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 7)":{name:"iPad (gen 7)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:810,height:1080},viewport:{width:810,height:1080},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 11)":{name:"iPad (gen 11)",userAgent:"Mozilla/5.0 (iPad; CPU OS 18_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/604.1",screen:{width:656,height:944},viewport:{width:656,height:944},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Mini":{name:"iPad Mini",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Pro 11":{name:"iPad Pro 11",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:834,height:1194},viewport:{width:834,height:1194},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6":{name:"iPhone 6",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6 Plus":{name:"iPhone 6 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7":{name:"iPhone 7",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7 Plus":{name:"iPhone 7 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8":{name:"iPhone 8",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8 Plus":{name:"iPhone 8 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE":{name:"iPhone SE",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 10_3_1 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/14E304 Safari/602.1",screen:{width:320,height:568},viewport:{width:320,height:568},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE (3rd gen)":{name:"iPhone SE (3rd gen)",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 18_5 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/602.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone X":{name:"iPhone X",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:812},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone XR":{name:"iPhone XR",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:896},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11":{name:"iPhone 11",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro":{name:"iPhone 11 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:635},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro Max":{name:"iPhone 11 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12":{name:"iPhone 12",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro":{name:"iPhone 12 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro Max":{name:"iPhone 12 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Mini":{name:"iPhone 12 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13":{name:"iPhone 13",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro":{name:"iPhone 13 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro Max":{name:"iPhone 13 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Mini":{name:"iPhone 13 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14":{name:"iPhone 14",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Plus":{name:"iPhone 14 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro":{name:"iPhone 14 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:660},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro Max":{name:"iPhone 14 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15":{name:"iPhone 15",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Plus":{name:"iPhone 15 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro":{name:"iPhone 15 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro Max":{name:"iPhone 15 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Kindle Fire HDX":{name:"Kindle Fire HDX",userAgent:"Mozilla/5.0 (Linux; U; en-us; KFAPWI Build/JDQ39) AppleWebKit/535.19 (KHTML, like Gecko) Silk/3.13 Safari/535.19 Silk-Accelerated=true",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"LG Optimus L70":{name:"LG Optimus L70",userAgent:"Mozilla/5.0 (Linux; U; Android 4.4.2; en-us; LGMS323 Build/KOT49I.MS32310c) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:1.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 550":{name:"Microsoft Lumia 550",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 550) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 950":{name:"Microsoft Lumia 950",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 950) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:4,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 10":{name:"Nexus 10",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 10 Build/MOB31T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 4":{name:"Nexus 4",userAgent:"Mozilla/5.0 (Linux; Android 4.4.2; Nexus 4 Build/KOT49H) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5":{name:"Nexus 5",userAgent:"Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5X":{name:"Nexus 5X",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 5X Build/OPR4.170623.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6":{name:"Nexus 6",userAgent:"Mozilla/5.0 (Linux; Android 7.1.1; Nexus 6 Build/N6F26U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6P":{name:"Nexus 6P",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 6P Build/OPP3.170518.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 7":{name:"Nexus 7",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 7 Build/MOB30X) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:600,height:960},viewport:{width:600,height:960},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia Lumia 520":{name:"Nokia Lumia 520",userAgent:"Mozilla/5.0 (compatible; MSIE 10.0; Windows Phone 8.0; Trident/6.0; IEMobile/10.0; ARM; Touch; NOKIA; Lumia 520)",screen:{width:320,height:533},viewport:{width:320,height:533},deviceScaleFactor:1.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia N9":{name:"Nokia N9",userAgent:"Mozilla/5.0 (MeeGo; NokiaN9) AppleWebKit/534.13 (KHTML, like Gecko) NokiaBrowser/8.5.0 Mobile Safari/534.13",screen:{width:480,height:854},viewport:{width:480,height:854},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Pixel 2":{name:"Pixel 2",userAgent:"Mozilla/5.0 (Linux; Android 8.0; Pixel 2 Build/OPD3.170816.012) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:731},viewport:{width:411,height:731},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 2 XL":{name:"Pixel 2 XL",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Pixel 2 XL Build/OPD1.170816.004) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:823},viewport:{width:411,height:823},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 3":{name:"Pixel 3",userAgent:"Mozilla/5.0 (Linux; Android 9; Pixel 3 Build/PQ1A.181105.017.A1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:786},viewport:{width:393,height:786},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4":{name:"Pixel 4",userAgent:"Mozilla/5.0 (Linux; Android 10; Pixel 4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:353,height:745},viewport:{width:353,height:745},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4a (5G)":{name:"Pixel 4a (5G)",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 4a (5G)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:892},viewport:{width:412,height:765},deviceScaleFactor:2.63,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 5":{name:"Pixel 5",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:851},viewport:{width:393,height:727},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 7":{name:"Pixel 7",userAgent:"Mozilla/5.0 (Linux; Android 14; Pixel 7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:915},viewport:{width:412,height:839},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Moto G4":{name:"Moto G4",userAgent:"Mozilla/5.0 (Linux; Android 7.0; Moto G (4)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Desktop Chrome HiDPI":{name:"Desktop Chrome HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge HiDPI":{name:"Desktop Edge HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Firefox HiDPI":{name:"Desktop Firefox HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"},"Desktop Safari":{name:"Desktop Safari",userAgent:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Safari/605.1.15",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"webkit"},"Desktop Chrome":{name:"Desktop Chrome",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome Medium Resolution":{name:"Desktop Chrome Medium Resolution",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome (Branded)":{name:"Desktop Chrome (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Chrome Medium Resolution (Branded)":{name:"Desktop Chrome Medium Resolution (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Edge":{name:"Desktop Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge (Branded)":{name:"Desktop Edge (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Edge Medium Resolution (Branded)":{name:"Desktop Edge Medium Resolution (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Firefox":{name:"Desktop Firefox",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"}};var $e={desktop:["Desktop Chrome","Desktop Chrome Medium Resolution","Desktop Chrome (Branded)","Desktop Chrome Medium Resolution (Branded)","Desktop Edge (Branded)","Desktop Edge Medium Resolution (Branded)","Desktop Safari"],mobile:["iPhone 15 Pro Max","iPhone 15 Pro","iPhone 15 Plus","iPhone 15","iPhone 14 Pro Max","iPhone 14 Pro","iPhone 14 Plus","iPhone 14","iPhone 13 Pro Max","iPhone 13 Pro","iPhone 13","iPhone 13 Mini","iPhone 12 Pro Max","iPhone 12 Pro","iPhone 12","iPhone 12 Mini","iPhone 11 Pro Max","iPhone 11 Pro","iPhone 11","iPhone XR","iPhone X","iPhone SE (3rd gen)","iPhone SE","iPhone 8 Plus","iPhone 8","iPhone 7 Plus","iPhone 7","iPhone 6 Plus","iPhone 6","Galaxy S24","Galaxy A55","Galaxy S9+","Galaxy S8","Galaxy S5","Galaxy Note 3","Galaxy Note II","Galaxy S III","Pixel 7","Pixel 5","Pixel 4a (5G)","Pixel 4","Pixel 3","Pixel 2 XL","Pixel 2","Nexus 6P","Nexus 6","Nexus 5X","Nexus 5","Nexus 4","Moto G4","LG Optimus L70","Microsoft Lumia 950","Microsoft Lumia 550","Nokia Lumia 520","Nokia N9","BlackBerry Z30"]},C=(t,e=!1)=>{let i=["chromium"];return e&&i.push("webkit"),$e[t].map(o=>Le[o]).filter(o=>o.defaultBrowserType&&i.includes(o.defaultBrowserType))};var mt={desktop:{label:"Desktop",type:"desktop",devices:C("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:C("mobile")}},ft={desktop:{label:"Desktop",type:"desktop",devices:C("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:C("mobile",!0)}};var B=(t=>(t.SMS="sms",t.EMAIL="email",t.TOTP="totp",t))(B||{});import{z as l}from"zod";var Fe=l.enum(["JS_CODE","AI_MODE"]),J=l.object({type:Fe,expression:l.string()}),We=l.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),_=l.object({uid:l.string(),type:We}),He=l.object({action_data:l.object({action_name:l.string(),kwargs:l.record(l.any()).optional(),args:l.array(l.any()).optional()}),action_description:l.string().optional(),url:l.string().optional(),xpath:l.string().nullable().optional(),locator:l.string().nullable().optional(),css_selector:l.string().nullable().optional(),unique_selector:l.string().nullable().optional(),element_index:l.number().nullable().optional(),frame_path:l.array(l.any()).optional(),artifacts:l.record(l.any()).optional(),feedback:l.string().optional(),original_browser_use_action:l.any().optional()}).passthrough(),Ne=_.extend({type:l.literal("DRAFT"),description:l.string()}),Ke=_.extend({type:l.literal("ACTION"),description:l.string(),action_entity:He.optional(),locator:l.string().optional(),use_pure_vision:l.boolean().optional()}),M=l.lazy(()=>l.union([Ne,Ke,_.extend({type:l.literal("STEP"),description:l.string().optional().default(""),statements:l.array(M),reference_id:l.number().optional()}),_.extend({type:l.literal("IF_ELSE"),description:l.string().optional(),condition:J,then:l.array(M),else:l.array(M).optional()}),_.extend({type:l.literal("WHILE_LOOP"),description:l.string().optional(),condition:J,body:l.array(M),timeout_ms:l.number().optional()})])),Be=l.object({version:l.string().optional(),goal:l.string(),url:l.string(),final_feedback:l.string().optional(),completed:l.boolean().optional(),success:l.boolean().optional(),statements:l.array(M),teardown:l.array(M).optional(),last_modified_at:l.string().optional()});var Re=ht(dt(),1);import{v4 as Ut}from"uuid";var zt=1024*1024;var R=class Ge{constructor(){$(this,"data",{});$(this,"sensitive",new Set)}get(e){return this.data[e]}set(e,i,o=!1){this.data[e]=i,o?this.sensitive.add(e):this.sensitive.has(e)&&this.sensitive.delete(e)}getAll(){return{...this.data}}isSensitive(e){return this.sensitive.has(e)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(e){return this.sensitive.delete(e),delete this.data[e]}clear(){this.data={},this.sensitive.clear()}has(e){return e in this.data}get size(){return Object.keys(this.data).length}merge(e){for(let[i,o]of Object.entries(e.getAll()))this.set(i,o,e.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(e){let i=new Ge;if(e.data){let o=new Set(e.sensitiveKeys||[]);for(let[a,r]of Object.entries(e.data))i.set(a,r,o.has(a))}return i}};import{z as Ue}from"zod";var yt=Ue.object({instruction:Ue.string().describe('The instruction of the operation to perform. Can only include one operation. Do not inlcude element indexes just describe the element, e.g. "select the text "Hello, world!" in "Hello, world!""')});function ze(t){t.register({name:"perform_accurate_operation",description:"Perform an operation that requires accurate interaction like dragging or interacting with a specific area of an element. Only use this action when neccecary.",schema:yt,usesElementIndex:!1,async execute(e,i){let{instruction:o}=e,a={page:i.page,agentServices:i.agentServices,domService:i.domService},r=await te(o,a,{});if(r.status==="error"||!r.actionEntity)return{success:!1,actionEntity:{action_description:o,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:o}}},error:r.error||"Failed to generate action"};let{actionEntity:c}=r,s=await Ie(c,a);return{success:s.success,actionEntity:c,message:s.success?`Successfully executed action: ${c.action_data?.action_name}`:void 0,error:s.error}}})}var G=null;async function A(){if(G)return G;let t=(await import("./handler-O7GYRDNA.js")).default;return G=new t,G}async function Ve(t){let e=await A(),i=e.getAction("click"),o=e.getAction("hover"),a=e.getAction("right_click"),r=e.getAction("double_click");return Ee(t,i),fe(t,o),be(t,a),xe(t,r),"Click, hover, double-click, right-click, or drag elements"}async function Xe(t){let e=await A(),i=e.getAction("go_to_url"),o=e.getAction("go_back"),a=e.getAction("reload_page");return me(t,i),Ae(t,o),ye(t,a),"Navigate to URLs, go back, or reload the page"}async function je(t){let e=await A(),i=e.getAction("clear_text"),o=e.getAction("input_text"),a=e.getAction("press");return _e(t,i),we(t,o),Se(t,a),"Type text into inputs, clear input values, or press keyboard keys"}async function Je(t){let e=await A(),i=e.getAction("scroll_on_element"),o=e.getAction("scroll_to_text"),a=e.getAction("scroll");return he(t,i),de(t,o),ue(t,a),"Scroll the page or scroll to specific text/elements"}async function Ye(t){let e=await A(),i=e.getAction("close_tab"),o=e.getAction("switch_tab");return De(t,i),oe(t,o),"Switch between browser tabs or close tabs"}async function qe(t){let e=await A(),i=e.getAction("upload_file"),o=e.getAction("wait_for_download_complete");return ae(t,i),se(t,o),"Upload files or wait for downloads to complete"}async function Ze(t){let e=await A(),i=e.getAction("get_dropdown_options"),o=e.getAction("select_dropdown_option"),a=e.getAction("set_date_for_native_date_picker");return ke(t,i),pe(t,o),ge(t,a),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function Qe(t){let e=await A(),i=e.getAction("wait"),o=e.getAction("save_variable"),a=e.getAction("done");return ne(t,i),le(t,o),ve(t,a),ze(t),"Wait for conditions, save variables, or complete tasks"}async function et(t){let e=(await A()).getAction("generate_2fa_code");return Te(t,e),"Generate 2FA codes"}async function tt(t){let e=await A(),i=e.getAction("verify"),o=e.getAction("ai_extract"),a=e.getAction("ai_wait_until");return Pe(t,i),Me(t,o),ce(t,a),"Perform AI-powered assertions, extractions, or wait conditions"}var vt=[Ve(b),Xe(b),je(b),Je(b),Ye(b),qe(b),Ze(b),Qe(b),tt(b),et(b)],Tr=Promise.all(vt);import{chromium as Br,firefox as Rr,webkit as Gr}from"playwright";var At=(t=>(t.Desktop="desktop",t.Mobile="mobile",t))(At||{});var it=class{constructor(t){this.currentPage=null,this.currentIndex=-1,this.context=t,this.initialize()}initialize(){this.context.on("page",async e=>{await this.handleNewPage(e)});let t=this.context.pages();t.length>0&&(this.currentPage=t[0],this.currentIndex=0);for(let e of t)this.setupPageListeners(e)}async handleNewPage(t){try{this.setupPageListeners(t);let e=this.context.pages().indexOf(t);await this.setCurrentPage(t,e)}catch{}}setupPageListeners(t){t.on("close",async()=>{await this.handlePageClose(t)})}async handlePageClose(t){try{if(this.currentPage===t){let e=this.context.pages(),i=e.slice().reverse().find(o=>!o.isClosed());i&&await this.setCurrentPage(i,e.indexOf(i))}}catch{}}async setCurrentPage(t,e){let i=this.currentPage!==t;this.currentPage=t,this.currentIndex=e,i&&await t.bringToFront()}async switchToPage(t){let e=this.context.pages();if(t<0||t>=e.length)throw new Error(`Invalid page index: ${t}. Available pages: 0-${e.length-1}`);let i=e[t];if(i.isClosed())throw new Error(`Page at index ${t} is closed`);return await this.setCurrentPage(i,t),i}async closePage(t){let e=this.context.pages();if(t<0||t>=e.length)throw new Error(`Invalid page index: ${t}. Available pages: 0-${e.length-1}`);let i=e[t];if(i.isClosed())throw new Error(`Page at index ${t} is already closed`);await i.close()}getCurrentPage(){return this.currentPage}getCurrentIndex(){return this.currentIndex}getAllPages(){return this.context.pages()}getPageCount(){return this.context.pages().length}};async function ot(t,e=3e3,i=1e3){try{await W(t,e,i)}catch{}}async function rt(t,e,i){let o=i*1e3,a=100,r=Date.now();for(;!e.downloadStatus||e.downloadStatus.status==="inProgress";){if(Date.now()-r>o){let c;throw e.downloadStatus?c=`Timed out after ${o}ms waiting for download to complete`:c="No download in progress or completed",n.error(c),new Error(c)}await t.waitForTimeout(a)}if(e.downloadStatus.status==="failed"){let c=`Download failed: ${e.downloadStatus.error||"Unknown error"}`;throw n.error(c),new Error(c)}e.agentNote=`Download completed: ${e.downloadStatus.filename}`}async function at(t,e,i,o=60,a){let r=Math.min(o,280),c=Math.max(10,r/10)*1e3,s=Date.now()+r*1e3;for(n.info(`Waiting for condition: "${e}" (timeout: ${r}s)`);;){let h=Date.now();try{if(await i(t,e,a))return n.info(`Condition met: "${e}"`),!0}catch(g){n.warn(`Error evaluating condition: ${g.message}`)}if(Date.now()>s)return n.warn(`Timeout waiting for condition: "${e}"`),!1;let p=c-(Date.now()-h);p>0&&await t.waitForTimeout(p)}}import*as nt from"fs";import*as O from"path";var Y=class{constructor(t){this.context=t,this.testDataFileNames=[]}setTestDataDownloader(t,e){this.testDataDownloader=t,this.testDataFileNames=e??[]}setupPageTracking(t){this.tabManager=new it(t)}async switchTab(t){if(!this.tabManager)throw new Error("Tab manager not initialized");return await this.tabManager.switchToPage(t)}async closeTab(t){if(!this.tabManager)throw new Error("Tab manager not initialized");await this.tabManager.closePage(t)}getCurrentPage(){return this.tabManager?this.tabManager.getCurrentPage():null}validatePage(t){let e=this.getCurrentPage();if(e&&e!==t&&!e.isClosed())return n.info(`[validatePage] Page changed, switching to ${e.url()}`),e;if(t.isClosed()){let i=t.context().pages().filter(o=>!o.isClosed());if(i.length>0){let o=i[i.length-1];return n.info(`[validatePage] Page closed, switching to ${o.url()}`),o}n.error("[validatePage] No valid pages found")}return t}replaceVariables(t){return V(t,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(t){let e=this.context.testDataDir||process.cwd();return O.join(e,t)}async downloadTestDataFiles(t){if(t.length===0){n.debug("[AgentServices] No file paths provided for download");return}let e=this.context.testDataDir||process.cwd(),i=t.filter(o=>{let a=O.basename(o),r=O.join(e,a),c=nt.existsSync(r);return c&&n.debug(`[AgentServices] File already exists locally: ${a}`),!c});if(i.length===0){n.debug("[AgentServices] All files exist locally, no download needed");return}if(!this.testDataDownloader){n.debug("[AgentServices] No test data downloader configured, assuming files are pre-populated");return}n.info(`[AgentServices] Downloading ${i.length} test data files: ${i.join(", ")}`),await this.testDataDownloader(i,e)}async waitForDownloadComplete(t,e){return rt(t,this.context,e)}getRecentDownloadedFilePath(){return this.context.downloadStatus?this.context.downloadStatus.status!=="completed"?(n.debug(`Download is ${this.context.downloadStatus.status}, not completed`),null):this.context.downloadStatus.filePath?(n.info(`Retrieved recent download path: ${this.context.downloadStatus.filePath}`),this.context.downloadStatus.filePath):(n.warn("Download completed but file path is missing"),null):(n.debug("No download found"),null)}addSensitive(t,e){this.context.variableStore.set(t,e,!0)}saveVariable(t,e){let i=t.startsWith("$")?t.slice(1):t;this.context.variableStore.set(i,e),n.debug(`Saved variable: ${i} = ${JSON.stringify(e)}`),this.context.agentNote=`A new value is saved to the variable "${i}".`}addNote(t){!t||t.trim()===""||(this.context.agentNote?this.context.agentNote+=`
|
|
4
|
+
${t.trim()}`:this.context.agentNote=t.trim())}readVariable(t){let e=t.startsWith("$")?t.slice(1):t,i=this.context.variableStore.get(e);return n.debug(`Read variable: ${e} = ${JSON.stringify(i)}`),i}async generate2faCode(t){try{let{authenticator:e}=await import("otplib"),i=e.generate(t);return n.info(`Generated 2FA code: ${i}`),i}catch(e){throw n.error(`Failed to generate 2FA code: ${e.message}`),new Error(`Failed to generate 2FA code: ${e.message}`)}}async getDOMText(t){return await t.evaluate(()=>document.body.innerText)}async waitUntilStable(t,e){return W(t,e)}setPage(t){this.context.setPage?(n.info("[AgentServices] Calling setPage callback"),this.context.setPage(t)):n.debug("[AgentServices] setPage callback not configured")}getModel(){return this.context.model}get variableStore(){return this.context.variableStore}getDownloadDir(){return this.context.downloadDir}getActionSettings(){return this.context.organizationSettings?.action_code_conversion_settings||{}}getInteractiveClassNames(){return this.context.organizationSettings?.agent_settings?.interactive_class_names||[]}isUseCleanScreenshotForAssertion(){return this.context.organizationSettings?.use_clean_screenshot_for_assertion||!1}isKnowledgeImagesEnabled(){return this.context.organizationSettings?.agent_settings?.enable_knowledge_images||!1}isSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.use_sliced_screenshots||!1}isResizeSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.resize_sliced_screenshots||!1}isAccessibilityTreeEnabled(){return this.context.organizationSettings?.agent_settings?.use_accessibility_tree||!1}isActionIntentFilteringEnabled(){return this.context.organizationSettings?.agent_settings?.use_action_intent_filtering||!1}isDomTreeTsEnabled(){let t=process.env.USE_DOM_TREE_TS;return t!==void 0?t==="true"||t==="1":this.context.organizationSettings?.agent_settings?.use_dom_tree_ts||!1}getDomServiceOptions(){return{useDomTreeTs:this.isDomTreeTsEnabled()}}setKnowledgeRetriever(t){this.knowledgeRetriever=t}hasKnowledgeRetriever(){return this.knowledgeRetriever!==void 0}async retrieveKnowledges(t,e,i,o){if(!this.knowledgeRetriever)return n.debug("[AgentServices] No knowledge retriever configured"),[];try{let a=await this.knowledgeRetriever(t,e,i,o);return n.debug(`[AgentServices] Retrieved ${a.length} knowledges for statement`),a}catch(a){return n.warn(`[AgentServices] Failed to retrieve knowledges: ${a.message}`),[]}}};import*as f from"fs";import*as S from"path";var Pt=3,Mt=3,_t=40;function L(t,e){let i={};for(let[o,a]of Object.entries(t))i[o]=e.has(o)?"*****":a;return i}var q=class{constructor(t){this.context=t,this._newActionEntities=new Map,this.agentServices=new Y(t),this.context.tokenUsages||(this.context.tokenUsages=[])}getNewActionEntities(){return this._newActionEntities}async getActionHandler(){if(!this._actionHandler){let{default:t}=await import("./handler-O7GYRDNA.js");this._actionHandler=new t}return this._actionHandler}async execAction(t,e,i){let o=(await this.getActionHandler()).getAction(t);if(!o)throw new Error(`Unknown action: ${t}`);await o.execute(e,i,this.agentServices)}async dismissModalIfPresent(t,e){try{let i=await this.execute(t,`TASK: Check if there is an INTRUSIVE POPUP blocking the page, and dismiss it if present.
|
|
3
5
|
|
|
4
6
|
ONLY dismiss intrusive popups such as:
|
|
5
7
|
- Cookie/GDPR consent banners
|
|
@@ -21,19 +23,19 @@ If you find an intrusive popup, dismiss it by clicking its close/X button or "No
|
|
|
21
23
|
IMPORTANT: Only act with HIGH CONFIDENCE. If unsure whether something is an intrusive popup, do nothing.
|
|
22
24
|
It's better to miss a popup than to accidentally interact with normal page elements.
|
|
23
25
|
|
|
24
|
-
If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,{strategy:"multi",maxSteps:kt}),o=!!(i.actions&&i.actions.length>0);return{success:i.success,modalDismissed:o,details:i.details||(o?"Modal dismissed":"No modal found")}}catch(i){return{success:!1,modalDismissed:!1,details:i.message||"Modal dismissal failed"}}}_getContext(){return this.context}setupDownloadTracking(t){a.info(`[Download Tracking] Setting up download tracking for page: ${t.url()}`),t.on("download",async e=>{let i=e.suggestedFilename();a.info(`[Download Tracking] Download event detected! File: ${i}`),this.context.downloadStatus={filename:i,status:"inProgress",startTime:Date.now()},a.info(`[Download Tracking] Download status set to inProgress: ${JSON.stringify(this.context.downloadStatus)}`);try{let o=this.context.downloadDir||T.join(process.cwd(),"downloads");S.existsSync(o)||S.mkdirSync(o,{recursive:!0});let n=T.join(o,i);a.info(`[Download Tracking] Downloading file to: ${n}`),await e.saveAs(n),this.context.downloadStatus={filename:i,status:"completed",startTime:this.context.downloadStatus.startTime,filePath:n,timestamp:Date.now()},a.info(`[Download Tracking] Download completed: ${n}`),a.info(`[Download Tracking] Download status set to completed: ${JSON.stringify(this.context.downloadStatus)}`)}catch(o){this.context.downloadStatus={filename:i,status:"failed",startTime:this.context.downloadStatus.startTime,error:o.message,timestamp:Date.now()},a.error(`[Download Tracking] Download failed for ${i}: ${o.message}`)}})}collectTokenUsages(t){let e;Array.isArray(t)?e=t:t?.tokenUsages&&(e=t.tokenUsages),e&&e.length>0?(this.context.tokenUsages||(this.context.tokenUsages=[]),this.context.tokenUsages.push(...e),a.debug(`[collectTokenUsages] Added ${e.length} token usage(s), total: ${this.context.tokenUsages.length}`)):a.debug("[collectTokenUsages] No token usages to collect (undefined or empty)")}trackAIAction(t,e,i,o=1,n,r){if(!t)return;let c=i?.tokenUsages||[];this.context.aiActionDetails||(this.context.aiActionDetails=[]);let s=this.context.aiActionDetails.find(h=>h.stepId===t&&h.actionType===e);s?(s.count+=o,c.length>0&&s.tokenUsages.push(...c),i?.userPrompt&&(s.userPrompt=i.userPrompt),i?.rawLlmResponse&&(s.rawLlmResponse=i.rawLlmResponse),i?.reasoningContent&&(s.reasoningContent=i.reasoningContent),i?.elementTree&&(s.elementTree=i.elementTree),i?.screenshotWithSom&&(s.screenshotWithSom=i.screenshotWithSom),r&&(s.explanation=r)):this.context.aiActionDetails.push({stepId:t,actionType:e,count:o,tokenUsages:[...c],statement:n,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:r,elementTree:i?.elementTree,screenshotWithSom:i?.screenshotWithSom}),a.debug(`[trackAIAction] Tracked ${e} for step ${t}, count: ${o}`)}async assert(t,e,i){a.info(`Asserting statement: ${e}`),i&&this.context.stepTracking&&await this.createStepResult(t,i,e),await this.agentServices.waitUntilStable(t);try{let o=this.getCompletedExecutionHistory(),n=await W(e,t,this.agentServices,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(n.debugInfo),this.context.lastActionDebugInfo=n.debugInfo;let r=n.explanation||n.error||"No explanation";if(i&&this.trackAIAction(i,"assert",n.debugInfo,1,e,r),this.context.agentNote=r,i&&this.context.stepTracking&&await this.updateStepResult(i,n.success?"success":"failure",r,void 0,n.debugInfo),!n.success)throw this.addToExecutionHistory(`Assert: "${e}"`,`Failed: ${r}`),new Error(`Assertion failed: ${r}`);return this.addToExecutionHistory(`Assert: "${e}"`,`Passed: ${r}`),!0}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),o}}async evaluate(t,e,i){i&&this.context.stepTracking&&await this.createStepResult(t,i,e),await this.agentServices.waitUntilStable(t);try{let o=this.getCompletedExecutionHistory(),n=await W(e,t,this.agentServices,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(n.debugInfo),this.context.lastActionDebugInfo=n.debugInfo;let r=n.explanation||n.error||"No explanation";return i&&this.trackAIAction(i,"evaluate",n.debugInfo,1,e,r),this.context.agentNote=r,i&&this.context.stepTracking&&await this.updateStepResult(i,"success",r,void 0,n.debugInfo),n.success?(this.addToExecutionHistory(`Evaluate: "${e}"`,`Result: true - ${r}`),!0):(a.warn(`AI evaluation returned false/unknown: ${r}`),this.addToExecutionHistory(`Evaluate: "${e}"`,`Unknown/False: ${r}`),!1)}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),o}}async performAction(t,e){a.info(`Act: ${e}`);let i=this.getCompletedExecutionHistory(),o=await N(e,t,this.agentServices,{executionHistory:i,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});if(this.collectTokenUsages(o.debugInfo),o.status!=="success"||o.actionEntities.length===0)return{success:!1,details:o.explanation||o.error||"Action failed"};let n=o.actionEntities[0]?.action_description||e;return this.addToExecutionHistory(e,n),{success:!0,details:o.explanation}}async execute(t,e,i,o,n){let r=n?.strategy||"single";a.info(`Executing statement: ${e} (strategy: ${r})`),i&&this.context.stepTracking&&await this.createStepResult(t,i,e);try{let c=this.getCompletedExecutionHistory();this.context.agentNote="";let s,h;if(r==="multi"){let g=i&&this.context.stepTracking?.artifactsDir?w=>{if(w.type==="action"&&w.debugInfo){let f=`${i}-step${w.step}`;this.saveDebugInfoToFiles(f,w.debugInfo,this.context.model)}}:void 0;if(s=await R(e,t,this.agentServices,g,{executionHistory:c,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:n?.maxSteps??Pt}),h=s.completed,this.collectTokenUsages(s.tokenUsages),i&&s.tokenUsages){let w={tokenUsages:s.tokenUsages};this.trackAIAction(i,"execute",w,s.actionEntities?.length||1,e,s.explanation||"Multi-step execution completed")}}else if(s=await N(e,t,this.agentServices,{executionHistory:c,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:o}),h=!0,this.collectTokenUsages(s.debugInfo),this.context.lastActionDebugInfo=s.debugInfo,i){let g=s.explanation||s.error||"No explanation";this.trackAIAction(i,"execute",s.debugInfo,1,e,g)}if(s.status!=="success"||s.actionEntities.length===0||!h){let g=s.explanation||s.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",g,void 0,s.debugInfo),new Error(`Action failed: ${g}`)}let d=this.context.agentNote||s.explanation||"Action executed successfully";return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,s.debugInfo),this.addToExecutionHistory(`Execute: "${e}"`,d),{success:!0,details:d,actions:s.actionEntities,debugInfo:s.debugInfo}}catch(c){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",c.message),this.addToExecutionHistory(`Execute: "${e}"`,`Failed: ${c.message}`),c}}async generate(t,e,i,o){i&&this.context.stepTracking&&await this.createStepResult(t,i,e);try{let n=this.getCompletedExecutionHistory(),r=await z(e,t,this.agentServices,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:o});if(this.collectTokenUsages(r.debugInfo),r.status!=="success"||r.actionEntities.length===0){let h=r.explanation||r.error||"No explanation";throw i&&this.trackAIAction(i,"generate",r.debugInfo,1,e,h),i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",h,void 0,r.debugInfo),new Error(h)}let c=r.completed,s=r.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",r.debugInfo,1,e,s),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",s,void 0,r.debugInfo),a.info(`[generate] Generated action for "${e}": ${s}, goalAccomplished: ${r.completed}`),{success:c,details:s,actions:r.actionEntities,debugInfo:r.debugInfo}}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async run(t,e,i,o){i&&this.context.stepTracking&&await this.createStepResult(t,i,e);try{let n=this.getCompletedExecutionHistory(),r=i&&this.context.stepTracking?.artifactsDir,c=o?.onAction||r?g=>{if(g.type==="action"&&g.action_entity&&(o?.onAction?.(g.action_entity),r&&g.debugInfo)){let w=`${i}-step${g.step}`;this.saveDebugInfoToFiles(w,g.debugInfo,this.context.model)}}:void 0,s=await R(e,t,this.agentServices,c,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:o?.abortSignal,maxSteps:o?.maxSteps});u.log(`Run task result: status=${s.status}, completed=${s.completed}, actions=${s.actionEntities?.length||0}`),this.collectTokenUsages(s.tokenUsages);let h=s.status==="success"&&s.completed,d=s.explanation||s.error||(h?"Step completed":"Step failed");if(i&&s.tokenUsages){let g={tokenUsages:s.tokenUsages};this.trackAIAction(i,"run",g,s.actionEntities?.length||1,e,d)}if(i&&this.context.stepTracking&&await this.updateStepResult(i,h?"success":"failure",d,void 0,void 0),this.addToExecutionHistory(`Run: "${e}"`,d),s.status==="error")throw new Error(d);return u.log(`Run result: success=${h}, details=${d}`),{success:h,details:d,actions:s.actionEntities}}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),this.addToExecutionHistory(`Run: "${e}"`,`Failed: ${n.message}`),n}}async step(t,e,i,o,n,r=!0,c){let s=Date.now();this.context.stepTracking&&await this.createStepResult(t,o,i),await this.agentServices.waitUntilStable(t),this.context.stepTracking&&(this.context.stepTracking.currentStepId=o);let h=t.url(),d=await this.captureDOMSnapshot(t),g=this.context.stepTracking?.captureVariables?F(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},w=this.context.stepTracking?.results[o]?.screenshot;try{a.info(`Executing step ${o}: ${i}`),this.addToExecutionHistory(i,""),this.context.agentNote="";let f=await e(),x=t.url(),v=await this.captureDOMSnapshot(t),b=this.context.stepTracking?.captureVariables?F(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking&&await this.updateStepResult(o,"success",""),this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let m=Date.now()-s,p=this.context.stepTracking.results[o]?.screenshot,P=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:h,domSnapshot:d||void 0,variables:g,screenshotPath:w,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:o,description:i,action:{playwrightCode:[e.toString()]},consoleLogs:this.getConsoleLogsForStep(o),durationMs:m,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:x,domSnapshot:v||void 0,variables:b,screenshotPath:p,timestamp:P})}let A=this.context.agentNote;return(!A||A.trim()==="")&&(A="Execution successful"),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=A),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),f}catch(f){let x=r&&!this.context.isSelfHealing&&this.context.selfHealingStrategy!=="none";if(x&&(this.context.stepTracking&&await this.updateStepResult(o,"failure",f.message),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=f.message)),!i||i.trim()==="")throw a.error("No description provided for self-healing"),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),f;if(!x){if(a.info(`Failed to heal at step ${o}. ${i}`),this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let m=t.url(),p=await this.captureDOMSnapshot(t),P=this.context.stepTracking.captureVariables?F(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},E=Date.now()-s,D=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:h,domSnapshot:d||void 0,variables:g,screenshotPath:w,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:o,description:i,action:{playwrightCode:[e.toString()]},consoleLogs:this.getConsoleLogsForStep(o),durationMs:E,status:"failure",errorMessage:f.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:m,domSnapshot:p||void 0,variables:P,timestamp:D})}throw this.context.stepTracking&&(await this.updateStepResult(o,void 0,void 0),this.context.stepTracking.currentStepId=void 0),f}this.context.isSelfHealing=!0,a.info(`Action failed at step ${o}. ${i}`),a.info(`with error: ${f.message}`);let v;if(this.context.autoDisableModal){a.info("Attempting modal dismissal before self-healing...");let m=await this.dismissModalIfPresent(t,i);if(a.info(`Modal dismissal result: ${m.details}`),m.modalDismissed){v=`[Auto-dismissed modal: ${m.details}]`,a.info(`Modal dismissed, retrying original action for step ${o}`);try{let p=await e();return this.context.isSelfHealing=!1,this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=v+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(o,"success",v),this.context.stepTracking.currentStepId=void 0),p}catch(p){a.info(`Retry after modal dismissal failed: ${p.message}, falling back to self-healing`)}}}let b,A;if(c!==void 0){if(c<=0)throw f;c===1?(b="single",A=1):(b="multi",A=c)}else b=this.context.selfHealingStrategy??"single",A=At;a.info(`Calling execute() to self-heal (strategy: ${b}${b==="multi"?`, maxSteps: ${A}`:""})`);try{let m=await this.execute(t,i,o,!1,{strategy:b,maxSteps:b==="multi"?A:void 0});if(this.context.isSelfHealing=!1,!m.success)throw new Error(`Self-healing failed: ${m.details}`);let p=m.actions?.at(-1);n&&p&&(this._newActionEntities.set(n,p),a.info(`Stored new action entity for stmtUid: ${n} (last of ${m.actions?.length} actions)`));let P=t.url(),E=await this.captureDOMSnapshot(t),D=this.context.stepTracking?.captureVariables?F(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking){let C=v||"";await this.updateStepResult(o,"success",C)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let C=Date.now()-s,st=this.context.stepTracking.results[o]?.screenshot,ct=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:h,domSnapshot:d||void 0,variables:g,screenshotPath:w,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:o,description:i,action:{actionEntity:p,playwrightCode:m.actions?.map(lt=>lt.locator||""),llmPrompt:m.debugInfo?.userPrompt,llmResponse:m.debugInfo?.rawLlmResponse,llmReasoning:m.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(o),durationMs:C,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:P,domSnapshot:E||void 0,variables:D,screenshotPath:st,timestamp:ct})}return this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}catch(m){if(this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let p=t.url(),P=await this.captureDOMSnapshot(t),E=this.context.stepTracking.captureVariables?F(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},D=Date.now()-s,C=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:h,domSnapshot:d||void 0,variables:g,screenshotPath:w,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:o,description:i,action:{playwrightCode:[e.toString()]},consoleLogs:this.getConsoleLogsForStep(o),durationMs:D,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:p,domSnapshot:P||void 0,variables:E,timestamp:C})}throw this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}}}async extract(t,e,i,o){o&&this.context.stepTracking&&await this.createStepResult(t,o,`Extract ${e} into ${i}`);try{let n=`Extract ${e} and save to ${i}`,r=await this.execute(t,n,o);if(!r.success)throw new Error(`AI extraction failed: ${r.details}`);o&&this.context.stepTracking&&await this.updateStepResult(o,"success",`Extracted ${e} to ${i}`)}catch(n){throw o&&this.context.stepTracking&&await this.updateStepResult(o,"failure",n.message),n}}async getDOMText(t){let e=new $(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames();return(await e.getClickableElements(t,{interactiveClassNames:i})).elementTree.clickableElementsToString()}async captureDOMSnapshot(t){if(!this.context.stepTracking?.captureStateTransitions||!this.context.stepTracking?.captureDom)return null;try{let e=new $(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),o=await e.getClickableElements(t,{interactiveClassNames:i,highlightElements:!1,viewportExpansion:0});return{elementTreeText:o.elementTree.clickableElementsToString(),elementCount:o.selectorMap.size,timestamp:Date.now()}}catch(e){return a.warn("Failed to capture DOM snapshot:",e),null}}getConsoleLogsForStep(t){return this.context.stepTracking?.consoleLogs?this.context.stepTracking.consoleLogs.filter(e=>e.stepId===t).map(e=>({type:e.type,message:e.message,timestamp:e.timestamp})):[]}async waitUntilStable(t,e=3e3,i=1e3){return ot(t,e,i)}async waitUntilCondition(t,e,i=60,o){return nt(t,e,(n,r,c)=>this.evaluate(n,r,c),i,o)}async uploadFile(t,e,i={},o){return re(t,e,i,this.context,(n,r,c)=>this.execute(n,r,c),o)}async loginPage(t,e,i){let{LoginType:o}=await import("./agentLogin-ARB3NEO4.js");if(a.info("Start login"),u.section("Login Flow"),u.log(`Site URL: ${e.site_url}`),u.log(`Account type: ${e.account.type}`),u.log(`Has cached actions: ${!!i?.cached_actions?.length}`),u.log(`Has validation exprs: ${!!i?.validation_exprs?.length}`),e.skip_verification)return a.info("Skipping login verification (skip_verification=true)"),{success:!0,page:t};if((e.account.type===o.PASSWORD||e.account.type===o.OAUTH2)&&(this.context.variableStore.set("username",e.account.username,!0),this.context.variableStore.set("password",e.account.password,!0)),e.account.two_factor_auth_config?.type==="totp"&&this.context.variableStore.set("otp_secret_key",e.account.two_factor_auth_config.data,!0),a.info(`Navigating to: ${e.site_url}`),await t.goto(e.site_url),await this.waitUntilStable(t,1e4,3e3),i?.validation_exprs&&i.validation_exprs.length>0){if(u.log("Level 1: Checking if already logged in via storage state..."),u.log(`Validation expressions: ${JSON.stringify(i.validation_exprs)}`),await j(t,i.validation_exprs)){u.log("Level 1 SUCCESS: Already logged in via storage state"),a.info("Login: Already logged in via storage state");let c=await t.context().storageState();return{success:!0,page:t,storage_state:c,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs,alreadyLoggedIn:!0}}u.log("Level 1 FAILED: Storage state validation failed, trying Level 2")}if(i?.cached_actions&&i.cached_actions.length>0&&i?.validation_exprs&&i.validation_exprs.length>0){u.log(`Level 2: Attempting cached login with ${i.cached_actions.length} actions`);try{if((await this.executeCachedLogin(t,i.cached_actions,i.validation_exprs)).success){u.log("Level 2 SUCCESS: Cached login succeeded"),a.info("Login: Cached login succeeded");let c=await t.context().storageState();return{success:!0,page:t,storage_state:c,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs}}u.log("Level 2 FAILED: Cached login failed, trying Level 3")}catch(r){u.log(`Level 2 ERROR: ${r.message}, trying Level 3`)}}else i?.cached_actions&&i.cached_actions.length>0&&u.log("Level 2 SKIPPED: Cached actions exist but no validation expressions, going to Level 3");let n=`First check if the page is already signed in. If it is, do nothing.
|
|
26
|
+
If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,{strategy:"multi",maxSteps:Mt}),o=!!(i.actions&&i.actions.length>0);return{success:i.success,modalDismissed:o,details:i.details||(o?"Modal dismissed":"No modal found")}}catch(i){return{success:!1,modalDismissed:!1,details:i.message||"Modal dismissal failed"}}}_getContext(){return this.context}setupDownloadTracking(t){n.info(`[Download Tracking] Setting up download tracking for page: ${t.url()}`),t.on("download",async e=>{let i=e.suggestedFilename();n.info(`[Download Tracking] Download event detected! File: ${i}`),this.context.downloadStatus={filename:i,status:"inProgress",startTime:Date.now()},n.info(`[Download Tracking] Download status set to inProgress: ${JSON.stringify(this.context.downloadStatus)}`);try{let o=this.context.downloadDir||S.join(process.cwd(),"downloads");f.existsSync(o)||f.mkdirSync(o,{recursive:!0});let a=S.join(o,i);n.info(`[Download Tracking] Downloading file to: ${a}`),await e.saveAs(a),this.context.downloadStatus={filename:i,status:"completed",startTime:this.context.downloadStatus.startTime,filePath:a,timestamp:Date.now()},n.info(`[Download Tracking] Download completed: ${a}`),n.info(`[Download Tracking] Download status set to completed: ${JSON.stringify(this.context.downloadStatus)}`)}catch(o){this.context.downloadStatus={filename:i,status:"failed",startTime:this.context.downloadStatus.startTime,error:o.message,timestamp:Date.now()},n.error(`[Download Tracking] Download failed for ${i}: ${o.message}`)}})}collectTokenUsages(t){let e;Array.isArray(t)?e=t:t?.tokenUsages&&(e=t.tokenUsages),e&&e.length>0?(this.context.tokenUsages||(this.context.tokenUsages=[]),this.context.tokenUsages.push(...e),n.debug(`[collectTokenUsages] Added ${e.length} token usage(s), total: ${this.context.tokenUsages.length}`)):n.debug("[collectTokenUsages] No token usages to collect (undefined or empty)")}trackAIAction(t,e,i,o=1,a,r){if(!t)return;let c=i?.tokenUsages||[];this.context.aiActionDetails||(this.context.aiActionDetails=[]);let s=this.context.aiActionDetails.find(h=>h.stepId===t&&h.actionType===e);s?(s.count+=o,c.length>0&&s.tokenUsages.push(...c),i?.userPrompt&&(s.userPrompt=i.userPrompt),i?.rawLlmResponse&&(s.rawLlmResponse=i.rawLlmResponse),i?.reasoningContent&&(s.reasoningContent=i.reasoningContent),i?.elementTree&&(s.elementTree=i.elementTree),i?.screenshotWithSom&&(s.screenshotWithSom=i.screenshotWithSom),r&&(s.explanation=r)):this.context.aiActionDetails.push({stepId:t,actionType:e,count:o,tokenUsages:[...c],statement:a,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:r,elementTree:i?.elementTree,screenshotWithSom:i?.screenshotWithSom}),n.debug(`[trackAIAction] Tracked ${e} for step ${t}, count: ${o}`)}async assert(t,e,i){n.info(`Asserting statement: ${e}`),i&&this.context.stepTracking&&await this.createStepResult(t,i,e),await this.agentServices.waitUntilStable(t);try{let o=this.getCompletedExecutionHistory(),a=await N(e,t,this.agentServices,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(a.debugInfo),this.context.lastActionDebugInfo=a.debugInfo;let r=a.explanation||a.error||"No explanation";if(i&&this.trackAIAction(i,"assert",a.debugInfo,1,e,r),this.context.agentNote=r,i&&this.context.stepTracking&&await this.updateStepResult(i,a.success?"success":"failure",r,void 0,a.debugInfo),!a.success)throw this.addToExecutionHistory(`Assert: "${e}"`,`Failed: ${r}`),new Error(`Assertion failed: ${r}`);return this.addToExecutionHistory(`Assert: "${e}"`,`Passed: ${r}`),!0}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),o}}async evaluate(t,e,i){i&&this.context.stepTracking&&await this.createStepResult(t,i,e),await this.agentServices.waitUntilStable(t);try{let o=this.getCompletedExecutionHistory(),a=await N(e,t,this.agentServices,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(a.debugInfo),this.context.lastActionDebugInfo=a.debugInfo;let r=a.explanation||a.error||"No explanation";return i&&this.trackAIAction(i,"evaluate",a.debugInfo,1,e,r),this.context.agentNote=r,i&&this.context.stepTracking&&await this.updateStepResult(i,"success",r,void 0,a.debugInfo),a.success?(this.addToExecutionHistory(`Evaluate: "${e}"`,`Result: true - ${r}`),!0):(n.warn(`AI evaluation returned false/unknown: ${r}`),this.addToExecutionHistory(`Evaluate: "${e}"`,`Unknown/False: ${r}`),!1)}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),o}}async performAction(t,e){n.info(`Act: ${e}`);let i=this.getCompletedExecutionHistory(),o=await H(e,t,this.agentServices,{executionHistory:i,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});if(this.collectTokenUsages(o.debugInfo),o.status!=="success"||o.actionEntities.length===0)return{success:!1,details:o.explanation||o.error||"Action failed"};let a=o.actionEntities[0]?.action_description||e;return this.addToExecutionHistory(e,a),{success:!0,details:o.explanation}}async execute(t,e,i,o,a){let r=a?.strategy||"single";n.info(`Executing statement: ${e} (strategy: ${r})`),i&&this.context.stepTracking&&await this.createStepResult(t,i,e);try{let c=this.getCompletedExecutionHistory();this.context.agentNote="";let s,h;if(r==="multi"){let g=i&&this.context.stepTracking?.artifactsDir?w=>{if(w.type==="action"&&w.debugInfo){let m=`${i}-step${w.step}`;this.saveDebugInfoToFiles(m,w.debugInfo,this.context.model)}}:void 0;if(s=await K(e,t,this.agentServices,g,{executionHistory:c,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:a?.maxSteps??_t}),h=s.completed,this.collectTokenUsages(s.tokenUsages),i&&s.tokenUsages){let w={tokenUsages:s.tokenUsages};this.trackAIAction(i,"execute",w,s.actionEntities?.length||1,e,s.explanation||"Multi-step execution completed")}}else if(s=await H(e,t,this.agentServices,{executionHistory:c,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:o}),h=!0,this.collectTokenUsages(s.debugInfo),this.context.lastActionDebugInfo=s.debugInfo,i){let g=s.explanation||s.error||"No explanation";this.trackAIAction(i,"execute",s.debugInfo,1,e,g)}if(s.status!=="success"||s.actionEntities.length===0||!h){let g=s.explanation||s.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",g,void 0,s.debugInfo),new Error(`Action failed: ${g}`)}let p=this.context.agentNote||s.explanation||"Action executed successfully";return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",p,void 0,s.debugInfo),this.addToExecutionHistory(`Execute: "${e}"`,p),{success:!0,details:p,actions:s.actionEntities,debugInfo:s.debugInfo}}catch(c){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",c.message),this.addToExecutionHistory(`Execute: "${e}"`,`Failed: ${c.message}`),c}}async generate(t,e,i,o){i&&this.context.stepTracking&&await this.createStepResult(t,i,e);try{let a=this.getCompletedExecutionHistory(),r=await z(e,t,this.agentServices,{executionHistory:a,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:o});if(this.collectTokenUsages(r.debugInfo),r.status!=="success"||r.actionEntities.length===0){let h=r.explanation||r.error||"No explanation";throw i&&this.trackAIAction(i,"generate",r.debugInfo,1,e,h),i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",h,void 0,r.debugInfo),new Error(h)}let c=r.completed,s=r.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",r.debugInfo,1,e,s),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",s,void 0,r.debugInfo),n.info(`[generate] Generated action for "${e}": ${s}, goalAccomplished: ${r.completed}`),{success:c,details:s,actions:r.actionEntities,debugInfo:r.debugInfo}}catch(a){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",a.message),a}}async run(t,e,i,o){i&&this.context.stepTracking&&await this.createStepResult(t,i,e);try{let a=this.getCompletedExecutionHistory(),r=i&&this.context.stepTracking?.artifactsDir,c=o?.onAction||r?g=>{if(g.type==="action"&&g.action_entity&&(o?.onAction?.(g.action_entity),r&&g.debugInfo)){let w=`${i}-step${g.step}`;this.saveDebugInfoToFiles(w,g.debugInfo,this.context.model)}}:void 0,s=await K(e,t,this.agentServices,c,{executionHistory:a,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:o?.abortSignal,maxSteps:o?.maxSteps});u.log(`Run task result: status=${s.status}, completed=${s.completed}, actions=${s.actionEntities?.length||0}`),this.collectTokenUsages(s.tokenUsages);let h=s.status==="success"&&s.completed,p=s.explanation||s.error||(h?"Step completed":"Step failed");if(i&&s.tokenUsages){let g={tokenUsages:s.tokenUsages};this.trackAIAction(i,"run",g,s.actionEntities?.length||1,e,p)}if(i&&this.context.stepTracking&&await this.updateStepResult(i,h?"success":"failure",p,void 0,void 0),this.addToExecutionHistory(`Run: "${e}"`,p),s.status==="error")throw new Error(p);return u.log(`Run result: success=${h}, details=${p}`),{success:h,details:p,actions:s.actionEntities}}catch(a){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",a.message),this.addToExecutionHistory(`Run: "${e}"`,`Failed: ${a.message}`),a}}async step(t,e,i,o,a,r=!0,c){let s=Date.now();this.context.stepTracking&&await this.createStepResult(t,o,i),await this.agentServices.waitUntilStable(t),this.context.stepTracking&&(this.context.stepTracking.currentStepId=o);let h=t.url(),p=await this.captureDOMSnapshot(t),g=this.context.stepTracking?.captureVariables?L(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},w=this.context.stepTracking?.results[o]?.screenshot;try{n.info(`Executing step ${o}: ${i}`),this.addToExecutionHistory(i,""),this.context.agentNote="";let m=await e(),y=t.url(),x=await this.captureDOMSnapshot(t),T=this.context.stepTracking?.captureVariables?L(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking&&await this.updateStepResult(o,"success",""),this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let d=Date.now()-s,v=this.context.stepTracking.results[o]?.screenshot,P=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:h,domSnapshot:p||void 0,variables:g,screenshotPath:w,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:o,description:i,action:{playwrightCode:[e.toString()]},consoleLogs:this.getConsoleLogsForStep(o),durationMs:d,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:y,domSnapshot:x||void 0,variables:T,screenshotPath:v,timestamp:P})}let k=this.context.agentNote;return(!k||k.trim()==="")&&(k="Execution successful"),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=k),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}catch(m){let y=r&&!this.context.isSelfHealing&&this.context.selfHealingStrategy!=="none";if(y&&(this.context.stepTracking&&await this.updateStepResult(o,"failure",m.message),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=m.message)),!i||i.trim()==="")throw n.error("No description provided for self-healing"),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m;if(!y){if(n.info(`Failed to heal at step ${o}. ${i}`),this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let d=t.url(),v=await this.captureDOMSnapshot(t),P=this.context.stepTracking.captureVariables?L(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},E=Date.now()-s,D=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:h,domSnapshot:p||void 0,variables:g,screenshotPath:w,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:o,description:i,action:{playwrightCode:[e.toString()]},consoleLogs:this.getConsoleLogsForStep(o),durationMs:E,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:d,domSnapshot:v||void 0,variables:P,timestamp:D})}throw this.context.stepTracking&&(await this.updateStepResult(o,void 0,void 0),this.context.stepTracking.currentStepId=void 0),m}this.context.isSelfHealing=!0,n.info(`Action failed at step ${o}. ${i}`),n.info(`with error: ${m.message}`);let x;if(this.context.autoDisableModal){n.info("Attempting modal dismissal before self-healing...");let d=await this.dismissModalIfPresent(t,i);if(n.info(`Modal dismissal result: ${d.details}`),d.modalDismissed){x=`[Auto-dismissed modal: ${d.details}]`,n.info(`Modal dismissed, retrying original action for step ${o}`);try{let v=await e();return this.context.isSelfHealing=!1,this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=x+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(o,"success",x),this.context.stepTracking.currentStepId=void 0),v}catch(v){n.info(`Retry after modal dismissal failed: ${v.message}, falling back to self-healing`)}}}let T,k;if(c!==void 0){if(c<=0)throw m;c===1?(T="single",k=1):(T="multi",k=c)}else T=this.context.selfHealingStrategy??"single",k=Pt;n.info(`Calling execute() to self-heal (strategy: ${T}${T==="multi"?`, maxSteps: ${k}`:""})`);try{let d=await this.execute(t,i,o,!1,{strategy:T,maxSteps:T==="multi"?k:void 0});if(this.context.isSelfHealing=!1,!d.success)throw new Error(`Self-healing failed: ${d.details}`);let v=d.actions?.at(-1);a&&v&&(this._newActionEntities.set(a,v),n.info(`Stored new action entity for stmtUid: ${a} (last of ${d.actions?.length} actions)`));let P=t.url(),E=await this.captureDOMSnapshot(t),D=this.context.stepTracking?.captureVariables?L(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking){let I=x||"";await this.updateStepResult(o,"success",I)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let I=Date.now()-s,ct=this.context.stepTracking.results[o]?.screenshot,lt=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:h,domSnapshot:p||void 0,variables:g,screenshotPath:w,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:o,description:i,action:{actionEntity:v,playwrightCode:d.actions?.map(ut=>ut.locator||""),llmPrompt:d.debugInfo?.userPrompt,llmResponse:d.debugInfo?.rawLlmResponse,llmReasoning:d.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(o),durationMs:I,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:P,domSnapshot:E||void 0,variables:D,screenshotPath:ct,timestamp:lt})}return this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),d}catch(d){if(this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let v=t.url(),P=await this.captureDOMSnapshot(t),E=this.context.stepTracking.captureVariables?L(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},D=Date.now()-s,I=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:h,domSnapshot:p||void 0,variables:g,screenshotPath:w,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:o,description:i,action:{playwrightCode:[e.toString()]},consoleLogs:this.getConsoleLogsForStep(o),durationMs:D,status:"failure",errorMessage:d.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:v,domSnapshot:P||void 0,variables:E,timestamp:I})}throw this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),d}}}async extract(t,e,i,o){o&&this.context.stepTracking&&await this.createStepResult(t,o,`Extract ${e} into ${i}`);try{let a=`Extract ${e} and save to ${i}`,r=await this.execute(t,a,o);if(!r.success)throw new Error(`AI extraction failed: ${r.details}`);o&&this.context.stepTracking&&await this.updateStepResult(o,"success",`Extracted ${e} to ${i}`)}catch(a){throw o&&this.context.stepTracking&&await this.updateStepResult(o,"failure",a.message),a}}async getDOMText(t){let e=new F(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames();return(await e.getClickableElements(t,{interactiveClassNames:i})).elementTree.clickableElementsToString()}async captureDOMSnapshot(t){if(!this.context.stepTracking?.captureStateTransitions||!this.context.stepTracking?.captureDom)return null;try{let e=new F(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),o=await e.getClickableElements(t,{interactiveClassNames:i,highlightElements:!1,viewportExpansion:0});return{elementTreeText:o.elementTree.clickableElementsToString(),elementCount:o.selectorMap.size,timestamp:Date.now()}}catch(e){return n.warn("Failed to capture DOM snapshot:",e),null}}getConsoleLogsForStep(t){return this.context.stepTracking?.consoleLogs?this.context.stepTracking.consoleLogs.filter(e=>e.stepId===t).map(e=>({type:e.type,message:e.message,timestamp:e.timestamp})):[]}async waitUntilStable(t,e=3e3,i=1e3){return ot(t,e,i)}async waitUntilCondition(t,e,i=60,o){return at(t,e,(a,r,c)=>this.evaluate(a,r,c),i,o)}async uploadFile(t,e,i={},o){return re(t,e,i,this.context,(a,r,c)=>this.execute(a,r,c),o)}async loginPage(t,e,i){let{LoginType:o}=await import("./agentLogin-QZDVIJMB.js");if(n.info("Start login"),u.section("Login Flow"),u.log(`Site URL: ${e.site_url}`),u.log(`Account type: ${e.account.type}`),u.log(`Has cached actions: ${!!i?.cached_actions?.length}`),u.log(`Has validation exprs: ${!!i?.validation_exprs?.length}`),e.skip_verification)return n.info("Skipping login verification (skip_verification=true)"),{success:!0,page:t};if((e.account.type===o.PASSWORD||e.account.type===o.OAUTH2)&&(this.context.variableStore.set("username",e.account.username,!0),this.context.variableStore.set("password",e.account.password,!0)),e.account.two_factor_auth_config?.type==="totp"&&this.context.variableStore.set("otp_secret_key",e.account.two_factor_auth_config.data,!0),n.info(`Navigating to: ${e.site_url}`),await t.goto(e.site_url),await this.waitUntilStable(t,1e4,3e3),i?.validation_exprs&&i.validation_exprs.length>0){if(u.log("Level 1: Checking if already logged in via storage state..."),u.log(`Validation expressions: ${JSON.stringify(i.validation_exprs)}`),await j(t,i.validation_exprs)){u.log("Level 1 SUCCESS: Already logged in via storage state"),n.info("Login: Already logged in via storage state");let r=await t.context().storageState();return{success:!0,page:t,storage_state:r,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs,alreadyLoggedIn:!0}}u.log("Level 1 FAILED: Storage state validation failed, trying Level 2")}if(i?.cached_actions&&i.cached_actions.length>0&&i?.validation_exprs&&i.validation_exprs.length>0){u.log(`Level 2: Attempting cached login with ${i.cached_actions.length} actions`);try{if((await this.executeCachedLogin(t,i.cached_actions,i.validation_exprs)).success){u.log("Level 2 SUCCESS: Cached login succeeded"),n.info("Login: Cached login succeeded");let r=await t.context().storageState();return{success:!0,page:t,storage_state:r,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs}}u.log("Level 2 FAILED: Cached login failed, trying Level 3")}catch(r){u.log(`Level 2 ERROR: ${r.message}, trying Level 3`)}}else i?.cached_actions&&i.cached_actions.length>0&&u.log("Level 2 SKIPPED: Cached actions exist but no validation expressions, going to Level 3");let a=`First check if the page is already signed in. If it is, do nothing.
|
|
25
27
|
Use your best judgement to determine if the page is signed in.
|
|
26
|
-
`;if(e.verification_hint&&(
|
|
28
|
+
`;if(e.verification_hint&&(a+=`
|
|
27
29
|
Signed in verification hint: ${e.verification_hint}
|
|
28
|
-
`),e.account.type===o.PASSWORD)
|
|
30
|
+
`),e.account.type===o.PASSWORD)a+=`
|
|
29
31
|
If the page is not signed in, sign in using provided credentials ($username, $password, etc).
|
|
30
|
-
`;else{let r=e.account;
|
|
32
|
+
`;else{let r=e.account;a+=`
|
|
31
33
|
If the page is not signed in, sign in with the OAuth provider "${r.provider_name}" using provided credentials
|
|
32
34
|
($username, $password), and use $otp_secret_key to generate $otp_code for two-factor authentication. If you can't login with the provided credentials, just stop and report the failure.
|
|
33
|
-
`}e.additional_prompt&&(
|
|
35
|
+
`}e.additional_prompt&&(a+=`
|
|
34
36
|
Additional instructions: ${e.additional_prompt}
|
|
35
37
|
`);try{u.log("Level 3: Attempting agent-based login"),u.log(`Login prompt:
|
|
36
|
-
${
|
|
38
|
+
${a}`);let r=this.agentServices.knowledgeRetriever,c=!1;this.agentServices.hasKnowledgeRetriever()&&r&&(u.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(m,y,x,T)=>await r(m,y,x,"login")),c=!0,u.log("Login knowledge retriever configured"));let s;try{if(s=await this.run(t,a,"login"),!s.success)return u.log("Level 3 FAILED: Agent login failed"),n.info("Login: Failed"),{success:!1,page:t}}finally{c&&r&&(this.agentServices.setKnowledgeRetriever(r),u.log("Restored original knowledge retriever"))}let h=await t.context().storageState(),p;if(e.num_verification_exprs!==0)try{u.log("Generating validation locators for future login verification...");let m=await Ce(t,e.site_url,{verification_hint:e.verification_hint,num_verification_exprs:e.num_verification_exprs},async(y,x)=>this.run(y,x),async y=>this.getDOMText(y));m?(p=m,u.log(`Generated ${p.length} validation locator(s): ${JSON.stringify(p)}`)):u.log("Failed to generate validation locators, login will still succeed")}catch(m){u.log(`Error generating validation locators: ${m.message}`)}else u.log("Skipping validation locator generation (num_verification_exprs=0)");u.log("Level 3 SUCCESS: Agent login succeeded"),n.info("Login: Agent login succeeded");let g=s.actions||[],w=g.length>0?g:i?.cached_actions;return{success:!0,page:t,storage_state:h,cached_actions:w,validation_exprs:p}}catch(r){return u.error(`Agent login failed: ${r.message}`),n.info("Login: Failed"),{success:!1,page:t}}}async executeCachedLogin(t,e,i){let o=(await import("./handler-O7GYRDNA.js")).default,a=new o;for(let r=0;r<e.length;r++){let c=e[r];u.log(`Executing cached action ${r+1}/${e.length}: ${c.action_description||c.action_data?.action_name}`);try{if(!c.action_data){u.log(`Action ${r+1} missing action_data, skipping`);continue}await a.execute(t,c,this.agentServices),await this.waitUntilStable(t,5e3)}catch(s){return u.error(`Cached action ${r+1} failed: ${s.message}`),{success:!1}}}return i&&i.length>0&&!await j(t,i)?{success:!1}:{success:!0}}getCompletedExecutionHistory(){if(!this.context.executionHistory||this.context.executionHistory.length===0)return[];let t=this.context.executionHistory[this.context.executionHistory.length-1];return!t[1]||t[1].trim()===""?this.context.executionHistory.slice(0,-1):this.context.executionHistory}addToExecutionHistory(t,e){this.context.executionHistory||(this.context.executionHistory=[]),this.context.executionHistory.push([t,e])}async createStepResult(t,e,i){if(!this.context.stepTracking||this.context.stepTracking.results[e])return;this.context.stepTracking.currentStepId=e,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(e),t=await this.agentServices.validatePage(t),await this.waitUntilStable(t);let o={description:i,startTime:Date.now(),artifacts:[]};if(this.context.stepTracking.artifactsDir){let a=S.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));f.mkdirSync(a,{recursive:!0});let r=S.join(a,"screenshot.png");await t.screenshot({type:"png",path:r}),o.screenshot=r}this.context.stepTracking.results[e]=o}saveDebugInfoToFiles(t,e,i){let o={};if(!this.context.stepTracking?.artifactsDir)return n.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),o;let a=S.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));try{if(f.mkdirSync(a,{recursive:!0}),e.systemPrompt){let r=S.join(a,"system_prompt.txt");f.writeFileSync(r,e.systemPrompt),o.system_prompt_path=r,n.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${r}`)}if(e.userPrompt)if(typeof e.userPrompt=="string"){let r=S.join(a,"user_prompt.txt");f.writeFileSync(r,e.userPrompt),o.user_prompt_path=r,n.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${r}`)}else{let r=e.userPrompt.map(h=>Array.isArray(h.content)?{...h,content:h.content.map(p=>p.type==="image"&&p.file?.startsWith("data:")?{...p,file:"[base64 image data stripped]"}:p)}:h),c=S.join(a,"messages.json"),s={system:e.systemPrompt,messages:r};f.writeFileSync(c,JSON.stringify(s,null,2)),o.messages_path=c,n.debug(`[saveDebugInfoToFiles] Saved messages to: ${c}`)}if(e.rawLlmResponse){let r=i?i.replace(/[\/\\:]/g,"-"):"llm",c=S.join(a,`${r}_response.txt`);f.writeFileSync(c,e.rawLlmResponse),o.response_path=c,n.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${c}`)}if(e.screenshotWithSom){let r=S.join(a,"screenshot.png");f.writeFileSync(r,Buffer.from(e.screenshotWithSom,"base64")),o.screenshot_path=r,n.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${r}`)}if(e.reasoningContent){let r=S.join(a,"reasoning.txt");f.writeFileSync(r,e.reasoningContent),o.reasoning_path=r,n.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${r}`)}n.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(o).length} artifacts for step ${t}`)}catch(r){n.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${t}:`,r)}return o}async updateStepResult(t,e,i,o,a){if(!this.context.stepTracking)return;let r=this.context.stepTracking.results[t];if(r){if(e&&(r.status=e,this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(r.message=i),o&&r.artifacts.push(o),a){let c=a.tokenUsages?.[0]?.model,s=this.saveDebugInfoToFiles(t,a,c);Object.keys(s).length>0&&r.artifacts.push(s)}r.duration=Date.now()-r.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(t,r)}}async writeExecutionResults(t,e){try{if(await f.promises.mkdir(t,{recursive:!0}),this.context.stepTracking?.results&&Object.keys(this.context.stepTracking.results).length>0){let i=S.join(t,"test-results.json");await f.promises.writeFile(i,JSON.stringify(this.context.stepTracking.results,null,2)),n.debug(`Test results written to: ${i}`)}if(e?.tokenUsages&&this.context.tokenUsages&&this.context.tokenUsages.length>0){let i=S.join(t,"token-usages.json");await f.promises.writeFile(i,JSON.stringify(this.context.tokenUsages,null,2)),n.debug(`Token usages written to: ${i}`)}if(this.context.aiActionDetails&&this.context.aiActionDetails.length>0){let i=S.join(t,"ai-actions.json");await f.promises.writeFile(i,JSON.stringify(this.context.aiActionDetails,null,2)),n.debug(`AI action details written to: ${i}`)}}catch(i){throw n.error("Failed to write execution results:",i),i}}};var st=(t=>(t.Started="started",t.Action="action",t.Completion="completion",t.Error="error",t.Aborted="aborted",t.Keepalive="keepalive",t))(st||{});function Et(){let t=new Date,e=new Intl.DateTimeFormat("en-US",{timeZone:"America/Los_Angeles",year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1}).formatToParts(t),i=e.find(d=>d.type==="year").value,o=e.find(d=>d.type==="month").value,a=e.find(d=>d.type==="day").value,r=e.find(d=>d.type==="hour").value,c=e.find(d=>d.type==="minute").value,s=e.find(d=>d.type==="second").value,h=String(t.getMilliseconds()).padStart(3,"0"),p=`${i}-${o}-${a}T${r}:${c}:${s}.${h}`,g=t.toISOString().slice(0,-1),w=Date.parse(p+"Z"),m=Date.parse(g+"Z"),y=Math.round((m-w)/(1e3*60)),x=String(Math.floor(Math.abs(y)/60)).padStart(2,"0"),T=String(Math.abs(y)%60).padStart(2,"0"),k=y<=0?"+":"-";return`${i}-${o}-${a}T${r}:${c}:${s}.${h}${k}${x}:${T}`}function Z(t){let e=t.variableStore;return e.has("currentTime")||e.set("currentTime",Et()),{model:t.model,variableStore:e,organizationId:t.organizationId,organizationSettings:t.organizationSettings,executionHistory:t.executionHistory||[],testDataDir:t.testDataDir,downloadDir:t.downloadDir,useNativeGenerator:t.useNativeGenerator,selfHealingStrategy:t.selfHealingStrategy,autoDisableModal:t.autoDisableModal,tokenUsages:[],aiActionDetails:[]}}var U=class{constructor(e){this.customActions=new Map;process.env.PWDEBUG!=="console"&&console.warn(`\u26A0\uFE0F Warning: PWDEBUG=console is recommended for @shiplightai/sdk.
|
|
37
39
|
Set it before running your script:
|
|
38
40
|
|
|
39
41
|
export PWDEBUG=console
|
|
@@ -41,4 +43,5 @@ ${n}`);let r=this.agentServices.knowledgeRetriever,c=!1;this.agentServices.hasKn
|
|
|
41
43
|
Or prefix your command:
|
|
42
44
|
|
|
43
45
|
PWDEBUG=console pnpm exec tsx your-script.ts
|
|
44
|
-
`),this.variableStore=new
|
|
46
|
+
`),this.variableStore=new R;let i=new Set(e.sensitiveKeys||[]);if(e.variables)for(let[a,r]of Object.entries(e.variables))this.variableStore.set(a,r,i.has(a));let o=Z({model:e.model,variableStore:this.variableStore,testDataDir:e.testDataDir,downloadDir:e.downloadDir,selfHealingStrategy:e.selfHealingStrategy??"single"});this.webAgent=new q(o)}registerAction(e){if(!e.name)throw new Error("CustomAction requires a name");if(!e.description)throw new Error("CustomAction requires a description");if(!e.schema)throw new Error("CustomAction requires a schema");if(!e.execute)throw new Error("CustomAction requires an execute function");if(this.customActions.has(e.name))throw new Error(`CustomAction '${e.name}' is already registered`);this.customActions.set(e.name,e);let i=this.variableStore;b.register({name:e.name,description:e.description,schema:e.schema,usesElementIndex:!1,availability:{openai:!0,mcp:!0},execute:async(o,a)=>{let r={page:a.page,variableStore:i};try{let c=await e.execute(o,r);return{success:c.success,message:c.message,actionEntity:{action_description:c.message||`Executed ${e.name}`,action_data:{action_name:e.name,kwargs:o}}}}catch(c){return{success:!1,error:c.message,actionEntity:{action_description:`Failed to execute ${e.name}`,action_data:{action_name:e.name,kwargs:o},feedback:c.message}}}}})}async act(e,i){return this.webAgent.performAction(e,i)}async run(e,i,o){return this.webAgent.run(e,i,void 0,{maxSteps:o?.maxSteps})}async assert(e,i){return this.webAgent.assert(e,i)}async evaluate(e,i){return this.webAgent.evaluate(e,i)}async extract(e,i,o){return this.webAgent.extract(e,i,o)}async login(e,i){let o={site_url:i.url,num_verification_exprs:0,account:{type:X.PASSWORD,username:i.username,password:i.password,...i.totpSecret&&{two_factor_auth_config:{type:B.TOTP,data:i.totpSecret}}}};return(await this.webAgent.loginPage(e,o)).success}getVariable(e){return this.variableStore.get(e)}setVariable(e,i,o=!1){this.variableStore.set(e,i,o)}async waitUntil(e,i,o=60){let a=`waitUntil_${Date.now()}`;return this.webAgent.waitUntilCondition(e,i,o,a)}async step(e,i,o,a){let r=`step_${Date.now()}`;try{let c=await this.webAgent.step(e,i,o,r,void 0,!0,a?.maxSteps);return c&&typeof c=="object"&&"success"in c?c:{success:!0}}catch(c){return{success:!1,details:c.message}}}};function Dt(t){return new U(t)}import{z as js}from"zod";export{U as Agent,ie as LogLevel,R as VariableStore,Q as configureSdk,Dt as createAgent,ee as getSdkConfig,js as z};
|
|
47
|
+
//# sourceMappingURL=index.js.map
|