shiplightai 0.1.40 → 0.1.41
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/debugger-pw.cjs +74 -76
- package/dist/cjs/fixture.cjs +73 -75
- package/dist/cjs/index.cjs +90 -92
- package/dist/cjs/reporter.cjs +4 -4
- package/dist/cli.js +12 -12
- package/dist/debugger-pw.js +74 -76
- package/dist/fixture.js +73 -75
- package/dist/index.js +90 -92
- package/dist/reporter.js +7 -7
- package/package.json +23 -21
package/dist/cjs/fixture.cjs
CHANGED
|
@@ -1,7 +1,22 @@
|
|
|
1
|
-
"use strict";var
|
|
2
|
-
`);o=s.pop()||"";for(let l of s){let d=null;if(l.startsWith("data: "))try{let c=l.slice(6);c.trim()&&(d=JSON.parse(c))}catch(c){console.error(`Failed to parse SSE event: ${l}`,c);continue}d&&t(d)}}}finally{i.releaseLock()}}var
|
|
1
|
+
"use strict";var wu=Object.create;var Fi=Object.defineProperty;var bu=Object.getOwnPropertyDescriptor;var yu=Object.getOwnPropertyNames;var xu=Object.getPrototypeOf,vu=Object.prototype.hasOwnProperty;var w=(e,t)=>()=>(e&&(t=e(e=0)),t);var Ue=(e,t)=>{for(var i in t)Fi(e,i,{get:t[i],enumerable:!0})},vr=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of yu(t))!vu.call(e,o)&&o!==i&&Fi(e,o,{get:()=>t[o],enumerable:!(n=bu(t,o))||n.enumerable});return e};var W=(e,t,i)=>(i=e!=null?wu(xu(e)):{},vr(t||!e||!e.__esModule?Fi(i,"default",{value:e,enumerable:!0}):i,e)),ku=e=>vr(Fi({},"__esModule",{value:!0}),e);function Er(e){Mo.updateConfig(e)}function G(){return Mo.getConfig()}function Tr(){switch(process.env.SDK_LOG_LEVEL?.toLowerCase()){case"debug":return 0;case"info":return 1;case"warn":return 2;case"error":return 3;case"silent":return 4;default:return}}var _u,Mo,Hi,te=w(()=>{"use strict";_u=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}},Mo=new _u,Hi=Mo});var Su,Eu,u,R=w(()=>{"use strict";te();Su=class{getLevel(){return Hi.get("logLevel")}isStderrOnly(){return Hi.get("stderrOnly")===!0}debug(...e){this.getLevel()<=0&&(this.isStderrOnly()?console.error("[DEBUG]",...e):console.log("[DEBUG]",...e))}info(...e){this.getLevel()<=1&&(this.isStderrOnly()?console.error("[INFO]",...e):console.log("[INFO]",...e))}log(...e){this.info(...e)}warn(...e){this.getLevel()<=2&&console.warn("[WARN]",...e)}error(...e){this.getLevel()<=3&&console.error("[ERROR]",...e)}setLevel(e){Hi.set("logLevel",e)}},Eu=new Su,u=Eu});async function Tu(e,t){let i=await import(e),n=Object.keys(i),o=new it.SyntheticModule(n,function(){for(let a of n)this.setExport(a,i[a])},{context:t});return await o.link(()=>{throw new Error("Nested imports not supported in VM context")}),await o.evaluate(),o}function Io(e,t,i,n=!1){if(e[t])if(n)u.info(`Overriding existing function: ${t}`),delete e[t];else{u.error(`The name ${t} is already defined in the global scope`);return}try{let o;if(it.isContext(e)?o=new it.Script(i,{importModuleDynamically:async a=>Tu(a,e)}).runInContext(e):o=(0,eval)(i),typeof o!="function")throw new Error("The injected code must be a function");e[t]=o}catch(o){u.error(`Error injecting user function ${t}: ${o.message}`)}}async function Mr(e,t,i=!1){try{let n=await Ar.readFile(t,"utf8"),o=JSON.parse(n);u.info(`Loading ${Object.keys(o).length} user functions...`);for(let[a,r]of Object.entries(o))Io(e,a,r,i)}catch(n){throw u.error("Failed to load user functions:",n),n}}var Ar,it,Ir=w(()=>{"use strict";R();Ar=W(require("fs/promises"),1),it=W(require("vm"),1)});async function Cr(e){try{let t=await Co.readFile(e,"utf8"),i=JSON.parse(t);return u.info(`Loaded ${i.length} knowledges from file`),i}catch(t){if(t.code==="ENOENT")return u.debug("No knowledges file found"),[];throw u.error("Failed to load knowledges:",t),t}}async function Pr(e){try{let t=await Co.readFile(e,"utf8"),i=JSON.parse(t);return u.info(`Loaded ${i.length} knowledge mappings from file`),i}catch(t){if(t.code==="ENOENT")return u.debug("No knowledge mappings file found"),[];throw u.error("Failed to load knowledge mappings:",t),t}}var Co,$r=w(()=>{"use strict";R();Co=W(require("fs/promises"),1)});async function Dr(e,t){if(!e.body)throw new Error("Response body is null");let i=e.body.getReader(),n=new TextDecoder,o="";try{for(;;){let{done:a,value:r}=await i.read();if(a)break;o+=n.decode(r,{stream:!0});let s=o.split(`
|
|
2
|
+
`);o=s.pop()||"";for(let l of s){let d=null;if(l.startsWith("data: "))try{let c=l.slice(6);c.trim()&&(d=JSON.parse(c))}catch(c){console.error(`Failed to parse SSE event: ${l}`,c);continue}d&&t(d)}}}finally{i.releaseLock()}}var Lr=w(()=>{"use strict"});var Po,Au,f,ie=w(()=>{"use strict";te();Po=require("fs"),Au=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=G().agentLogPath;if(e)try{(0,Po.appendFileSync)(e,`
|
|
3
|
+
=== Agent Execution Log ===
|
|
4
|
+
Started: ${new Date().toISOString()}
|
|
5
|
+
|
|
6
|
+
`),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=G().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();(0,Po.appendFileSync)(t,`[${i}] ${e}
|
|
7
|
+
`)}catch{}}}section(e){this.log(`
|
|
8
|
+
${"=".repeat(60)}
|
|
9
|
+
${e}
|
|
10
|
+
${"=".repeat(60)}`)}step(e,t,i){this.section(`Step ${e}/${t}`),i.task&&this.log(`Task: ${i.task}`),i.url&&this.log(`URL: ${i.url}`),i.thinking&&this.log(`Thinking: ${i.thinking}`),i.evaluation&&this.log(`Evaluation: ${i.evaluation}`),i.memory&&this.log(`Memory: ${i.memory}`),i.goal&&this.log(`Goal: ${i.goal}`),i.actions&&this.log(`Actions: ${i.actions}`)}llmCall(e,t,i){if(this.log(`LLM Call: ${e}`),this.log(`Duration: ${(t/1e3).toFixed(2)}s`),i){let n=i.promptTokens||i.inputTokens||0,o=i.completionTokens||i.outputTokens||0,a=i.totalTokens||0;this.log(`Tokens: ${n} prompt + ${o} completion = ${a} total`)}}thinking(e){this.log(`Native Thinking:
|
|
11
|
+
${e}`)}prompt(e,t){this.section("LLM Prompt"),this.log(`System Prompt:
|
|
12
|
+
${e}`),this.log(`
|
|
13
|
+
User Prompt:
|
|
14
|
+
${t}`)}response(e){this.log(`LLM Response:
|
|
15
|
+
${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!G().agentLogPath}},f=new Au});var Wi,Mu,Iu,Cu,Pu,Or,Bi,$o,Nr,Do,Lo,fe=w(()=>{"use strict";Wi=Object.defineProperty,Mu=Object.getOwnPropertyDescriptor,Iu=Object.getOwnPropertyNames,Cu=Object.prototype.hasOwnProperty,Pu=(e,t,i)=>t in e?Wi(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,Or=(e,t)=>()=>(e&&(t=e(e=0)),t),Bi=(e,t)=>{for(var i in t)Wi(e,i,{get:t[i],enumerable:!0})},$o=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Iu(t))!Cu.call(e,o)&&o!==i&&Wi(e,o,{get:()=>t[o],enumerable:!(n=Mu(t,o))||n.enumerable});return e},Nr=(e,t,i)=>($o(e,t,"default"),i&&$o(i,t,"default")),Do=e=>$o(Wi({},"__esModule",{value:!0}),e),Lo=(e,t,i)=>Pu(e,typeof t!="symbol"?t+"":t,i)});function D(e,t){return t??e?.getActionSettings()?.action_timeout_ms??No}function $u(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function O(e,t){let i=Pe(t);return i?new Function("page",`return ${i}`)(e):null}async function Oo(e,t=[]){let i=e;for(let n of t){let o=await i.locator(n).elementHandle();if(!o)return null;let a=await o.contentFrame();if(await o.dispose(),!a)return null;i=a}return i}function Du(e){let t={action_data:e.action_data};return e.locator&&(t.locator=e.locator),e.xpath&&(t.xpath=e.xpath),e.frame_path&&(t.frame_path=e.frame_path),t}function Lu(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Ou(e){let t=e.xpath;return typeof t=="string"&&t.trim()?!t.startsWith("xpath=")&&!t.startsWith("/")&&!t.startsWith("//")?`xpath=//${t}`:t.startsWith("xpath=")?t:`xpath=${t}`:null}function Pe(e){let t=Lu(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Ou(e);if(n){let o=JSON.stringify(n);return`${t}.locator(${o}).first()`}return null}var Gi,At,No,we,P,F=w(()=>{"use strict";fe();Gi={};Bi(Gi,{ACTION_TIMEOUT:()=>No,GOTO_TIMEOUT:()=>we,LOCATOR_TIMEOUT:()=>At,getActionTimeoutMs:()=>D,getFrameContext:()=>Oo,getLocator:()=>O,getMinimalActionEntity:()=>Du,getPageLocatorExpression:()=>Pe,sanitizeForComment:()=>$u});P=Or(()=>{At=5e3,No=1e4,we=2e4})});async function Mt(e,t,i=[],n=[]){try{let o=await Oo(e,i);if(!o)return u.warn(`Could not find frame context for xpath: ${t}`),null;let a=null;if(n.length>0){let s=n[0];if(!s)return u.warn(`Missing shadow host xpath for element: ${t}`),null;let l=o.locator(`xpath=${Rr(s)}`),d=Nu(t);if(a=await(d?l.locator(`css=${d}`):l.locator(`xpath=${Rr(t)}`)).elementHandle({timeout:At}),!a)return u.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(a=await o.locator(`xpath=${t}`).elementHandle({timeout:At}),!a)return u.warn(`Could not find element with xpath: ${t}`),null;let r=await o.evaluate(s=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(s):null,a);return await a.dispose(),r?(u.debug(`Generated locator for ${t}: ${r}`),r):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(o){return u.error(`Error in pickBestLocator: ${o}`),null}}async function Ui(e,t){try{let i=await(await t.ownerFrame()??e).evaluate(n=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(n):null,t);return await t.dispose(),i?(u.debug(`Generated locator: ${i}`),i):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return u.error(`Error in pickBestLocator: ${i}`),null}}async function Fr(e,t){let i=new Map;return await Promise.all(t.map(async n=>{let o=await Mt(e,n);i.set(n,o)})),i}function Rr(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function Nu(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),n=[];for(let o of i){let a=o.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!a)return null;let r=a[1].toLowerCase(),s=a[2]?`:nth-of-type(${a[2]})`:"";n.push(`${r}${s}`)}return n.join(" > ")}var Ke=w(()=>{"use strict";R();F();P()});async function Hr(e,t,i){await e.evaluate(()=>{document.getElementById("playwright-highlight-container")?.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(l=>l()),window._highlightCleanupFunctions=[])});let n=await e.screenshot({type:"png",fullPage:!1}),{default:o}=await import("sharp"),a=o(n),{width:r=0,height:s=0}=await a.metadata();return f.log(`Screenshot actual: ${r}x${s}, viewport: ${t}x${i}`),(r!==t||s!==i?await a.resize(t,i).png().toBuffer():n).toString("base64")}async function ae(e,t,i){let n=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),o=n.asElement();if(!o)throw await n.dispose(),new Error(`No element found at (${t}, ${i})`);let a=await o.boundingBox();if(!a)throw await n.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(a.x+a.width/2),relative_y:i-(a.y+a.height/2),element:o}}async function Ki(e,t){return t?{xpath:void 0,locator:await Ui(e,t)??void 0,frame_path:[]}:{xpath:void 0,locator:void 0,frame_path:[]}}function ji(e,t,i){return{action_description:e,action_data:t,locator:i.locator??void 0,xpath:i.xpath??void 0,frame_path:i.frame_path}}var nt=w(()=>{"use strict";ie();Ke()});function zi(){let e=(G().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function Ur(e){let t=G().env||{};if(zi()){let n=t.GOOGLE_CLOUD_PROJECT;if(!n)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let o=e==="gemini-3-flash-preview"?"global":t.GOOGLE_CLOUD_LOCATION;if(!o)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return u.debug(`Using Vertex AI provider: model=${e}, location=${o}`),(0,Gr.createVertex)({project:n,location:o})(e)}let i=t.GOOGLE_API_KEY;if(!i)throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.");return u.debug(`Using Google AI provider (API key): model=${e}`),(0,Br.createGoogleGenerativeAI)({apiKey:i})(e)}function Kr(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:Wr.MEDIA_RESOLUTION_HIGH},o;switch(t){case"gemini-3-flash-preview":o={...n};break;default:o={...i},e===1&&(o.mediaResolution=Wr.MEDIA_RESOLUTION_HIGH)}return zi()?{vertex:o}:{google:o}}var Br,Gr,Wr,ot=w(()=>{"use strict";R();te();Br=require("@ai-sdk/google"),Gr=require("@ai-sdk/google-vertex"),Wr={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});function J(e,t){return Math.round(e/1e3*t)}async function Fu(e,t,i,n,o){let a=null,r=null;try{switch(t){case"click_at":{let s=J(i.x,n),l=J(i.y,o),d=await ae(e,s,l);a={action_name:"click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"right_click_at":{let s=J(i.x,n),l=J(i.y,o),d=await ae(e,s,l);a={action_name:"right_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"double_click_at":{let s=J(i.x,n),l=J(i.y,o),d=await ae(e,s,l);a={action_name:"double_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"hover_at":{let s=J(i.x,n),l=J(i.y,o),d=await ae(e,s,l);a={action_name:"hover",kwargs:{}},r=d.element;break}case"scroll_at":{let s=J(i.x,n),l=J(i.y,o),d=await ae(e,s,l),c=i.direction??"down",h=J(i.magnitude??800,c==="left"||c==="right"?n:o),p=c==="right"?h:c==="left"?-h:0,g=c==="down"?h:c==="up"?-h:0;a={action_name:"scroll_on_element",kwargs:{delta_x:p,delta_y:g}},r=d.element;break}case"drag_and_drop":{let s=J(i.x,n),l=J(i.y,o),d=J(i.destination_x,n),c=J(i.destination_y,o),h=await ae(e,s,l);a={action_name:"drag_drop",kwargs:{relative_x:h.relative_x,relative_y:h.relative_y,delta_x:d-s,delta_y:c-l}},r=h.element;break}default:f.log(`Unsupported Gemini function: ${t}`)}}catch(s){f.error(`Error mapping Gemini action "${t}"`,s)}return{action_data:a,locatorInfo:await Ki(e,r)}}async function zr(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:o,viewportHeight:a,modelId:r}=e,s=G(),l;if(zi()){let m=s.env?.GOOGLE_CLOUD_PROJECT;if(!m)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let x=s.env?.GOOGLE_CLOUD_LOCATION??"global";l={vertexai:!0,project:m,location:x}}else{let m=s.env?.GOOGLE_API_KEY;if(!m)return{status:"error",error:"GOOGLE_API_KEY not found in SDK env config."};l={apiKey:m}}let d=new Vi.GoogleGenAI(l);f.log("Sending request to Gemini CUA...");let c=await d.models.generateContent({model:r,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:Vi.Environment.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination"]}},{functionDeclarations:Ru}],temperature:.1}});f.log("Received response from Gemini CUA");let h=c.candidates?.[0];if(!h)return{status:"error",error:"No candidates in Gemini response"};let p=h.content?.parts?.find(m=>m.functionCall);if(!p)return{status:"error",reasoning:h.content?.parts?.filter(m=>m.text).map(m=>m.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:g,args:b}=p.functionCall;f.log(`Generated function call: ${g} with args ${JSON.stringify(b)}`),u.debug(`Generated function call: ${g} with args ${JSON.stringify(b)}`);let{action_data:k,locatorInfo:y}=await Fu(i,g,b,o,a);return k?{status:"success",actionEntity:ji(t,k,y),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${g}`}}var Vi,jr,Ru,Xi=w(()=>{"use strict";nt();ie();ot();R();te();Vi=require("@google/genai");jr={type:"object",properties:{x:{type:"integer",description:"X coordinate in the 0-1000 normalized space."},y:{type:"integer",description:"Y coordinate in the 0-1000 normalized space."}},required:["x","y"]},Ru=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:jr},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:jr}]});async function Hu(e,t){let i=null,n=null;switch(t.type){case"click":{if(t.x===void 0||t.y===void 0)break;let o=t.button==="right"?"right_click_by_coordinates":"click_by_coordinates",a=await ae(e,t.x,t.y);i={action_name:o,kwargs:{relative_x:a.relative_x,relative_y:a.relative_y}},n=a.element;break}case"double_click":{if(t.x===void 0||t.y===void 0)break;let o=await ae(e,t.x,t.y);i={action_name:"double_click_by_coordinates",kwargs:{relative_x:o.relative_x,relative_y:o.relative_y}},n=o.element;break}case"drag":{if(!t.path||t.path.length<2)break;let[o,a]=[t.path[0],t.path[1]],r=await ae(e,o.x,o.y);i={action_name:"drag_drop",kwargs:{relative_x:r.relative_x,relative_y:r.relative_y,delta_x:a.x-o.x,delta_y:a.y-o.y}},n=r.element;break}case"move":{if(t.x===void 0||t.y===void 0)break;let o=await ae(e,t.x,t.y);i={action_name:"hover",kwargs:{}},n=o.element;break}case"scroll":{if(t.x===void 0||t.y===void 0)break;let o=await ae(e,t.x,t.y);i={action_name:"scroll_on_element",kwargs:{delta_x:t.scroll_x,delta_y:t.scroll_y}},n=o.element;break}}return{action_data:i,locatorInfo:await Ki(e,n)}}async function Xr(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:o,viewportHeight:a}=e,r=G().env?.OPENAI_API_KEY;if(!r)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let s=new Vr.default({apiKey:r});f.log("Sending request to OpenAI CUA...");let l=`You will be given an action to execute and screenshot of the current screen.
|
|
16
|
+
Output one computer_call object that will accomplish this action.
|
|
17
|
+
Action: ${t}`,d=await s.responses.create({model:"computer-use-preview",tools:[{type:"computer_use_preview",display_width:o,display_height:a,environment:"browser"}],input:[{role:"user",content:[{type:"input_text",text:l},{type:"input_image",detail:"auto",image_url:`data:image/png;base64,${n}`}]}],truncation:"auto",temperature:.1});f.log("Received response from OpenAI CUA");let c=d.output.find(g=>g.type==="computer_call")??null;if(!c)return{status:"error",reasoning:d.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};f.log(`Generated action: ${JSON.stringify(c.action)}`);let{action_data:h,locatorInfo:p}=await Hu(i,c.action);return h?{status:"success",actionEntity:ji(t,h,p),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:"Failed to map OpenAI action"}}var Vr,Yi=w(()=>{"use strict";nt();ie();te();Vr=W(require("openai"),1)});function Wu(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function Ro(e){return G().env?.[e]??process.env[e]}function Bu(){return Wu(Ro("ANTHROPIC_MODELS_USE_VERTEXAI"))}function qr(e){if(Bu()){let i=Ro("GOOGLE_CLOUD_PROJECT"),n=Ro("GOOGLE_CLOUD_LOCATION");if(!i)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!n)throw new Error("GOOGLE_CLOUD_LOCATION is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");return u.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${i}, location=${n}`),(0,Jr.createVertexAnthropic)({project:i,location:n})(e)}let t=G().env?.ANTHROPIC_API_KEY;if(!t)throw new Error("ANTHROPIC_API_KEY not configured in SDK config");return u.debug(`Using Anthropic provider: model=${e}`),(0,Yr.createAnthropic)({apiKey:t})(e)}function Fo(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var Yr,Jr,It=w(()=>{"use strict";R();te();Yr=require("@ai-sdk/anthropic"),Jr=require("@ai-sdk/google-vertex/anthropic")});function Qr(e){let t=G(),i=t.env?.OPENAI_API_KEY;if(!i)throw new Error("OPENAI_API_KEY not configured in SDK config");let n=t.env?.OPENAI_BASE_URL;return u.debug(`Using OpenAI provider: model=${e}${n?`, baseURL=${n}`:""}`),(0,Zr.createOpenAI)({apiKey:i,baseURL:n})(e)}function es(e){return{}}var Zr,Ct=w(()=>{"use strict";R();te();Zr=require("@ai-sdk/openai")});function is(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(Gu.test(e))return"openai"}function Ji(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(Uu.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function be(e){let{provider:t,modelId:i}=Ji(e),n=t??is(i);if(!n)throw new Error(`Cannot determine provider for model: ${e}. Use a known model prefix (claude-*, gemini-*, gpt-*) or specify a provider (e.g., "openai:${i}", "azure:${i}", "bedrock:${i}").`);if(!i)throw new Error(`Empty model ID in model string: "${e}". Specify a model after the provider prefix (e.g., "${n}:gpt-5.4-mini").`);let o=ts[n];if(!o)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(ts).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return o(i)}function ye(e,t){let{provider:i,modelId:n}=Ji(e),o=i??is(n);return o==="anthropic"||o==="vertex"?Fo(n):o==="openai"||o==="azure"?es(n):o==="bedrock"?n.startsWith("anthropic.")?Fo(n):{}:Kr(t,n)}var Gu,Uu,ts,Ee=w(()=>{"use strict";It();ot();Ct();Gu=/^(gpt-|o\d|chatgpt-)/;Uu=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);ts={anthropic:qr,google:Ur,openai:Qr}});function ju(e){return e.startsWith("gemini-")?"google":"openai"}async function at(e,t,i={}){let{page:n}=t,o=n.viewportSize();if(!o)return{status:"error",error:"Viewport size not available"};let{width:a,height:r}=o;f.log(`Viewport: ${a}x${r}`);let s=await Hr(n,a,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:d}=Ji(l),c=ju(d),h=Ku[c];f.log(`Using CUA provider: ${c} (model: ${d})`);let p={statement:e,page:n,screenshotB64:s,viewportWidth:a,viewportHeight:r,modelId:d};try{return await h(p)}catch(g){return f.error(`CUA provider "${c}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var Ku,rt=w(()=>{"use strict";Xi();Yi();nt();ie();Ee();Ku={google:zr,openai:Xr}});function qi(e){let t=(0,Ho.zodToJsonSchema)(e,{$refStrategy:"none"});if(t.$schema&&delete t.$schema,t.type!=="object")throw new Error(`Schema must be a Zod object schema, got type: ${t.type}`);return Pt(t),t}function Zi(e){return(0,Ho.zodToJsonSchema)(e,{$refStrategy:"none"})}function Pt(e){if(!(typeof e!="object"||e===null)){if(e.type==="object"&&(e.additionalProperties=!1,e.properties)){let t=Object.keys(e.properties);e.required=t;for(let i of Object.values(e.properties))Pt(i)}e.type==="array"&&e.items&&Pt(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(Pt);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&Pt(i)}}var Ho,$t=w(()=>{"use strict";Ho=require("zod-to-json-schema")});var Qi,en=w(()=>{"use strict";$t();Qi=class{constructor(e){this.registry=e}getToolDefinitions(){return this.registry.getTools().filter(e=>e.availability.openai).map(e=>({type:"function",function:{name:e.name,description:e.description,parameters:qi(e.schema),strict:!0}}))}getToolDefinitionsFiltered(e){let t=new Set(e);return this.registry.getTools().filter(i=>t.has(i.name)&&i.availability.openai).map(i=>({type:"function",function:{name:i.name,description:i.description,parameters:qi(i.schema),strict:!0}}))}toJSON(){return this.getToolDefinitions()}getToolDefinition(e){let t=this.registry.get(e);if(t)return{type:"function",function:{name:t.name,description:t.description,parameters:qi(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});function zu(e,t){let i=new Map;for(let l of t)l.hash&&l.url?i.set(l.hash,l.url):l.uuid&&l.url&&i.set(l.uuid,l.url);let n=/!\[([^\]]*)\]\(image:([a-f0-9]{64}|[a-zA-Z0-9\-]+)\)/g,o=[],a=0,r;for(;(r=n.exec(e))!==null;){let l=e.slice(a,r.index);l&&o.push({type:"text",text:l});let d=r[2];i.has(d)?o.push({type:"image",image:new URL(i.get(d))}):o.push({type:"text",text:r[0]}),a=r.index+r[0].length}let s=e.slice(a);return s&&o.push({type:"text",text:s}),o.length===0&&o.push({type:"text",text:e}),o}function Vu(e){let t=[];for(let i of e){let n=i.content||"",o=i.images||[],a=zu(n,o);t.length>0&&a.length>0&&t.push({type:"text",text:`
|
|
3
18
|
|
|
4
|
-
`}),t.push(...a)}return t}function
|
|
19
|
+
`}),t.push(...a)}return t}function tn(e,t=ns){if(t){let i=Vu(e);if(i.length===0)return[];let n={type:"text",text:`
|
|
5
20
|
|
|
6
21
|
<retrieved_knowledge>
|
|
7
22
|
|
|
@@ -21,7 +36,7 @@ Below are expert curated knowledge that are retrieved from the knowledge base; A
|
|
|
21
36
|
|
|
22
37
|
</retrieved_knowledge>
|
|
23
38
|
|
|
24
|
-
`}]:[]}}function
|
|
39
|
+
`}]:[]}}function os(e,t=ns){if(!t)return 0;let i=0;for(let n of e)n.images&&(i+=n.images.length);return i}var ns,Dt=w(()=>{"use strict";ns=!1});function Xu(){let e=new Date,t=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,timeZoneName:"short"}).formatToParts(e),i=t.find(c=>c.type==="year").value,n=t.find(c=>c.type==="month").value,o=t.find(c=>c.type==="day").value,a=t.find(c=>c.type==="hour").value,r=t.find(c=>c.type==="minute").value,s=t.find(c=>c.type==="second").value,l=t.find(c=>c.type==="timeZoneName").value,d=String(e.getMilliseconds()).padStart(3,"0");return`${i}-${n}-${o} ${a}:${r}:${s}.${d} ${l}`}function as(e){return`# Your Role
|
|
25
40
|
You are part of a end-to-end testing system that is designed to automate the testing of a website. Given an instruction in natural language, your job is to translate it into an action in the predefined actions. The instruction might not match any action in the predefined actions or might require to interact with an element that is not on the page. It's your job to detect these cases and return an empty action.
|
|
26
41
|
|
|
27
42
|
# Rules
|
|
@@ -81,11 +96,11 @@ Example of empty action when the target element is not on the page, or the instr
|
|
|
81
96
|
"action": {}, // empty action object to indicate the instruction cannot be completed
|
|
82
97
|
"completes_instruction": false
|
|
83
98
|
}
|
|
84
|
-
`}function
|
|
99
|
+
`}function Yu(e){if(!e||e.length===0)return"";let t="";return e.forEach(([i,n],o)=>{t+=`(${o+1}) Description: ${i}
|
|
85
100
|
Feedback: ${n}
|
|
86
101
|
`}),`## Additional context
|
|
87
102
|
You just executed following steps in order:
|
|
88
|
-
${t}`}function
|
|
103
|
+
${t}`}function rs(e,t,i,n,o,a,r=!1,s=Xu(),l=!1,d){let c=[],h=`
|
|
89
104
|
# Instruction
|
|
90
105
|
"${t}"
|
|
91
106
|
|
|
@@ -105,7 +120,7 @@ ${e.tabsText}
|
|
|
105
120
|
|
|
106
121
|
## Interactive elements from current page:
|
|
107
122
|
${e.elementsText}
|
|
108
|
-
`;if(c.push({type:"text",text:h}),r&&e.slicedScreenshotsBase64)for(let g of e.slicedScreenshotsBase64)c.push({type:"text",text:"The following images provided are sliced screenshots of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),c.push({type:"image",image:g});else a&&(c.push({type:"text",text:"The following image provided is a screenshot of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),c.push({type:"image",image:a}));if(o&&o.length>0){let g=
|
|
123
|
+
`;if(c.push({type:"text",text:h}),r&&e.slicedScreenshotsBase64)for(let g of e.slicedScreenshotsBase64)c.push({type:"text",text:"The following images provided are sliced screenshots of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),c.push({type:"image",image:g});else a&&(c.push({type:"text",text:"The following image provided is a screenshot of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),c.push({type:"image",image:a}));if(o&&o.length>0){let g=tn(o,l);c.push(...g)}let p="";if(p+=`
|
|
109
124
|
Current local time is ${s}.
|
|
110
125
|
`,i&&Object.keys(i).length>0){let g=[];for(let b of Object.keys(i))if(d?.has(b))g.push(` - ${b}: [SENSITIVE - value hidden]`);else{let k=i[b],y=typeof k=="string"?k:JSON.stringify(k);g.push(` - ${b}: "${y}"`)}p+=`
|
|
111
126
|
## Available Data Placeholders
|
|
@@ -118,42 +133,25 @@ To use them, write Jinja-like template syntax: {{ placeholder_name }}
|
|
|
118
133
|
- Do NOT use the actual value directly
|
|
119
134
|
- The values shown are for context only to help you understand what data is available
|
|
120
135
|
- In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")
|
|
121
|
-
`}if(n&&n.length>0){let g=
|
|
136
|
+
`}if(n&&n.length>0){let g=Yu(n);p+=`
|
|
122
137
|
`+g}return p+=`
|
|
123
138
|
Based on the above information, please determine the right action to accomplish the task.
|
|
124
|
-
`,c.push({type:"text",text:p}),c}var
|
|
125
|
-
=== Agent Execution Log ===
|
|
126
|
-
Started: ${new Date().toISOString()}
|
|
127
|
-
|
|
128
|
-
`),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=U().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();(0,ko.appendFileSync)(t,`[${i}] ${e}
|
|
129
|
-
`)}catch{}}}section(e){this.log(`
|
|
130
|
-
${"=".repeat(60)}
|
|
131
|
-
${e}
|
|
132
|
-
${"=".repeat(60)}`)}step(e,t,i){this.section(`Step ${e}/${t}`),i.task&&this.log(`Task: ${i.task}`),i.url&&this.log(`URL: ${i.url}`),i.thinking&&this.log(`Thinking: ${i.thinking}`),i.evaluation&&this.log(`Evaluation: ${i.evaluation}`),i.memory&&this.log(`Memory: ${i.memory}`),i.goal&&this.log(`Goal: ${i.goal}`),i.actions&&this.log(`Actions: ${i.actions}`)}llmCall(e,t,i){if(this.log(`LLM Call: ${e}`),this.log(`Duration: ${(t/1e3).toFixed(2)}s`),i){let n=i.promptTokens||i.inputTokens||0,o=i.completionTokens||i.outputTokens||0,a=i.totalTokens||0;this.log(`Tokens: ${n} prompt + ${o} completion = ${a} total`)}}thinking(e){this.log(`Native Thinking:
|
|
133
|
-
${e}`)}prompt(e,t){this.section("LLM Prompt"),this.log(`System Prompt:
|
|
134
|
-
${e}`),this.log(`
|
|
135
|
-
User Prompt:
|
|
136
|
-
${t}`)}response(e){this.log(`LLM Response:
|
|
137
|
-
${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!U().agentLogPath}},f=new yu});var Ui,xu,vu,ku,_u,Ir,Ki,_o,Cr,So,Eo,pe=w(()=>{"use strict";Ui=Object.defineProperty,xu=Object.getOwnPropertyDescriptor,vu=Object.getOwnPropertyNames,ku=Object.prototype.hasOwnProperty,_u=(e,t,i)=>t in e?Ui(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,Ir=(e,t)=>()=>(e&&(t=e(e=0)),t),Ki=(e,t)=>{for(var i in t)Ui(e,i,{get:t[i],enumerable:!0})},_o=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of vu(t))!ku.call(e,o)&&o!==i&&Ui(e,o,{get:()=>t[o],enumerable:!(n=xu(t,o))||n.enumerable});return e},Cr=(e,t,i)=>(_o(e,t,"default"),i&&_o(i,t,"default")),So=e=>_o(Ui({},"__esModule",{value:!0}),e),Eo=(e,t,i)=>_u(e,typeof t!="symbol"?t+"":t,i)});function D(e,t){return t??e?.getActionSettings()?.action_timeout_ms??Ao}function Su(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function O(e,t){let i=Me(t);return i?new Function("page",`return ${i}`)(e):null}async function To(e,t=[]){let i=e;for(let n of t){let o=await i.locator(n).elementHandle();if(!o)return null;let a=await o.contentFrame();if(await o.dispose(),!a)return null;i=a}return i}function Eu(e){let t={action_data:e.action_data};return e.locator&&(t.locator=e.locator),e.xpath&&(t.xpath=e.xpath),e.frame_path&&(t.frame_path=e.frame_path),t}function Tu(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Au(e){let t=e.xpath;return typeof t=="string"&&t.trim()?!t.startsWith("xpath=")&&!t.startsWith("/")&&!t.startsWith("//")?`xpath=//${t}`:t.startsWith("xpath=")?t:`xpath=${t}`:null}function Me(e){let t=Tu(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Au(e);if(n){let o=JSON.stringify(n);return`${t}.locator(${o}).first()`}return null}var ji,Tt,Ao,ge,P,R=w(()=>{"use strict";pe();ji={};Ki(ji,{ACTION_TIMEOUT:()=>Ao,GOTO_TIMEOUT:()=>ge,LOCATOR_TIMEOUT:()=>Tt,getActionTimeoutMs:()=>D,getFrameContext:()=>To,getLocator:()=>O,getMinimalActionEntity:()=>Eu,getPageLocatorExpression:()=>Me,sanitizeForComment:()=>Su});P=Ir(()=>{Tt=5e3,Ao=1e4,ge=2e4})});async function At(e,t,i=[],n=[]){try{let o=await To(e,i);if(!o)return u.warn(`Could not find frame context for xpath: ${t}`),null;let a=null;if(n.length>0){let s=n[0];if(!s)return u.warn(`Missing shadow host xpath for element: ${t}`),null;let l=o.locator(`xpath=${Pr(s)}`),d=Mu(t);if(a=await(d?l.locator(`css=${d}`):l.locator(`xpath=${Pr(t)}`)).elementHandle({timeout:Tt}),!a)return u.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(a=await o.locator(`xpath=${t}`).elementHandle({timeout:Tt}),!a)return u.warn(`Could not find element with xpath: ${t}`),null;let r=await o.evaluate(s=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(s):null,a);return await a.dispose(),r?(u.debug(`Generated locator for ${t}: ${r}`),r):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(o){return u.error(`Error in pickBestLocator: ${o}`),null}}async function zi(e,t){try{let i=await(await t.ownerFrame()??e).evaluate(n=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(n):null,t);return await t.dispose(),i?(u.debug(`Generated locator: ${i}`),i):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return u.error(`Error in pickBestLocator: ${i}`),null}}async function $r(e,t){let i=new Map;return await Promise.all(t.map(async n=>{let o=await At(e,n);i.set(n,o)})),i}function Pr(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function Mu(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),n=[];for(let o of i){let a=o.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!a)return null;let r=a[1].toLowerCase(),s=a[2]?`:nth-of-type(${a[2]})`:"";n.push(`${r}${s}`)}return n.join(" > ")}var Ge=w(()=>{"use strict";F();R();P()});async function Iu(e,t,i){await e.evaluate(()=>{let c=document.getElementById("playwright-highlight-container");c&&c.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(h=>h()),window._highlightCleanupFunctions=[])});let n=await e.screenshot({type:"png",fullPage:!1}),{default:o}=await import("sharp"),a=o(n),r=await a.metadata(),s=r.width||0,l=r.height||0;f.log(`Screenshot actual dimensions: ${s}x${l}, viewport: ${t}x${i}`);let d;return s!==t||l!==i?(f.log(`Resizing screenshot from ${s}x${l} to ${t}x${i}`),d=await a.resize(t,i).png().toBuffer()):d=n,d.toString("base64")}async function Mo(e,t,i){let n=await e.evaluateHandle(l=>document.elementFromPoint(l.x,l.y),{x:t,y:i});if(!n)throw new Error(`No element found at (${t}, ${i})`);let o=n.asElement();if(!o)throw await n.dispose(),new Error(`No element found at (${t}, ${i})`);let a=await o.boundingBox();if(!a)throw await n.dispose(),new Error("Element has no bounding box");let r=t-(a.x+a.width/2),s=i-(a.y+a.height/2);return{relative_x:r,relative_y:s,element:o}}async function Cu(e,t){return t?{xpath:void 0,locator:(t?await zi(e,t):null)||void 0,frame_path:[]}:{xpath:void 0,locator:void 0,frame_path:[]}}async function Pu(e,t){let i=null,n=null;switch(t.type){case"click":{let a=t.button==="right"?"right_click_by_coordinates":"click_by_coordinates";if(t.x===void 0||t.y===void 0)break;let r=await Mo(e,t.x,t.y);i={action_name:a,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},n=r.element;break}case"double_click":{if(t.x===void 0||t.y===void 0)break;let a=await Mo(e,t.x,t.y);i={action_name:"double_click_by_coordinates",kwargs:{relative_x:a.relative_x,relative_y:a.relative_y}},n=a.element;break}case"drag":{if(!t.path||t.path.length<2)break;let a=t.path[0].x,r=t.path[0].y,s=t.path[1].x,l=t.path[1].y,d=await Mo(e,a,r);i={action_name:"drag_drop",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y,delta_x:s-a,delta_y:l-r}},n=d.element;break}}let o=await Cu(e,n);return{action_data:i,locatorInfo:o}}async function tt(e,t,i={}){try{let{page:n}=t,o=n.viewportSize();if(!o)return{status:"error",error:"Viewport size not available"};let a=o.width,r=o.height;f.log(`Viewport size: ${a}x${r}`);let s=await Iu(n,a,r),l=U().env?.OPENAI_API_KEY;if(!l)return{status:"error",error:"OpenAI API key not found. Set OPENAI_API_KEY environment variable or configure via SDK config."};let d=new Dr.default({apiKey:l});f.log("Sending request to OpenAI CUA...");let c=[{role:"user",content:[{type:"input_text",text:`
|
|
138
|
-
You will be given an action to execute and screenshot of the current screen.
|
|
139
|
-
Output one computer_call object that will accomplish this action.
|
|
140
|
-
Action: ${e}
|
|
141
|
-
`},{type:"input_image",detail:"auto",image_url:`data:image/png;base64,${s}`}]}],h=await d.responses.create({model:"computer-use-preview",tools:[{type:"computer_use_preview",display_width:a,display_height:r,environment:"browser"}],input:c,truncation:"auto",temperature:.1});f.log("Received response from OpenAI CUA");let p=h.output.filter(y=>y.type==="computer_call")[0]??null;if(!p)return{status:"error",reasoning:h.output_text||""||"Invalid action generation response",error:"No computer_call action generated"};let g=p.action;f.log(`Generated action: ${JSON.stringify(g)}`);let{action_data:b,locatorInfo:k}=await Pu(n,g);return b?{status:"success",actionEntity:{action_description:e,action_data:b,locator:k.locator||void 0,xpath:k.xpath||void 0,frame_path:k.frame_path},reasoning:"Action generated successfully using pure vision mode",goalAccomplished:!0}:{status:"error",error:"Failed to map action to ActionDataEntity"}}catch(n){return f.error("Error generating CUA action",n),{status:"error",error:n.message||"Failed to generate action with pure vision"}}}var Dr,it=w(()=>{"use strict";de();Ge();ie();Dr=W(require("openai"),1)});function Vi(e,t){return e?{prompt_tokens:e.promptTokens||e.inputTokens||0,completion_tokens:e.completionTokens||e.outputTokens||0,total_tokens:e.totalTokens||0,model:t}:null}var Mt=w(()=>{"use strict"});async function $u(e){let t=e.context().pages(),i=null,n=[];for(let a=0;a<t.length;a++){let r=t[a];r===e&&(i=a);let s="(title unavailable)";try{s=await Promise.race([r.title(),new Promise((d,c)=>setTimeout(()=>c(new Error("timeout")),1e3))])}catch{}let l=`Tab ${a}: ${r.url()}`;s&&(l+=` - ${s.slice(0,50)}`),n.push(l)}let o=n.length>0?n.join(`
|
|
139
|
+
`,c.push({type:"text",text:p}),c}var nn=w(()=>{"use strict";Dt()});function on(e,t){return e?{prompt_tokens:e.promptTokens||e.inputTokens||0,completion_tokens:e.completionTokens||e.outputTokens||0,total_tokens:e.totalTokens||0,model:t}:null}var Lt=w(()=>{"use strict"});async function Ju(e){let t=e.context().pages(),i=null,n=[];for(let a=0;a<t.length;a++){let r=t[a];r===e&&(i=a);let s="(title unavailable)";try{s=await Promise.race([r.title(),new Promise((d,c)=>setTimeout(()=>c(new Error("timeout")),1e3))])}catch{}let l=`Tab ${a}: ${r.url()}`;s&&(l+=` - ${s.slice(0,50)}`),n.push(l)}let o=n.length>0?n.join(`
|
|
142
140
|
`):"";return{currentTabText:i!==null?`Current tab: ${i}
|
|
143
|
-
`:"",tabsText:o}}async function
|
|
141
|
+
`:"",tabsText:o}}async function qu(e,t){let{currentTabText:i,tabsText:n}=await Ju(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function an(e,t){let{page:i,domService:n,agentServices:o}=e,a=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},r=o.getInteractiveClassNames(),s=o.getIframeFallbackDomains(),{domState:l,screenshotBase64:d,slicedScreenshotsBase64:c}=await n.getClickableElementsWithScreenshot(i,{interactiveClassNames:r,playwrightFrameFallbackDomains:s,useCleanScreenshot:a.useCleanScreenshot,useSlicedScreenshots:a.useSlicedScreenshots,resizeSlicedScreenshots:a.resizeSlicedScreenshots,useAccessibilityTree:a.useAccessibilityTree,actionIntent:a.actionIntent}),h=l.elementTree.clickableElementsToString(),p=await qu(i,h);return c&&(p.slicedScreenshotsBase64=c),{domTree:h,screenshotBase64:d,slicedScreenshotsBase64:c,domState:l,pageContext:p}}var Ot=w(()=>{"use strict"});var se,st,H,Te=w(()=>{"use strict";se=require("zod"),st=class{constructor(){this.tools=new Map}register(e){if(this.tools.has(e.name))throw new Error(`Tool '${e.name}' is already registered`);let t={name:e.name,description:e.description,schema:e.schema,execute:e.execute,usesElementIndex:e.usesElementIndex??!1,availability:{openai:e.availability?.openai??!0,mcp:e.availability?.mcp??!0}};this.tools.set(e.name,t)}get(e){return this.tools.get(e)}has(e){return this.tools.has(e)}getToolNames(){return Array.from(this.tools.keys())}getTools(){return Array.from(this.tools.values())}async execute(e,t,i){let n=this.tools.get(e);if(!n)throw new Error(`Tool not found: ${e}`);try{let o=t?.description,a={...t};delete a.description;let r=n.schema.parse(a),s={...i,actionDescription:o};return await n.execute(r,s)}catch(o){if(o instanceof se.z.ZodError){let a=o.issues.map(r=>`${r.path.join(".")}: ${r.message}`).join(", ");return{success:!1,error:`Invalid arguments for tool '${e}': ${a}`,actionEntity:{action_description:t?.description||`${e} (validation failed)`,action_data:{action_name:e,kwargs:t},feedback:`Validation error: ${a}`}}}throw o}}clear(){this.tools.clear()}size(){return this.tools.size}buildActionUnionSchema(){let e=this.getTools().filter(t=>t.availability.openai);return this.buildUnionSchemaFromTools(e)}buildActionUnionSchemaForTools(e,t=!1){let i=new Set(e),n=this.getTools().filter(o=>i.has(o.name));return this.buildUnionSchemaFromTools(n,t)}buildUnionSchemaFromTools(e,t=!1){if(e.length===0)return se.z.object({done:se.z.any()});let i=e.map(r=>{let s=r.schema;if(t&&s instanceof se.z.ZodObject){let l=s._def.shape();s=se.z.object({...l,description:se.z.string().describe("Semantic, human-readable description of the action")})}if(s instanceof se.z.ZodObject){let l=s._def.shape();Object.keys(l).length===0&&(s=se.z.object({_empty:se.z.boolean().optional()}))}return se.z.object({[r.name]:s})});if(i.length===1)return i[0];let[n,o,...a]=i;return se.z.union([n,o,...a])}},H=new st});async function B(e,t){if(t<0)return;let{page:i,domService:n}=e;return(e.domState||await n.getClickableElements(i)).selectorMap.get(t)}function Zu(e){let t=e.split("/").filter(o=>o);if(t.length===0)return"*";let i=t[t.length-1],n=i.match(/^(\w+)(?:\[(\d+)\])?$/);if(n){let[,o,a]=n;return a?`${o}:nth-of-type(${a})`:o}return i}function Qu(e,t=!0){try{let i=Zu(e.xpath);if(e.attributes.class&&t){let o=/^[a-zA-Z_][a-zA-Z0-9_-]*$/,a=e.attributes.class.split(/\s+/);for(let r of a)r.trim()&&o.test(r)&&(i+=`.${r}`)}let n=new Set(["id","name","type","placeholder","aria-label","aria-labelledby","aria-describedby","role","for","autocomplete","required","readonly","alt","title","target"]);t&&["data-id","data-qa","data-cy","data-testid","data-handlepos"].forEach(o=>n.add(o));for(let[o,a]of Object.entries(e.attributes)){if(o==="class"||!o.trim()||!n.has(o))continue;let r=o.replace(/:/g,"\\:");if(a==="")i+=`[${r}]`;else if(/["'<>`\n\r\t]/.test(a)){let s=a;a.includes(`
|
|
144
142
|
`)&&(s=a.split(`
|
|
145
|
-
`)[0]),s=s.replace(/\s+/g," ").trim();let l=s.replace(/"/g,'\\"');i+=`[${r}*="${l}"]`}else i+=`[${r}="${a}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function
|
|
146
|
-
Parameters: ${JSON.stringify(
|
|
143
|
+
`)[0]),s=s.replace(/\s+/g," ").trim();let l=s.replace(/"/g,'\\"');i+=`[${r}*="${l}"]`}else i+=`[${r}="${a}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function eh(e){let t=e.attributes;if(t.title)return`iframe[title="${t.title.replace(/"/g,'\\"')}"]`;if(t.id)return`iframe#${t.id}`;if(t.name)return`iframe[name="${t.name.replace(/"/g,'\\"')}"]`;if(t.src){try{let i=new URL(t.src);if(i.protocol==="chrome-extension:")return`iframe[src^="${i.origin}"]`}catch{}return`iframe[src="${t.src.replace(/"/g,'\\"')}"]`}return Qu(e,!1)}function Wo(e){let t=[],i=e;for(;i&&i.parent!==null;){let a=i.parent;t.push(a),i=a}t.reverse();let n=[],o=t.filter(a=>a.tagName==="iframe");for(let a of o){let r=eh(a);u.debug("[frame-path] iframe attrs:",JSON.stringify(a.attributes),"\u2192",r),n.push(r)}return n}async function N(e,t){let i=null,n=Wo(t);return t.xpath&&(i=await Mt(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var K=w(()=>{"use strict";Ke();R()});function th(e){let t=e.toLowerCase();return[/\b(type|enter|input|fill|write|set)\b/,/\b(text|value|field|box)\b.*\b(to|with|as)\b/,/\b(username|password|email|search|query)\b/].some(i=>i.test(t))?"input":[/\bscroll\b/,/\b(scroll|swipe)\s*(up|down|left|right)\b/,/\b(page|move)\s*(down|up)\b/].some(i=>i.test(t))?"scroll":[/\b(click|tap|press|select|choose|pick|check|toggle)\b/,/\b(open|close|submit|confirm|cancel|dismiss)\b/,/\b(button|link|menu|dropdown|checkbox|radio)\b/].some(i=>i.test(t))?"click":"all"}function ih(e){if(!e)return null;if(e instanceof URL)return e.href;if(typeof e=="object"&&e.href)return String(e.href);if(typeof e=="object"&&typeof e.toString=="function"){let t=e.toString();if(t.startsWith("http://")||t.startsWith("https://"))return t}return typeof e=="string"&&(e.startsWith("http://")||e.startsWith("https://"))?e:null}function nh(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let n=i.image,o=ih(n);if(o)return{type:"image",file:o};let a=typeof n=="string"?n:"";return{type:"image",file:a.startsWith("data:")?a:`data:image/png;base64,${a}`}}return{type:"text",text:i.text}}):t.content}))}async function ss(e,t,i={}){let{page:n,agentServices:o}=t,a=o.getModel(),r=i.temperature??0,s=o.retrieveKnowledges(e).catch(oe=>(f.log(`Failed to retrieve knowledges: ${oe.message}`),[])),l=o.isSlicedScreenshotsEnabled(),d=o.isResizeSlicedScreenshotsEnabled(),c=o.isKnowledgeImagesEnabled(),h=o.isAccessibilityTreeEnabled(),p=o.isActionIntentFilteringEnabled(),g=p?th(e):"all";p&&g!=="all"&&f.log(`Action intent filtering: detected '${g}' intent from statement`);let{screenshotBase64:b,domState:k,pageContext:y}=await an(t,{useSlicedScreenshots:l,resizeSlicedScreenshots:d,useAccessibilityTree:h,actionIntent:g});t.domState=k;let m=new Qi(H).getToolDefinitions().map(oe=>{let et=oe.function;return`${et.name}: ${et.description}
|
|
144
|
+
Parameters: ${JSON.stringify(et.parameters,null,2)}`}).join(`
|
|
147
145
|
|
|
148
|
-
`),
|
|
146
|
+
`),x=as(m),A=await s,v=rs(y,e,t.variables,t.executionHistory,A.length>0?A:void 0,b,l,void 0,c,t.sensitiveKeys),E=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(oe=>{oe.role==="user"?E.push({role:"user",content:oe.content}):oe.role==="assistant"&&E.push({role:"assistant",content:oe.content})}),E.push({role:"user",content:v});let T=nh(E),C=H.buildActionUnionSchema(),I=Nt.z.object({thought:Nt.z.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:Nt.z.string().describe("Detailed description of the action to be performed").optional().default(""),action:C,completes_instruction:Nt.z.boolean().describe("Whether this action completes the given instruction").optional().default(!1)}),L=Array.isArray(v)?v.filter(oe=>oe.type==="image").length:0,V=ye(a,L),Z=await(0,rn.generateText)({model:be(a),system:x,messages:E,temperature:r,output:rn.Output.object({schema:I}),providerOptions:V}),_e=Z.reasoningText;u.info(`Action Generation Reasoning: ${_e}`);let z=Z.output,X=JSON.stringify(z,null,2);u.info(`Generate Action Raw Output: ${X}`);let Se=[],He=on(Z.usage,a);He&&Se.push(He);let We={systemPrompt:x,userPrompt:T,rawLlmResponse:X,tokenUsages:Se},Be=z.thought||"",Ge=z.description||"",U=z.action||{},Q=z.completes_instruction||!1;if(!U||Object.keys(U).length===0)return{status:"error",reasoning:Be||Ge||"No action generated",goalAccomplished:Q,error:"Agent did not generate any action",debugInfo:We};let Y=Object.keys(U)[0];if(Y==="done")return{status:"error",reasoning:Be||Ge||"Task marked as done",goalAccomplished:Q,error:"Agent indicated task is done without generating an action",debugInfo:We};if(Y==="perform_accurate_operation")return await at(e,t,i);let he=U[Y]||{},yr={};if(typeof he.element_index=="number"){let oe=he.element_index;if(oe<0)return{status:"error",reasoning:Be||Ge||"No action generated",goalAccomplished:Q,error:"Agent did not generate any action",debugInfo:We};let et=k.selectorMap.get(oe);et&&(yr=await N(n,et))}let xr=Ge;return Y==="verify"&&(xr=e,he.statement=e),{status:"success",actionEntity:{...yr,action_description:xr||Be||`${Y}(${JSON.stringify(he)})`,action_data:{action_name:Y,kwargs:he}},reasoning:Be||Ge,goalAccomplished:Q,debugInfo:We}}var rn,Nt,sn=w(()=>{"use strict";rt();en();nn();Lt();Ot();Te();ie();Ee();K();R();rn=require("ai"),Nt=require("zod")});function oh(e){if(!e)return null;if(e instanceof URL)return e.href;if(typeof e=="object"&&e.href)return String(e.href);if(typeof e=="object"&&typeof e.toString=="function"){let t=e.toString();if(t.startsWith("http://")||t.startsWith("https://"))return t}return typeof e=="string"&&(e.startsWith("http://")||e.startsWith("https://"))?e:null}async function Bo(e,t,i={}){return i.usePureVision?at(e,t,i):ss(e,t,i)}function rh(){let e=new Date,t=e.toLocaleDateString("en-US",{weekday:"long",year:"numeric",month:"long",day:"numeric",timeZone:"America/Los_Angeles"}),i=e.toLocaleTimeString("en-US",{hour:"2-digit",minute:"2-digit",second:"2-digit",fractionalSecondDigits:3,timeZoneName:"short",timeZone:"America/Los_Angeles"});return{dateString:t,timeString:i}}function sh(){return`# Role
|
|
149
147
|
You are an experienced QA person for web applications.
|
|
150
148
|
You are tasked to verify the validity of a given statement based on the screenshot and element tree of a web page.
|
|
151
|
-
`}async function
|
|
149
|
+
`}async function ls(e,t,i={}){let{page:n,executionHistory:o}=t,a=t.agentServices.getModel();try{let r=t.agentServices.isSlicedScreenshotsEnabled(),s=t.agentServices.isResizeSlicedScreenshotsEnabled(),l=t.agentServices.isKnowledgeImagesEnabled(),d=t.agentServices.isAccessibilityTreeEnabled(),{domTree:c,screenshotBase64:h,slicedScreenshotsBase64:p,domState:g,pageContext:b}=await an(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:r,resizeSlicedScreenshots:s,useAccessibilityTree:d});t.domState=g;let k="";o&&o.length>0&&(k=`
|
|
152
150
|
# Previous actions in this session:
|
|
153
|
-
${o.map(([
|
|
154
|
-
Result: ${
|
|
151
|
+
${o.map(([U,Q],Y)=>`${Y+1}. Action: ${U}
|
|
152
|
+
Result: ${Q}`).join(`
|
|
155
153
|
`)}
|
|
156
|
-
`);let{dateString:y,timeString:m}=
|
|
154
|
+
`);let{dateString:y,timeString:m}=rh(),x=`
|
|
157
155
|
# User statement
|
|
158
156
|
"${e}"
|
|
159
157
|
|
|
@@ -172,22 +170,22 @@ ${c}
|
|
|
172
170
|
|
|
173
171
|
## Screenshot
|
|
174
172
|
${r&&p?"The following images are sliced screenshots of the current webpage (left, middle, right sections).":"The image provided is a screenshot of the current webpage."}
|
|
175
|
-
`,A="";if(t.variables&&Object.keys(t.variables).length>0){let
|
|
173
|
+
`,A="";if(t.variables&&Object.keys(t.variables).length>0){let U=[];for(let Q of Object.keys(t.variables))if(!t.sensitiveKeys?.has(Q)){let Y=t.variables[Q],he=typeof Y=="string"?Y:JSON.stringify(Y);U.push(` - ${Q}: "${he}"`)}U.length>0&&(A=`
|
|
176
174
|
## Available Variables
|
|
177
175
|
The following non-sensitive variables are available:
|
|
178
|
-
${
|
|
179
|
-
`)}`)}let
|
|
176
|
+
${U.join(`
|
|
177
|
+
`)}`)}let v=`
|
|
180
178
|
${A}
|
|
181
179
|
${k}
|
|
182
180
|
|
|
183
181
|
Today is ${y}. Current local time is ${m}.
|
|
184
182
|
Based on the above information, please determine if the statement is true.
|
|
185
|
-
`,E=await t.agentServices.retrieveKnowledges(e),T=[{type:"text",text:
|
|
183
|
+
`,E=await t.agentServices.retrieveKnowledges(e),T=[{type:"text",text:x}],C=0;if(r&&p&&p.length>0)for(let U of p)T.push({type:"image",image:U}),C++;else T.push({type:"image",image:h}),C=1;if(E&&E.length>0){let U=tn(E,l);T.push(...U)}T.push({type:"text",text:v});let I=E?os(E,l):0,L=C+I,V=ye(a,L),Z=sh(),_e=await(0,ln.generateText)({model:be(a),system:Z,messages:[{role:"user",content:T}],output:ln.Output.object({schema:ah}),temperature:0,providerOptions:V}),{conclusion:z,explanation:X}=_e.output,Se=JSON.stringify(_e.output,null,2),He=[],We=on(_e.usage,a);We&&He.push(We);let Be=[{role:"user",content:T.map(U=>{if(U.type==="text")return{type:"text",text:U.text};if(U.type==="image"){let Q=U.image,Y=oh(Q);if(Y)return{type:"image",file:Y};let he=typeof Q=="string"?Q:"";return{type:"image",file:he.startsWith("data:")?he:`data:image/png;base64,${he}`}}return{type:"text",text:"[unknown content type]"}})}],Ge={systemPrompt:Z,userPrompt:Be,rawLlmResponse:Se,screenshotWithSom:h,tokenUsages:He,retrievedKnowledges:E&&E.length>0?E:void 0,elementTree:c};return{success:z==="true",explanation:X,debugInfo:Ge}}catch(r){return{success:!1,error:r.message}}}var ln,Rt,ah,cn=w(()=>{"use strict";sn();rt();Lt();Ot();Dt();Ee();ln=require("ai"),Rt=require("zod");ah=Rt.z.object({screenshotDescription:Rt.z.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
|
|
186
184
|
and a description of their location: formatting example: [12] A red button with text "Submit", next to [11]
|
|
187
185
|
[45] A modal dialog titled "Confirmation",
|
|
188
|
-
in the center of the screen`),explanation:
|
|
189
|
-
`).trim()}clickableElementsToString(t){let i=t?.includeAttributes??
|
|
190
|
-
`)}}});function
|
|
186
|
+
in the center of the screen`),explanation:Rt.z.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:Rt.z.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function ds(){let{default:e}=await import("sharp");return e}async function Go(e,t){let i=await ds(),n=await i(e).metadata(),o=n.width||0,a=n.height||0;if(o===0||a===0)throw new Error("Invalid image dimensions");let r=a,s=0,l=Math.floor((o-r)/2),d=Math.max(0,o-r),c=(b,k)=>{let y=i(e).extract({left:b,top:0,width:k,height:r});return t?.resize&&(y=y.resize(cs,cs)),y.png().toBuffer()},[h,p,g]=await Promise.all([c(s,Math.min(r,o)),c(l,Math.min(r,o-l)),c(d,Math.min(r,o-d))]);return[h,p,g]}async function us(e){let t=(await ds())(e),i=await t.metadata(),n=i.width||0,o=i.height||0;if(n===0||o===0)throw new Error("Invalid image dimensions");let{data:a}=await t.grayscale().raw().toBuffer({resolveWithObject:!0}),r=[];for(let s=0;s<o;s++){r[s]=[];for(let l=0;l<n;l++)r[s][l]=a[s*n+l]}return{pixels:r,width:n,height:o}}var cs,Ft=w(()=>{"use strict";cs=768});function hs(e){return e?Ht.has(e):!1}function ms(e){return lt.has(e)}function ps(e){return e.filter(t=>lt.has(t.type))}var Ht,lt,dn,un,Wt=w(()=>{"use strict";Ht=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),lt=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),dn=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],un=500});function gs(e,t){return e.length>t?e.slice(0,t)+"...":e}var Bt=w(()=>{"use strict"});var fs,ws,Gt=w(()=>{"use strict";fs=["title","type","checked","name","role","value","placeholder","data-date-format","alt","aria-label","aria-expanded","data-state","aria-checked","data-id","data-testid","data-test-id","data-handlepos","data-item-id"],ws={"react-flow__(\\S+)":"$1"}});var bs,Ut,xe,ct=w(()=>{"use strict";Bt();Gt();bs=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},Ut=class extends bs{constructor(e,t,i=null){super(t,i),this.text=e,this.type="TEXT_NODE"}hasParentWithHighlightIndex(){let e=this.parent;for(;e!==null;){if(e.highlightIndex!==null)return!0;e=e.parent}return!1}isParentInViewport(){return this.parent===null?!1:this.parent.isInViewport}isParentTopElement(){return this.parent===null?!1:this.parent.isTopElement}},xe=class hn extends bs{constructor(t,i,n,o,a,r=!1,s=!1,l=!1,d=!1,c=!1,h=!1,p=null,g=null,b=null,k=null,y=[],m=null){super(a,m),this.tagName=t,this.xpath=i,this.attributes=n,this.children=o,this.isInteractive=r,this.isScrollable=s,this.markAsClickable=l,this.isTopElement=d,this.isInViewport=c,this.shadowRoot=h,this.highlightIndex=p,this.viewportCoordinates=g,this.pageCoordinates=b,this.viewportInfo=k,this.isNew=null,this.shadowHostXPaths=y}getAllTextTillNextClickableElement(t=-1){let i=[],n=(o,a)=>{if(!(t!==-1&&a>t)&&!(o instanceof hn&&o!==this&&o.highlightIndex!==null)){if(o instanceof Ut)i.push(o.text);else if(o instanceof hn)for(let r of o.children)n(r,a+1)}};return n(this,0),i.join(`
|
|
187
|
+
`).trim()}clickableElementsToString(t){let i=t?.includeAttributes??fs,n=t?.includeClassesWithRename??ws,o=[],a=(r,s)=>{let l=s,d=" ".repeat(s);if(r instanceof hn){if(r.highlightIndex!==null){l+=1;let c=r.isScrollable?"":r.getAllTextTillNextClickableElement(),h=null;if(i.length>0){let m={};for(let v of Object.keys(r.attributes))if(i.includes(v)){let E=r.attributes[v].trim();E!==""&&(m[v]=E)}let x=i.filter(v=>v in m);if(x.length>1){let v=new Set,E={};for(let T of x){let C=m[T];C.length>5&&(C in E?v.add(T):E[C]=T)}for(let T of v)delete m[T]}r.tagName===m.role&&delete m.role;let A=["aria-label","placeholder","title"];for(let v of A)m[v]&&m[v].trim().toLowerCase()===c.trim().toLowerCase()&&delete m[v];Object.keys(m).length>0&&(h=Object.entries(m).map(([v,E])=>`${v}=${gs(E,200)}`).join(" "))}let p=r.isNew?`*[${r.highlightIndex}]`:`[${r.highlightIndex}]`,g=[];if(Object.keys(n).length>0&&r.attributes.class){let m=r.attributes.class.split(/\s+/);for(let x of m)for(let[A,v]of Object.entries(n))try{let E=new RegExp(`^${A}$`);if(x.match(E)){let T=x.replace(E,v);T&&g.push(T);break}}catch{continue}}let b=r.isScrollable?" (SCROLLABLE)":"",k=r.markAsClickable?" (CLICKABLE)":"",y=`${d}${p}${b}${k}<${r.tagName}`;if(g.length>0&&(y+=` ${g.join(" ")}`),h&&(y+=` ${h}`),c){let m=c.trim();h||(y+=" "),y+=`>${m}`}else h||(y+=" ");y+=" />",o.push(y)}else{let c=["data-testid","data-test-id"].filter(h=>r.attributes[h]);c.length>0&&(l+=1,o.push(`${d}<${r.tagName} ${c.map(h=>`${h}="${r.attributes[h]}"`).join(" ")} />`))}for(let c of r.children)a(c,l)}else if(r instanceof Ut){if(r.hasParentWithHighlightIndex())return;r.parent&&r.parent.isVisible&&r.parent.isTopElement&&o.push(`${d}${r.text}`)}};return a(this,0),o.join(`
|
|
188
|
+
`)}}});function dh(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var lh,ch,me,je=w(()=>{"use strict";Ft();Wt();ct();R();lh=`(
|
|
191
189
|
args = {
|
|
192
190
|
doHighlightElements: true,
|
|
193
191
|
focusHighlightIndex: -1,
|
|
@@ -1955,7 +1953,7 @@ Based on the above information, please determine if the statement is true.
|
|
|
1955
1953
|
|
|
1956
1954
|
return { rootId, map: DOM_HASH_MAP };
|
|
1957
1955
|
}
|
|
1958
|
-
`,
|
|
1956
|
+
`,ch=`((args = {
|
|
1959
1957
|
doHighlightElements: true,
|
|
1960
1958
|
focusHighlightIndex: -1,
|
|
1961
1959
|
viewportExpansion: 0,
|
|
@@ -4003,7 +4001,7 @@ Based on the above information, please determine if the statement is true.
|
|
|
4003
4001
|
// Return element data from boxes phase for use in labels phase
|
|
4004
4002
|
elementData: phase === 'boxes' ? collectedElementData : undefined,
|
|
4005
4003
|
};
|
|
4006
|
-
})`;
|
|
4004
|
+
})`;me=class{normalizeDomain(e){let t=e.trim().toLowerCase();if(!t)return"";try{if(t.includes("://"))return new URL(t).hostname.toLowerCase()}catch{return""}return t.split("/")[0].split(":")[0]}isConfiguredIframeFallbackDomain(e,t){let i;try{i=new URL(e).hostname.toLowerCase()}catch{return!1}for(let n of t){let o=this.normalizeDomain(n);if(o&&(i===o||i.endsWith(`.${o}`)))return!0}return!1}shouldProcessWithPlaywrightFrameFallback(e,t){if(!e.inaccessibleFrame)return!1;let i=e.attributes?.src;return i?i.startsWith("chrome-extension://")?!0:this.isConfiguredIframeFallbackDomain(i,t):!1}constructor(e={}){u.debug("\u{1F333} Initializing DomService with options:",e),this.useDomTreeTs=e.useDomTreeTs??!1,this.domTreeRoot=e.domTreeRoot??"body",this.jsCode=this.useDomTreeTs?ch:lh}async getClickableElements(e,t={}){let{highlightElements:i=!0,focusElement:n=-1,viewportExpansion:o=0,interactiveClassNames:a=[],playwrightFrameFallbackDomains:r=[],alwaysHighlightFileInput:s=!1,sameRectIoUThreshold:l,actionIntent:d="all"}=t,[c,h]=await this.buildDomTree(e,i,n,o,a,r,s,l,d);return{elementTree:c,selectorMap:h}}async getClickableElementsWithScreenshot(e,t={}){if(t.useAccessibilityTree)return this.getClickableElementsWithAXTree(e,t);let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let n=await this.getClickableElements(e,t);if(await e.waitForTimeout(100),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]),!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let o=i.toString("base64"),a;if(t.useSlicedScreenshots)try{a=(await Go(i,{resize:t.resizeSlicedScreenshots})).map(r=>r.toString("base64"))}catch(r){u.warn("Failed to slice screenshot:",r)}return{domState:n,screenshotBase64:o,screenshot:i,slicedScreenshotsBase64:a}}async getClickableElementsWithAXTree(e,t={}){u.debug("\u{1F333} Using CDP Accessibility Tree for element detection");let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let n=await e.context().newCDPSession(e),{nodes:o}=await n.send("Accessibility.getFullAXTree",{depth:-1});u.debug(`\u{1F4CA} Got ${o.length} AXNodes from accessibility tree`);let a=o.filter(m=>{if(m.ignored)return!1;let x=m.role?.value;return!(!x||!Ht.has(x)||m.properties?.find(A=>A.name==="disabled")?.value?.value||!m.backendDOMNodeId)});u.debug(`\u2705 Found ${a.length} interactive elements from AXTree`);let r=o.filter(m=>m.role?.value==="button");u.debug(`\u{1F518} Total buttons in AXTree: ${r.length}`);for(let m of r){let x=[];m.ignored&&x.push("ignored"),m.backendDOMNodeId||x.push("no-backendDOMNodeId"),m.properties?.find(A=>A.name==="disabled")?.value?.value&&x.push("disabled"),u.debug(` - "${m.name?.value||"(no name)"}" ${x.length>0?`[SKIPPED: ${x.join(", ")}]`:"[INCLUDED]"}`)}let s=new Set(a.map(m=>m.backendDOMNodeId)),l=await this.getElementsWithEventListeners(n,t.eventListenerLimit??500),d=0;for(let m of l)s.has(m.backendNodeId)||(a.push({nodeId:`synthetic-${m.backendNodeId}`,ignored:!1,backendDOMNodeId:m.backendNodeId,role:{type:"role",value:"generic"},name:{type:"string",value:""},properties:[{name:"eventListeners",value:{type:"string",value:m.eventTypes.join(",")}}]}),s.add(m.backendNodeId),d++);u.debug(`\u{1F3AF} Added ${d} elements from event listeners (total: ${a.length})`);let c=await this.resolveAXNodesToDOM(n,a),h=c.filter(m=>m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect),p=c.filter(m=>!(m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect));if(p.length>0){u.debug(`\u{1F6AB} Filtered out ${p.length} elements:`);for(let m of p){let x=[];m.isVisible||x.push("not-visible"),m.isInViewport||x.push("not-in-viewport"),m.isTopElement||x.push("not-top-element"),m.boundingRect||x.push("no-bounding-rect"),u.debug(` - <${m.tagName}> "${m.axNode.name?.value||""}" [${x.join(", ")}]`)}}u.debug(`\u{1F441}\uFE0F ${h.length} elements are visible and in viewport`);let{domState:g,highlightIndex:b}=await this.buildDomStateFromAXTree(h);t.highlightElements!==!1&&b>0&&(await this.renderHighlightsForAXElements(e,h.slice(0,b)),await e.waitForTimeout(100)),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]);try{await n.detach()}catch{}if(!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let k=i.toString("base64"),y;if(t.useSlicedScreenshots)try{y=(await Go(i,{resize:t.resizeSlicedScreenshots})).map(m=>m.toString("base64"))}catch(m){u.warn("Failed to slice screenshot:",m)}return{domState:g,screenshotBase64:k,screenshot:i,slicedScreenshotsBase64:y}}async resolveAXNodesToDOM(e,t){let i=[],n=t.map(a=>a.backendDOMNodeId).filter(a=>a!==void 0);if(n.length===0)return i;let o=[];for(let a of n)try{let{object:r}=await e.send("DOM.resolveNode",{backendNodeId:a});o.push(r.objectId||null)}catch{o.push(null)}for(let a=0;a<t.length;a++){let r=t[a],s=o[a];if(s)try{let{result:l}=await e.send("Runtime.callFunctionOn",{objectId:s,functionDeclaration:`function() {
|
|
4007
4005
|
const el = this;
|
|
4008
4006
|
const rect = el.getBoundingClientRect();
|
|
4009
4007
|
const rects = el.getClientRects();
|
|
@@ -4087,34 +4085,34 @@ Based on the above information, please determine if the statement is true.
|
|
|
4087
4085
|
} : null,
|
|
4088
4086
|
clientRects: clientRectsArray
|
|
4089
4087
|
};
|
|
4090
|
-
}`,returnByValue:!0});l.value&&i.push({axNode:r,...l.value})}catch(l){u.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=en){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),o=Qi.join(","),{nodeIds:a}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:o});u.debug(`\u{1F50D} Checking ${Math.min(a.length,t)} elements for event listeners`);for(let r of a.slice(0,t))try{let{object:s}=await e.send("DOM.resolveNode",{nodeId:r});if(!s.objectId)continue;let{listeners:l}=await e.send("DOMDebugger.getEventListeners",{objectId:s.objectId}),d=l.filter(c=>ot.has(c.type));if(d.length>0){let{node:c}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:c.backendNodeId,eventTypes:d.map(h=>h.type)})}await e.send("Runtime.releaseObject",{objectId:s.objectId})}catch{}u.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){u.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new be("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),n=0;for(let o of e){let a=o.axNode.role?.value||"",r=o.axNode.name?.value||"",s=["button","link","menuitem","tab","switch"].includes(a),l=new be(o.tagName,o.xpath,o.attributes,[],o.isVisible,!0,a==="scrollbar",s,o.isTopElement,o.isInViewport,!1,n,o.boundingRect?{topLeft:{x:o.boundingRect.x,y:o.boundingRect.y},topRight:{x:o.boundingRect.x+o.boundingRect.width,y:o.boundingRect.y},bottomLeft:{x:o.boundingRect.x,y:o.boundingRect.y+o.boundingRect.height},bottomRight:{x:o.boundingRect.x+o.boundingRect.width,y:o.boundingRect.y+o.boundingRect.height},center:{x:o.boundingRect.x+o.boundingRect.width/2,y:o.boundingRect.y+o.boundingRect.height/2},width:o.boundingRect.width,height:o.boundingRect.height}:null,null,null,[],i);if(r){let d=new Wt(r,!0,l);l.children.push(d)}i.children.push(l),t.set(n,l),n++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:n}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:n,colors:o})=>{let a="playwright-highlight-container",r=document.getElementById(a);r||(r=document.createElement("div"),r.id=a,r.style.position="fixed",r.style.pointerEvents="none",r.style.top="0",r.style.left="0",r.style.width="100%",r.style.height="100%",r.style.zIndex="2147483647",r.style.backgroundColor="transparent",document.body.appendChild(r)),n.forEach((s,l)=>{if(!s.boundingRect)return;let d=o[l%o.length],c=s.boundingRect,h=document.createElement("div");h.style.position="fixed",h.style.border=`1px solid ${d}`,h.style.backgroundColor="transparent",h.style.pointerEvents="none",h.style.boxSizing="border-box",h.style.top=`${c.y}px`,h.style.left=`${c.x}px`,h.style.width=`${c.width}px`,h.style.height=`${c.height}px`,r.appendChild(h);let p=document.createElement("div");p.style.position="fixed",p.style.background=d,p.style.color="white",p.style.padding="1px 4px",p.style.borderRadius="4px",p.style.fontSize=l>=100?"8px":"12px",p.textContent=String(l);let g=Math.max(0,c.y-16),b=Math.max(0,Math.min(c.x+c.width-20,window.innerWidth-25));p.style.top=`${g}px`,p.style.left=`${b}px`,r.appendChild(p)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let n=document.getElementById("playwright-highlight-container");n&&n.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(o=>o()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),u.debug("\u2705 Highlights removed from page")}catch(n){u.warn("Failed to remove highlights:",n.message)}for(let n of e.frames()){let o=n.url();if(!(!o.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(o,t)))try{await n.evaluate(i)}catch{}}}async getCrossOriginIframes(e){let t=await e.locator("iframe").filter({hasNot:e.locator(":visible")}).evaluateAll(s=>s.map(l=>l.src)),i=s=>{try{let l=new URL(s);return["doubleclick.net","adroll.com","googletagmanager.com"].some(d=>l.hostname.includes(d))}catch{return!1}},n=e.url(),o=new URL(n).hostname,a=e.frames(),r=[];for(let s of a){let l=s.url();try{let d=new URL(l).hostname;d&&d!==o&&!t.includes(l)&&!i(l)&&r.push(l)}catch{continue}}return r}async buildDomTree(e,t,i,n,o,a,r,s,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(Ju(e.url()))return[new be("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let d={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:o,alwaysHighlightFileInput:r,sameRectIoUThreshold:s,actionIntent:l,domTreeRoot:this.domTreeRoot};u.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let c,h=null;if(this.useDomTreeTs&&t)try{let y={...d,phase:"boxes",grayscaleImage:null},m=await e.evaluate(({code:C,argsObj:I})=>new Function("return "+C)()(I),{code:this.jsCode,argsObj:y});u.debug(`\u{1F4E6} Phase 1: Drew ${m.elementData?.length||0} bounding boxes`);let v=await e.screenshot({type:"png",fullPage:!1});u.debug("\u{1F4F8} Captured screenshot with bounding boxes");let A=performance.now(),x=await Qr(v);h=x.pixels;let E=Math.round(performance.now()-A);u.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${x.width}x${x.height}) in ${E}ms`);let T={...d,phase:"labels",grayscaleImage:h,elementData:m.elementData};c=await e.evaluate(({code:C,argsObj:I})=>new Function("return "+C)()(I),{code:this.jsCode,argsObj:T}),c.map=m.map,c.rootId=m.rootId,c.highlightCount=m.highlightCount,c.perfMetrics=m.perfMetrics,u.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(y){u.warn("Two-phase rendering failed, falling back to legacy mode:",y.message),h=null;let m={...d,grayscaleImage:null};c=await e.evaluate(({code:v,argsObj:A})=>new Function("return "+v)()(A),{code:this.jsCode,argsObj:m}),u.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{c=await e.evaluate(({code:y,argsObj:m})=>new Function("return "+y)()(m),{code:this.jsCode,argsObj:d}),u.debug("\u2705 JavaScript DOM analysis completed")}catch(y){throw u.error("Error evaluating JavaScript:",y.message),y}if(!c||typeof c!="object")throw u.error("JavaScript returned invalid result:",c),new Error("JavaScript DOM analysis returned invalid result");if(!c.map||!c.rootId)throw u.error("JavaScript result missing map or rootId:",JSON.stringify(c,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(l!=="all"&&c.highlightCount===0){u.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let y={...d,actionIntent:"all"};c=await e.evaluate(({code:m,argsObj:v})=>new Function("return "+m)()(v),{code:this.jsCode,argsObj:y})}let p=Object.entries(c.map).filter(([,y])=>y.tagName==="iframe");u.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${p.length}`);for(let[y,m]of p){let v=m;u.debug(`\u{1F50D} [ext-iframe] iframe node id=${y} src=${v.attributes?.src} inaccessibleFrame=${v.inaccessibleFrame}`)}let g=e.frames();u.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let y of g)u.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${y.url()}`);let b=[];for(let[y,m]of Object.entries(c.map)){let v=m;this.shouldProcessWithPlaywrightFrameFallback(v,a)&&b.push({nodeId:y,src:v.attributes.src})}if(u.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${b.length}`),b.length>0){u.debug(`\u{1F50C} Found ${b.length} inaccessible iframe(s) for Playwright fallback, processing`);let y=-1;for(let m of Object.values(c.map)){let v=m;v.highlightIndex!=null&&(y=Math.max(y,v.highlightIndex))}u.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${y}`);for(let m=0;m<b.length;m++){let{nodeId:v,src:A}=b[m];u.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${m}]: ${A}`);let x=I=>{try{let L=new URL(I);if(L.protocol==="chrome-extension:"&&L.hostname)return`chrome-extension://${L.hostname}`;let V=L.origin;return V==="null"?null:V}catch{return null}},E=x(A);u.debug(`\u{1F50D} [ext-iframe] iframe src origin=${E??"null"}`);let T=null,C=e.frames().find(I=>{let L=I.url();if(L===A)return T="exact",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${L}`),!0;let V=x(L);return u.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${L} origin=${V??"null"} vs srcOrigin=${E??"null"}`),E&&V===E?(T="origin",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${L}`),!0):!1});if(!C){u.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${A}`),u.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(I=>I.url()).join(", ")}`);continue}u.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${A} (frame url: ${C.url()})`);try{let I={...d,initialHighlightIndex:y+1,domTreeRoot:"body"};u.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${I.initialHighlightIndex}`);let L=await C.evaluate(({code:z,argsObj:X})=>new Function("return "+z)()(X),{code:this.jsCode,argsObj:I});if(u.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(L?.map??{}).length} rootId=${L?.rootId}`),!L?.map||!L.rootId){u.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let V=Object.values(L.map).filter(z=>z.highlightIndex!=null);u.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${V.length}`);for(let z of V){let X=z;u.debug(`\u{1F50D} [ext-iframe] - <${X.tagName}> highlightIndex=${X.highlightIndex} text="${X.children?.length?"...":""}"`)}for(let z of Object.values(L.map)){let X=z;X.highlightIndex!=null&&(y=Math.max(y,X.highlightIndex))}let q=`ext_${m}_`;for(let[z,X]of Object.entries(L.map)){let ke={...X};ke.children&&(ke.children=ke.children.map(Re=>`${q}${Re}`)),c.map[`${q}${z}`]=ke}let ve=c.map[v];ve?(ve.children=[...ve.children||[],`${q}${L.rootId}`],u.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${v}`)):u.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${v} not found in map`),u.debug(`\u2705 Merged fallback iframe content from: ${A}`)}catch(I){u.warn(`Failed to process fallback iframe ${A}:`,I)}}}if(c&&c.perfMetrics){let y=c.perfMetrics.nodeMetrics?.totalNodes??0,m=0;if(c.map)for(let A of Object.values(c.map))typeof A=="object"&&A!==null&&A.isInteractive&&m++;let v=e.url().length>50?e.url().slice(0,50)+"...":e.url();u.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${v} interactive=${m}/${y}`)}u.debug("\u{1F504} Starting TypeScript DOM tree construction...");let k=await this.constructDomTree(c);return u.debug("\u2705 TypeScript DOM tree construction completed"),k}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,o=new Map,a=new Map;for(let[s,l]of Object.entries(t)){let[d,c]=this.parseNode(l);d!==null&&(o.set(s,d),a.set(s,c),d instanceof be&&d.highlightIndex!==null&&n.set(d.highlightIndex,d))}for(let[s,l]of a){let d=o.get(s);if(d instanceof be)for(let c of l){let h=o.get(c);h&&(h.parent=d,d.children.push(h))}}let r=o.get(i);if(!r||!(r instanceof be))throw new Error("Failed to parse HTML to dictionary");return[r,n]}parseNode(e){if(!e)return[null,[]];if(e.type==="TEXT_NODE")return[new Wt(e.text,e.isVisible,null),[]];let t=null;e.viewport&&(t={width:e.viewport.width,height:e.viewport.height,scrollX:e.viewport.scrollX,scrollY:e.viewport.scrollY});let i=e.shadowHostXPaths??[],n=new be(e.tagName,e.xpath,e.attributes||{},[],e.isVisible??!1,e.isInteractive??!1,e.isScrollable??!1,e.markAsClickable??!1,e.isTopElement??!1,e.isInViewport??!1,e.shadowRoot??!1,e.highlightIndex??null,e.viewportCoordinates??null,e.pageCoordinates??null,t,i,null),o=e.children||[];return[n,o]}}});var ss,nn=w(()=>{"use strict";R();P();ss=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.keys;if(!o||typeof o!="string")throw new Error("Missing or invalid keys for send keys on element action");let a=O(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.press(o,{timeout:r}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=Me(e);if(!t){let o=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(o)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",n=D();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});var ls,cs,Ng,on=w(()=>{"use strict";ls=require("zod"),cs=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},Ng=ls.z.object({})});var ds,an=w(()=>{"use strict";R();P();ds=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=O(e,t);if(o){await o.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let r=a.x+n.kwargs.relative_x+a.width/2,s=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s,{button:"right",delay:100}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.kwargs.y,{button:"right"}),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("right_click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var us,rn=w(()=>{"use strict";us=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.code;if(!o)throw new Error("Missing code for js_action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 js_action requires an agent reference");await new Function("page","agent",`
|
|
4088
|
+
}`,returnByValue:!0});l.value&&i.push({axNode:r,...l.value})}catch(l){u.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=un){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),o=dn.join(","),{nodeIds:a}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:o});u.debug(`\u{1F50D} Checking ${Math.min(a.length,t)} elements for event listeners`);for(let r of a.slice(0,t))try{let{object:s}=await e.send("DOM.resolveNode",{nodeId:r});if(!s.objectId)continue;let{listeners:l}=await e.send("DOMDebugger.getEventListeners",{objectId:s.objectId}),d=l.filter(c=>lt.has(c.type));if(d.length>0){let{node:c}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:c.backendNodeId,eventTypes:d.map(h=>h.type)})}await e.send("Runtime.releaseObject",{objectId:s.objectId})}catch{}u.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){u.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new xe("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),n=0;for(let o of e){let a=o.axNode.role?.value||"",r=o.axNode.name?.value||"",s=["button","link","menuitem","tab","switch"].includes(a),l=new xe(o.tagName,o.xpath,o.attributes,[],o.isVisible,!0,a==="scrollbar",s,o.isTopElement,o.isInViewport,!1,n,o.boundingRect?{topLeft:{x:o.boundingRect.x,y:o.boundingRect.y},topRight:{x:o.boundingRect.x+o.boundingRect.width,y:o.boundingRect.y},bottomLeft:{x:o.boundingRect.x,y:o.boundingRect.y+o.boundingRect.height},bottomRight:{x:o.boundingRect.x+o.boundingRect.width,y:o.boundingRect.y+o.boundingRect.height},center:{x:o.boundingRect.x+o.boundingRect.width/2,y:o.boundingRect.y+o.boundingRect.height/2},width:o.boundingRect.width,height:o.boundingRect.height}:null,null,null,[],i);if(r){let d=new Ut(r,!0,l);l.children.push(d)}i.children.push(l),t.set(n,l),n++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:n}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:n,colors:o})=>{let a="playwright-highlight-container",r=document.getElementById(a);r||(r=document.createElement("div"),r.id=a,r.style.position="fixed",r.style.pointerEvents="none",r.style.top="0",r.style.left="0",r.style.width="100%",r.style.height="100%",r.style.zIndex="2147483647",r.style.backgroundColor="transparent",document.body.appendChild(r)),n.forEach((s,l)=>{if(!s.boundingRect)return;let d=o[l%o.length],c=s.boundingRect,h=document.createElement("div");h.style.position="fixed",h.style.border=`1px solid ${d}`,h.style.backgroundColor="transparent",h.style.pointerEvents="none",h.style.boxSizing="border-box",h.style.top=`${c.y}px`,h.style.left=`${c.x}px`,h.style.width=`${c.width}px`,h.style.height=`${c.height}px`,r.appendChild(h);let p=document.createElement("div");p.style.position="fixed",p.style.background=d,p.style.color="white",p.style.padding="1px 4px",p.style.borderRadius="4px",p.style.fontSize=l>=100?"8px":"12px",p.textContent=String(l);let g=Math.max(0,c.y-16),b=Math.max(0,Math.min(c.x+c.width-20,window.innerWidth-25));p.style.top=`${g}px`,p.style.left=`${b}px`,r.appendChild(p)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let n=document.getElementById("playwright-highlight-container");n&&n.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(o=>o()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),u.debug("\u2705 Highlights removed from page")}catch(n){u.warn("Failed to remove highlights:",n.message)}for(let n of e.frames()){let o=n.url();if(!(!o.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(o,t)))try{await n.evaluate(i)}catch{}}}async getCrossOriginIframes(e){let t=await e.locator("iframe").filter({hasNot:e.locator(":visible")}).evaluateAll(s=>s.map(l=>l.src)),i=s=>{try{let l=new URL(s);return["doubleclick.net","adroll.com","googletagmanager.com"].some(d=>l.hostname.includes(d))}catch{return!1}},n=e.url(),o=new URL(n).hostname,a=e.frames(),r=[];for(let s of a){let l=s.url();try{let d=new URL(l).hostname;d&&d!==o&&!t.includes(l)&&!i(l)&&r.push(l)}catch{continue}}return r}async buildDomTree(e,t,i,n,o,a,r,s,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(dh(e.url()))return[new xe("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let d={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:o,alwaysHighlightFileInput:r,sameRectIoUThreshold:s,actionIntent:l,domTreeRoot:this.domTreeRoot};u.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let c,h=null;if(this.useDomTreeTs&&t)try{let y={...d,phase:"boxes",grayscaleImage:null},m=await e.evaluate(({code:C,argsObj:I})=>new Function("return "+C)()(I),{code:this.jsCode,argsObj:y});u.debug(`\u{1F4E6} Phase 1: Drew ${m.elementData?.length||0} bounding boxes`);let x=await e.screenshot({type:"png",fullPage:!1});u.debug("\u{1F4F8} Captured screenshot with bounding boxes");let A=performance.now(),v=await us(x);h=v.pixels;let E=Math.round(performance.now()-A);u.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${v.width}x${v.height}) in ${E}ms`);let T={...d,phase:"labels",grayscaleImage:h,elementData:m.elementData};c=await e.evaluate(({code:C,argsObj:I})=>new Function("return "+C)()(I),{code:this.jsCode,argsObj:T}),c.map=m.map,c.rootId=m.rootId,c.highlightCount=m.highlightCount,c.perfMetrics=m.perfMetrics,u.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(y){u.warn("Two-phase rendering failed, falling back to legacy mode:",y.message),h=null;let m={...d,grayscaleImage:null};c=await e.evaluate(({code:x,argsObj:A})=>new Function("return "+x)()(A),{code:this.jsCode,argsObj:m}),u.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{c=await e.evaluate(({code:y,argsObj:m})=>new Function("return "+y)()(m),{code:this.jsCode,argsObj:d}),u.debug("\u2705 JavaScript DOM analysis completed")}catch(y){throw u.error("Error evaluating JavaScript:",y.message),y}if(!c||typeof c!="object")throw u.error("JavaScript returned invalid result:",c),new Error("JavaScript DOM analysis returned invalid result");if(!c.map||!c.rootId)throw u.error("JavaScript result missing map or rootId:",JSON.stringify(c,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(l!=="all"&&c.highlightCount===0){u.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let y={...d,actionIntent:"all"};c=await e.evaluate(({code:m,argsObj:x})=>new Function("return "+m)()(x),{code:this.jsCode,argsObj:y})}let p=Object.entries(c.map).filter(([,y])=>y.tagName==="iframe");u.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${p.length}`);for(let[y,m]of p){let x=m;u.debug(`\u{1F50D} [ext-iframe] iframe node id=${y} src=${x.attributes?.src} inaccessibleFrame=${x.inaccessibleFrame}`)}let g=e.frames();u.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let y of g)u.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${y.url()}`);let b=[];for(let[y,m]of Object.entries(c.map)){let x=m;this.shouldProcessWithPlaywrightFrameFallback(x,a)&&b.push({nodeId:y,src:x.attributes.src})}if(u.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${b.length}`),b.length>0){u.debug(`\u{1F50C} Found ${b.length} inaccessible iframe(s) for Playwright fallback, processing`);let y=-1;for(let m of Object.values(c.map)){let x=m;x.highlightIndex!=null&&(y=Math.max(y,x.highlightIndex))}u.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${y}`);for(let m=0;m<b.length;m++){let{nodeId:x,src:A}=b[m];u.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${m}]: ${A}`);let v=I=>{try{let L=new URL(I);if(L.protocol==="chrome-extension:"&&L.hostname)return`chrome-extension://${L.hostname}`;let V=L.origin;return V==="null"?null:V}catch{return null}},E=v(A);u.debug(`\u{1F50D} [ext-iframe] iframe src origin=${E??"null"}`);let T=null,C=e.frames().find(I=>{let L=I.url();if(L===A)return T="exact",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${L}`),!0;let V=v(L);return u.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${L} origin=${V??"null"} vs srcOrigin=${E??"null"}`),E&&V===E?(T="origin",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${L}`),!0):!1});if(!C){u.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${A}`),u.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(I=>I.url()).join(", ")}`);continue}u.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${A} (frame url: ${C.url()})`);try{let I={...d,initialHighlightIndex:y+1,domTreeRoot:"body"};u.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${I.initialHighlightIndex}`);let L=await C.evaluate(({code:z,argsObj:X})=>new Function("return "+z)()(X),{code:this.jsCode,argsObj:I});if(u.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(L?.map??{}).length} rootId=${L?.rootId}`),!L?.map||!L.rootId){u.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let V=Object.values(L.map).filter(z=>z.highlightIndex!=null);u.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${V.length}`);for(let z of V){let X=z;u.debug(`\u{1F50D} [ext-iframe] - <${X.tagName}> highlightIndex=${X.highlightIndex} text="${X.children?.length?"...":""}"`)}for(let z of Object.values(L.map)){let X=z;X.highlightIndex!=null&&(y=Math.max(y,X.highlightIndex))}let Z=`ext_${m}_`;for(let[z,X]of Object.entries(L.map)){let Se={...X};Se.children&&(Se.children=Se.children.map(He=>`${Z}${He}`)),c.map[`${Z}${z}`]=Se}let _e=c.map[x];_e?(_e.children=[..._e.children||[],`${Z}${L.rootId}`],u.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${x}`)):u.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${x} not found in map`),u.debug(`\u2705 Merged fallback iframe content from: ${A}`)}catch(I){u.warn(`Failed to process fallback iframe ${A}:`,I)}}}if(c&&c.perfMetrics){let y=c.perfMetrics.nodeMetrics?.totalNodes??0,m=0;if(c.map)for(let A of Object.values(c.map))typeof A=="object"&&A!==null&&A.isInteractive&&m++;let x=e.url().length>50?e.url().slice(0,50)+"...":e.url();u.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${x} interactive=${m}/${y}`)}u.debug("\u{1F504} Starting TypeScript DOM tree construction...");let k=await this.constructDomTree(c);return u.debug("\u2705 TypeScript DOM tree construction completed"),k}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,o=new Map,a=new Map;for(let[s,l]of Object.entries(t)){let[d,c]=this.parseNode(l);d!==null&&(o.set(s,d),a.set(s,c),d instanceof xe&&d.highlightIndex!==null&&n.set(d.highlightIndex,d))}for(let[s,l]of a){let d=o.get(s);if(d instanceof xe)for(let c of l){let h=o.get(c);h&&(h.parent=d,d.children.push(h))}}let r=o.get(i);if(!r||!(r instanceof xe))throw new Error("Failed to parse HTML to dictionary");return[r,n]}parseNode(e){if(!e)return[null,[]];if(e.type==="TEXT_NODE")return[new Ut(e.text,e.isVisible,null),[]];let t=null;e.viewport&&(t={width:e.viewport.width,height:e.viewport.height,scrollX:e.viewport.scrollX,scrollY:e.viewport.scrollY});let i=e.shadowHostXPaths??[],n=new xe(e.tagName,e.xpath,e.attributes||{},[],e.isVisible??!1,e.isInteractive??!1,e.isScrollable??!1,e.markAsClickable??!1,e.isTopElement??!1,e.isInViewport??!1,e.shadowRoot??!1,e.highlightIndex??null,e.viewportCoordinates??null,e.pageCoordinates??null,t,i,null),o=e.children||[];return[n,o]}}});var ys,mn=w(()=>{"use strict";F();P();ys=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.keys;if(!o||typeof o!="string")throw new Error("Missing or invalid keys for send keys on element action");let a=O(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.press(o,{timeout:r}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=Pe(e);if(!t){let o=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(o)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",n=D();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});var xs,vs,hf,pn=w(()=>{"use strict";xs=require("zod"),vs=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},hf=xs.z.object({})});var ks,gn=w(()=>{"use strict";F();P();ks=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=O(e,t);if(o){await o.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let r=a.x+n.kwargs.relative_x+a.width/2,s=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s,{button:"right",delay:100}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.kwargs.y,{button:"right"}),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("right_click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var _s,fn=w(()=>{"use strict";_s=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.code;if(!o)throw new Error("Missing code for js_action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 js_action requires an agent reference");await new Function("page","agent",`
|
|
4091
4089
|
return (async () => {
|
|
4092
4090
|
${o}
|
|
4093
4091
|
})();
|
|
4094
4092
|
`)(e,a)}transpile(e){let t=e.action_data?.kwargs?.code;return t?t.split(`
|
|
4095
|
-
`):["// Skipping js_action: missing code"]}}});var
|
|
4093
|
+
`):["// Skipping js_action: missing code"]}}});var Uo,Ss,xf,wn=w(()=>{"use strict";Uo=require("zod"),Ss=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.code;if(!o)throw new Error("Missing code for js_code action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 js_code requires an agent reference");await new Function("page","agent",`
|
|
4096
4094
|
return (async () => {
|
|
4097
4095
|
${o}
|
|
4098
4096
|
})();
|
|
4099
4097
|
`)(e,a)}transpile(e){let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
|
|
4100
|
-
`);for(let o of n)i.push(` ${o}`);return i.push("}"),i}},
|
|
4098
|
+
`);for(let o of n)i.push(` ${o}`);return i.push("}"),i}},xf=Uo.z.object({code:Uo.z.string().describe("JavaScript code to execute in the browser context")})});var Es,bn=w(()=>{"use strict";F();P();Es=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=O(e,t);if(o){await o.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let r=a.x+n.kwargs.relative_x+a.width/2,s=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s),await e.waitForTimeout(500)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(500);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var Ts,yn=w(()=>{"use strict";F();P();Ts=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=O(e,t);if(o){await o.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let r=a.x+n.kwargs.relative_x+a.width/2,s=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.dblclick(r,s,{delay:50}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.dblclick(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("double_click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var As,xn=w(()=>{"use strict";F();P();As=class{async execute(e,t,i){let n=i.getActionSettings().drag_drop_steps??10,o=t.action_data;if(!o)throw new Error("Action data not found");let a=o.kwargs,r=[a.coord_source_x,a.coord_source_y],s=[a.coord_target_x,a.coord_target_y];if(typeof a.relative_x=="number"&&typeof a.relative_y=="number"&&typeof a.delta_x=="number"&&typeof a.delta_y=="number"){let l=O(e,t);if(!l)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await l.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let d=await(await l).boundingBox();if(!d)throw new Error("Could not get bounding box for drag_drop element");let c=d.x+a.relative_x+d.width/2,h=d.y+a.relative_y+d.height/2,p=c+a.delta_x,g=h+a.delta_y;await e.mouse.move(c,h),await e.mouse.down(),n>0?await e.mouse.move(p,g,{steps:n}):await e.mouse.move(p,g),await e.mouse.up()}else if(r.every(l=>typeof l=="number")&&s.every(l=>typeof l=="number")){let[l,d]=r,[c,h]=s;await e.mouse.move(l,d),await e.mouse.down(),n>0?await e.mouse.move(c,h,{steps:n}):await e.mouse.move(c,h),await e.mouse.up()}else throw new Error("Missing coordinates for drag_drop action: requires either element-anchored coordinates with delta, or full absolute coordinates");await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return typeof t.relative_x=="number"&&(n.relative_x=t.relative_x),typeof t.relative_y=="number"&&(n.relative_y=t.relative_y),typeof t.delta_x=="number"&&(n.delta_x=t.delta_x),typeof t.delta_y=="number"&&(n.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(n.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(n.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(n.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(n.coord_target_y=t.coord_target_y),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("drag_drop", page, {',...i.map(o=>` ${o},`),"});"]}}});var Ms,vn=w(()=>{"use strict";Ms=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=this.generateFunctionCallCode(n.kwargs);if(!o)throw new Error("Missing function name for function action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 FunctionAction requires an agent reference");await new Function("page","agent",`
|
|
4101
4099
|
return (async () => {
|
|
4102
4100
|
${o}
|
|
4103
4101
|
})();
|
|
4104
|
-
`)(e,a)}transpile(e){let t=this.generateFunctionCallCode(e.action_data?.kwargs||{});return t?[t.endsWith(";")?t:`${t};`]:["// Skipping function: missing functionName"]}generateFunctionCallCode(e){let t=e.functionName;if(!t)return null;let i;if(Array.isArray(e.args))i=e.args.map(String);else if(Array.isArray(e.parameterNames)){let r=e.parameterValues||[];i=e.parameterNames.map((s,l)=>l<r.length?String(r[l]):"undefined")}else return`await ${t}()`;if(i.length===0)return`await ${t}()`;let n=["page","testContext","request","agent"],o=["undefined","null","true","false"],a=i.map(r=>n.includes(r)||o.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${a.join(", ")})`}}});var
|
|
4102
|
+
`)(e,a)}transpile(e){let t=this.generateFunctionCallCode(e.action_data?.kwargs||{});return t?[t.endsWith(";")?t:`${t};`]:["// Skipping function: missing functionName"]}generateFunctionCallCode(e){let t=e.functionName;if(!t)return null;let i;if(Array.isArray(e.args))i=e.args.map(String);else if(Array.isArray(e.parameterNames)){let r=e.parameterValues||[];i=e.parameterNames.map((s,l)=>l<r.length?String(r[l]):"undefined")}else return`await ${t}()`;if(i.length===0)return`await ${t}()`;let n=["page","testContext","request","agent"],o=["undefined","null","true","false"],a=i.map(r=>n.includes(r)||o.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${a.join(", ")})`}}});var kn,Is,_n=w(()=>{"use strict";ct();kn=require("crypto"),Is=class{static convertDomElementToHistoryElement(e){let t=this.getParentBranchPath(e),i=this.generateCssSelector(e);return{tagName:e.tagName,xpath:e.xpath,highlightIndex:e.highlightIndex,entireParentBranchPath:t,attributes:e.attributes,shadowRoot:e.shadowRoot,cssSelector:i,pageCoordinates:e.pageCoordinates,viewportCoordinates:e.viewportCoordinates,viewportInfo:e.viewportInfo}}static findHistoryElementInTree(e,t){let i=this.hashDomHistoryElement(e),n=o=>{if(o.highlightIndex!==null){let a=this.hashDomElement(o);if(this.compareHashes(a,i))return o}for(let a of o.children)if(a instanceof xe){let r=n(a);if(r!==null)return r}return null};return n(t)}static compareHistoryElementAndDomElement(e,t){let i=this.hashDomHistoryElement(e),n=this.hashDomElement(t);return this.compareHashes(i,n)}static hashDomHistoryElement(e){let t=this.parentBranchPathHash(e.entireParentBranchPath),i=this.attributesHash(e.attributes),n=this.xpathHash(e.xpath);return{branchPathHash:t,attributesHash:i,xpathHash:n}}static hashDomElement(e){let t=this.getParentBranchPath(e),i=this.parentBranchPathHash(t),n=this.attributesHash(e.attributes),o=this.xpathHash(e.xpath);return{branchPathHash:i,attributesHash:n,xpathHash:o}}static getParentBranchPath(e){let t=[],i=e;for(;i!==null&&i.parent!==null;)t.push(i),i=i.parent;return t.reverse(),t.map(n=>n.tagName)}static parentBranchPathHash(e){let t=e.join("/");return(0,kn.createHash)("sha256").update(t).digest("hex")}static attributesHash(e){let t=Object.entries(e).map(([i,n])=>`${i}=${n}`).join("");return(0,kn.createHash)("sha256").update(t).digest("hex")}static xpathHash(e){return(0,kn.createHash)("sha256").update(e).digest("hex")}static compareHashes(e,t){return e.branchPathHash===t.branchPathHash&&e.attributesHash===t.attributesHash&&e.xpathHash===t.xpathHash}static generateCssSelector(e){let t=e.attributes.id;if(t)return`#${t}`;let i=e.attributes.class;if(i){let n=i.split(/\s+/).filter(o=>o.trim());if(n.length>0)return`${e.tagName}.${n.join(".")}`}return e.tagName}}});var Ko,dt=w(()=>{"use strict";Ko=(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))(Ko||{})});var ut={};Ue(ut,{evaluateStatement:()=>Ve,executeAction:()=>Kt,executeStep:()=>ze,generateActionStep:()=>mt,runTask:()=>Xe});var ht=w(()=>{"use strict";jt();cn();sn();rt();Xi();Yi();nt();en();nn();Lt();Ot();Te();$t();Dt();_n();je();Ft();Wt();ct();Bt();Gt();ie();Ee();It();ot();Ct();K();Ke();R();te();dt();F();fe()});var jo,Cs,ww,Sn=w(()=>{"use strict";jo=require("zod"),Cs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.statement;if(!o)throw new Error("Missing statement for ai_action");let a=n.kwargs.use_pure_vision,{executeStep:r}=await Promise.resolve().then(()=>(ht(),ut)),s=await r(o,e,i,{usePureVision:a});if(s.status!=="success")throw new Error(s.error||"Action execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let n=JSON.stringify(i),o=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${n}, '${t||""}', ${o});`]}},ww=jo.z.object({statement:jo.z.string().describe('The action to perform (e.g., "click the submit button")')})});var zo,Ps,xw,En=w(()=>{"use strict";zo=require("zod"),Ps=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.statement;if(!o)throw new Error("Missing statement for ai_step");let{runTask:a}=await Promise.resolve().then(()=>(ht(),ut)),r=await a(o,e,i);if(r.status!=="success")throw new Error(r.error||"Task execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;return i?[`await agent.run(page, ${JSON.stringify(i)}, '${t||""}');`]:["// Skipping ai_step: missing statement"]}},xw=zo.z.object({statement:zo.z.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});function Ds(e,t){e.register({name:"ai_wait_until",description:'Wait until a specific condition is met on the page (e.g., "page loads", "spinner disappears", "button becomes enabled"). Use this instead of wait when the goal is to wait for something to happen rather than waiting a fixed duration.',schema:uh,async execute(i,n){let{condition:o,timeout_seconds:a=60}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Wait until: ${o}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:o,timeout_seconds:a}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Condition met: ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Wait until: ${o} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:o,timeout_seconds:a}},feedback:l.message}}}}})}var Tn,$s,uh,zt=w(()=>{"use strict";Tn=require("zod"),$s=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.condition;if(!o)throw new Error("Missing condition for ai_wait_until");let a=(n.kwargs.timeout_seconds||60)*1e3,r=5e3,s=Date.now(),{evaluateStatement:l}=await Promise.resolve().then(()=>(ht(),ut));for(;Date.now()-s<a;){if((await l(o,e,i,{})).success)return;await e.waitForTimeout(r)}throw new Error(`Timeout waiting for condition: ${o}`)}transpile(e,t){let i=e.action_data?.kwargs?.condition,n=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${n}, '${t}');`]:["// Skipping ai_wait_until: missing condition"]}},uh=Tn.z.object({condition:Tn.z.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:Tn.z.number().positive().optional().describe("Timeout in seconds (default: 60)")})});async function hh(e,t,i,n){return{...await N(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function Ls(e,t){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:"select_dropdown_option",kwargs:t},feedback:"Element not found in DOM"}}function Ns(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:mh,usesElementIndex:!0,async execute(i,n){let{element_index:o,option:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await B(n,o);if(!d)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:Ls(l||`Select option in dropdown ${o}`,{index:o,option:a})};let c=await hh(d,r,a,l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Selected option "${a}" in dropdown ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:Ls(`Select option in dropdown ${o}`,{index:o,option:a})}}}})}var Vt,Os,mh,Xt=w(()=>{"use strict";K();F();Vt=require("zod");P();Os=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.text||n.kwargs.option,a=O(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(a&&o)await a.selectOption(o,{timeout:r});else throw new Error("Missing locator or option label for select_dropdown_option action")}transpile(e){let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("select_dropdown_option", page, {',...i.map(n=>` ${n},`),"});"]}};mh=Vt.z.object({element_index:Vt.z.number().int().describe("Index of the dropdown/select element"),option:Vt.z.string().describe("Option value, label, or index to select"),timeout_ms:Vt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function ph(e,t,i,n){return{...await N(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function Vo(e,t){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:"set_date_for_native_date_picker",kwargs:t},feedback:"Element not found in DOM"}}function Fs(e,t){e.register({name:"set_date_for_native_date_picker",description:`Set a date in a native HTML date picker input (<input type="date">).
|
|
4105
4103
|
|
|
4106
4104
|
IMPORTANT: ONLY use this action for input elements that have type="date" attribute (native HTML date picker).
|
|
4107
4105
|
Do NOT use it for custom/non-native date pickers
|
|
4108
4106
|
|
|
4109
|
-
The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:th,usesElementIndex:!0,async execute(i,n){let{element_index:o,date:a}=i,{page:r,agentServices:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Date picker element with index ${o} not found`,actionEntity:Fo(`Set date to ${a} on element ${o}`,{index:o,date:a})};let d=l.attributes.type;if(d!=="date")return{success:!1,error:`Element ${o} is not a native date picker (type="${d}"). This action only works with <input type="date">.`,actionEntity:Fo(`Set date to ${a} on element ${o}`,{index:o,date:a})};let c=await eh(`Set date to ${a} on element ${o}`,l,r,a);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Set date to ${a} on element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Fo(`Set date to ${a} on element ${o}`,{index:o,date:a})}}}})}var zt,Es,th,Vt=w(()=>{"use strict";K();R();zt=require("zod");P();Es=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.date;if(!o)throw new Error("Date value is required");if(!/^\d{4}-\d{2}-\d{2}$/.test(o))throw new Error(`Invalid date format: ${o}. Expected format: YYYY-MM-DD (e.g., 2024-03-15)`);let a=i.replaceVariables(String(o)),r=O(e,t);if(r){let s=await r.getAttribute("type").catch(()=>null);if(s&&s!=="date")throw new Error(`Element is not a native date picker (type="${s}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await r.fill(a,{timeout:D(i,t.action_data?.kwargs?.timeout_ms)})}else throw new Error("No locator found for set_date_for_native_date_picker action")}transpile(e){let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(n=>` ${n},`),"});"]}};th=zt.z.object({element_index:zt.z.number().int().describe("Index of the native date picker input element"),date:zt.z.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:zt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Ms(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:ih,async execute(i,n){let o=i.tab_index,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Switch to tab ${o}`,action_data:{action_name:"switch_tab",kwargs:{page_id:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Switched to tab ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Switch to tab ${o}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:o}},feedback:l.message}}}}})}var Ho,As,ih,Xt=w(()=>{"use strict";Ho=require("zod"),As=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.page_id??n.kwargs.tab_index??0;if(typeof o=="number"){let a=e.context().pages(),r=o===-1?a.length-1:o;if(i){let s=await i.switchTab(r);await s.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await s.waitForTimeout(500)}}else throw new Error("Missing page_id for switch_tab action")}transpile(e){return['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]}},ih=Ho.z.object({tab_index:Ho.z.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});async function Ps(e,t,i,n,o,a){let r=Array.isArray(t)?t:[t];if(r.length===0)throw new Error("No file paths provided for upload");let s=r.map(c=>{if(c.startsWith("/")||c.match(/^[A-Za-z]:\\/))return c;let h=n.testDataDir||process.cwd();return Cs.default.join(h,c)});u.info(`Uploading files: ${s.join(", ")}`);let l=i.timeout||2e4,d={useFileInput:i.useFileInput||!1,timeout:l};if(i.selector&&typeof i.selector!="string"){let c=i.selector;await wn(e,c,s,d);return}if(i.selector&&typeof i.selector=="string"){let c=i.selector,h=(c.startsWith("xpath="),e.locator(c));await wn(e,h,s,d);return}if(o){let c=r.map(p=>`"${p}"`).join(", "),h="";i.targetDescription?h=`Upload ${c} to ${i.targetDescription}`:h=`Upload ${c}`,u.info(`Using AI to handle file upload: ${h}`),await o(e,h,a)}else throw new Error("No selector provided and AI action execution is not available")}async function wn(e,t,i,n){let{useFileInput:o,timeout:a,mockShowOpenFilePicker:r}=n;if(r){u.info("Using mockShowOpenFilePicker approach");let s=i.map(l=>({path:l,buffer:new Uint8Array(Is.default.readFileSync(l))}));await e.evaluate(l=>{window.__pw_showOpenFilePicker_mock_files=l},s),await t.click({timeout:a}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(o)u.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:a}),await e.waitForTimeout(3e3);else{u.info("Using file chooser approach");let s=e.waitForEvent("filechooser",{timeout:a});s.catch(()=>{}),await t.click({timeout:a}),await(await s).setFiles(i),await e.waitForTimeout(3e3)}u.info(`Successfully uploaded ${i.length} file(s)`)}var Is,Cs,Yt=w(()=>{"use strict";F();Is=W(require("fs"),1),Cs=W(require("path"),1)});async function nh(e,t,i={},n){return{...await N(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function $s(e,t){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:"upload_file",kwargs:t},feedback:"Element not found in DOM"}}function Ls(e,t){e.register({name:"upload_file",description:'Click on target element (usually contains hints like "Upload file" or "Choose file" etc.) to trigger the file upload dialog, and choose the files to upload',schema:oh,usesElementIndex:!0,async execute(i,n){let{element_index:o,paths:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await B(n,o);if(!d)return{success:!1,error:`File input element with index ${o} not found`,actionEntity:$s(l||`Upload file to element ${o}`,{index:o,paths:a})};let c=await nh(d,r,{paths:a},l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Uploaded file to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:$s(l||`Upload file to element ${o}`,{index:o,paths:a})}}}})}var Se,Ds,oh,lw,Jt=w(()=>{"use strict";Yt();K();R();Se=require("zod");P();Ds=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=[];if(n.kwargs.paths?o=Array.isArray(n.kwargs.paths)?n.kwargs.paths:[n.kwargs.paths]:n.kwargs.path&&(o=Array.isArray(n.kwargs.path)?n.kwargs.path:[n.kwargs.path]),o.length===0)throw new Error("No file paths provided for upload_file action");await i.downloadTestDataFiles(o);let a=o.map(d=>i.getTestDataFilePath(d)),r=O(e,t);if(!r)throw new Error("Missing locator for upload_file action");let s=n.kwargs.use_file_input||!1,l=i.getActionSettings().mock_show_open_file_picker??!1;await wn(e,r,a,{useFileInput:s,timeout:D(i,t.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:l})}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return t.paths?n.paths=t.paths:t.path&&(n.path=t.path),t.use_file_input&&(n.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...i.map(o=>` ${o},`),"});"]}};oh=Se.z.object({element_index:Se.z.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:Se.z.string().describe("Paths to the files to upload"),timeout_ms:Se.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});lw=Se.z.object({element_index:Se.z.number().int().describe("Index of the file input element"),paths:Se.z.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:Se.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Ns(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:ah,async execute(i,n){let{seconds:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Wait ${o} seconds`,action_data:{action_name:"wait",kwargs:{seconds:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Waited ${o} seconds`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Wait ${o} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:o}},feedback:l.message}}}}})}var Wo,Os,ah,qt=w(()=>{"use strict";Wo=require("zod"),Os=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.seconds||1;await e.waitForTimeout(n*1e3)}transpile(e){return[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]}},ah=Wo.z.object({seconds:Wo.z.number().positive().describe("Number of seconds to wait")})});function Fs(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:rh,async execute(i,n){let{timeout_seconds:o=10}=i,{page:a,agentServices:r}=n;try{let s={action_description:`Wait for download to complete (timeout: ${o}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:o}}};return await t.execute(a,s,r),{success:!0,actionEntity:s,message:"Download completed"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:o}},feedback:s.message}}}}})}var Bo,Rs,rh,Zt=w(()=>{"use strict";Bo=require("zod"),Rs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,o)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},rh=Bo.z.object({timeout_seconds:Bo.z.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});function Hs(e,t){e.register({name:"press",description:"Press a single keyboard key or key combination. Supports combinations like `Control+A` for select all. Does NOT support sequences - call this action multiple times to press keys in sequence.",schema:sh,async execute(i,n){let{keys:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Press keys "${o}"`,action_data:{action_name:"press",kwargs:{keys:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Pressed keys "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Press keys "${o}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:o}},feedback:l.message}}}}})}var Go,Uo,sh,Qt=w(()=>{"use strict";Go=require("zod"),Uo=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.keys;if(!n||typeof n!="string")throw new Error("Missing or invalid keys for press action");await e.keyboard.press(n),await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]}},sh=Go.z.object({keys:Go.z.string().describe("A single key or key combination to press (e.g. Escape, Backspace, Insert, PageDown, Delete, Tab, Enter). Key combinations like `Control+o`, `Control+Shift+T`, `ControlOrMeta+a` are supported. Note: This does NOT support sequences - to press multiple keys in sequence (e.g., Control+A then Backspace), call this action multiple times.")})});function Gs(e,t){e.register({name:"reload_page",description:"Reload the current page. WARNING: This will reset any in-progress forms or multi-step flows (like login). Only use when you need to refresh stale data or clear a stuck state. Do NOT use during login, checkout, or form submission flows.",schema:lh,async execute(i,n){let{page:o,agentServices:a}=n;try{let r={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await t.execute(o,r,a),{success:!0,actionEntity:r,message:`Reloaded ${o.url()}`}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Reload page (failed)",action_data:{action_name:"reload_page",kwargs:{}},feedback:r.message}}}}})}var Ws,Bs,lh,ei=w(()=>{"use strict";R();Ws=require("zod");P();Bs=class{async execute(e,t){await e.reload({timeout:ge}),await e.waitForLoadState("load",{timeout:ge}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},lh=Ws.z.object({})});async function ch(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Us(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Ks(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:dh,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:Us(`Right-click element ${o}`,"right_click",{index:o})};let d=s||`Right-click element ${o}`,c=await ch("right_click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Right-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Us(`Right-click element ${o}`,"right_click",{index:o})}}}})}var bn,Ko,dh,ti=w(()=>{"use strict";K();R();bn=require("zod");P();Ko=class{async execute(e,t,i){let n=O(e,t),o=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({button:"right",timeout:o});else throw new Error("No locator found for right_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("right_click", page, {});']:['await agent.execAction("right_click", page, {',...t.map(i=>` ${i},`),"});"]}};dh=bn.z.object({element_index:bn.z.number().int().describe("Index of the element to right-click"),timeout_ms:bn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function zs(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:uh,async execute(i,n){let{name:o,value:a}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Save variable "${o}" = "${a}"`,action_data:{action_name:"save_variable",kwargs:{name:o,value:a}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Saved variable "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Save variable "${o}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:o,value:a}},feedback:l.message}}}}})}var yn,js,uh,ii=w(()=>{"use strict";yn=require("zod"),js=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.name,a=n.kwargs.value;if(!o||a===void 0)throw new Error("Missing variable name or value for save_variable");o.startsWith("$")&&(o=o.slice(1)),i.saveVariable(o,a)}transpile(e){let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]}},uh=yn.z.object({name:yn.z.string().describe("Variable name to save"),value:yn.z.string().describe("Value to save in the variable")})});async function hh(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function mh(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function Vs(e,t){e.register({name:"scroll",description:"Scroll the page by specified number of pages (set down=True to scroll down, down=False to scroll up, num_pages=number of pages to scroll like 0.5 for half page, 1.0 for one page, etc.). ",schema:ph,async execute(i,n){let{down:o,num_pages:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=l||`Scroll ${o?"down":"up"} ${a} page(s)`,c=await hh("scroll",d,{down:o,num_pages:a});return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Scrolled ${o?"down":"up"} ${a} page(s)`}}catch(d){return{success:!1,error:d.message,actionEntity:mh(l||`Scroll ${o?"down":"up"} ${a} page(s)`,"scroll",{down:o,num_pages:a})}}}})}var xn,ni,ph,oi=w(()=>{"use strict";xn=require("zod"),ni=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.down??!0,o=i.kwargs.num_pages??1,a=n?1:-1;await e.evaluate(`window.scrollBy(0, window.innerHeight * ${o} * ${a})`)}transpile(e){let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]}};ph=xn.z.object({down:xn.z.boolean().describe("True to scroll down, False to scroll up"),num_pages:xn.z.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});async function gh(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Xs(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Js(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:fh,usesElementIndex:!0,async execute(i,n){let{element_index:o,delta_x:a,delta_y:r}=i,{page:s,agentServices:l}=n;try{let d=await B(n,o);if(!d)return{success:!1,error:`Element with index ${o} not found`,actionEntity:Xs(`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:r})};let c=await gh("scroll_on_element",`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,d,s,{delta_x:a,delta_y:r});return await t.execute(s,c,l),{success:!0,actionEntity:c,message:`Scrolled on element ${o} horizontally: ${a}px, vertically: ${r}px`}}catch(d){return{success:!1,error:d.message,actionEntity:Xs(`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:r})}}}})}var dt,Ys,fh,ai=w(()=>{"use strict";K();R();dt=require("zod");P();Ys=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.delta_x||0,a=n.kwargs.delta_y||0,r=O(e,t),s=D(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:s}),await e.mouse.wheel(o,a);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Me(e);if(!t){let o=e.action_data?.kwargs?.delta_x||0,a=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${o}, delta_y: ${a} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,n=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${D()} });`,`await page.mouse.wheel(${i}, ${n});`]}};fh=dt.z.object({element_index:dt.z.number().int().describe("Index of the scrollable element"),delta_x:dt.z.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:dt.z.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:dt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Zs(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:wh,async execute(i,n){let{text:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Scroll to text "${o}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Scrolled to text "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Scroll to text "${o}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:o}},feedback:l.message}}}}})}var jo,qs,wh,ri=w(()=>{"use strict";jo=require("zod"),qs=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.text;if(n)await e.getByText(n,{exact:!1}).first().scrollIntoViewIfNeeded(),await e.waitForTimeout(500);else throw new Error("Missing text for scroll_to_text action")}transpile(e){let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]}},wh=jo.z.object({text:jo.z.string().describe("Text to scroll to on the page")})});async function bh(e,t,i){return{...await N(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function Qs(e,t){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:"get_dropdown_options",kwargs:t},feedback:"Element not found in DOM"}}function tl(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:yh,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:Qs(s||`Get options from dropdown ${o}`,{index:o})};let d=await bh(l,a,s);return await t.execute(a,d,r),{success:!0,actionEntity:d,message:d.feedback||"No options found"}}catch(l){return{success:!1,error:l.message,actionEntity:Qs(s||`Get options from dropdown ${o}`,{index:o})}}}})}var zo,el,yh,si=w(()=>{"use strict";K();zo=require("zod"),el=class{async execute(e,t,i){if(!t.xpath)throw new Error("XPath not found in action entity");let n=[];for(let o of e.frames())try{let a=await o.evaluate(r=>{let s=document.evaluate(r,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return s?{options:Array.from(s.options).map(l=>({text:l.text,value:l.value,index:l.index})),id:s.id,name:s.name}:null},t.xpath);if(a){let r=[];for(let s of a.options){let l=JSON.stringify(s.text);r.push(`${s.index}: text=${l}`)}n.push(...r)}}catch{}if(n.length>0){let o=n.join(`
|
|
4107
|
+
The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:gh,usesElementIndex:!0,async execute(i,n){let{element_index:o,date:a}=i,{page:r,agentServices:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Date picker element with index ${o} not found`,actionEntity:Vo(`Set date to ${a} on element ${o}`,{index:o,date:a})};let d=l.attributes.type;if(d!=="date")return{success:!1,error:`Element ${o} is not a native date picker (type="${d}"). This action only works with <input type="date">.`,actionEntity:Vo(`Set date to ${a} on element ${o}`,{index:o,date:a})};let c=await ph(`Set date to ${a} on element ${o}`,l,r,a);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Set date to ${a} on element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Vo(`Set date to ${a} on element ${o}`,{index:o,date:a})}}}})}var Yt,Rs,gh,Jt=w(()=>{"use strict";K();F();Yt=require("zod");P();Rs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.date;if(!o)throw new Error("Date value is required");if(!/^\d{4}-\d{2}-\d{2}$/.test(o))throw new Error(`Invalid date format: ${o}. Expected format: YYYY-MM-DD (e.g., 2024-03-15)`);let a=i.replaceVariables(String(o)),r=O(e,t);if(r){let s=await r.getAttribute("type").catch(()=>null);if(s&&s!=="date")throw new Error(`Element is not a native date picker (type="${s}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await r.fill(a,{timeout:D(i,t.action_data?.kwargs?.timeout_ms)})}else throw new Error("No locator found for set_date_for_native_date_picker action")}transpile(e){let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(n=>` ${n},`),"});"]}};gh=Yt.z.object({element_index:Yt.z.number().int().describe("Index of the native date picker input element"),date:Yt.z.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:Yt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Ws(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:fh,async execute(i,n){let o=i.tab_index,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Switch to tab ${o}`,action_data:{action_name:"switch_tab",kwargs:{page_id:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Switched to tab ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Switch to tab ${o}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:o}},feedback:l.message}}}}})}var Xo,Hs,fh,qt=w(()=>{"use strict";Xo=require("zod"),Hs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.page_id??n.kwargs.tab_index??0;if(typeof o=="number"){let a=e.context().pages(),r=o===-1?a.length-1:o;if(i){let s=await i.switchTab(r);await s.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await s.waitForTimeout(500)}}else throw new Error("Missing page_id for switch_tab action")}transpile(e){return['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]}},fh=Xo.z.object({tab_index:Xo.z.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});async function Us(e,t,i,n,o,a){let r=Array.isArray(t)?t:[t];if(r.length===0)throw new Error("No file paths provided for upload");let s=r.map(c=>{if(c.startsWith("/")||c.match(/^[A-Za-z]:\\/))return c;let h=n.testDataDir||process.cwd();return Gs.default.join(h,c)});u.info(`Uploading files: ${s.join(", ")}`);let l=i.timeout||2e4,d={useFileInput:i.useFileInput||!1,timeout:l};if(i.selector&&typeof i.selector!="string"){let c=i.selector;await An(e,c,s,d);return}if(i.selector&&typeof i.selector=="string"){let c=i.selector,h=(c.startsWith("xpath="),e.locator(c));await An(e,h,s,d);return}if(o){let c=r.map(p=>`"${p}"`).join(", "),h="";i.targetDescription?h=`Upload ${c} to ${i.targetDescription}`:h=`Upload ${c}`,u.info(`Using AI to handle file upload: ${h}`),await o(e,h,a)}else throw new Error("No selector provided and AI action execution is not available")}async function An(e,t,i,n){let{useFileInput:o,timeout:a,mockShowOpenFilePicker:r}=n;if(r){u.info("Using mockShowOpenFilePicker approach");let s=i.map(l=>({path:l,buffer:new Uint8Array(Bs.default.readFileSync(l))}));await e.evaluate(l=>{window.__pw_showOpenFilePicker_mock_files=l},s),await t.click({timeout:a}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(o)u.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:a}),await e.waitForTimeout(3e3);else{u.info("Using file chooser approach");let s=e.waitForEvent("filechooser",{timeout:a});s.catch(()=>{}),await t.click({timeout:a}),await(await s).setFiles(i),await e.waitForTimeout(3e3)}u.info(`Successfully uploaded ${i.length} file(s)`)}var Bs,Gs,Zt=w(()=>{"use strict";R();Bs=W(require("fs"),1),Gs=W(require("path"),1)});async function wh(e,t,i={},n){return{...await N(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function Ks(e,t){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:"upload_file",kwargs:t},feedback:"Element not found in DOM"}}function zs(e,t){e.register({name:"upload_file",description:'Click on target element (usually contains hints like "Upload file" or "Choose file" etc.) to trigger the file upload dialog, and choose the files to upload',schema:bh,usesElementIndex:!0,async execute(i,n){let{element_index:o,paths:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await B(n,o);if(!d)return{success:!1,error:`File input element with index ${o} not found`,actionEntity:Ks(l||`Upload file to element ${o}`,{index:o,paths:a})};let c=await wh(d,r,{paths:a},l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Uploaded file to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:Ks(l||`Upload file to element ${o}`,{index:o,paths:a})}}}})}var Ae,js,bh,Ww,Qt=w(()=>{"use strict";Zt();K();F();Ae=require("zod");P();js=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=[];if(n.kwargs.paths?o=Array.isArray(n.kwargs.paths)?n.kwargs.paths:[n.kwargs.paths]:n.kwargs.path&&(o=Array.isArray(n.kwargs.path)?n.kwargs.path:[n.kwargs.path]),o.length===0)throw new Error("No file paths provided for upload_file action");await i.downloadTestDataFiles(o);let a=o.map(d=>i.getTestDataFilePath(d)),r=O(e,t);if(!r)throw new Error("Missing locator for upload_file action");let s=n.kwargs.use_file_input||!1,l=i.getActionSettings().mock_show_open_file_picker??!1;await An(e,r,a,{useFileInput:s,timeout:D(i,t.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:l})}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return t.paths?n.paths=t.paths:t.path&&(n.path=t.path),t.use_file_input&&(n.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...i.map(o=>` ${o},`),"});"]}};bh=Ae.z.object({element_index:Ae.z.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:Ae.z.string().describe("Paths to the files to upload"),timeout_ms:Ae.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});Ww=Ae.z.object({element_index:Ae.z.number().int().describe("Index of the file input element"),paths:Ae.z.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:Ae.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Xs(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:yh,async execute(i,n){let{seconds:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Wait ${o} seconds`,action_data:{action_name:"wait",kwargs:{seconds:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Waited ${o} seconds`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Wait ${o} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:o}},feedback:l.message}}}}})}var Yo,Vs,yh,ei=w(()=>{"use strict";Yo=require("zod"),Vs=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.seconds||1;await e.waitForTimeout(n*1e3)}transpile(e){return[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]}},yh=Yo.z.object({seconds:Yo.z.number().positive().describe("Number of seconds to wait")})});function Js(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:xh,async execute(i,n){let{timeout_seconds:o=10}=i,{page:a,agentServices:r}=n;try{let s={action_description:`Wait for download to complete (timeout: ${o}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:o}}};return await t.execute(a,s,r),{success:!0,actionEntity:s,message:"Download completed"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:o}},feedback:s.message}}}}})}var Jo,Ys,xh,ti=w(()=>{"use strict";Jo=require("zod"),Ys=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,o)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},xh=Jo.z.object({timeout_seconds:Jo.z.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});function qs(e,t){e.register({name:"press",description:"Press a single keyboard key or key combination. Supports combinations like `Control+A` for select all. Does NOT support sequences - call this action multiple times to press keys in sequence.",schema:vh,async execute(i,n){let{keys:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Press keys "${o}"`,action_data:{action_name:"press",kwargs:{keys:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Pressed keys "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Press keys "${o}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:o}},feedback:l.message}}}}})}var qo,Zo,vh,ii=w(()=>{"use strict";qo=require("zod"),Zo=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.keys;if(!n||typeof n!="string")throw new Error("Missing or invalid keys for press action");await e.keyboard.press(n),await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]}},vh=qo.z.object({keys:qo.z.string().describe("A single key or key combination to press (e.g. Escape, Backspace, Insert, PageDown, Delete, Tab, Enter). Key combinations like `Control+o`, `Control+Shift+T`, `ControlOrMeta+a` are supported. Note: This does NOT support sequences - to press multiple keys in sequence (e.g., Control+A then Backspace), call this action multiple times.")})});function el(e,t){e.register({name:"reload_page",description:"Reload the current page. WARNING: This will reset any in-progress forms or multi-step flows (like login). Only use when you need to refresh stale data or clear a stuck state. Do NOT use during login, checkout, or form submission flows.",schema:kh,async execute(i,n){let{page:o,agentServices:a}=n;try{let r={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await t.execute(o,r,a),{success:!0,actionEntity:r,message:`Reloaded ${o.url()}`}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Reload page (failed)",action_data:{action_name:"reload_page",kwargs:{}},feedback:r.message}}}}})}var Zs,Qs,kh,ni=w(()=>{"use strict";F();Zs=require("zod");P();Qs=class{async execute(e,t){await e.reload({timeout:we}),await e.waitForLoadState("load",{timeout:we}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},kh=Zs.z.object({})});async function _h(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function tl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function il(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:Sh,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:tl(`Right-click element ${o}`,"right_click",{index:o})};let d=s||`Right-click element ${o}`,c=await _h("right_click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Right-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:tl(`Right-click element ${o}`,"right_click",{index:o})}}}})}var Mn,Qo,Sh,oi=w(()=>{"use strict";K();F();Mn=require("zod");P();Qo=class{async execute(e,t,i){let n=O(e,t),o=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({button:"right",timeout:o});else throw new Error("No locator found for right_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("right_click", page, {});']:['await agent.execAction("right_click", page, {',...t.map(i=>` ${i},`),"});"]}};Sh=Mn.z.object({element_index:Mn.z.number().int().describe("Index of the element to right-click"),timeout_ms:Mn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function ol(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:Eh,async execute(i,n){let{name:o,value:a}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Save variable "${o}" = "${a}"`,action_data:{action_name:"save_variable",kwargs:{name:o,value:a}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Saved variable "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Save variable "${o}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:o,value:a}},feedback:l.message}}}}})}var In,nl,Eh,ai=w(()=>{"use strict";In=require("zod"),nl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.name,a=n.kwargs.value;if(!o||a===void 0)throw new Error("Missing variable name or value for save_variable");o.startsWith("$")&&(o=o.slice(1)),i.saveVariable(o,a)}transpile(e){let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]}},Eh=In.z.object({name:In.z.string().describe("Variable name to save"),value:In.z.string().describe("Value to save in the variable")})});async function Th(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function Ah(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function al(e,t){e.register({name:"scroll",description:"Scroll the page by specified number of pages (set down=True to scroll down, down=False to scroll up, num_pages=number of pages to scroll like 0.5 for half page, 1.0 for one page, etc.). ",schema:Mh,async execute(i,n){let{down:o,num_pages:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=l||`Scroll ${o?"down":"up"} ${a} page(s)`,c=await Th("scroll",d,{down:o,num_pages:a});return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Scrolled ${o?"down":"up"} ${a} page(s)`}}catch(d){return{success:!1,error:d.message,actionEntity:Ah(l||`Scroll ${o?"down":"up"} ${a} page(s)`,"scroll",{down:o,num_pages:a})}}}})}var Cn,ri,Mh,si=w(()=>{"use strict";Cn=require("zod"),ri=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.down??!0,o=i.kwargs.num_pages??1,a=n?1:-1;await e.evaluate(`window.scrollBy(0, window.innerHeight * ${o} * ${a})`)}transpile(e){let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]}};Mh=Cn.z.object({down:Cn.z.boolean().describe("True to scroll down, False to scroll up"),num_pages:Cn.z.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});async function Ih(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function rl(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function ll(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:Ch,usesElementIndex:!0,async execute(i,n){let{element_index:o,delta_x:a,delta_y:r}=i,{page:s,agentServices:l}=n;try{let d=await B(n,o);if(!d)return{success:!1,error:`Element with index ${o} not found`,actionEntity:rl(`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:r})};let c=await Ih("scroll_on_element",`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,d,s,{delta_x:a,delta_y:r});return await t.execute(s,c,l),{success:!0,actionEntity:c,message:`Scrolled on element ${o} horizontally: ${a}px, vertically: ${r}px`}}catch(d){return{success:!1,error:d.message,actionEntity:rl(`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:r})}}}})}var pt,sl,Ch,li=w(()=>{"use strict";K();F();pt=require("zod");P();sl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.delta_x||0,a=n.kwargs.delta_y||0,r=O(e,t),s=D(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:s}),await e.mouse.wheel(o,a);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Pe(e);if(!t){let o=e.action_data?.kwargs?.delta_x||0,a=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${o}, delta_y: ${a} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,n=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${D()} });`,`await page.mouse.wheel(${i}, ${n});`]}};Ch=pt.z.object({element_index:pt.z.number().int().describe("Index of the scrollable element"),delta_x:pt.z.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:pt.z.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:pt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function dl(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:Ph,async execute(i,n){let{text:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Scroll to text "${o}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Scrolled to text "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Scroll to text "${o}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:o}},feedback:l.message}}}}})}var ea,cl,Ph,ci=w(()=>{"use strict";ea=require("zod"),cl=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.text;if(n)await e.getByText(n,{exact:!1}).first().scrollIntoViewIfNeeded(),await e.waitForTimeout(500);else throw new Error("Missing text for scroll_to_text action")}transpile(e){let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]}},Ph=ea.z.object({text:ea.z.string().describe("Text to scroll to on the page")})});async function $h(e,t,i){return{...await N(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function ul(e,t){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:"get_dropdown_options",kwargs:t},feedback:"Element not found in DOM"}}function ml(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:Dh,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:ul(s||`Get options from dropdown ${o}`,{index:o})};let d=await $h(l,a,s);return await t.execute(a,d,r),{success:!0,actionEntity:d,message:d.feedback||"No options found"}}catch(l){return{success:!1,error:l.message,actionEntity:ul(s||`Get options from dropdown ${o}`,{index:o})}}}})}var ta,hl,Dh,di=w(()=>{"use strict";K();ta=require("zod"),hl=class{async execute(e,t,i){if(!t.xpath)throw new Error("XPath not found in action entity");let n=[];for(let o of e.frames())try{let a=await o.evaluate(r=>{let s=document.evaluate(r,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return s?{options:Array.from(s.options).map(l=>({text:l.text,value:l.value,index:l.index})),id:s.id,name:s.name}:null},t.xpath);if(a){let r=[];for(let s of a.options){let l=JSON.stringify(s.text);r.push(`${s.index}: text=${l}`)}n.push(...r)}}catch{}if(n.length>0){let o=n.join(`
|
|
4110
4108
|
`);o+=`
|
|
4111
|
-
Use the exact text string in select_dropdown_option`,i.addNote(o)}else i.addNote("No options found in any frame for dropdown")}transpile(e){let t=[];return e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("get_dropdown_options", page, {});']:['await agent.execAction("get_dropdown_options", page, {',...t.map(i=>` ${i},`),"});"]}};yh=zo.z.object({element_index:zo.z.number().int().describe("Index of the dropdown/select element")})});function ol(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:xh,async execute(i,n){let{page:o,agentServices:a,actionDescription:r}=n;try{let s={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(o,s,a),{success:!0,actionEntity:s,message:"Navigated back"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(r||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:s.message}}}}})}var il,nl,xh,li=w(()=>{"use strict";R();il=require("zod");P();nl=class{async execute(e,t){await e.goBack({timeout:ge}),await e.waitForLoadState("load",{timeout:ge}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},xh=il.z.object({})});function al(e,t){e.register({name:"go_to_url",description:"Navigate to a specific URL. Use this to visit web pages. Set new_tab=true to open in a new tab.",schema:vh,async execute(i,n){let{url:o,new_tab:a,timeout_seconds:r}=i,{page:s,agentServices:l,actionDescription:d}=n,c={url:o,new_tab:a??!1};r!==void 0&&(c.timeout_seconds=r);let h=r?` (timeout: ${r}s)`:"";try{let p=a?`Open ${o} in new tab`:`Navigate to ${o}`,g={action_description:d||p,action_data:{action_name:"go_to_url",kwargs:c}};return await t.execute(s,g,l),{success:!0,actionEntity:g,message:(a?`Opened ${o} in new tab`:`Navigated to ${o}`)+h}}catch(p){let g=a?`Open ${o} in new tab`:`Navigate to ${o}`;return{success:!1,error:p.message,actionEntity:{action_description:(d||g)+" (failed)",action_data:{action_name:"go_to_url",kwargs:c},feedback:p.message}}}}})}var ci,Vo,vh,di=w(()=>{"use strict";R();ci=require("zod");P();Vo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.url;if(!o)throw new Error("Missing URL for go_to_url action");let a=n.kwargs.new_tab===!0,r=i.replaceVariables(String(o));if(r.startsWith("/")){let d=e.url(),c=null;try{let h=new URL(d);h.origin&&h.origin!=="null"&&(c=h.origin)}catch{}c&&(r=c+r)}let s=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:ge,l=e;a&&(l=await e.context().newPage(),i.setPage(l)),await l.goto(r,{timeout:s})}transpile(e){let t=e.action_data?.kwargs?.url||"",i=e.action_data?.kwargs?.new_tab===!0,n=e.action_data?.kwargs?.timeout_seconds,o=[`url: ${JSON.stringify(t)}`];return i&&o.push("new_tab: true"),n&&o.push(`timeout_seconds: ${n}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${o.join(", ")} } },`,"});"]}},vh=ci.z.object({url:ci.z.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:ci.z.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:ci.z.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});async function kh(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function rl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function sl(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:_h,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:rl(`Hover element ${o}`,"hover",{index:o})};let d=s||`Hover over element ${o}`,c=await kh("hover",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Hovered over element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:rl(`Hover element ${o}`,"hover",{index:o})}}}})}var vn,Xo,_h,ui=w(()=>{"use strict";K();R();vn=require("zod");P();Xo=class{async execute(e,t,i){let n=O(e,t),o=D(i,t.action_data?.kwargs?.timeout_ms);if(n){await n.waitFor({state:"attached",timeout:o});let a=await n.elementHandle();if(!a)throw new Error("Unable to obtain element handle for hover action");let r=await a.boundingBox();if(!r)throw new Error("Unable to determine bounding box for hover action");let s=r.x+r.width/2,l=r.y+r.height/2;await e.mouse.move(s,l)}else throw new Error("No locator found for hover action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("hover", page, {});']:['await agent.execAction("hover", page, {',...t.map(i=>` ${i},`),"});"]}};_h=vn.z.object({element_index:vn.z.number().int().describe("Index of the element to hover over"),timeout_ms:vn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Sh(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function ll(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function cl(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:Eh,usesElementIndex:!0,async execute(i,n){let{element_index:o,text:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await B(n,o);if(!d)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:ll(l||`Input text to element ${o}`,"input_text",{index:o,text:a})};let c=l||`Input text to element ${o}`,h=await Sh("input_text",c,d,r,{text:a});return await t.execute(r,h,s),{success:!0,actionEntity:h,message:`Input text to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:ll(`Input text to element ${o}`,"input_text",{index:o,text:a})}}}})}var hi,Yo,Eh,mi=w(()=>{"use strict";K();R();hi=require("zod");P();Yo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.text??n.kwargs.value??"",a=i.replaceVariables(String(o)),r=O(e,t),s=D(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(d=>{d.value&&(d.value="")},null,{timeout:s}),await r.click({timeout:s}),await e.waitForTimeout(200);let l=i.getActionSettings().type_delay;l!==void 0?await e.keyboard.type(a,{delay:l}):await e.keyboard.type(a)}else throw new Error("No locator found for input_text action")}transpile(e){let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("input_text", page, {',...i.map(n=>` ${n},`),"});"]}};Eh=hi.z.object({element_index:hi.z.number().int().describe("Index of the input element"),text:hi.z.string().describe("Text to type into the input. To use a placeholder, write {{ placeholder_name }} using exact placeholder name. Use clear_input first if you want to replace existing content."),timeout_ms:hi.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function ul(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:Th,async execute(i,n){let{index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Close tab ${o}`,action_data:{action_name:"close_tab",kwargs:{page_id:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Closed tab ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:l.message}}}}})}var Jo,dl,Th,pi=w(()=>{"use strict";Jo=require("zod"),dl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.page_id??n.kwargs.index;if(o===void 0&&(o=e.context().pages().indexOf(e)),typeof o=="number"){if(o===0)throw new Error("Cannot close the first tab (page_id 0). Skipping close_tab action.");i&&await i.closeTab(o)}else throw new Error("Missing page_id for close_tab action")}transpile(e){let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]}},Th=Jo.z.object({index:Jo.z.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});function ml(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:Ah,async execute(i,n){let{page:o,agentServices:a}=n;try{let r={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await t.execute(o,r,a),{success:!0,actionEntity:r,message:"Task marked as complete"}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Task completed (failed)",action_data:{action_name:"done",kwargs:{}},feedback:r.message}}}}})}var kn,hl,Ah,gi=w(()=>{"use strict";kn=require("zod"),hl=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},Ah=kn.z.object({success:kn.z.boolean().describe("Whether the task was completed successfully"),summary:kn.z.string().describe("Summary of what was accomplished or why it failed")})});async function Mh(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function pl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function gl(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:Ih,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:pl(`Double-click element ${o}`,"double_click",{index:o})};let d=s||`Double-click element ${o}`,c=await Mh("double_click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Double-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:pl(`Double-click element ${o}`,"double_click",{index:o})}}}})}var _n,qo,Ih,fi=w(()=>{"use strict";K();R();_n=require("zod");P();qo=class{async execute(e,t,i){let n=O(e,t),o=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.dblclick({timeout:o});else throw new Error("No locator found for double_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("double_click", page, {});']:['await agent.execAction("double_click", page, {',...t.map(i=>` ${i},`),"});"]}};Ih=_n.z.object({element_index:_n.z.number().int().describe("Index of the element to double-click"),timeout_ms:_n.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function wl(e,t){e.register({name:"generate_2fa_code",description:'Generate a 2FA code from an OTP secret key. The code is saved to the "otp_code" variable. To use the otp_code, you must use `$otp_code` to access it.',schema:Ch,async execute(i,n){let{otp_secret_key:o}=i,{page:a,agentServices:r}=n;try{let s={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:o}}};return await t.execute(a,s,r),{success:!0,actionEntity:s,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:o}},feedback:s.message}}}}})}var Zo,fl,Ch,wi=w(()=>{"use strict";Zo=require("zod"),fl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.otp_secret_key;if(!o)throw new Error("Missing otp_secret_key for generate_2fa_code");let a=i.replaceVariables(String(o)),r=await i.generate2faCode(a);i.saveVariable("otp_code",r)}transpile(e){let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]}},Ch=Zo.z.object({otp_secret_key:Zo.z.string().describe("The OTP secret key to generate the 2FA code from")})});function yl(e){if(!e.trim())return!1;try{return(0,bl.parse)(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var bl,Sn=w(()=>{"use strict";bl=require("@babel/parser")});function vl(e,t){e.register({name:"verify",description:"Verify that a statement is true based on the current page state. Use this to check assertions about the page content, element visibility, or any condition.",schema:$h,async execute(i,n){let{statement:o}=i,{page:a,agentServices:r}=n;try{let s={action_description:`${o}`,action_data:{action_name:"verify",kwargs:{statement:o}}};return await t.execute(a,s,r),{success:!0,actionEntity:s,message:`Assertion verified: ${o}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Verify: ${o} (failed)`,action_data:{action_name:"verify",kwargs:{statement:o}},feedback:s.message}}}},availability:{openai:!0,mcp:!0}})}var Qo,Ph,xl,ea,En,$h,bi=w(()=>{"use strict";Sn();F();pe();Qo=require("zod"),Ph=W(require("playwright/test"),1),xl=W(require("playwright/test"),1),ea={};Ki(ea,{default:()=>xl.default});Cr(ea,Ph);En=class{async execute(e,t,i){let n=t.action_data?.kwargs,o=typeof n?.code=="string",a=o?n?.statement||t.action_description:t.action_description||n?.statement;if(o&&a){let c=Date.now();try{await this.executeJSAssertion(e,n.code,i),u.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${a}`),i.addNote(`Assertion passed: ${a}`);return}catch(h){let p=((Date.now()-c)/1e3).toFixed(1);u.info(`[VERIFY:JS\u2192AI] JS failed ${p}s (${h instanceof Error?h.message:String(h)}), falling back to AI: ${a}`)}}else if(o){let c=Date.now();await this.executeJSAssertion(e,n.code,i),u.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${a||"js-only"}`),i.addNote(`Assertion passed: ${a||"js-only"}`);return}if(!a)throw new Error("Missing statement or code for verify action");let r=Date.now();u.info(`[VERIFY:AI] Evaluating: ${a}`);let{evaluateStatement:s}=await Promise.resolve().then(()=>(lt(),st)),l=await s(a,e,i,{useCleanScreenshotForAssertion:!0}),d=l.explanation||l.error||(l.success?`Assertion passed: ${a}`:"Assertion failed");if(i.addNote(d),!l.success)throw u.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${a}`),new Error(l.error||l.explanation||"Assertion failed");u.info(`[VERIFY:AI] \u2713 ${((Date.now()-r)/1e3).toFixed(1)}s: ${a}`)}async executeJSAssertion(e,t,i){let n=i.agent;if(!n)throw new Error("Agent not initialized on AgentServices \u2014 ai_assert requires an agent reference");try{await new Function("page","expect","agent",`
|
|
4109
|
+
Use the exact text string in select_dropdown_option`,i.addNote(o)}else i.addNote("No options found in any frame for dropdown")}transpile(e){let t=[];return e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("get_dropdown_options", page, {});']:['await agent.execAction("get_dropdown_options", page, {',...t.map(i=>` ${i},`),"});"]}};Dh=ta.z.object({element_index:ta.z.number().int().describe("Index of the dropdown/select element")})});function fl(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:Lh,async execute(i,n){let{page:o,agentServices:a,actionDescription:r}=n;try{let s={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(o,s,a),{success:!0,actionEntity:s,message:"Navigated back"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(r||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:s.message}}}}})}var pl,gl,Lh,ui=w(()=>{"use strict";F();pl=require("zod");P();gl=class{async execute(e,t){await e.goBack({timeout:we}),await e.waitForLoadState("load",{timeout:we}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},Lh=pl.z.object({})});function wl(e,t){e.register({name:"go_to_url",description:"Navigate to a specific URL. Use this to visit web pages. Set new_tab=true to open in a new tab.",schema:Oh,async execute(i,n){let{url:o,new_tab:a,timeout_seconds:r}=i,{page:s,agentServices:l,actionDescription:d}=n,c={url:o,new_tab:a??!1};r!==void 0&&(c.timeout_seconds=r);let h=r?` (timeout: ${r}s)`:"";try{let p=a?`Open ${o} in new tab`:`Navigate to ${o}`,g={action_description:d||p,action_data:{action_name:"go_to_url",kwargs:c}};return await t.execute(s,g,l),{success:!0,actionEntity:g,message:(a?`Opened ${o} in new tab`:`Navigated to ${o}`)+h}}catch(p){let g=a?`Open ${o} in new tab`:`Navigate to ${o}`;return{success:!1,error:p.message,actionEntity:{action_description:(d||g)+" (failed)",action_data:{action_name:"go_to_url",kwargs:c},feedback:p.message}}}}})}var hi,ia,Oh,mi=w(()=>{"use strict";F();hi=require("zod");P();ia=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.url;if(!o)throw new Error("Missing URL for go_to_url action");let a=n.kwargs.new_tab===!0,r=i.replaceVariables(String(o));if(r.startsWith("/")){let d=e.url(),c=null;try{let h=new URL(d);h.origin&&h.origin!=="null"&&(c=h.origin)}catch{}c&&(r=c+r)}let s=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:we,l=e;a&&(l=await e.context().newPage(),i.setPage(l)),await l.goto(r,{timeout:s})}transpile(e){let t=e.action_data?.kwargs?.url||"",i=e.action_data?.kwargs?.new_tab===!0,n=e.action_data?.kwargs?.timeout_seconds,o=[`url: ${JSON.stringify(t)}`];return i&&o.push("new_tab: true"),n&&o.push(`timeout_seconds: ${n}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${o.join(", ")} } },`,"});"]}},Oh=hi.z.object({url:hi.z.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:hi.z.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:hi.z.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});async function Nh(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function bl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function yl(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:Rh,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:bl(`Hover element ${o}`,"hover",{index:o})};let d=s||`Hover over element ${o}`,c=await Nh("hover",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Hovered over element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:bl(`Hover element ${o}`,"hover",{index:o})}}}})}var Pn,na,Rh,pi=w(()=>{"use strict";K();F();Pn=require("zod");P();na=class{async execute(e,t,i){let n=O(e,t),o=D(i,t.action_data?.kwargs?.timeout_ms);if(n){await n.waitFor({state:"attached",timeout:o});let a=await n.elementHandle();if(!a)throw new Error("Unable to obtain element handle for hover action");let r=await a.boundingBox();if(!r)throw new Error("Unable to determine bounding box for hover action");let s=r.x+r.width/2,l=r.y+r.height/2;await e.mouse.move(s,l)}else throw new Error("No locator found for hover action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("hover", page, {});']:['await agent.execAction("hover", page, {',...t.map(i=>` ${i},`),"});"]}};Rh=Pn.z.object({element_index:Pn.z.number().int().describe("Index of the element to hover over"),timeout_ms:Pn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Fh(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function xl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function vl(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:Hh,usesElementIndex:!0,async execute(i,n){let{element_index:o,text:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await B(n,o);if(!d)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:xl(l||`Input text to element ${o}`,"input_text",{index:o,text:a})};let c=l||`Input text to element ${o}`,h=await Fh("input_text",c,d,r,{text:a});return await t.execute(r,h,s),{success:!0,actionEntity:h,message:`Input text to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:xl(`Input text to element ${o}`,"input_text",{index:o,text:a})}}}})}var gi,oa,Hh,fi=w(()=>{"use strict";K();F();gi=require("zod");P();oa=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.text??n.kwargs.value??"",a=i.replaceVariables(String(o)),r=O(e,t),s=D(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(d=>{d.value&&(d.value="")},null,{timeout:s}),await r.click({timeout:s}),await e.waitForTimeout(200);let l=i.getActionSettings().type_delay;l!==void 0?await e.keyboard.type(a,{delay:l}):await e.keyboard.type(a)}else throw new Error("No locator found for input_text action")}transpile(e){let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("input_text", page, {',...i.map(n=>` ${n},`),"});"]}};Hh=gi.z.object({element_index:gi.z.number().int().describe("Index of the input element"),text:gi.z.string().describe("Text to type into the input. To use a placeholder, write {{ placeholder_name }} using exact placeholder name. Use clear_input first if you want to replace existing content."),timeout_ms:gi.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function _l(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:Wh,async execute(i,n){let{index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Close tab ${o}`,action_data:{action_name:"close_tab",kwargs:{page_id:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Closed tab ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:l.message}}}}})}var aa,kl,Wh,wi=w(()=>{"use strict";aa=require("zod"),kl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.page_id??n.kwargs.index;if(o===void 0&&(o=e.context().pages().indexOf(e)),typeof o=="number"){if(o===0)throw new Error("Cannot close the first tab (page_id 0). Skipping close_tab action.");i&&await i.closeTab(o)}else throw new Error("Missing page_id for close_tab action")}transpile(e){let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]}},Wh=aa.z.object({index:aa.z.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});function El(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:Bh,async execute(i,n){let{page:o,agentServices:a}=n;try{let r={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await t.execute(o,r,a),{success:!0,actionEntity:r,message:"Task marked as complete"}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Task completed (failed)",action_data:{action_name:"done",kwargs:{}},feedback:r.message}}}}})}var $n,Sl,Bh,bi=w(()=>{"use strict";$n=require("zod"),Sl=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},Bh=$n.z.object({success:$n.z.boolean().describe("Whether the task was completed successfully"),summary:$n.z.string().describe("Summary of what was accomplished or why it failed")})});async function Gh(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Tl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Al(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:Uh,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:Tl(`Double-click element ${o}`,"double_click",{index:o})};let d=s||`Double-click element ${o}`,c=await Gh("double_click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Double-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Tl(`Double-click element ${o}`,"double_click",{index:o})}}}})}var Dn,ra,Uh,yi=w(()=>{"use strict";K();F();Dn=require("zod");P();ra=class{async execute(e,t,i){let n=O(e,t),o=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.dblclick({timeout:o});else throw new Error("No locator found for double_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("double_click", page, {});']:['await agent.execAction("double_click", page, {',...t.map(i=>` ${i},`),"});"]}};Uh=Dn.z.object({element_index:Dn.z.number().int().describe("Index of the element to double-click"),timeout_ms:Dn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Il(e,t){e.register({name:"generate_2fa_code",description:'Generate a 2FA code from an OTP secret key. The code is saved to the "otp_code" variable. To use the otp_code, you must use `$otp_code` to access it.',schema:Kh,async execute(i,n){let{otp_secret_key:o}=i,{page:a,agentServices:r}=n;try{let s={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:o}}};return await t.execute(a,s,r),{success:!0,actionEntity:s,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:o}},feedback:s.message}}}}})}var sa,Ml,Kh,xi=w(()=>{"use strict";sa=require("zod"),Ml=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.otp_secret_key;if(!o)throw new Error("Missing otp_secret_key for generate_2fa_code");let a=i.replaceVariables(String(o)),r=await i.generate2faCode(a);i.saveVariable("otp_code",r)}transpile(e){let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]}},Kh=sa.z.object({otp_secret_key:sa.z.string().describe("The OTP secret key to generate the 2FA code from")})});function Pl(e){if(!e.trim())return!1;try{return(0,Cl.parse)(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var Cl,Ln=w(()=>{"use strict";Cl=require("@babel/parser")});function Dl(e,t){e.register({name:"verify",description:"Verify that a statement is true based on the current page state. Use this to check assertions about the page content, element visibility, or any condition.",schema:zh,async execute(i,n){let{statement:o}=i,{page:a,agentServices:r}=n;try{let s={action_description:`${o}`,action_data:{action_name:"verify",kwargs:{statement:o}}};return await t.execute(a,s,r),{success:!0,actionEntity:s,message:`Assertion verified: ${o}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Verify: ${o} (failed)`,action_data:{action_name:"verify",kwargs:{statement:o}},feedback:s.message}}}},availability:{openai:!0,mcp:!0}})}var la,jh,$l,ca,On,zh,vi=w(()=>{"use strict";Ln();R();fe();la=require("zod"),jh=W(require("playwright/test"),1),$l=W(require("playwright/test"),1),ca={};Bi(ca,{default:()=>$l.default});Nr(ca,jh);On=class{async execute(e,t,i){let n=t.action_data?.kwargs,o=typeof n?.code=="string",a=o?n?.statement||t.action_description:t.action_description||n?.statement;if(o&&a){let c=Date.now();try{await this.executeJSAssertion(e,n.code,i),u.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${a}`),i.addNote(`Assertion passed: ${a}`);return}catch(h){let p=((Date.now()-c)/1e3).toFixed(1);u.info(`[VERIFY:JS\u2192AI] JS failed ${p}s (${h instanceof Error?h.message:String(h)}), falling back to AI: ${a}`)}}else if(o){let c=Date.now();await this.executeJSAssertion(e,n.code,i),u.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${a||"js-only"}`),i.addNote(`Assertion passed: ${a||"js-only"}`);return}if(!a)throw new Error("Missing statement or code for verify action");let r=Date.now();u.info(`[VERIFY:AI] Evaluating: ${a}`);let{evaluateStatement:s}=await Promise.resolve().then(()=>(ht(),ut)),l=await s(a,e,i,{useCleanScreenshotForAssertion:!0}),d=l.explanation||l.error||(l.success?`Assertion passed: ${a}`:"Assertion failed");if(i.addNote(d),!l.success)throw u.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${a}`),new Error(l.error||l.explanation||"Assertion failed");u.info(`[VERIFY:AI] \u2713 ${((Date.now()-r)/1e3).toFixed(1)}s: ${a}`)}async executeJSAssertion(e,t,i){let n=i.agent;if(!n)throw new Error("Agent not initialized on AgentServices \u2014 ai_assert requires an agent reference");try{await new Function("page","expect","agent",`
|
|
4112
4110
|
return (async () => {
|
|
4113
4111
|
${t}
|
|
4114
4112
|
})();
|
|
4115
|
-
`)(e,
|
|
4113
|
+
`)(e,ca.expect,n)}catch(o){throw new Error(`Assertion failed: ${o instanceof Error?o.message:String(o)}`)}}transpile(e,t){let i=e.action_data?.kwargs,n=typeof i?.code=="string",o=n?i?.statement||e.action_description:e.action_description||i?.statement,a=JSON.stringify(t||"");if(n){let r=i.code;if(!Pl(r))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(r)});`];if(o){let s=r.split(`
|
|
4116
4114
|
`),l=JSON.stringify(o);return["{ const _t = Date.now(); try {",...s.map(d=>` ${d}`),` console.log(\`[VERIFY:JS] \u2713 \${((Date.now()-_t)/1000).toFixed(1)}s: ${l}\`);`,"} catch (_e) {",` console.log(\`[VERIFY:JS\u2192AI] JS failed \${((Date.now()-_t)/1000).toFixed(1)}s: (\${_e instanceof Error ? _e.message : String(_e)}), falling back to AI: ${l}\`);`,` await agent.assert(page, ${l}, ${a});`,"} }"]}return r.split(`
|
|
4117
|
-
`)}return o?[`await agent.assert(page, ${JSON.stringify(o)}, ${a});`]:["// Skipping verify: missing statement or code"]}},$h=Qo.z.object({statement:Qo.z.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});function _l(e,t){e.register({name:"ai_extract",description:"Use AI to extract information from the page and save it to a variable. MCP-only tool.",schema:Dh,async execute(i,n){let{element_description:o,variable_name:a}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Extract ${o} to ${a}`,action_data:{action_name:"ai_extract",kwargs:{element_description:o,variable_name:a}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Extracted ${o} to ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Extract ${o} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:o,variable_name:a}},feedback:l.message}}}},availability:{openai:!1,mcp:!0}})}var Tn,kl,Dh,yi=w(()=>{"use strict";Tn=require("zod"),kl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.element_description,a=n.kwargs.variable_name;if(!o||!a)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${o} and save to ${a}`,{executeStep:s}=await Promise.resolve().then(()=>(lt(),st)),l=await s(r,e,i);if(l.status!=="success")throw new Error(l.error||"Extraction failed")}transpile(e,t){let i=e.action_data?.kwargs?.element_description,n=e.action_data?.kwargs?.variable_name;if(!i||!n)return["// Skipping ai_extract: missing element_description or variable_name"];let o=JSON.stringify(i),a=JSON.stringify(n);return[`await agent.extract(page, ${o}, ${a}, '${t||""}');`]}},Dh=Tn.z.object({element_description:Tn.z.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:Tn.z.string().describe("Name of the variable to store the extracted value")})});async function Lh(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Sl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Tl(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:Oh,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:Sl(s||`Clear element ${o}`,"clear_input",{index:o})};let d=s||`Clear element ${o}`,c=await Lh("clear_input",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Cleared element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Sl(`Clear element ${o}`,"clear_input",{index:o})}}}})}var An,El,Oh,xi=w(()=>{"use strict";K();R();An=require("zod");P();El=class{async execute(e,t,i){let n=O(e,t),o=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:o}),await e.keyboard.press("ControlOrMeta+a"),await e.waitForTimeout(200),await e.keyboard.press("Backspace"),await e.waitForTimeout(200);else throw new Error("No locator found for clear_input action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("clear_input", page, {});']:['await agent.execAction("clear_input", page, {',...t.map(i=>` ${i},`),"});"]}};Oh=An.z.object({element_index:An.z.number().int().describe("Index of the input element to clear"),timeout_ms:An.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Nh(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Al(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Ml(e,t){e.register({name:"click",description:"Click an interactive element.",schema:Rh,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:Al(`Click element ${o}`,"click",{index:o})};let d=s||`Click element ${o}`,c=await Nh("click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Al(`Click element ${o}`,"click",{index:o})}}}})}var Mn,In,Rh,vi=w(()=>{"use strict";K();R();Mn=require("zod");P();In=class{async execute(e,t,i){let n=O(e,t),o=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:o});else throw new Error("No locator found for click action")}transpile(e){let t=Me(e);if(!t)return['await agent.execAction("click", page, {});'];let i=D();return[`await ${t}.click({ timeout: ${i} });`]}};Rh=Mn.z.object({element_index:Mn.z.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:Mn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});var Fh,Hh,ki,Cn=w(()=>{"use strict";Fh=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Hh=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],ki=class{static isAiAction(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:Fh.includes(t)}static getAiStatement(e){let t=e.action_data?.action_name;if(!t)return null;let i=e.action_data?.kwargs||{};switch(t){case"ai_action":case"ai_step":return i.statement||null;case"verify":case"ai_assert":case"assert":return i.statement||e.action_description||null;case"ai_extract":let n=i.element_description,o=i.variable_name;return n&&o?`Extract ${n} and save to ${o}`:null;case"ai_wait_until":return i.condition||null;default:return null}}static canSelfHeal(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!Hh.includes(t)}}});var ta,ia,Pn,na=w(()=>{"use strict";nn();on();an();rn();sn();ln();cn();dn();un();pn();gn();Ut();jt();Vt();Xt();Jt();qt();Zt();Qt();ei();ti();ii();oi();ai();ri();si();li();di();ui();mi();pi();gi();fi();wi();bi();yi();xi();vi();Cn();R();pe();ta=class M{static registerAction(t,i){M.actions.set(t,i)}constructor(){M.initialized||(this.registerBuiltinActions(),M.initialized=!0)}registerBuiltinActions(){M.registerAction("go_to_url",new Vo),M.registerAction("go_back",new nl),M.registerAction("reload_page",new Bs),M.registerAction("close_tab",new dl),M.registerAction("switch_tab",new As),M.registerAction("click",new In),M.registerAction("hover",new Xo),M.registerAction("right_click",new Ko),M.registerAction("double_click",new qo),M.registerAction("click_by_coordinates",new ms),M.registerAction("right_click_by_coordinates",new ds),M.registerAction("double_click_by_coordinates",new ps),M.registerAction("drag_drop",new gs),M.registerAction("input_text",new Yo),M.registerAction("clear_input",new El),M.registerAction("press",new Uo),M.registerAction("send_keys_on_element",new ss),M.registerAction("scroll_on_element",new Ys),M.registerAction("scroll_to_text",new qs),M.registerAction("scroll",new ni),M.registerAction("upload_file",new Ds),M.registerAction("wait_for_download_complete",new Rs),M.registerAction("get_dropdown_options",new el),M.registerAction("select_dropdown_option",new _s),M.registerAction("set_date_for_native_date_picker",new Es),M.registerAction("verify",new En),M.registerAction("ai_action",new bs),M.registerAction("ai_extract",new kl),M.registerAction("ai_step",new ys),M.registerAction("ai_wait_until",new xs),M.registerAction("generate_2fa_code",new fl),M.registerAction("wait",new Os),M.registerAction("wait_for_page_ready",new cs),M.registerAction("save_variable",new js),M.registerAction("js_code",new hs),M.registerAction("js_action",new us),M.registerAction("function",new fs),M.registerAction("done",new hl),M.registerAction("click_element",new In),M.registerAction("click_element_by_index",new In),M.registerAction("hover_element_by_index",new Xo),M.registerAction("right_click_on_element",new Ko),M.registerAction("double_click_on_element",new qo),M.registerAction("scroll_down",new ni),M.registerAction("scroll_up",new ni),M.registerAction("scroll_element",new ni),M.registerAction("send_keys",new Uo),M.registerAction("open_tab",new Vo),M.registerAction("fill",new Yo),M.registerAction("ai_assert",new En),M.registerAction("assert",new En)}getAction(t){return M.actions.get(t)}hasAction(t){return M.actions.has(t)}getActionNames(){return Array.from(M.actions.keys())}async execute(t,i,n){if(!n)throw new Error("AgentServices not found");let o=i.action_data?.action_name;if(!o)throw new Error("Action name not found in action_data");let a=this.getAction(o);if(!a)throw new Error(`Unknown action: ${o}`);await a.execute(t,i,n)}transpile(t,i,n){let{sanitizeForComment:o}=(P(),So(ji)),a=t.action_description||"",r=t.action_data?.action_name||"",s=this.getAction(r);if(!s)return[`// ${i}: Unknown action: ${r}`];let l=s.transpile(t,i);if(ki.isAiAction(t))return[`// ${i}: ${o(a)}`,"page = agent.agentServices.validatePage(page);",...l];let d=JSON.stringify(a),c=l.map(g=>` ${g}`),h=ki.canSelfHeal(t),p=n?JSON.stringify(n):"undefined";return[`// ${i}: ${o(a)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...c,`}, ${d}, '${i}', ${p}, ${h});`]}transpileUncachedAction(t,i,n=!1,o=!1,a){let{sanitizeForComment:r}=(P(),So(ji));if(!t)return[`// ${i}: Skipping - no description`];let s=JSON.stringify(t);if(o){let l=a?`, { stmtUid: ${JSON.stringify(a)} }`:"";return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${s}, '${i}'${l});`]}return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${s}, '${i}', ${n});`]}};ta.actions=new Map,ta.initialized=!1;ia=ta,Pn=ia});var ut={};Be(ut,{ActionHandler:()=>ia,default:()=>Pn});var ht=w(()=>{"use strict";na();nn();on();an();rn();sn();ln();cn();dn();un();pn();gn();Ut();jt();Vt();Xt();Jt();qt();Zt();Qt();ei();ti();ii();oi();ai();ri();si();li();di();ui();mi();pi();gi();fi();wi();bi();yi();xi();vi();Sn();Yt();K();Ge();F();ie();rt();Cn();R();pe()});function $n(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
|
|
4115
|
+
`)}return o?[`await agent.assert(page, ${JSON.stringify(o)}, ${a});`]:["// Skipping verify: missing statement or code"]}},zh=la.z.object({statement:la.z.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});function Ol(e,t){e.register({name:"ai_extract",description:"Use AI to extract information from the page and save it to a variable. MCP-only tool.",schema:Vh,async execute(i,n){let{element_description:o,variable_name:a}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Extract ${o} to ${a}`,action_data:{action_name:"ai_extract",kwargs:{element_description:o,variable_name:a}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Extracted ${o} to ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Extract ${o} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:o,variable_name:a}},feedback:l.message}}}},availability:{openai:!1,mcp:!0}})}var Nn,Ll,Vh,ki=w(()=>{"use strict";Nn=require("zod"),Ll=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.element_description,a=n.kwargs.variable_name;if(!o||!a)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${o} and save to ${a}`,{executeStep:s}=await Promise.resolve().then(()=>(ht(),ut)),l=await s(r,e,i);if(l.status!=="success")throw new Error(l.error||"Extraction failed")}transpile(e,t){let i=e.action_data?.kwargs?.element_description,n=e.action_data?.kwargs?.variable_name;if(!i||!n)return["// Skipping ai_extract: missing element_description or variable_name"];let o=JSON.stringify(i),a=JSON.stringify(n);return[`await agent.extract(page, ${o}, ${a}, '${t||""}');`]}},Vh=Nn.z.object({element_description:Nn.z.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:Nn.z.string().describe("Name of the variable to store the extracted value")})});async function Xh(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Nl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Fl(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:Yh,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:Nl(s||`Clear element ${o}`,"clear_input",{index:o})};let d=s||`Clear element ${o}`,c=await Xh("clear_input",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Cleared element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Nl(`Clear element ${o}`,"clear_input",{index:o})}}}})}var Rn,Rl,Yh,_i=w(()=>{"use strict";K();F();Rn=require("zod");P();Rl=class{async execute(e,t,i){let n=O(e,t),o=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:o}),await e.keyboard.press("ControlOrMeta+a"),await e.waitForTimeout(200),await e.keyboard.press("Backspace"),await e.waitForTimeout(200);else throw new Error("No locator found for clear_input action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("clear_input", page, {});']:['await agent.execAction("clear_input", page, {',...t.map(i=>` ${i},`),"});"]}};Yh=Rn.z.object({element_index:Rn.z.number().int().describe("Index of the input element to clear"),timeout_ms:Rn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Jh(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Hl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Wl(e,t){e.register({name:"click",description:"Click an interactive element.",schema:qh,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:Hl(`Click element ${o}`,"click",{index:o})};let d=s||`Click element ${o}`,c=await Jh("click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Hl(`Click element ${o}`,"click",{index:o})}}}})}var Fn,Hn,qh,Si=w(()=>{"use strict";K();F();Fn=require("zod");P();Hn=class{async execute(e,t,i){let n=O(e,t),o=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:o});else throw new Error("No locator found for click action")}transpile(e){let t=Pe(e);if(!t)return['await agent.execAction("click", page, {});'];let i=D();return[`await ${t}.click({ timeout: ${i} });`]}};qh=Fn.z.object({element_index:Fn.z.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:Fn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});var Zh,Qh,Ei,Wn=w(()=>{"use strict";Zh=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Qh=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],Ei=class{static isAiAction(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:Zh.includes(t)}static getAiStatement(e){let t=e.action_data?.action_name;if(!t)return null;let i=e.action_data?.kwargs||{};switch(t){case"ai_action":case"ai_step":return i.statement||null;case"verify":case"ai_assert":case"assert":return i.statement||e.action_description||null;case"ai_extract":let n=i.element_description,o=i.variable_name;return n&&o?`Extract ${n} and save to ${o}`:null;case"ai_wait_until":return i.condition||null;default:return null}}static canSelfHeal(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!Qh.includes(t)}}});var da,ua,Bn,ha=w(()=>{"use strict";mn();pn();gn();fn();wn();bn();yn();xn();vn();Sn();En();zt();Xt();Jt();qt();Qt();ei();ti();ii();ni();oi();ai();si();li();ci();di();ui();mi();pi();fi();wi();bi();yi();xi();vi();ki();_i();Si();Wn();F();fe();da=class M{static registerAction(t,i){M.actions.set(t,i)}constructor(){M.initialized||(this.registerBuiltinActions(),M.initialized=!0)}registerBuiltinActions(){M.registerAction("go_to_url",new ia),M.registerAction("go_back",new gl),M.registerAction("reload_page",new Qs),M.registerAction("close_tab",new kl),M.registerAction("switch_tab",new Hs),M.registerAction("click",new Hn),M.registerAction("hover",new na),M.registerAction("right_click",new Qo),M.registerAction("double_click",new ra),M.registerAction("click_by_coordinates",new Es),M.registerAction("right_click_by_coordinates",new ks),M.registerAction("double_click_by_coordinates",new Ts),M.registerAction("drag_drop",new As),M.registerAction("input_text",new oa),M.registerAction("clear_input",new Rl),M.registerAction("press",new Zo),M.registerAction("send_keys_on_element",new ys),M.registerAction("scroll_on_element",new sl),M.registerAction("scroll_to_text",new cl),M.registerAction("scroll",new ri),M.registerAction("upload_file",new js),M.registerAction("wait_for_download_complete",new Ys),M.registerAction("get_dropdown_options",new hl),M.registerAction("select_dropdown_option",new Os),M.registerAction("set_date_for_native_date_picker",new Rs),M.registerAction("verify",new On),M.registerAction("ai_action",new Cs),M.registerAction("ai_extract",new Ll),M.registerAction("ai_step",new Ps),M.registerAction("ai_wait_until",new $s),M.registerAction("generate_2fa_code",new Ml),M.registerAction("wait",new Vs),M.registerAction("wait_for_page_ready",new vs),M.registerAction("save_variable",new nl),M.registerAction("js_code",new Ss),M.registerAction("js_action",new _s),M.registerAction("function",new Ms),M.registerAction("done",new Sl),M.registerAction("click_element",new Hn),M.registerAction("click_element_by_index",new Hn),M.registerAction("hover_element_by_index",new na),M.registerAction("right_click_on_element",new Qo),M.registerAction("double_click_on_element",new ra),M.registerAction("scroll_down",new ri),M.registerAction("scroll_up",new ri),M.registerAction("scroll_element",new ri),M.registerAction("send_keys",new Zo),M.registerAction("open_tab",new ia),M.registerAction("fill",new oa),M.registerAction("ai_assert",new On),M.registerAction("assert",new On)}getAction(t){return M.actions.get(t)}hasAction(t){return M.actions.has(t)}getActionNames(){return Array.from(M.actions.keys())}async execute(t,i,n){if(!n)throw new Error("AgentServices not found");let o=i.action_data?.action_name;if(!o)throw new Error("Action name not found in action_data");let a=this.getAction(o);if(!a)throw new Error(`Unknown action: ${o}`);await a.execute(t,i,n)}transpile(t,i,n){let{sanitizeForComment:o}=(P(),Do(Gi)),a=t.action_description||"",r=t.action_data?.action_name||"",s=this.getAction(r);if(!s)return[`// ${i}: Unknown action: ${r}`];let l=s.transpile(t,i);if(Ei.isAiAction(t))return[`// ${i}: ${o(a)}`,"page = agent.agentServices.validatePage(page);",...l];let d=JSON.stringify(a),c=l.map(g=>` ${g}`),h=Ei.canSelfHeal(t),p=n?JSON.stringify(n):"undefined";return[`// ${i}: ${o(a)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...c,`}, ${d}, '${i}', ${p}, ${h});`]}transpileUncachedAction(t,i,n=!1,o=!1,a){let{sanitizeForComment:r}=(P(),Do(Gi));if(!t)return[`// ${i}: Skipping - no description`];let s=JSON.stringify(t);if(o){let l=a?`, { stmtUid: ${JSON.stringify(a)} }`:"";return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${s}, '${i}'${l});`]}return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${s}, '${i}', ${n});`]}};da.actions=new Map,da.initialized=!1;ua=da,Bn=ua});var gt={};Ue(gt,{ActionHandler:()=>ua,default:()=>Bn});var ft=w(()=>{"use strict";ha();mn();pn();gn();fn();wn();bn();yn();xn();vn();Sn();En();zt();Xt();Jt();qt();Qt();ei();ti();ii();ni();oi();ai();si();li();ci();di();ui();mi();pi();fi();wi();bi();yi();xi();vi();ki();_i();Si();Ln();Zt();K();Ke();R();te();dt();Wn();F();fe()});function Gn(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
|
|
4118
4116
|
${e.stepHistory.slice(-3).map(l=>{let d=`${l.outcome.success?"\u2713":"\u2717"} Step ${l.stepNumber}: ${l.goal}`;if(l.actions.length>1)l.actions.forEach((c,h)=>{let p=c.action_description||"Unknown action";d+=`
|
|
4119
4117
|
\u2192 Action ${h+1}: ${p}`});else if(l.actions.length===1){let c=l.actions[0]?.action_description||"Unknown action";d+=`
|
|
4120
4118
|
\u2192 ${c}`}if(!l.outcome.success&&l.outcome.error){let c=l.outcome.error.substring(0,100);d+=`
|
|
@@ -4134,7 +4132,7 @@ ${e.memory.map((l,d)=>`${d+1}. ${l}`).join(`
|
|
|
4134
4132
|
**Current URL**: ${i}
|
|
4135
4133
|
**Step**: ${e.currentStep+1}/${e.maxSteps}
|
|
4136
4134
|
|
|
4137
|
-
${a()}${r()}${o()}${n()}${s()}`.trim()}function
|
|
4135
|
+
${a()}${r()}${o()}${n()}${s()}`.trim()}function Bl(){return`
|
|
4138
4136
|
\u26A0\uFE0F **FINAL STEP WARNING** \u26A0\uFE0F
|
|
4139
4137
|
|
|
4140
4138
|
This is your last step. You MUST use the "done" action now.
|
|
@@ -4143,8 +4141,8 @@ This is your last step. You MUST use the "done" action now.
|
|
|
4143
4141
|
- If the task is incomplete or partially complete, set success=false
|
|
4144
4142
|
- Include everything you've accomplished in the done action's text field
|
|
4145
4143
|
- No other actions are allowed on this step
|
|
4146
|
-
`.trim()}function
|
|
4147
|
-
`)}function
|
|
4144
|
+
`.trim()}function em(){let e=H.getTools().filter(i=>!i.name.startsWith("ai_")&&!["set_goal","evaluate_step","update_memory","mark_complete"].includes(i.name)).map(i=>{let n="";if(i.schema instanceof wt.z.ZodObject){let o=i.schema.shape,a=[];Object.keys(o).forEach(r=>{let s=o[r],l="any";s instanceof wt.z.ZodNumber?l="number":s instanceof wt.z.ZodString?l="string":s instanceof wt.z.ZodBoolean?l="boolean":s instanceof wt.z.ZodEnum&&(l=s._def.values.map(d=>`"${d}"`).join(" | ")),a.push(`${r}: ${l}`)}),n=`{${a.join(", ")}}`}return{name:i.name,description:i.description,params:n}}).sort((i,n)=>i.name.localeCompare(n.name)),t=[];return t.push("## AVAILABLE ACTIONS"),t.push(""),t.push("Use these exact action names in your JSON response:"),t.push(""),e.forEach(i=>{t.push(`- \`${i.name}\` - ${i.description} (kwargs: ${i.params})`)}),t.push(""),t.join(`
|
|
4145
|
+
`)}function Un(e,t={}){if(e)return e;let{useThinking:i=!0,useMemory:n=!0,useEvaluation:o=!0,useMultiAction:a=!0}=t,r=o?`
|
|
4148
4146
|
1. **Evaluate Previous Step**: After each action, evaluate whether the previous goal was accomplished:
|
|
4149
4147
|
- "success: <reason>" if the goal was fully achieved
|
|
4150
4148
|
- "partial: <reason>" if the goal was partially achieved but needs more work
|
|
@@ -4251,7 +4249,7 @@ CRITICAL: Detect when you are stuck and stop immediately:
|
|
|
4251
4249
|
|
|
4252
4250
|
When stuck, call \`done\` with success=false and explain what happened.
|
|
4253
4251
|
|
|
4254
|
-
${
|
|
4252
|
+
${em()}
|
|
4255
4253
|
## Reasoning Rules
|
|
4256
4254
|
|
|
4257
4255
|
Use the \`thinking\` field to reason about each step:
|
|
@@ -4287,7 +4285,7 @@ ${p}
|
|
|
4287
4285
|
**Current Goal Examples:**
|
|
4288
4286
|
- "Add the product to the cart"
|
|
4289
4287
|
- "Find more product listings and extract details from the next 5 items on the page"
|
|
4290
|
-
${g}`.trim()}var
|
|
4288
|
+
${g}`.trim()}var wt,Kn=w(()=>{"use strict";Te();wt=require("zod")});var jn,ma=w(()=>{"use strict";Kn();ie();jn=class{constructor(e){this.messages=[],this.systemPrompt=e}getMessages(){return{system:this.systemPrompt,messages:[...this.messages]}}addStateMessage(e,t,i,n,o,a={}){let{executionHistory:r,placeholderData:s,sensitiveKeys:l,isFinalStep:d,finalStepWarning:c}=a,h=[],p=Gn(o,e,t);if(h.push({type:"text",text:p}),h.push({type:"text",text:`## CURRENT PAGE STATE
|
|
4291
4289
|
|
|
4292
4290
|
**Interactive Elements**:
|
|
4293
4291
|
${i}`}),r&&Array.isArray(r)&&r.length>0){let g=r.map(([b,k],y)=>`${y+1}. ${b} \u2192 ${k}`);h.push({type:"text",text:`## EXECUTION HISTORY (from test)
|
|
@@ -4303,7 +4301,7 @@ ${g.join(`
|
|
|
4303
4301
|
`,n+=`- Use the EXACT placeholder name as shown above
|
|
4304
4302
|
`,n+=`- Do NOT use the actual value directly in the action
|
|
4305
4303
|
`,n+=`- The values shown are for context only to help you understand what data is available
|
|
4306
|
-
`,n+='- In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")',n}}});var
|
|
4304
|
+
`,n+='- In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")',n}}});var bt,yt=w(()=>{"use strict";bt=`
|
|
4307
4305
|
// check to make sure we're not inside the PDF viewer
|
|
4308
4306
|
window.isPdfViewer = !!document?.body?.querySelector('body > embed[type="application/pdf"][width="100%"]')
|
|
4309
4307
|
if (!window.isPdfViewer) {
|
|
@@ -4358,9 +4356,9 @@ if (!window.isPdfViewer) {
|
|
|
4358
4356
|
};
|
|
4359
4357
|
})();
|
|
4360
4358
|
}
|
|
4361
|
-
`});function Cl(e,t=!0,i=!1){return[...e!==void 0?[`--remote-debugging-port=${e}`,"--remote-allow-origins=*"]:[],"--no-sandbox","--disable-blink-features=AutomationControlled","--timezone=America/Los_Angeles",...i?["--headless"]:[],...t?["--disable-web-security","--disable-site-isolation-trials","--disable-features=IsolateOrigins,site-per-process","--allow-running-insecure-content","--ignore-certificate-errors","--ignore-ssl-errors","--ignore-certificate-errors-spki-list"]:[]]}async function Pl(e,t){let i=await e.newContext(t);return i.addInitScript(pt),i}async function Nn(e){return(await(await fetch(`http://127.0.0.1:${e}/json/version`)).json()).webSocketDebuggerUrl.replace("localhost","127.0.0.1")}async function $l(e,t){let i=await(await fetch(`http://localhost:${e}/json/list`)).json();for(let n of i)if(n.type==="page"&&n.id===t)return n.webSocketDebuggerUrl;throw new Error(`No page found for id: ${t}`)}async function Dl(e){let t=await e.context().newCDPSession(e),i=await t.send("Target.getTargetInfo");return await t.detach(),i.targetInfo}async function jh(e,t){let i=new Set,n=Date.now(),o=new Set(["document","stylesheet","image","font","script","iframe"]),a=new Set(["text/html","text/css","application/javascript","image/","font/","application/json"]),r=["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"],s=h=>{let p=h.toLowerCase();return p.startsWith("data:")||p.startsWith("blob:")?!0:r.some(g=>p.includes(g))},l=h=>{let p=h.resourceType(),g=h.url();if(!o.has(p)||s(g))return;let b=h.headers();b.purpose==="prefetch"||["video","audio"].includes(b["sec-fetch-dest"])||(i.add(h),n=Date.now())},d=async h=>{let p=h.request();if(!i.has(p))return;let g=(h.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(k=>g.includes(k))){i.delete(p);return}if(![...a].some(k=>g.startsWith(k))){i.delete(p);return}let b=h.headers()["content-length"];if(b)try{if(parseInt(b,10)>5*1024*1024){i.delete(p);return}}catch{}i.delete(p),n=Date.now()},c=Date.now()-Kh;for(let h of await e.requests()){let p=h.resourceType(),g=h.url(),b=h.timing();o.has(p)&&!s(g)&&b.responseEnd===-1&&b.startTime>=c&&(i.add(h),n=Date.now())}u.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",d);try{let h=Date.now(),p=Uh;for(;;){await new Promise(b=>setTimeout(b,100));let g=Date.now();if(i.size===0&&g-n>=p){u.debug(`[waitForStableNetwork] Network idle after ${g-h}ms`);break}if(g-h>t){u.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",l),e.removeListener("response",d)}}async function Ee(e,t=Gh,i=Bh){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),jh(e,t)])}catch(r){throw r instanceof Error?new Error(`Failed during network stabilization: ${r.message}`):new Error("An unknown error occurred during network stabilization.")}let o=Date.now()-n,a=Math.max(i-o,0);a>0&&await new Promise(r=>setTimeout(r,a))}var Rn,Bh,Gh,Uh,Kh,Te=w(()=>{"use strict";gt();F();Rn=async(e,t,i)=>{let n=await e.context().newCDPSession(e),o=await n.send("Browser.getWindowForTarget");await n.send("Browser.setWindowBounds",{windowId:o.windowId,bounds:{width:t,height:i,windowState:"normal"}});try{await Promise.race([n.detach(),new Promise((a,r)=>setTimeout(()=>r(new Error("CDP detach timeout")),1e3))])}catch{}},Bh=.5*1e3,Gh=30*1e3,Uh=1*1e3,Kh=3*1e3});function zh(e,t){return e?{prompt_tokens:e.promptTokens||e.inputTokens||0,completion_tokens:e.completionTokens||e.outputTokens||0,total_tokens:e.totalTokens||0,model:t}:null}async function Nl(e,t,i={}){let n=Date.now();if(i.maxSteps!==void 0&&i.maxSteps<=0)throw new Error(`maxSteps must be >= 1, got ${i.maxSteps}`);let o=i.maxSteps??15,a=3,r=t.agentServices.getModel(),s=t.domService||new ue(t.agentServices.getDomServiceOptions()),l={...t,domService:s};f.init(),f.section("Task Execution Started"),f.log(`Task: ${e}`),f.log(`Max steps: ${o}`),f.log(`Model: ${r}`);let d={currentStep:0,maxSteps:o,consecutiveFailures:0,maxFailures:a,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},c=[],h=Dn(i.customPrompt),p=new On(h);f.log(`System prompt length: ${h.length} chars`);let g=!1,b="",k=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:o});d.currentStep<o;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");d.currentStep++;let y=Date.now();f.section(`Step ${d.currentStep}/${o}`),f.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:d.currentStep});try{f.log("Waiting for page to stabilize..."),await Ee(l.page),f.log("Page stabilized")}catch{f.log("Page stabilization timed out, continuing anyway")}let m;try{f.log("Preparing context (DOM + screenshot)...");let C=l.agentServices.getInteractiveClassNames(),I=l.agentServices.getIframeFallbackDomains();m=await Ll(l.page,l.domService,C,I),f.log("Context prepared")}catch(C){if(C.message.includes("Execution context was destroyed")){f.log("Page navigating, waiting for load..."),await Ee(l.page);let I=l.agentServices.getInteractiveClassNames(),L=l.agentServices.getIframeFallbackDomains();m=await Ll(l.page,l.domService,I,L)}else throw f.error("Error preparing context",C),C}p.addStateMessage(e,m.currentUrl,m.domTree,m.screenshotBase64,d,{isFinalStep:d.currentStep===o-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let v=await Xh(p,r,i,m.screenshotBase64);if(v.tokenUsages&&v.tokenUsages.length>0&&c.push(...v.tokenUsages),!v.stepOutput){if(f.error("Failed to get valid LLM response"),d.consecutiveFailures++,d.consecutiveFailures>=a){b="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let A=v.stepOutput;Zh(d.currentStep,o,A);let x=await Jh(A,l,m.domState,d.currentStep,i.onEvent,m.screenshotBase64,v.debugInfo);k.push(...x.actionEntities);let E=qh(d.currentStep,A,x,d,y,v.debugInfo,v.tokenUsages),T=Date.now()-y;if(i.onEvent?.({type:"step_complete",step:d.currentStep,duration:T}),d.consecutiveFailures>=a){f.error(`Too many consecutive failures (${d.consecutiveFailures}), stopping`),b=`Reached the maximum allowed consecutive failures. Most recent error: ${d.lastFailReason}`;break}if(x.doneResult){g=x.doneResult.success,b=x.doneResult.summary;break}if(x.completesInstruction){g=!0,b="Instruction completed";break}}return d.currentStep>=o&&!g&&(b="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:d.currentStep,duration:Date.now()-n}),f.log(`Build success result: summary=${b}, completed=${g}, actions=${k.length}, tokens=${c.length}`),Qh(d,k,g,b,n,c,r)}catch(y){let m=y.message;return f.error(`Task execution failed: ${m}`,y),i.onEvent?.({type:"error",error:m,recoverable:!1}),em(d,m,n,c,r)}}async function Ll(e,t,i,n){let{domState:o,screenshotBase64:a}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n}),r=o.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:r,screenshotBase64:a,domState:o}}function Vh(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let n=i.image,o=typeof n=="string"?n:"";return{type:"image",file:o.startsWith("data:")?o:`data:image/png;base64,${o}`}}return{type:"text",text:i.text}}):t.content}))}async function Xh(e,t,i,n){let o=i.temperature??0,{system:a,messages:r}=e.getMessages(),s=0;for(let h of r)Array.isArray(h.content)&&(s+=h.content.filter(p=>p.type==="image").length);let l=we(t,s),d={model:fe(t),system:a,messages:r,temperature:o,providerOptions:l},c=3;for(let h=0;h<c;h++)try{let p=Date.now();f.log(`Calling LLM (${t})...`);let g=await(0,Ol.generateText)(d),b=Date.now()-p,k=g,y=k.usage;f.llmCall(t,b,y);let m=k.reasoningText;m&&(f.thinking(m),i.onEvent?.({type:"thinking",text:m})),e.addAssistantMessage(g.text);let v={systemPrompt:a,userPrompt:Vh(r),rawLlmResponse:g.text,reasoningContent:m,screenshotWithSom:n},A=[],x=zh(y,t);x&&A.push(x);let E=Yh(g.text);if(!E)if(h<c-1){f.log(`Attempt ${h+1}/${c}: Failed to parse response, retrying...`),e.addTextMessage("user","Your response was not valid JSON. Please respond with a properly formatted JSON object according to the expected format."),await new Promise(T=>setTimeout(T,i.retryDelay||1e3));continue}else return f.error("All parsing attempts failed"),{stepOutput:null,debugInfo:v,tokenUsages:A};return{stepOutput:E,debugInfo:v,tokenUsages:A}}catch(p){if(h<c-1){f.log(`Attempt ${h+1}/${c}: LLM call failed (${p.message}), retrying...`),await new Promise(g=>setTimeout(g,i.retryDelay||1e3));continue}else throw f.error("All LLM call attempts failed",p),p}return{stepOutput:null}}function Yh(e){let t=e.trim();t.startsWith("```json")?t=t.replace(/^```json\s*/,"").replace(/\s*```\s*$/,""):t.startsWith("```")&&(t=t.replace(/^```\s*/,"").replace(/\s*```\s*$/,""));try{let i=JSON.parse(t);if(!i.current_goal)return f.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return f.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return f.error("Action missing required field: action_name"),null;if(!n.description)return f.error("Action missing required field: description"),null}return i}catch(i){return f.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),f.error(`Parse error: ${i.message}`),null}}async function Jh(e,t,i,n,o,a,r){let s=[],l=!0,d=null;f.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let c=null,h={...t,domState:i},p=a;for(let g of e.actions){if(g.action_name==="done"){c={success:g.kwargs.success??!0,summary:g.kwargs.summary||g.kwargs.text||"Task completed"};break}let b={},k=g.kwargs?.element_index??g.kwargs?.index;if(typeof k=="number"){let m=i.selectorMap.get(k);m&&(b=await N(t.page,m))}let y={...b,action_description:g.description,action_data:{action_name:g.action_name,kwargs:g.kwargs}};try{let m=await H.execute(g.action_name,g.kwargs,h);g.action_name==="perform_accurate_operation"&&(y=m.actionEntity);let v=await h.agentServices.getCurrentPage();if(v&&(h.page=v,t.page=h.page),m?.success===!1){l=!1,f.log("Action failed, stopping execution of remaining actions in this step"),d=m.error||"Action execution failed";break}s.push(y),o?.({type:"action",action_entity:y,step:n,debugInfo:r})}catch(m){l=!1,d=m.message,f.error(`Action execution failed: ${m.message}`);break}}return{allSuccess:l,failReason:d,actionEntities:s,doneResult:c,completesInstruction:e.completes_instruction??!1}}function qh(e,t,i,n,o,a,r){let s={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:o,duration:Date.now()-o,outcome:{success:i.allSuccess},debugInfo:a,tokenUsages:r};if(n.lastGoal=t.current_goal,t.evaluation_previous_goal&&(n.lastEvaluation=t.evaluation_previous_goal),t.memory&&t.memory.trim()){let l=t.memory.trim();n.memory.includes(l)||(n.memory.push(l),n.memory.length>10&&(n.memory=n.memory.slice(-10)))}return i.allSuccess?(n.consecutiveFailures=0,n.lastFailReason=null):(n.consecutiveFailures++,n.lastFailReason=i.failReason),n.stepHistory.push(s),s}function Zh(e,t,i){if(f.log(`Step ${e}/${t}`),i.thinking&&f.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&f.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&f.log(`Memory: ${i.memory}`),f.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];f.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else f.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,o)=>{f.log(` ${o+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function Qh(e,t,i,n,o,a,r){let s=a.reduce((c,h)=>c+h.prompt_tokens,0),l=a.reduce((c,h)=>c+h.completion_tokens,0),d=a.reduce((c,h)=>c+h.total_tokens,0);return{success:!0,completed:i,summary:n,trajectory:{steps:e.currentStep,actions:t,stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-o,model:r,successfulSteps:e.stepHistory.filter(c=>c.outcome.success).length,failedSteps:e.stepHistory.filter(c=>!c.outcome.success).length,promptTokens:s,completionTokens:l,totalTokens:d,tokenUsages:a}}}function em(e,t,i,n,o){let a=n.reduce((l,d)=>l+d.prompt_tokens,0),r=n.reduce((l,d)=>l+d.completion_tokens,0),s=n.reduce((l,d)=>l+d.total_tokens,0);return{success:!1,completed:!1,error:t,trajectory:{steps:e.currentStep,actions:[],stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-i,model:o,successfulSteps:e.stepHistory.filter(l=>l.outcome.success).length,failedSteps:e.stepHistory.filter(l=>!l.outcome.success).length,promptTokens:a,completionTokens:r,totalTokens:s,tokenUsages:n}}}var Ol,Rl=w(()=>{"use strict";oa();Ln();_e();Ue();de();Te();Ie();K();Ol=require("ai")});var Fl={};Be(Fl,{TaskMessageManager:()=>On,formatFinalStepWarning:()=>Il,formatTaskContext:()=>$n,getBrowserTaskJSONPrompt:()=>Dn,runTaskLoop:()=>Nl});var Hl=w(()=>{"use strict";Rl();oa();Ln();_e();mn();Ue();Ot();Rt();at();Ft();Ht();de();Te();gt();Ie();Ct();Pt();$t();K();Ge();F();ie();rt();R();pe()});async function Bt(e,t){try{if(!e.action_data)return{success:!1,error:"Action entity missing action_data"};let{action_name:i,kwargs:n}=e.action_data;if(H.has(i)){let o=await H.execute(i,n,t),a=o?.success!==!1,r=o?.error||o?.message;return{success:a,error:a?void 0:r}}else{let{page:o,agentServices:a}=t;return await(await tm()).execute(o,e,a),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function tm(){if(Fn)return Fn;let e=await Promise.resolve().then(()=>(ht(),ut));return Fn=new e.default,Fn}async function ct(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new ue(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await $o(r,a,n);return s.status==="error"?{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error,debugInfo:s.debugInfo}:{status:"success",completed:s.goalAccomplished||!1,actionEntities:s.actionEntity?[s.actionEntity]:[],explanation:s.reasoning,debugInfo:s.debugInfo}}async function Ke(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new ue(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await $o(r,a,n);if(s.status==="error"||!s.actionEntity)return{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error||"No action generated",debugInfo:s.debugInfo};let{actionEntity:l,reasoning:d,goalAccomplished:c,debugInfo:h}=s,p=await Bt(l,a);return p.success?(d&&i.addNote(d),{status:"success",completed:c||!1,actionEntities:[l],explanation:d,debugInfo:h}):{status:"error",completed:!1,actionEntities:[l],error:p.error||"Action execution failed",debugInfo:h}}async function je(e,t,i,n={}){let o={page:t,agentServices:i,domService:new ue(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},a=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),Jr(a,o,n)}async function ze(e,t,i,n,o={}){let{runTaskLoop:a}=await Promise.resolve().then(()=>(Hl(),Fl)),r=n?l=>{n(l)}:void 0,s=await a(e,{page:t,agentServices:i,domService:void 0,executionHistory:o.executionHistory,variables:o.variables,sensitiveKeys:o.sensitiveKeys},{maxSteps:o.maxSteps,onEvent:r,abortSignal:o.abortSignal});return{status:s.success?"success":"error",completed:s.completed,actionEntities:s.trajectory.actions,explanation:s.summary,error:s.error,tokenUsages:s.metadata.tokenUsages}}var Fn,Gt=w(()=>{"use strict";Zi();_e();Ue();Fn=null});function Wl(e){e.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:im,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,o={page:i.page,agentServices:i.agentServices,domService:i.domService},a=await tt(n,o,{});if(a.status==="error"||!a.actionEntity)return{success:!1,actionEntity:{action_description:n,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:n}}},error:a.error||"Failed to generate action"};let{actionEntity:r}=a,s=await Bt(r,o);return{success:s.success,actionEntity:r,message:s.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:s.error}}})}var aa,im,ra=w(()=>{"use strict";Gt();it();aa=require("zod"),im=aa.z.object({instruction:aa.z.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!""')})});async function nm(e,t,i){let{apiKey:n,domain:o}=e;if(!n||!o)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let a=[];try{let r=`https://api.mailgun.net/v3/${o}/events`,s={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(s.from=i.from_email),i.since)s.begin=Math.floor(i.since/1e3).toString();else{let c=new Date(Date.now()-6e5);s.begin=Math.floor(c.getTime()/1e3).toString()}u.info(`Mailgun params: ${JSON.stringify(s)}`);let l=await fetch(r+"?"+new URLSearchParams(s),{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!l.ok){let c=await l.text();throw new Error(`Mailgun events API error: ${c}`)}let d=(await l.json()).items||[];for(let c of d.slice(0,10)){if(c.event!=="accepted")continue;let h=(c.storage||{}).url;if(u.info(`message_url: ${h}`),!h){let b=(c.message||{}).headers||{},k=b.subject||"",y=b.from||"",m=b.to||"";if(i.from_email&&!y.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!m.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!k.toLowerCase().includes(i.subject.toLowerCase()))continue;a.push({subject:k,from:y,to:m,date:new Date(c.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:b["message-id"]||""});continue}let p=h.split("/"),g=p[p.length-1];if(u.info(`Storage key: ${g}`),g){let b=`https://api.mailgun.net/v3/domains/${o}/messages/${g}`;try{let k=await fetch(b,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,Accept:"application/json"}});if(k.ok){let y=await k.json(),m=y.Subject||"",v=y.From||"",A=y.To||"",x=y.Date||"",E=y["Message-Id"]||"";u.info(`subject: ${m}`),u.info(`from_addr: ${v}`),u.info(`to_addr: ${A}`),u.info(`date: ${x}`),u.info(`message_id: ${E}`);let T=y["body-html"]||y["body-plain"]||"";if(T&&T.includes("<")&&(T=(0,Gl.convert)(T)),u.info(`Body: ${T.substring(0,200)}...`),i.subject&&!m.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!T.toLowerCase().includes(i.body_contains.toLowerCase()))continue;a.push({subject:m,from:v,to:A,date:x,body:T,message_id:E});continue}else u.warn(`Messages API returned ${k.status}`)}catch(k){u.warn(`Failed to parse JSON response: ${k}`)}}try{let b=await fetch(h,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!b.ok){u.warn(`Could not fetch stored message: ${b.status}`);continue}let k=await b.text();u.info(`Fallback: Raw email length: ${k.length}`);let y=k.split(`
|
|
4362
|
-
`),m=!0,
|
|
4363
|
-
`}let x
|
|
4359
|
+
`});function Gl(e,t=!0,i=!1){return[...e!==void 0?[`--remote-debugging-port=${e}`,"--remote-allow-origins=*"]:[],"--no-sandbox","--disable-blink-features=AutomationControlled","--timezone=America/Los_Angeles",...i?["--headless"]:[],...t?["--disable-web-security","--disable-site-isolation-trials","--disable-features=IsolateOrigins,site-per-process","--allow-running-insecure-content","--ignore-certificate-errors","--ignore-ssl-errors","--ignore-certificate-errors-spki-list"]:[]]}async function Ul(e,t){let i=await e.newContext(t);return i.addInitScript(bt),i}async function zn(e){return(await(await fetch(`http://127.0.0.1:${e}/json/version`)).json()).webSocketDebuggerUrl.replace("localhost","127.0.0.1")}async function Kl(e,t){let i=await(await fetch(`http://localhost:${e}/json/list`)).json();for(let n of i)if(n.type==="page"&&n.id===t)return n.webSocketDebuggerUrl;throw new Error(`No page found for id: ${t}`)}async function jl(e){let t=await e.context().newCDPSession(e),i=await t.send("Target.getTargetInfo");return await t.detach(),i.targetInfo}async function am(e,t){let i=new Set,n=Date.now(),o=new Set(["document","stylesheet","image","font","script","iframe"]),a=new Set(["text/html","text/css","application/javascript","image/","font/","application/json"]),r=["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"],s=h=>{let p=h.toLowerCase();return p.startsWith("data:")||p.startsWith("blob:")?!0:r.some(g=>p.includes(g))},l=h=>{let p=h.resourceType(),g=h.url();if(!o.has(p)||s(g))return;let b=h.headers();b.purpose==="prefetch"||["video","audio"].includes(b["sec-fetch-dest"])||(i.add(h),n=Date.now())},d=async h=>{let p=h.request();if(!i.has(p))return;let g=(h.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(k=>g.includes(k))){i.delete(p);return}if(![...a].some(k=>g.startsWith(k))){i.delete(p);return}let b=h.headers()["content-length"];if(b)try{if(parseInt(b,10)>5*1024*1024){i.delete(p);return}}catch{}i.delete(p),n=Date.now()},c=Date.now()-om;for(let h of await e.requests()){let p=h.resourceType(),g=h.url(),b=h.timing();o.has(p)&&!s(g)&&b.responseEnd===-1&&b.startTime>=c&&(i.add(h),n=Date.now())}u.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",d);try{let h=Date.now(),p=nm;for(;;){await new Promise(b=>setTimeout(b,100));let g=Date.now();if(i.size===0&&g-n>=p){u.debug(`[waitForStableNetwork] Network idle after ${g-h}ms`);break}if(g-h>t){u.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",l),e.removeListener("response",d)}}async function Me(e,t=im,i=tm){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),am(e,t)])}catch(r){throw r instanceof Error?new Error(`Failed during network stabilization: ${r.message}`):new Error("An unknown error occurred during network stabilization.")}let o=Date.now()-n,a=Math.max(i-o,0);a>0&&await new Promise(r=>setTimeout(r,a))}var Vn,tm,im,nm,om,Ie=w(()=>{"use strict";yt();R();Vn=async(e,t,i)=>{let n=await e.context().newCDPSession(e),o=await n.send("Browser.getWindowForTarget");await n.send("Browser.setWindowBounds",{windowId:o.windowId,bounds:{width:t,height:i,windowState:"normal"}});try{await Promise.race([n.detach(),new Promise((a,r)=>setTimeout(()=>r(new Error("CDP detach timeout")),1e3))])}catch{}},tm=.5*1e3,im=30*1e3,nm=1*1e3,om=3*1e3});function rm(e,t){return e?{prompt_tokens:e.promptTokens||e.inputTokens||0,completion_tokens:e.completionTokens||e.outputTokens||0,total_tokens:e.totalTokens||0,model:t}:null}async function Xl(e,t,i={}){let n=Date.now();if(i.maxSteps!==void 0&&i.maxSteps<=0)throw new Error(`maxSteps must be >= 1, got ${i.maxSteps}`);let o=i.maxSteps??15,a=3,r=t.agentServices.getModel(),s=t.domService||new me(t.agentServices.getDomServiceOptions()),l={...t,domService:s};f.init(),f.section("Task Execution Started"),f.log(`Task: ${e}`),f.log(`Max steps: ${o}`),f.log(`Model: ${r}`);let d={currentStep:0,maxSteps:o,consecutiveFailures:0,maxFailures:a,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},c=[],h=Un(i.customPrompt),p=new jn(h);f.log(`System prompt length: ${h.length} chars`);let g=!1,b="",k=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:o});d.currentStep<o;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");d.currentStep++;let y=Date.now();f.section(`Step ${d.currentStep}/${o}`),f.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:d.currentStep});try{f.log("Waiting for page to stabilize..."),await Me(l.page),f.log("Page stabilized")}catch{f.log("Page stabilization timed out, continuing anyway")}let m;try{f.log("Preparing context (DOM + screenshot)...");let C=l.agentServices.getInteractiveClassNames(),I=l.agentServices.getIframeFallbackDomains();m=await zl(l.page,l.domService,C,I),f.log("Context prepared")}catch(C){if(C.message.includes("Execution context was destroyed")){f.log("Page navigating, waiting for load..."),await Me(l.page);let I=l.agentServices.getInteractiveClassNames(),L=l.agentServices.getIframeFallbackDomains();m=await zl(l.page,l.domService,I,L)}else throw f.error("Error preparing context",C),C}p.addStateMessage(e,m.currentUrl,m.domTree,m.screenshotBase64,d,{isFinalStep:d.currentStep===o-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let x=await lm(p,r,i,m.screenshotBase64);if(x.tokenUsages&&x.tokenUsages.length>0&&c.push(...x.tokenUsages),!x.stepOutput){if(f.error("Failed to get valid LLM response"),d.consecutiveFailures++,d.consecutiveFailures>=a){b="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let A=x.stepOutput;hm(d.currentStep,o,A);let v=await dm(A,l,m.domState,d.currentStep,i.onEvent,m.screenshotBase64,x.debugInfo);k.push(...v.actionEntities);let E=um(d.currentStep,A,v,d,y,x.debugInfo,x.tokenUsages),T=Date.now()-y;if(i.onEvent?.({type:"step_complete",step:d.currentStep,duration:T}),d.consecutiveFailures>=a){f.error(`Too many consecutive failures (${d.consecutiveFailures}), stopping`),b=`Reached the maximum allowed consecutive failures. Most recent error: ${d.lastFailReason}`;break}if(v.doneResult){g=v.doneResult.success,b=v.doneResult.summary;break}if(v.completesInstruction){g=!0,b="Instruction completed";break}}return d.currentStep>=o&&!g&&(b="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:d.currentStep,duration:Date.now()-n}),f.log(`Build success result: summary=${b}, completed=${g}, actions=${k.length}, tokens=${c.length}`),mm(d,k,g,b,n,c,r)}catch(y){let m=y.message;return f.error(`Task execution failed: ${m}`,y),i.onEvent?.({type:"error",error:m,recoverable:!1}),pm(d,m,n,c,r)}}async function zl(e,t,i,n){let{domState:o,screenshotBase64:a}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n}),r=o.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:r,screenshotBase64:a,domState:o}}function sm(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let n=i.image,o=typeof n=="string"?n:"";return{type:"image",file:o.startsWith("data:")?o:`data:image/png;base64,${o}`}}return{type:"text",text:i.text}}):t.content}))}async function lm(e,t,i,n){let o=i.temperature??0,{system:a,messages:r}=e.getMessages(),s=0;for(let h of r)Array.isArray(h.content)&&(s+=h.content.filter(p=>p.type==="image").length);let l=ye(t,s),d={model:be(t),system:a,messages:r,temperature:o,providerOptions:l},c=3;for(let h=0;h<c;h++)try{let p=Date.now();f.log(`Calling LLM (${t})...`);let g=await(0,Vl.generateText)(d),b=Date.now()-p,k=g,y=k.usage;f.llmCall(t,b,y);let m=k.reasoningText;m&&(f.thinking(m),i.onEvent?.({type:"thinking",text:m})),e.addAssistantMessage(g.text);let x={systemPrompt:a,userPrompt:sm(r),rawLlmResponse:g.text,reasoningContent:m,screenshotWithSom:n},A=[],v=rm(y,t);v&&A.push(v);let E=cm(g.text);if(!E)if(h<c-1){f.log(`Attempt ${h+1}/${c}: Failed to parse response, retrying...`),e.addTextMessage("user","Your response was not valid JSON. Please respond with a properly formatted JSON object according to the expected format."),await new Promise(T=>setTimeout(T,i.retryDelay||1e3));continue}else return f.error("All parsing attempts failed"),{stepOutput:null,debugInfo:x,tokenUsages:A};return{stepOutput:E,debugInfo:x,tokenUsages:A}}catch(p){if(h<c-1){f.log(`Attempt ${h+1}/${c}: LLM call failed (${p.message}), retrying...`),await new Promise(g=>setTimeout(g,i.retryDelay||1e3));continue}else throw f.error("All LLM call attempts failed",p),p}return{stepOutput:null}}function cm(e){let t=e.trim();t.startsWith("```json")?t=t.replace(/^```json\s*/,"").replace(/\s*```\s*$/,""):t.startsWith("```")&&(t=t.replace(/^```\s*/,"").replace(/\s*```\s*$/,""));try{let i=JSON.parse(t);if(!i.current_goal)return f.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return f.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return f.error("Action missing required field: action_name"),null;if(!n.description)return f.error("Action missing required field: description"),null}return i}catch(i){return f.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),f.error(`Parse error: ${i.message}`),null}}async function dm(e,t,i,n,o,a,r){let s=[],l=!0,d=null;f.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let c=null,h={...t,domState:i},p=a;for(let g of e.actions){if(g.action_name==="done"){c={success:g.kwargs.success??!0,summary:g.kwargs.summary||g.kwargs.text||"Task completed"};break}let b={},k=g.kwargs?.element_index??g.kwargs?.index;if(typeof k=="number"){let m=i.selectorMap.get(k);m&&(b=await N(t.page,m))}let y={...b,action_description:g.description,action_data:{action_name:g.action_name,kwargs:g.kwargs}};try{let m=await H.execute(g.action_name,g.kwargs,h);g.action_name==="perform_accurate_operation"&&(y=m.actionEntity);let x=await h.agentServices.getCurrentPage();if(x&&(h.page=x,t.page=h.page),m?.success===!1){l=!1,f.log("Action failed, stopping execution of remaining actions in this step"),d=m.error||"Action execution failed";break}s.push(y),o?.({type:"action",action_entity:y,step:n,debugInfo:r})}catch(m){l=!1,d=m.message,f.error(`Action execution failed: ${m.message}`);break}}return{allSuccess:l,failReason:d,actionEntities:s,doneResult:c,completesInstruction:e.completes_instruction??!1}}function um(e,t,i,n,o,a,r){let s={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:o,duration:Date.now()-o,outcome:{success:i.allSuccess},debugInfo:a,tokenUsages:r};if(n.lastGoal=t.current_goal,t.evaluation_previous_goal&&(n.lastEvaluation=t.evaluation_previous_goal),t.memory&&t.memory.trim()){let l=t.memory.trim();n.memory.includes(l)||(n.memory.push(l),n.memory.length>10&&(n.memory=n.memory.slice(-10)))}return i.allSuccess?(n.consecutiveFailures=0,n.lastFailReason=null):(n.consecutiveFailures++,n.lastFailReason=i.failReason),n.stepHistory.push(s),s}function hm(e,t,i){if(f.log(`Step ${e}/${t}`),i.thinking&&f.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&f.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&f.log(`Memory: ${i.memory}`),f.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];f.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else f.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,o)=>{f.log(` ${o+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function mm(e,t,i,n,o,a,r){let s=a.reduce((c,h)=>c+h.prompt_tokens,0),l=a.reduce((c,h)=>c+h.completion_tokens,0),d=a.reduce((c,h)=>c+h.total_tokens,0);return{success:!0,completed:i,summary:n,trajectory:{steps:e.currentStep,actions:t,stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-o,model:r,successfulSteps:e.stepHistory.filter(c=>c.outcome.success).length,failedSteps:e.stepHistory.filter(c=>!c.outcome.success).length,promptTokens:s,completionTokens:l,totalTokens:d,tokenUsages:a}}}function pm(e,t,i,n,o){let a=n.reduce((l,d)=>l+d.prompt_tokens,0),r=n.reduce((l,d)=>l+d.completion_tokens,0),s=n.reduce((l,d)=>l+d.total_tokens,0);return{success:!1,completed:!1,error:t,trajectory:{steps:e.currentStep,actions:[],stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-i,model:o,successfulSteps:e.stepHistory.filter(l=>l.outcome.success).length,failedSteps:e.stepHistory.filter(l=>!l.outcome.success).length,promptTokens:a,completionTokens:r,totalTokens:s,tokenUsages:n}}}var Vl,Yl=w(()=>{"use strict";ma();Kn();Te();je();ie();Ie();Ee();K();Vl=require("ai")});var Jl={};Ue(Jl,{TaskMessageManager:()=>jn,formatFinalStepWarning:()=>Bl,formatTaskContext:()=>Gn,getBrowserTaskJSONPrompt:()=>Un,runTaskLoop:()=>Xl});var ql=w(()=>{"use strict";Yl();ma();Kn();Te();_n();je();Ft();Wt();ct();Bt();Gt();ie();Ie();yt();Ee();It();ot();Ct();K();Ke();R();te();dt();F();fe()});async function Kt(e,t){try{if(!e.action_data)return{success:!1,error:"Action entity missing action_data"};let{action_name:i,kwargs:n}=e.action_data;if(H.has(i)){let o=await H.execute(i,n,t),a=o?.success!==!1,r=o?.error||o?.message;return{success:a,error:a?void 0:r}}else{let{page:o,agentServices:a}=t;return await(await gm()).execute(o,e,a),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function gm(){if(Xn)return Xn;let e=await Promise.resolve().then(()=>(ft(),gt));return Xn=new e.default,Xn}async function mt(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new me(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Bo(r,a,n);return s.status==="error"?{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error,debugInfo:s.debugInfo}:{status:"success",completed:s.goalAccomplished||!1,actionEntities:s.actionEntity?[s.actionEntity]:[],explanation:s.reasoning,debugInfo:s.debugInfo}}async function ze(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new me(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Bo(r,a,n);if(s.status==="error"||!s.actionEntity)return{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error||"No action generated",debugInfo:s.debugInfo};let{actionEntity:l,reasoning:d,goalAccomplished:c,debugInfo:h}=s,p=await Kt(l,a);return p.success?(d&&i.addNote(d),{status:"success",completed:c||!1,actionEntities:[l],explanation:d,debugInfo:h}):{status:"error",completed:!1,actionEntities:[l],error:p.error||"Action execution failed",debugInfo:h}}async function Ve(e,t,i,n={}){let o={page:t,agentServices:i,domService:new me(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},a=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),ls(a,o,n)}async function Xe(e,t,i,n,o={}){let{runTaskLoop:a}=await Promise.resolve().then(()=>(ql(),Jl)),r=n?l=>{n(l)}:void 0,s=await a(e,{page:t,agentServices:i,domService:void 0,executionHistory:o.executionHistory,variables:o.variables,sensitiveKeys:o.sensitiveKeys},{maxSteps:o.maxSteps,onEvent:r,abortSignal:o.abortSignal});return{status:s.success?"success":"error",completed:s.completed,actionEntities:s.trajectory.actions,explanation:s.summary,error:s.error,tokenUsages:s.metadata.tokenUsages}}var Xn,jt=w(()=>{"use strict";cn();Te();je();Xn=null});function Zl(e){e.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:fm,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,o={page:i.page,agentServices:i.agentServices,domService:i.domService},a=await at(n,o,{});if(a.status==="error"||!a.actionEntity)return{success:!1,actionEntity:{action_description:n,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:n}}},error:a.error||"Failed to generate action"};let{actionEntity:r}=a,s=await Kt(r,o);return{success:s.success,actionEntity:r,message:s.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:s.error}}})}var pa,fm,ga=w(()=>{"use strict";jt();rt();pa=require("zod"),fm=pa.z.object({instruction:pa.z.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!""')})});async function wm(e,t,i){let{apiKey:n,domain:o}=e;if(!n||!o)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let a=[];try{let r=`https://api.mailgun.net/v3/${o}/events`,s={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(s.from=i.from_email),i.since)s.begin=Math.floor(i.since/1e3).toString();else{let c=new Date(Date.now()-6e5);s.begin=Math.floor(c.getTime()/1e3).toString()}u.info(`Mailgun params: ${JSON.stringify(s)}`);let l=await fetch(r+"?"+new URLSearchParams(s),{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!l.ok){let c=await l.text();throw new Error(`Mailgun events API error: ${c}`)}let d=(await l.json()).items||[];for(let c of d.slice(0,10)){if(c.event!=="accepted")continue;let h=(c.storage||{}).url;if(u.info(`message_url: ${h}`),!h){let b=(c.message||{}).headers||{},k=b.subject||"",y=b.from||"",m=b.to||"";if(i.from_email&&!y.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!m.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!k.toLowerCase().includes(i.subject.toLowerCase()))continue;a.push({subject:k,from:y,to:m,date:new Date(c.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:b["message-id"]||""});continue}let p=h.split("/"),g=p[p.length-1];if(u.info(`Storage key: ${g}`),g){let b=`https://api.mailgun.net/v3/domains/${o}/messages/${g}`;try{let k=await fetch(b,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,Accept:"application/json"}});if(k.ok){let y=await k.json(),m=y.Subject||"",x=y.From||"",A=y.To||"",v=y.Date||"",E=y["Message-Id"]||"";u.info(`subject: ${m}`),u.info(`from_addr: ${x}`),u.info(`to_addr: ${A}`),u.info(`date: ${v}`),u.info(`message_id: ${E}`);let T=y["body-html"]||y["body-plain"]||"";if(T&&T.includes("<")&&(T=(0,ec.convert)(T)),u.info(`Body: ${T.substring(0,200)}...`),i.subject&&!m.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!T.toLowerCase().includes(i.body_contains.toLowerCase()))continue;a.push({subject:m,from:x,to:A,date:v,body:T,message_id:E});continue}else u.warn(`Messages API returned ${k.status}`)}catch(k){u.warn(`Failed to parse JSON response: ${k}`)}}try{let b=await fetch(h,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!b.ok){u.warn(`Could not fetch stored message: ${b.status}`);continue}let k=await b.text();u.info(`Fallback: Raw email length: ${k.length}`);let y=k.split(`
|
|
4360
|
+
`),m=!0,x={},A="";for(let L=0;L<y.length;L++){let V=y[L];if(V.trim()===""&&m){m=!1;continue}if(m){let Z=V.match(/^([^:]+):\s*(.+)$/);Z&&(x[Z[1].toLowerCase()]=Z[2])}else A+=V+`
|
|
4361
|
+
`}let v=x.subject||"",E=x.from||"",T=x.to||"",C=x.date||"",I=x["message-id"]||"";if(i.subject&&!v.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!A.toLowerCase().includes(i.body_contains.toLowerCase()))continue;a.push({subject:v,from:E,to:T,date:C,body:A.trim(),message_id:I})}catch(b){u.warn(`Error fetching raw message: ${b}`)}}if(a.length>0){try{a.sort((h,p)=>{let g=new Date(h.date).getTime();return new Date(p.date).getTime()-g})}catch{}let c=a[0];return u.info(`Returning most recent email: ${c.subject}`),[c]}return a}catch(r){throw u.error(`Error fetching emails from Mailgun: ${r.message}`),new Error(`Error fetching emails from Mailgun: ${r.message}`)}}function bm(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
|
|
4364
4362
|
|
|
4365
4363
|
Please carefully examine the email content and look for:
|
|
4366
4364
|
1. Numeric codes (usually 4-8 digits)
|
|
@@ -4417,28 +4415,28 @@ Examples of what to extract:
|
|
|
4417
4415
|
Extract: https://service.com/v/longtoken123456789abcdefghijklmnopqrstuvwxyz?param1=value1¶m2=value2
|
|
4418
4416
|
|
|
4419
4417
|
Return ONLY the complete extracted URL or "NOT_FOUND".`;if(e==="custom"){if(!t)throw new Error("Custom prompt is required when extraction_type is custom");return t+`
|
|
4420
|
-
Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function
|
|
4418
|
+
Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function ym(e,t,i){try{let n=`${t}
|
|
4421
4419
|
---
|
|
4422
4420
|
Email Content:
|
|
4423
4421
|
---
|
|
4424
4422
|
${e}
|
|
4425
4423
|
---
|
|
4426
|
-
`,o=
|
|
4424
|
+
`,o=be(i);return(await(0,Ql.generateText)({model:o,messages:[{role:"user",content:n}],temperature:0,providerOptions:ye(i,0)})).text.trim()||"NOT_FOUND"}catch(n){throw u.error(`Error in LLM extraction: ${n.message}`),new Error(`Error in LLM extraction: ${n.message}`)}}async function tc(e,t){u.info(`extract_email_content:
|
|
4427
4425
|
forward_email: ${t.forward_email}
|
|
4428
4426
|
extraction_type: ${t.extraction_type}
|
|
4429
4427
|
filters: ${JSON.stringify(t.filters||{})}
|
|
4430
4428
|
timeout: ${t.timeout||60}
|
|
4431
|
-
polling_interval: 10`);let i=t.timeout||60,n=10;try{if(t.extraction_type==="custom"&&!t.prompt)return{data:void 0,status:"error",message:"Custom prompt is required when extraction_type is custom"};let o=
|
|
4429
|
+
polling_interval: 10`);let i=t.timeout||60,n=10;try{if(t.extraction_type==="custom"&&!t.prompt)return{data:void 0,status:"error",message:"Custom prompt is required when extraction_type is custom"};let o=bm(t.extraction_type,t.prompt),a=new Date,r=new Date(a.getTime()+i*1e3),s=0;for(u.info(`Starting email polling for ${i} seconds with ${n}s intervals`);new Date<r;){s++,u.info(`Polling attempt ${s}`);try{let d=t.filters||{},c=await wm(e,t.forward_email,d);if(c.length>0){u.info(`Found ${c.length} emails matching criteria`);let h=[];for(let p of c){let g=`Subject: ${p.subject}
|
|
4432
4430
|
From: ${p.from}
|
|
4433
4431
|
To: ${p.to}
|
|
4434
4432
|
Date: ${p.date}
|
|
4435
4433
|
|
|
4436
4434
|
Body:
|
|
4437
|
-
${p.body}`,b=await
|
|
4438
|
-
`)}var
|
|
4439
|
-
`)}var sm,lm,ec=w(()=>{"use strict";ca();_e();sm=[Wn(H),Bn(H),Gn(H),Un(H),Kn(H),jn(H),zn(H),Vn(H),Yn(H),Xn(H)],lm=Promise.all(sm)});var tc=w(()=>{"use strict"});function nc(e){return e.getTools().map(t=>({name:t.name,description:t.description,inputSchema:Fi(t.schema)}))}var ic,oc=w(()=>{"use strict";St();ic=class{constructor(e,t){this.registry=e,this.getContext=t}getToolDefinitions(){return this.registry.getTools().filter(e=>e.availability.mcp).map(e=>({name:e.name,description:e.description,inputSchema:Fi(e.schema)}))}getToolDefinitionsFiltered(e){let t=new Set(e);return this.registry.getTools().filter(i=>t.has(i.name)&&i.availability.mcp).map(i=>({name:i.name,description:i.description,inputSchema:Fi(i.schema)}))}async createServer(e="web-sdk-tools"){throw new Error("MCP server creation not yet implemented. Install and configure an MCP SDK like @modelcontextprotocol/sdk")}async executeTool(e,t){let i=await this.getContext(),n=await this.registry.execute(e,t,i);return{content:[{type:"text",text:n.success?n.message||"Tool executed successfully":n.error||"Tool execution failed"}]}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});function qn(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let r=a.startsWith("$")?a.slice(1):a,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o}var _,e0,l0,u0,cm,Zn,dm,um,hm,mm,pm,gm,fm,wm,Ve,ft,rc,bm,Jn,Si,qv,Zv,Qn,sc,lc,cc,dc,Ei,da,ua,ym,ac,xm,_i,vm,km,_m,ae,Sm,Em,Qv,d0,wt=w(()=>{"use strict";pe();_=require("zod"),e0=require("yaml"),l0=require("uuid"),u0=require("yaml");cm="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",Zn=112,dm=1920,um=1080,hm=1920,mm=1080-Zn,pm=1280,gm=720,fm=500,wm=500,Ve="Desktop Chrome",ft=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(ft||{}),rc={"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"}},bm={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"]},Jn=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),bm[e].map(n=>rc[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Si=e=>rc[e],qv={desktop:{label:"Desktop",type:"desktop",devices:Jn("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:Jn("mobile")}},Zv={desktop:{label:"Desktop",type:"desktop",devices:Jn("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:Jn("mobile",!0)}},Qn=(e,t=!1)=>{let i={userAgent:cm,viewport:{width:hm,height:mm},isMobile:!1,hasTouch:!1};if(!e||e===Ve)return i;let n=Si(e);if(!n)return i;let{width:o,height:a}=n.viewport,r=Math.max(fm/o,1),s=Math.max(wm/a,1),l=Math.max(r,s),d={width:Math.round(o*l),height:Math.round(a*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},sc=e=>{let t={width:dm,height:um};if(!e||e===Ve)return t;let i=Qn(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+Zn}:t},lc=e=>{let t={width:pm,height:gm};if(!e||e===Ve)return t;let i=Qn(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},cc=e=>!e||e===Ve?void 0:Si(e)?.channel,dc=e=>!e||e===Ve?"chromium":Si(e)?.defaultBrowserType??"chromium",Ei=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Ei||{}),da=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(da||{}),ua=class uc{constructor(){Eo(this,"data",{}),Eo(this,"sensitive",new Set)}get(t){return this.data[t]}set(t,i,n=!1){this.data[t]=i,n?this.sensitive.add(t):this.sensitive.has(t)&&this.sensitive.delete(t)}getAll(){return{...this.data}}isSensitive(t){return this.sensitive.has(t)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(t){return this.sensitive.delete(t),delete this.data[t]}clear(){this.data={},this.sensitive.clear()}has(t){return t in this.data}get size(){return Object.keys(this.data).length}merge(t){for(let[i,n]of Object.entries(t.getAll()))this.set(i,n,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new uc;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[o,a]of Object.entries(t.data))i.set(o,a,n.has(o))}return i}},ym=_.z.enum(["JS_CODE","AI_MODE"]),ac=_.z.object({type:ym,expression:_.z.string()}),xm=_.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),_i=_.z.object({uid:_.z.string(),type:xm,comment:_.z.string().optional()}),vm=_.z.object({action_data:_.z.object({action_name:_.z.string(),kwargs:_.z.record(_.z.any()).optional(),args:_.z.array(_.z.any()).optional()}),action_description:_.z.string().optional(),url:_.z.string().optional(),xpath:_.z.string().nullable().optional(),locator:_.z.string().nullable().optional(),css_selector:_.z.string().nullable().optional(),unique_selector:_.z.string().nullable().optional(),element_index:_.z.number().nullable().optional(),frame_path:_.z.array(_.z.any()).optional(),artifacts:_.z.record(_.z.any()).optional(),feedback:_.z.string().optional(),original_browser_use_action:_.z.any().optional()}).passthrough(),km=_i.extend({type:_.z.literal("DRAFT"),description:_.z.string()}),_m=_i.extend({type:_.z.literal("ACTION"),description:_.z.string(),action_entity:vm.optional(),locator:_.z.string().optional(),use_pure_vision:_.z.boolean().optional()}),ae=_.z.lazy(()=>_.z.union([km,_m,_i.extend({type:_.z.literal("STEP"),description:_.z.string().optional().default(""),statements:_.z.array(ae),reference_id:_.z.number().optional()}),_i.extend({type:_.z.literal("IF_ELSE"),description:_.z.string().optional(),condition:ac,then:_.z.array(ae),else:_.z.array(ae).optional()}),_i.extend({type:_.z.literal("WHILE_LOOP"),description:_.z.string().optional(),condition:ac,body:_.z.array(ae),timeout_ms:_.z.number().optional()})])),Sm=_.z.object({name:_.z.string(),statements:_.z.array(ae),teardown:_.z.array(ae).optional(),skip:_.z.union([_.z.boolean(),_.z.string()]).optional(),timeout:_.z.number().optional(),fail:_.z.union([_.z.boolean(),_.z.string()]).optional(),only:_.z.boolean().optional(),slow:_.z.boolean().optional()}),Em=_.z.object({tests:_.z.array(Sm).min(1),beforeAll:_.z.array(ae).optional(),afterAll:_.z.array(ae).optional(),beforeEach:_.z.array(ae).optional(),afterEach:_.z.array(ae).optional()}),Qv=_.z.object({comment:_.z.string().optional(),version:_.z.string().optional(),goal:_.z.string().optional(),url:_.z.string().optional(),baseURL:_.z.string().optional(),final_feedback:_.z.string().optional(),completed:_.z.boolean().optional(),success:_.z.boolean().optional(),statements:_.z.array(ae).optional(),teardown:_.z.array(ae).optional(),last_modified_at:_.z.string().optional(),testGroup:Em.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"}),d0=1024*1024});async function Tm(e,t){let i=JSON.parse(Ce.default.readFileSync(t,"utf-8"));i.cookies?.length&&await e.addCookies(i.cookies)}var Ce,hc,bt,Xe,mc,pc=w(()=>{"use strict";wt();Te();gt();F();Ce=W(require("fs"),1),hc=W(require("os"),1),bt=W(require("path"),1),Xe=require("playwright");mc=class{constructor(e={}){e.testDir&&(this.testDir=e.testDir,this.videoBasePath=bt.default.join(e.testDir,"videos"),this.statesBasePath=bt.default.join(e.testDir,"states"),this.downloadsBasePath=bt.default.join(e.testDir,"downloads"),Ce.default.mkdirSync(this.videoBasePath,{recursive:!0}),Ce.default.mkdirSync(this.statesBasePath,{recursive:!0}),Ce.default.mkdirSync(this.downloadsBasePath,{recursive:!0})),this.terminationTimeout=e.terminationTimeout??null,this.defaultHeadless=e.headless??!1,this.additionalArgs=e.additionalArgs??[]}async launchBrowser(e={}){let t=e.debugPort,i=e.headless??this.defaultHeadless,n=dc(e.deviceName),o=cc(e.deviceName),a=n===ft.Chromium,r=!!e.extensionPath;u.info(`[BrowserManager] Launching ${n} browser for device: ${e.deviceName||"default"}${t?` on port ${t}`:""}`);let s={headless:i};if(a){r&&i&&(u.warn("[BrowserManager] Extension requested in headless mode; forcing headed mode to load extension."),i=!1,s.headless=!1);let x=[];(e.enableCamera||e.enableMicrophone)&&(x.push("--use-fake-device-for-media-stream","--use-fake-ui-for-media-stream"),e.enableMicrophone&&e.fakeAudioCapturePath&&(x.push(`--use-file-for-fake-audio-capture=${e.fakeAudioCapturePath}`),u.info(`[BrowserManager] Using fake audio capture file: ${e.fakeAudioCapturePath}`)));let E=r&&e.extensionPath?[`--disable-extensions-except=${e.extensionPath}`,`--load-extension=${e.extensionPath}`]:[];s.args=[...Cl(t,e.disableSecurity??!0,i),...x,...E,...this.additionalArgs],o&&(s.channel=o,u.debug(`[BrowserManager] Launching browser with channel: ${o}`))}let l=Qn(e.deviceName),d=lc(e.deviceName),c={acceptDownloads:!0,...l,timezoneId:e.timezoneId||"America/Los_Angeles",locale:e.locale||"en-US"};e.viewport&&(c.viewport=e.viewport,c.screen=e.viewport),e.isMobile!==void 0&&(c.isMobile=e.isMobile),e.hasTouch!==void 0&&(c.hasTouch=e.hasTouch),e.userAgent&&(c.userAgent=e.userAgent),e.colorScheme&&(c.colorScheme=e.colorScheme),e.geolocation&&(c.geolocation=e.geolocation,c.permissions=[...c.permissions||[],"geolocation"]);let h=r&&a?e.localStorageStatePath:void 0;e.localStorageStatePath&&!h&&(c.storageState=e.localStorageStatePath),e.recordVideo&&this.videoBasePath&&(c.recordVideo={dir:this.videoBasePath,size:{width:d.width,height:d.height}}),e.proxy&&(c.proxy=e.proxy);let p,g,b,k=!1;if(a&&(r||e.userDataDir)){if(e.userDataDir)b=e.userDataDir;else{let E=this.testDir||Ce.default.mkdtempSync(bt.default.join(hc.default.tmpdir(),"shiplight-"));b=bt.default.join(E,`ext-profile-${Date.now()}`),Ce.default.mkdirSync(b,{recursive:!0}),k=!0}let x={...s,...c};g=await Xe.chromium.launchPersistentContext(b,x),h&&(await Tm(g,h),u.info(`[BrowserManager] Loaded storage state into persistent context from ${h}`)),p=g.browser(),u.info(`[BrowserManager] Launched persistent context${e.extensionPath?` for extension at ${e.extensionPath}`:` with profile at ${b}`}`)}else{switch(n){case ft.Firefox:p=await Xe.firefox.launch(s);break;case ft.Webkit:p=await Xe.webkit.launch(s);break;case ft.Chromium:default:p=await Xe.chromium.launch(s);break}g=await p.newContext(c)}if(g.addInitScript(pt),a){let x=["clipboard-read","clipboard-write"];e.enableCamera&&x.push("camera"),e.enableMicrophone&&x.push("microphone");try{await g.grantPermissions(x),u.info(`[BrowserManager] Granted permissions: ${x.join(", ")}`)}catch(E){u.warn("[BrowserManager] Failed to grant permissions:",E)}}else(e.enableCamera||e.enableMicrophone)&&u.warn("[BrowserManager] Camera/microphone enabled but browser is not Chromium; ignoring.");if(e.cookies&&e.cookies.length>0){let x=(Date.now()+31536e6)/1e3,E=e.cookies.map(T=>({...T,expires:x}));await g.addCookies(E),u.info(`[BrowserManager] Added ${e.cookies.length} cookies to browser context with expires=${x}`)}let y=e.viewport,m=y?{width:y.width,height:y.height+Zn}:sc(e.deviceName);if(u.info(`[BrowserManager] windowSize=${JSON.stringify(m)}`),a){let x=async E=>{try{await Rn(E,m.width,m.height),y&&await E.setViewportSize(y)}catch(T){u.warn("[BrowserManager] Failed to set window bounds via CDP:",T)}};for(let E of g.pages())await x(E);g.on("page",x)}let v="";if(a&&t!==void 0)try{v=await Nn(t)}catch(x){u.warn("[BrowserManager] Failed to get CDP WebSocket URL:",x)}let A={debugPort:t,browser:p,context:g,startTime:new Date,timeout:null,browserWsUrl:v,downloadsBasePath:this.downloadsBasePath,browserType:n,userDataDir:b,isTempUserDataDir:k};if(this.terminationTimeout!==null){let x=setTimeout(()=>{u.info(`[BrowserManager] Browser auto-terminated after ${this.terminationTimeout}ms`),this.terminateBrowser(A).catch(E=>u.error("[BrowserManager] Error terminating browser:",E))},this.terminationTimeout);A.timeout=x}return A}async terminateBrowser(e){if(e.timeout&&clearTimeout(e.timeout),await e.context.close(),await e.browser.close(),e.isTempUserDataDir&&e.userDataDir)try{Ce.default.rmSync(e.userDataDir,{recursive:!0,force:!0})}catch(t){u.warn("[BrowserManager] Failed to clean up temp user data dir:",e.userDataDir,t)}}getVideoBasePath(){return this.videoBasePath}getStatesBasePath(){return this.statesBasePath}getDownloadsBasePath(){return this.downloadsBasePath}}});var gc,fc=w(()=>{"use strict";wt();gc=e=>{if(!e||e===Ve)return"desktop";let t=Si(e);return t&&t.isMobile?"mobile":"desktop"}});var Am,wc=w(()=>{"use strict";Am=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Am||{})});async function bc(e,t){let i=Object.getPrototypeOf(async()=>{}).constructor,n=`
|
|
4435
|
+
${p.body}`,b=await ym(g,o,t.model);u.info(`Extracted content: ${b}`),b&&b!=="NOT_FOUND"&&h.push({content:b,email_subject:p.subject,email_from:p.from,email_date:p.date})}if(h.length>0){let p=h[0],g=`$email_${t.extraction_type}`;t.extraction_type==="custom"?g="$email_extracted_content":t.extraction_type==="activation_link"?g="$email_magic_link":t.extraction_type==="verification_code"&&(g="$email_otp_code");let b=(new Date().getTime()-a.getTime())/1e3;return u.info(`Successfully extracted content after ${s} attempts in ${b.toFixed(1)} seconds`),{data:p.content,result_variable:g,status:"success",message:`Successfully extracted content from email: ${p.email_subject.substring(0,50)}... (attempts: ${s})`}}else u.info(`Found emails but no extractable content in attempt ${s}`)}else u.info(`No emails found in attempt ${s}`)}catch(d){u.warn(`Error in polling attempt ${s}: ${d.message}`)}if(new Date(Date.now()+n*1e3)>=r){u.info("Not enough time for another polling attempt");break}u.info(`Waiting ${n} seconds before next attempt...`),await new Promise(d=>setTimeout(d,n*1e3))}let l=(new Date().getTime()-a.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${s} attempts over ${l.toFixed(1)} seconds`}}catch(o){return u.error(`Error extracting email content: ${o.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${o.message}`}}}var Ql,ec,fa=w(()=>{"use strict";Ee();R();Ql=require("ai"),ec=require("html-to-text")});function ic(e){switch(e){case"verification_code":return"email_otp_code";case"activation_link":return"email_magic_link";case"custom":return"email_extracted_content";default:return"email_content"}}function oc(e,t){e.register({name:"extract_email_content",description:"Extract verification codes, magic links, or custom content from emails received via Mailgun. Polls the Mailgun inbox for matching emails and uses AI to extract the requested content.",schema:xm,async execute(i,n){let{forward_email:o,extraction_type:a,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:h}=i,{page:p,agentServices:g}=n;u.info(`[extract_email_content] Extracting ${a} from ${o}`);try{let b={action_description:`Extract ${a} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:o,extraction_type:a,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:h}}};await t.execute(p,b,g);let k=ic(a);return{success:!0,actionEntity:b,message:`Extracted ${a} and saved to $${k}`}}catch(b){return{success:!1,error:b.message,actionEntity:{action_description:`Extract ${a} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:o,extraction_type:a,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:h}},feedback:b.message}}}}})}var ve,nc,xm,wa=w(()=>{"use strict";fa();R();te();ve=require("zod");nc=class{getMailgunConfig(){let e=G().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""}}async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=this.getMailgunConfig();if(!o)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN in SDK config.");let a=n.kwargs,r=i.getModel?.()||"gemini-2.5-pro",s=await tc(o,{model:r,forward_email:a.forward_email,extraction_type:a.extraction_type,prompt:a.prompt,filters:{from_email:a.filter_from_email,to_email:a.filter_to_email,subject:a.filter_subject,body_contains:a.filter_body_contains},timeout:a.timeout});if(s.status==="success"&&s.data){let l=s.result_variable?.replace(/^\$/,"")||ic(a.extraction_type);i.variableStore.set(l,s.data),u.info(`[extract_email_content] Extracted and saved to ${l}`)}else throw new Error(s.message||"Failed to extract email content")}transpile(e){let t=e.action_data?.kwargs||{};return['await agent.execAction("extract_email_content", page, {',` action_data: { kwargs: ${JSON.stringify(t)} },`,"});"]}},xm=ve.z.object({forward_email:ve.z.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:ve.z.enum(["verification_code","activation_link","custom"]).describe("Type of content to extract: verification_code for OTP codes, activation_link for magic links, custom for custom prompts"),prompt:ve.z.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:ve.z.string().optional().describe("Filter emails by sender address"),filter_to_email:ve.z.string().optional().describe("Filter emails by recipient address"),filter_subject:ve.z.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:ve.z.string().optional().describe("Filter emails by body content (partial match)"),timeout:ve.z.number().optional().describe("Timeout in seconds for polling (default: 60)")})});async function ke(){if(Yn)return Yn;let e=(await Promise.resolve().then(()=>(ft(),gt))).default;return Yn=new e,Yn}async function Jn(e){let t=await ke(),i=t.getAction("click"),n=t.getAction("hover"),o=t.getAction("right_click"),a=t.getAction("double_click");return Wl(e,i),yl(e,n),il(e,o),Al(e,a),"Click, hover, double-click, right-click, or drag elements"}async function qn(e){let t=await ke(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),o=t.getAction("reload_page");return wl(e,i),fl(e,n),el(e,o),"Navigate to URLs, go back, or reload the page"}async function Zn(e){let t=await ke(),i=t.getAction("clear_input"),n=t.getAction("input_text"),o=t.getAction("press");return Fl(e,i),vl(e,n),qs(e,o),"Type text into inputs, clear input values, or press keyboard keys"}async function Qn(e){let t=await ke(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),o=t.getAction("scroll");return ll(e,i),dl(e,n),al(e,o),"Scroll the page or scroll to specific text/elements"}async function eo(e){let t=await ke(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return _l(e,i),Ws(e,n),"Switch between browser tabs or close tabs"}async function to(e){let t=await ke(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return zs(e,i),Js(e,n),"Upload files or wait for downloads to complete"}async function io(e){let t=await ke(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),o=t.getAction("set_date_for_native_date_picker");return ml(e,i),Ns(e,n),Fs(e,o),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function no(e){let t=await ke(),i=t.getAction("wait"),n=t.getAction("save_variable"),o=t.getAction("done");return Xs(e,i),ol(e,n),El(e,o),Zl(e),"Wait for conditions, save variables, or complete tasks"}async function oo(e){let t=(await ke()).getAction("generate_2fa_code");Il(e,t);let i=new nc;return(await Promise.resolve().then(()=>(ft(),gt))).default.registerAction("extract_email_content",i),oc(e,i),"Generate 2FA codes or extract email/activation codes"}async function ao(e){let t=await ke(),i=t.getAction("verify"),n=t.getAction("ai_extract"),o=t.getAction("ai_wait_until");return Dl(e,i),Ol(e,n),Ds(e,o),"Perform AI-powered assertions, extractions, or wait conditions"}async function ac(e){let[t,i,n,o,a,r,s,l,d,c]=await Promise.all([Jn(e),qn(e),Zn(e),Qn(e),eo(e),to(e),io(e),no(e),oo(e),ao(e)]);return{mouse:t,navigation:i,input:n,scroll:o,tabs:a,files:r,forms:s,utility:l,auth:d,ai:c}}function rc(e){return[`- Mouse: ${e.mouse}`,`- Navigation: ${e.navigation}`,`- Input: ${e.input}`,`- Scroll: ${e.scroll}`,`- Tabs: ${e.tabs}`,`- Files: ${e.files}`,`- Forms: ${e.forms}`,`- Utility: ${e.utility}`,`- Auth: ${e.auth}`,`- AI: ${e.ai}`].join(`
|
|
4436
|
+
`)}var Yn,ba=w(()=>{"use strict";ga();wa();zt();Xt();Jt();qt();Qt();ei();ti();ii();ni();oi();ai();si();li();ci();di();ui();mi();pi();fi();wi();bi();yi();xi();vi();ki();_i();Si();Yn=null});async function sc(){await km}function lc(){return H}function cc(e=!0){let t=new st;return e&&(Jn(t),qn(t),Zn(t),Qn(t),eo(t),to(t),io(t),oo(t),no(t),ao(t)),t}async function dc(){let e=new st,t=await ac(e),i=rc(t);return{registry:e,capabilities:t,summary:i}}function uc(){return["- Mouse: Click, hover, double-click, right-click or drag on elements","- Navigation: Navigate to URLs, go back, or reload the page","- Input: Type text into inputs, clear input fields, or press keyboard keys","- Scroll: Scroll the page or scroll to specific text/elements","- Tabs: Switch between browser tabs or close tabs","- Files: Upload files or wait for downloads to complete","- Forms: Get dropdown options or select dropdown values","- Utility: Wait for conditions, save variables, or complete tasks","- Auth: Generate 2FA codes or extract email/activation codes","- AI: Perform AI-powered verifications, extractions, or wait conditions"].join(`
|
|
4437
|
+
`)}var vm,km,hc=w(()=>{"use strict";ba();Te();vm=[Jn(H),qn(H),Zn(H),Qn(H),eo(H),to(H),io(H),no(H),ao(H),oo(H)],km=Promise.all(vm)});function pc(e){return e.getTools().map(t=>({name:t.name,description:t.description,inputSchema:Zi(t.schema)}))}var mc,gc=w(()=>{"use strict";$t();mc=class{constructor(e,t){this.registry=e,this.getContext=t}getToolDefinitions(){return this.registry.getTools().filter(e=>e.availability.mcp).map(e=>({name:e.name,description:e.description,inputSchema:Zi(e.schema)}))}getToolDefinitionsFiltered(e){let t=new Set(e);return this.registry.getTools().filter(i=>t.has(i.name)&&i.availability.mcp).map(i=>({name:i.name,description:i.description,inputSchema:Zi(i.schema)}))}async createServer(e="web-sdk-tools"){throw new Error("MCP server creation not yet implemented. Install and configure an MCP SDK like @modelcontextprotocol/sdk")}async executeTool(e,t){let i=await this.getContext(),n=await this.registry.execute(e,t,i);return{content:[{type:"text",text:n.success?n.message||"Tool executed successfully":n.error||"Tool execution failed"}]}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});var fc=w(()=>{"use strict"});function co(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let r=a.startsWith("$")?a.slice(1):a,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o}var _,$0,W0,U0,_m,so,Sm,Em,Tm,Am,Mm,Im,Cm,Pm,Ye,xt,bc,$m,ro,Ai,I0,C0,lo,yc,xc,vc,kc,Mi,ya,xa,Dm,wc,Lm,Ti,Om,Nm,Rm,le,Fm,Hm,P0,G0,vt=w(()=>{"use strict";fe();_=require("zod"),$0=require("yaml"),W0=require("uuid"),U0=require("yaml"),_m="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",so=112,Sm=1920,Em=1080,Tm=1920,Am=1080-so,Mm=1280,Im=720,Cm=500,Pm=500,Ye="Desktop Chrome",xt=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(xt||{}),bc={"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"}},$m={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"]},ro=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),$m[e].map(n=>bc[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Ai=e=>bc[e],I0={desktop:{label:"Desktop",type:"desktop",devices:ro("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:ro("mobile")}},C0={desktop:{label:"Desktop",type:"desktop",devices:ro("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:ro("mobile",!0)}},lo=(e,t=!1)=>{let i={userAgent:_m,viewport:{width:Tm,height:Am},isMobile:!1,hasTouch:!1};if(!e||e===Ye)return i;let n=Ai(e);if(!n)return i;let{width:o,height:a}=n.viewport,r=Math.max(Cm/o,1),s=Math.max(Pm/a,1),l=Math.max(r,s),d={width:Math.round(o*l),height:Math.round(a*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},yc=e=>{let t={width:Sm,height:Em};if(!e||e===Ye)return t;let i=lo(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+so}:t},xc=e=>{let t={width:Mm,height:Im};if(!e||e===Ye)return t;let i=lo(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},vc=e=>!e||e===Ye?void 0:Ai(e)?.channel,kc=e=>!e||e===Ye?"chromium":Ai(e)?.defaultBrowserType??"chromium",Mi=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Mi||{}),ya=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(ya||{});xa=class _c{constructor(){Lo(this,"data",{}),Lo(this,"sensitive",new Set)}get(t){return this.data[t]}set(t,i,n=!1){this.data[t]=i,n?this.sensitive.add(t):this.sensitive.has(t)&&this.sensitive.delete(t)}getAll(){return{...this.data}}isSensitive(t){return this.sensitive.has(t)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(t){return this.sensitive.delete(t),delete this.data[t]}clear(){this.data={},this.sensitive.clear()}has(t){return t in this.data}get size(){return Object.keys(this.data).length}merge(t){for(let[i,n]of Object.entries(t.getAll()))this.set(i,n,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new _c;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[o,a]of Object.entries(t.data))i.set(o,a,n.has(o))}return i}},Dm=_.z.enum(["JS_CODE","AI_MODE"]),wc=_.z.object({type:Dm,expression:_.z.string()}),Lm=_.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Ti=_.z.object({uid:_.z.string(),type:Lm,comment:_.z.string().optional()}),Om=_.z.object({action_data:_.z.object({action_name:_.z.string(),kwargs:_.z.record(_.z.any()).optional(),args:_.z.array(_.z.any()).optional()}),action_description:_.z.string().optional(),url:_.z.string().optional(),xpath:_.z.string().nullable().optional(),locator:_.z.string().nullable().optional(),css_selector:_.z.string().nullable().optional(),unique_selector:_.z.string().nullable().optional(),element_index:_.z.number().nullable().optional(),frame_path:_.z.array(_.z.any()).optional(),artifacts:_.z.record(_.z.any()).optional(),feedback:_.z.string().optional(),original_browser_use_action:_.z.any().optional()}).passthrough(),Nm=Ti.extend({type:_.z.literal("DRAFT"),description:_.z.string()}),Rm=Ti.extend({type:_.z.literal("ACTION"),description:_.z.string(),action_entity:Om.optional(),locator:_.z.string().optional(),use_pure_vision:_.z.boolean().optional()}),le=_.z.lazy(()=>_.z.union([Nm,Rm,Ti.extend({type:_.z.literal("STEP"),description:_.z.string().optional().default(""),statements:_.z.array(le),reference_id:_.z.number().optional()}),Ti.extend({type:_.z.literal("IF_ELSE"),description:_.z.string().optional(),condition:wc,then:_.z.array(le),else:_.z.array(le).optional()}),Ti.extend({type:_.z.literal("WHILE_LOOP"),description:_.z.string().optional(),condition:wc,body:_.z.array(le),timeout_ms:_.z.number().optional()})])),Fm=_.z.object({name:_.z.string(),statements:_.z.array(le),teardown:_.z.array(le).optional(),skip:_.z.union([_.z.boolean(),_.z.string()]).optional(),timeout:_.z.number().optional(),fail:_.z.union([_.z.boolean(),_.z.string()]).optional(),only:_.z.boolean().optional(),slow:_.z.boolean().optional()}),Hm=_.z.object({tests:_.z.array(Fm).min(1),beforeAll:_.z.array(le).optional(),afterAll:_.z.array(le).optional(),beforeEach:_.z.array(le).optional(),afterEach:_.z.array(le).optional()}),P0=_.z.object({comment:_.z.string().optional(),version:_.z.string().optional(),goal:_.z.string().optional(),url:_.z.string().optional(),baseURL:_.z.string().optional(),final_feedback:_.z.string().optional(),completed:_.z.boolean().optional(),success:_.z.boolean().optional(),statements:_.z.array(le).optional(),teardown:_.z.array(le).optional(),last_modified_at:_.z.string().optional(),testGroup:Hm.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"}),G0=1024*1024});async function Wm(e,t){let i=JSON.parse($e.default.readFileSync(t,"utf-8"));i.cookies?.length&&await e.addCookies(i.cookies)}var $e,Sc,kt,Je,Ec,Tc=w(()=>{"use strict";vt();Ie();yt();R();$e=W(require("fs"),1),Sc=W(require("os"),1),kt=W(require("path"),1),Je=require("playwright");Ec=class{constructor(e={}){e.testDir&&(this.testDir=e.testDir,this.videoBasePath=kt.default.join(e.testDir,"videos"),this.statesBasePath=kt.default.join(e.testDir,"states"),this.downloadsBasePath=kt.default.join(e.testDir,"downloads"),$e.default.mkdirSync(this.videoBasePath,{recursive:!0}),$e.default.mkdirSync(this.statesBasePath,{recursive:!0}),$e.default.mkdirSync(this.downloadsBasePath,{recursive:!0})),this.terminationTimeout=e.terminationTimeout??null,this.defaultHeadless=e.headless??!1,this.additionalArgs=e.additionalArgs??[]}async launchBrowser(e={}){let t=e.debugPort,i=e.headless??this.defaultHeadless,n=kc(e.deviceName),o=vc(e.deviceName),a=n===xt.Chromium,r=!!e.extensionPath;u.info(`[BrowserManager] Launching ${n} browser for device: ${e.deviceName||"default"}${t?` on port ${t}`:""}`);let s={headless:i};if(a){r&&i&&(u.warn("[BrowserManager] Extension requested in headless mode; forcing headed mode to load extension."),i=!1,s.headless=!1);let v=[];(e.enableCamera||e.enableMicrophone)&&(v.push("--use-fake-device-for-media-stream","--use-fake-ui-for-media-stream"),e.enableMicrophone&&e.fakeAudioCapturePath&&(v.push(`--use-file-for-fake-audio-capture=${e.fakeAudioCapturePath}`),u.info(`[BrowserManager] Using fake audio capture file: ${e.fakeAudioCapturePath}`)));let E=r&&e.extensionPath?[`--disable-extensions-except=${e.extensionPath}`,`--load-extension=${e.extensionPath}`]:[];s.args=[...Gl(t,e.disableSecurity??!0,i),...v,...E,...this.additionalArgs],o&&(s.channel=o,u.debug(`[BrowserManager] Launching browser with channel: ${o}`))}let l=lo(e.deviceName),d=xc(e.deviceName),c={acceptDownloads:!0,...l,timezoneId:e.timezoneId||"America/Los_Angeles",locale:e.locale||"en-US"};e.viewport&&(c.viewport=e.viewport,c.screen=e.viewport),e.isMobile!==void 0&&(c.isMobile=e.isMobile),e.hasTouch!==void 0&&(c.hasTouch=e.hasTouch),e.userAgent&&(c.userAgent=e.userAgent),e.colorScheme&&(c.colorScheme=e.colorScheme),e.geolocation&&(c.geolocation=e.geolocation,c.permissions=[...c.permissions||[],"geolocation"]);let h=r&&a?e.localStorageStatePath:void 0;e.localStorageStatePath&&!h&&(c.storageState=e.localStorageStatePath),e.recordVideo&&this.videoBasePath&&(c.recordVideo={dir:this.videoBasePath,size:{width:d.width,height:d.height}}),e.proxy&&(c.proxy=e.proxy);let p,g,b,k=!1;if(a&&(r||e.userDataDir)){if(e.userDataDir)b=e.userDataDir;else{let E=this.testDir||$e.default.mkdtempSync(kt.default.join(Sc.default.tmpdir(),"shiplight-"));b=kt.default.join(E,`ext-profile-${Date.now()}`),$e.default.mkdirSync(b,{recursive:!0}),k=!0}let v={...s,...c};g=await Je.chromium.launchPersistentContext(b,v),h&&(await Wm(g,h),u.info(`[BrowserManager] Loaded storage state into persistent context from ${h}`)),p=g.browser(),u.info(`[BrowserManager] Launched persistent context${e.extensionPath?` for extension at ${e.extensionPath}`:` with profile at ${b}`}`)}else{switch(n){case xt.Firefox:p=await Je.firefox.launch(s);break;case xt.Webkit:p=await Je.webkit.launch(s);break;case xt.Chromium:default:p=await Je.chromium.launch(s);break}g=await p.newContext(c)}if(g.addInitScript(bt),a){let v=["clipboard-read","clipboard-write"];e.enableCamera&&v.push("camera"),e.enableMicrophone&&v.push("microphone");try{await g.grantPermissions(v),u.info(`[BrowserManager] Granted permissions: ${v.join(", ")}`)}catch(E){u.warn("[BrowserManager] Failed to grant permissions:",E)}}else(e.enableCamera||e.enableMicrophone)&&u.warn("[BrowserManager] Camera/microphone enabled but browser is not Chromium; ignoring.");if(e.cookies&&e.cookies.length>0){let v=(Date.now()+31536e6)/1e3,E=e.cookies.map(T=>({...T,expires:v}));await g.addCookies(E),u.info(`[BrowserManager] Added ${e.cookies.length} cookies to browser context with expires=${v}`)}let y=e.viewport,m=y?{width:y.width,height:y.height+so}:yc(e.deviceName);if(u.info(`[BrowserManager] windowSize=${JSON.stringify(m)}`),a){let v=async E=>{try{await Vn(E,m.width,m.height),y&&await E.setViewportSize(y)}catch(T){u.warn("[BrowserManager] Failed to set window bounds via CDP:",T)}};for(let E of g.pages())await v(E);g.on("page",v)}let x="";if(a&&t!==void 0)try{x=await zn(t)}catch(v){u.warn("[BrowserManager] Failed to get CDP WebSocket URL:",v)}let A={debugPort:t,browser:p,context:g,startTime:new Date,timeout:null,browserWsUrl:x,downloadsBasePath:this.downloadsBasePath,browserType:n,userDataDir:b,isTempUserDataDir:k};if(this.terminationTimeout!==null){let v=setTimeout(()=>{u.info(`[BrowserManager] Browser auto-terminated after ${this.terminationTimeout}ms`),this.terminateBrowser(A).catch(E=>u.error("[BrowserManager] Error terminating browser:",E))},this.terminationTimeout);A.timeout=v}return A}async terminateBrowser(e){if(e.timeout&&clearTimeout(e.timeout),await e.context.close(),await e.browser.close(),e.isTempUserDataDir&&e.userDataDir)try{$e.default.rmSync(e.userDataDir,{recursive:!0,force:!0})}catch(t){u.warn("[BrowserManager] Failed to clean up temp user data dir:",e.userDataDir,t)}}getVideoBasePath(){return this.videoBasePath}getStatesBasePath(){return this.statesBasePath}getDownloadsBasePath(){return this.downloadsBasePath}}});var Ac,Mc=w(()=>{"use strict";vt();Ac=e=>{if(!e||e===Ye)return"desktop";let t=Ai(e);return t&&t.isMobile?"mobile":"desktop"}});var Bm,Ic=w(()=>{"use strict";Bm=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Bm||{})});async function Cc(e,t){let i=Object.getPrototypeOf(async()=>{}).constructor,n=`
|
|
4440
4438
|
return await (${t});
|
|
4441
|
-
`;return await new i("page",n)(e)}async function
|
|
4439
|
+
`;return await new i("page",n)(e)}async function Ii(e,t,i){let n=[],o=[];for(let a of t){let r=!1;try{let s=`page.${a}`;f.log(`Checking element existence: ${s}`),n.push(`Checking element existence: ${s}`);try{await Cc(e,`${s}.waitFor({ state: 'attached', timeout: ${Gm} })`),f.log(`Element is attached: ${s}`),n.push(`Element is attached: ${s}`),r=!0}catch{await Cc(e,`${s}.count()`)>0?(f.log(`Element found (snapshot): ${s}`),n.push(`Element found (snapshot): ${s}`),r=!0):(f.log(`Element not found: ${s}`),n.push(`Element not found: ${s}`),r=!1)}}catch(s){f.log(`Error checking element: ${s.message}`),n.push(`Error checking element: ${s.message}`),r=!1}if(o.push(r),!r&&i)break}return{successResults:o,logs:n}}async function va(e,t,i=!0){let{successResults:n,logs:o}=await Ii(e,t,i);return{success:n.length===t.length&&n.every(a=>a),logs:o}}async function Ci(e,t){if(!t||t.length===0)return f.log("No validation expressions provided, cannot validate login"),!1;f.log(`Validating login with ${t.length} expression(s)`);let{success:i,logs:n}=await va(e,t,!0);return i?f.log("All validation expressions passed"):f.log(`Validation failed: ${n.join(", ")}`),i}async function ka(e,t){let i=e.context().browser();if(!i)throw new Error("Cannot create unsigned-in context: browser not available");let n=await i.newContext(),o=await n.newPage();return await o.goto(t),await Me(o,Um),{context:n,page:o,close:async()=>{await o.close(),await n.close()}}}async function _a(e,t,i,n,o,a){let r=`
|
|
4442
4440
|
Based on the current page status, generate ${o} Playwright locators in JavaScript code that can
|
|
4443
4441
|
be used by a program to verify the page is signed in.
|
|
4444
4442
|
Each expression should yield a locator object that can be used for waiting and checking visibility.
|
|
@@ -4482,20 +4480,20 @@ ${n}
|
|
|
4482
4480
|
Remember, you must have the javascript code block in your final response.
|
|
4483
4481
|
`,f.log("Agent generating validation locators"),f.log(`Prompt:
|
|
4484
4482
|
${r}`);let s=await a(e,r);if(!s.success)throw new Error(s.details||"Agent failed to generate verification code");let l=(s.details||"").match(/```javascript\n(.*)\n```/s);if(!l)throw new Error("Agent failed to generate verification code: no javascript code block found");return l[1].split(`
|
|
4485
|
-
`).map(d=>d.trim()).filter(d=>d.length>0).map(d=>(d.startsWith("page.")&&(d=d.slice(5)),d))}async function
|
|
4483
|
+
`).map(d=>d.trim()).filter(d=>d.length>0).map(d=>(d.startsWith("page.")&&(d=d.slice(5)),d))}async function uo(e,t,i,n,o){let a=null;try{a=await ka(e,t);let r=await o(a.page),s=3,l="";for(let d=0;d<s;d++)try{let c=await _a(e,r,l||null,i.verification_hint??null,i.num_verification_exprs??1,n);f.log(`Generated validation locators: ${JSON.stringify(c)}`);{let{successResults:h,logs:p}=await Ii(e,c,!1);if(l+=`Test results on a SIGNED IN page. EXPECT ALL PASS:
|
|
4486
4484
|
${p.join(`
|
|
4487
4485
|
`)}
|
|
4488
4486
|
|
|
4489
4487
|
`,!h.every(g=>g)){f.log(`Locator validation on signed-in page failed. Results: ${JSON.stringify(h)}`),f.log(`Validation logs:
|
|
4490
4488
|
${p.join(`
|
|
4491
|
-
`)}`);continue}}{f.log("Validating locators in unsigned-in context, EXPECT ALL TO FAIL");let{successResults:h,logs:p}=await
|
|
4489
|
+
`)}`);continue}}{f.log("Validating locators in unsigned-in context, EXPECT ALL TO FAIL");let{successResults:h,logs:p}=await Ii(a.page,c,!1);if(l+=`Test results on an UNSIGNED IN page. EXPECT ALL FAIL:
|
|
4492
4490
|
${p.join(`
|
|
4493
4491
|
`)}
|
|
4494
4492
|
|
|
4495
4493
|
`,h.some(g=>g)){f.log(`Locator validation on unsigned-in page failed (some passed when should fail). Results: ${JSON.stringify(h)}`),f.log(`Validation logs:
|
|
4496
4494
|
${p.join(`
|
|
4497
|
-
`)}`);continue}}return f.log("Generated validation locators passed dual validation"),c}catch(c){f.log(`Failed to generate validation expressions (attempt ${d+1}/${s}): ${c.message}`)}return f.log("Failed to generate valid locators after max retries"),null}finally{a&&await a.close()}}var
|
|
4498
|
-
${e.trim()}`:this.context.agentNote=e.trim())}readVariable(e){let t=e.startsWith("$")?e.slice(1):e,i=this.context.variableStore.get(t);return u.debug(`Read variable: ${t} = ${JSON.stringify(i)}`),i}async generate2faCode(e){try{let t=
|
|
4495
|
+
`)}`);continue}}return f.log("Generated validation locators passed dual validation"),c}catch(c){f.log(`Failed to generate validation expressions (attempt ${d+1}/${s}): ${c.message}`)}return f.log("Failed to generate valid locators after max retries"),null}finally{a&&await a.close()}}var Gm,Um,ho=w(()=>{"use strict";ie();Ie();Gm=5e3,Um=1e4});var Pc,Sa=w(()=>{"use strict";Pc=class{constructor(e){this.currentPage=null,this.currentIndex=-1,this.context=e,this.initialize()}initialize(){this.context.on("page",async t=>{await this.handleNewPage(t)});let e=this.context.pages();e.length>0&&(this.currentPage=e[0],this.currentIndex=0);for(let t of e)this.setupPageListeners(t)}async handleNewPage(e){try{this.setupPageListeners(e);let t=this.context.pages().indexOf(e);await this.setCurrentPage(e,t)}catch{}}setupPageListeners(e){e.on("close",async()=>{await this.handlePageClose(e)})}async handlePageClose(e){try{if(this.currentPage===e){let t=this.context.pages(),i=t.slice().reverse().find(n=>!n.isClosed());i&&await this.setCurrentPage(i,t.indexOf(i))}}catch{}}async setCurrentPage(e,t){let i=this.currentPage!==e;this.currentPage=e,this.currentIndex=t,i&&await e.bringToFront()}async switchToPage(e){let t=this.context.pages();if(e<0||e>=t.length)throw new Error(`Invalid page index: ${e}. Available pages: 0-${t.length-1}`);let i=t[e];if(i.isClosed())throw new Error(`Page at index ${e} is closed`);return await this.setCurrentPage(i,e),i}async closePage(e){let t=this.context.pages();if(e<0||e>=t.length)throw new Error(`Invalid page index: ${e}. Available pages: 0-${t.length-1}`);let i=t[e];if(i.isClosed())throw new Error(`Page at index ${e} 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 $c(e,t=3e3,i=1e3){try{await Me(e,t,i)}catch{}}async function Dc(e,t,i){let n=i*1e3,o=100,a=Date.now();for(;!t.downloadStatus||t.downloadStatus.status==="inProgress";){if(Date.now()-a>n){let r;throw t.downloadStatus?r=`Timed out after ${n}ms waiting for download to complete`:r="No download in progress or completed",u.error(r),new Error(r)}await e.waitForTimeout(o)}if(t.downloadStatus.status==="failed"){let r=`Download failed: ${t.downloadStatus.error||"Unknown error"}`;throw u.error(r),new Error(r)}t.agentNote=`Download completed: ${t.downloadStatus.filename}`}async function Lc(e,t,i,n=60,o){let a=Math.min(n,280),r=Math.max(10,a/10)*1e3,s=Date.now()+a*1e3;for(u.info(`Waiting for condition: "${t}" (timeout: ${a}s)`);;){let l=Date.now();try{if(await i(e,t,o))return u.info(`Condition met: "${t}"`),!0}catch(c){u.warn(`Error evaluating condition: ${c.message}`)}if(Date.now()>s)return u.warn(`Timeout waiting for condition: "${t}"`),!1;let d=r-(Date.now()-l);d>0&&await e.waitForTimeout(d)}}var mo=w(()=>{"use strict";Ie();R()});function Rc(e){return e.url()===":"}var Oc,Pi,Nc,po,Ea=w(()=>{"use strict";Sa();vt();mo();Ie();R();Oc=W(require("fs"),1),Pi=W(require("path"),1),Nc=require("otplib");po=class{constructor(e){this.context=e,this.testDataFileNames=[],this.extensionEnabled=!1}setTestDataDownloader(e,t){this.testDataDownloader=e,this.testDataFileNames=t??[]}setupPageTracking(e){this.tabManager=new Pc(e)}async switchTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");return await this.tabManager.switchToPage(e)}async closeTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");await this.tabManager.closePage(e)}getCurrentPage(){return this.tabManager?this.tabManager.getCurrentPage():null}validatePage(e){let t=this.getCurrentPage();if(t&&t!==e&&!t.isClosed())return u.info(`[validatePage] Page changed, switching to ${t.url()}`),t;if(e.isClosed()){let i=e.context().pages().filter(n=>!n.isClosed());if(i.length>0){let n=i[i.length-1];return u.info(`[validatePage] Page closed, switching to ${n.url()}`),n}u.error("[validatePage] No valid pages found")}return e}replaceVariables(e){return co(e,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(e){let t=this.context.testDataDir||process.cwd();return Pi.join(t,e)}async downloadTestDataFiles(e){if(e.length===0){u.debug("[AgentServices] No file paths provided for download");return}let t=this.context.testDataDir||process.cwd(),i=e.filter(n=>{let o=Pi.basename(n),a=Pi.join(t,o),r=Oc.existsSync(a);return r&&u.debug(`[AgentServices] File already exists locally: ${o}`),!r});if(i.length===0){u.debug("[AgentServices] All files exist locally, no download needed");return}if(!this.testDataDownloader){u.debug("[AgentServices] No test data downloader configured, assuming files are pre-populated");return}u.info(`[AgentServices] Downloading ${i.length} test data files: ${i.join(", ")}`),await this.testDataDownloader(i,t)}async waitForDownloadComplete(e,t){return Dc(e,this.context,t)}getRecentDownloadedFilePath(){return this.context.downloadStatus?this.context.downloadStatus.status!=="completed"?(u.debug(`Download is ${this.context.downloadStatus.status}, not completed`),null):this.context.downloadStatus.filePath?(u.info(`Retrieved recent download path: ${this.context.downloadStatus.filePath}`),this.context.downloadStatus.filePath):(u.warn("Download completed but file path is missing"),null):(u.debug("No download found"),null)}addSensitive(e,t){this.context.variableStore.set(e,t,!0)}saveVariable(e,t){let i=e.startsWith("$")?e.slice(1):e;this.context.variableStore.set(i,t),u.debug(`Saved variable: ${i} = ${JSON.stringify(t)}`),this.context.agentNote=`A new value is saved to the variable "${i}".`}addNote(e){!e||e.trim()===""||(this.context.agentNote?this.context.agentNote+=`
|
|
4496
|
+
${e.trim()}`:this.context.agentNote=e.trim())}readVariable(e){let t=e.startsWith("$")?e.slice(1):e,i=this.context.variableStore.get(t);return u.debug(`Read variable: ${t} = ${JSON.stringify(i)}`),i}async generate2faCode(e){try{let t=(0,Nc.generateSync)({secret:e});return u.info(`Generated 2FA code: ${t}`),t}catch(t){throw u.error(`Failed to generate 2FA code: ${t.message}`),new Error(`Failed to generate 2FA code: ${t.message}`)}}async getDOMText(e){return await e.evaluate(()=>document.body.innerText)}async waitUntilStable(e,t){return Me(e,t)}setPage(e){this.context.setPage?(u.info("[AgentServices] Calling setPage callback"),this.context.setPage(e)):u.debug("[AgentServices] setPage callback not configured")}getModel(){if(!this.context.model)throw new Error("No LLM model configured. An LLM model is required for AI-powered actions (login, verify, ai_extract, ai_wait_until, etc.). Set GOOGLE_API_KEY or ANTHROPIC_API_KEY in your MCP server configuration.");return this.context.model}getComputerUseModel(){return this.context.computer_use_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||[]}getIframeFallbackDomains(){return this.context.organizationSettings?.agent_settings?.iframe_fallback_domains||[]}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 e=process.env.USE_DOM_TREE_TS;return e!==void 0?e==="true"||e==="1":this.context.organizationSettings?.agent_settings?.use_dom_tree_ts||!1}setExtensionEnabled(e){this.extensionEnabled=e}getDomServiceOptions(){return{useDomTreeTs:this.isDomTreeTsEnabled(),domTreeRoot:this.extensionEnabled?"document":"body"}}setKnowledgeRetriever(e){this.knowledgeRetriever=e}hasKnowledgeRetriever(){return this.knowledgeRetriever!==void 0}async retrieveKnowledges(e,t,i,n){if(!this.knowledgeRetriever)return u.debug("[AgentServices] No knowledge retriever configured"),[];try{let o=await this.knowledgeRetriever(e,t,i,n);return u.debug(`[AgentServices] Retrieved ${o.length} knowledges for statement`),o}catch(o){return u.warn(`[AgentServices] Failed to retrieve knowledges: ${o.message}`),[]}}}});var Ta,go,Aa=w(()=>{"use strict";Ta=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(Ta||{}),go=class extends Error{constructor(e){super(e),this.name="AgentTaskFailedError",this.details=e}}});var Fc={};Ue(Fc,{LoginType:()=>Mi,checkLocators:()=>Ii,createUnsignedInContext:()=>ka,generateAndValidateLoginLocators:()=>uo,generateValidationLocators:()=>_a,validateLogin:()=>Ci,validateLoginLocators:()=>va});var Hc=w(()=>{"use strict";ho();ie();vt();Ie();yt();R();te();dt();fe()});function $i(e,t){let i={};for(let[n,o]of Object.entries(e))i[n]=t.has(n)?"*****":o;return i}var j,q,Km,jm,zm,Ma,Wc=w(()=>{"use strict";jt();je();ho();ie();Ea();mo();Aa();Zt();R();j=W(require("fs"),1),q=W(require("path"),1),Km=1,jm=3,zm=40;Ma=class{constructor(e){this.context=e,this._newActionEntities=new Map,this.agentServices=new po(e),this.agentServices.agent=this,this.context.tokenUsages||(this.context.tokenUsages=[])}getNewActionEntities(){return this._newActionEntities}getAgentNote(){return this.context.agentNote||void 0}async getActionHandler(){if(!this._actionHandler){let{default:e}=await Promise.resolve().then(()=>(ft(),gt));this._actionHandler=new e}return this._actionHandler}async execAction(e,t,i){let n=(await this.getActionHandler()).getAction(e);if(!n)throw new Error(`Unknown action: ${e}`);await n.execute(t,i,this.agentServices)}async dismissModalIfPresent(e,t){try{let i=await this.execute(e,`TASK: Check if there is an INTRUSIVE POPUP blocking the page, and dismiss it if present.
|
|
4499
4497
|
|
|
4500
4498
|
ONLY dismiss intrusive popups such as:
|
|
4501
4499
|
- Cookie/GDPR consent banners
|
|
@@ -4517,7 +4515,7 @@ If you find an intrusive popup, dismiss it by clicking its close/X button or "No
|
|
|
4517
4515
|
IMPORTANT: Only act with HIGH CONFIDENCE. If unsure whether something is an intrusive popup, do nothing.
|
|
4518
4516
|
It's better to miss a popup than to accidentally interact with normal page elements.
|
|
4519
4517
|
|
|
4520
|
-
If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,Pm),n=!!(i.actions&&i.actions.length>0);return{success:i.success,modalDismissed:n,details:i.details||(n?"Modal dismissed":"No modal found"),actions:i.actions}}catch(i){return{success:!1,modalDismissed:!1,details:i.message||"Modal dismissal failed"}}}_getContext(){return this.context}setupDownloadTracking(e){if(u.info(`[Download Tracking] Setting up download tracking for page: ${e.url()}`),Ec(e)){u.info(`[Download Tracking] Skipping download tracking for blank tab: ${e.url()}`),e.close();return}e.on("download",async t=>{let i=t.suggestedFilename();u.info(`[Download Tracking] Download event detected! File: ${i}`),this.context.downloadStatus={filename:i,status:"inProgress",startTime:Date.now()},u.info(`[Download Tracking] Download status set to inProgress: ${JSON.stringify(this.context.downloadStatus)}`);try{let n=this.context.downloadDir||J.join(process.cwd(),"downloads");j.existsSync(n)||j.mkdirSync(n,{recursive:!0});let o=J.join(n,i);u.info(`[Download Tracking] Downloading file to: ${o}`),await t.saveAs(o),this.context.downloadStatus={filename:i,status:"completed",startTime:this.context.downloadStatus.startTime,filePath:o,timestamp:Date.now()},u.info(`[Download Tracking] Download completed: ${o}`),u.info(`[Download Tracking] Download status set to completed: ${JSON.stringify(this.context.downloadStatus)}`)}catch(n){this.context.downloadStatus={filename:i,status:"failed",startTime:this.context.downloadStatus.startTime,error:n.message,timestamp:Date.now()},u.error(`[Download Tracking] Download failed for ${i}: ${n.message}`)}})}setupDialogHandling(e){if(u.debug(`[Dialog Handling] setupDialogHandling called, isClosed=${e.isClosed()}, url=${e.url()}`),e.isClosed()){u.debug("[Dialog Handling] Skipping - page is closed");return}u.info(`[Dialog Handling] Setting up dialog handling for page: ${e.url()}`),e.on("dialog",async t=>{let i=t.type(),n=t.message();u.info(`[Dialog Handling] Dialog detected - type: ${i}, message: "${n}"`);let o=i==="beforeunload";try{o?await t.dismiss():await t.accept(),this.context.dialogStatus={type:i,message:n,response:o?"dismiss":"accept",timestamp:Date.now()},u.info(`[Dialog Handling] Dialog ${o?"dismissed":"accepted"} - type: ${i}, message: "${n}"`)}catch(a){u.warn(`[Dialog Handling] Failed to handle dialog (already dismissed?): ${a}`)}})}getRecentDownloadedFilePath(){return this.agentServices.getRecentDownloadedFilePath()}addNote(e){this.agentServices.addNote(e)}collectTokenUsages(e){let t;Array.isArray(e)?t=e:e?.tokenUsages&&(t=e.tokenUsages),t&&t.length>0?(this.context.tokenUsages||(this.context.tokenUsages=[]),this.context.tokenUsages.push(...t),u.debug(`[collectTokenUsages] Added ${t.length} token usage(s), total: ${this.context.tokenUsages.length}`)):u.debug("[collectTokenUsages] No token usages to collect (undefined or empty)")}trackAIAction(e,t,i,n=1,o,a){if(!e)return;let r=i?.tokenUsages||[];this.context.aiActionDetails||(this.context.aiActionDetails=[]);let s=this.context.aiActionDetails.find(l=>l.stepId===e&&l.actionType===t);s?(s.count+=n,r.length>0&&s.tokenUsages.push(...r),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),a&&(s.explanation=a)):this.context.aiActionDetails.push({stepId:e,actionType:t,count:n,tokenUsages:[...r],statement:o,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:a,elementTree:i?.elementTree,screenshotWithSom:i?.screenshotWithSom}),u.debug(`[trackAIAction] Tracked ${t} for step ${e}, count: ${n}`)}async assert(e,t,i){u.info(`Asserting statement: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),o=await je(t,e,this.agentServices,{executionHistory:n,useCleanScreenshotForAssertion:!0,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(o.debugInfo),this.context.lastActionDebugInfo=o.debugInfo;let a=o.explanation||o.error||"No explanation";if(i&&this.trackAIAction(i,"assert",o.debugInfo,1,t,a),this.context.agentNote=a,i&&this.context.stepTracking&&await this.updateStepResult(i,o.success?"success":"failure",a,void 0,o.debugInfo),!o.success)throw this.addToExecutionHistory(`Assert: "${t}"`,`Failed: ${a}`),new Error(`Assertion failed: ${a}`);return this.addToExecutionHistory(`Assert: "${t}"`,`Passed: ${a}`),!0}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async evaluate(e,t,i){u.info(`Evaluating condition: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),o=await je(t,e,this.agentServices,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(o.debugInfo),this.context.lastActionDebugInfo=o.debugInfo;let a=o.explanation||o.error||"No explanation";return i&&this.trackAIAction(i,"evaluate",o.debugInfo,1,t,a),this.context.agentNote=a,i&&this.context.stepTracking&&await this.updateStepResult(i,"success",a,void 0,o.debugInfo),o.success?(this.addToExecutionHistory(`Evaluate: "${t}"`,`Result: true - ${a}`),!0):(u.warn(`AI evaluation returned false/unknown: ${a}`),this.addToExecutionHistory(`Evaluate: "${t}"`,`Unknown/False: ${a}`),!1)}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async performAction(e,t){u.info(`Act: ${t}`);let i=this.getCompletedExecutionHistory(),n=await Ke(t,e,this.agentServices,{executionHistory:i,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});if(this.collectTokenUsages(n.debugInfo),n.status!=="success"||n.actionEntities.length===0)return{success:!1,details:n.explanation||n.error||"Action failed"};let o=n.actionEntities[0]?.action_description||t;return this.addToExecutionHistory(t,o),{success:!0,details:n.explanation}}async execute(e,t,i,n,o){if(o!==void 0&&o<=0)throw new Error(`maxSteps must be >= 1, got ${o}`);let a=o!==void 0&&o>1;u.info(`Executing statement: ${t} (${a?`multi, maxSteps: ${o}`:"single"})`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t),e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e);try{let r=this.getCompletedExecutionHistory();this.context.agentNote="";let s,l;if(a){let c=i&&this.context.stepTracking?.artifactsDir?h=>{if(h.type==="action"&&h.debugInfo){let p=`${i}-step${h.step}`;this.saveDebugInfoToFiles(p,h.debugInfo,this.context.model)}}:void 0;if(s=await ze(t,e,this.agentServices,c,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:o??$m}),l=s.completed,this.collectTokenUsages(s.tokenUsages),i&&s.tokenUsages){let h={tokenUsages:s.tokenUsages};this.trackAIAction(i,"execute",h,s.actionEntities?.length||1,t,s.explanation||"Multi-step execution completed")}}else if(e=this.agentServices.validatePage(e),s=await Ke(t,e,this.agentServices,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n}),l=s.completed,this.collectTokenUsages(s.debugInfo),this.context.lastActionDebugInfo=s.debugInfo,i){let c=s.explanation||s.error||"No explanation";this.trackAIAction(i,"execute",s.debugInfo,1,t,c)}if(s.status!=="success"||s.actionEntities.length===0){let c=s.explanation||s.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",c,void 0,s.debugInfo),new Error(`Action failed: ${c}`)}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: "${t}"`,d),{success:!0,details:d,actions:s.actionEntities,debugInfo:s.debugInfo}}catch(r){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",r.message),this.addToExecutionHistory(`Execute: "${t}"`,`Failed: ${r.message}`),r}}async generate(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t);try{let o=this.getCompletedExecutionHistory(),a=await ct(t,e,this.agentServices,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n});if(this.collectTokenUsages(a.debugInfo),a.status!=="success"||a.actionEntities.length===0){let l=a.explanation||a.error||"No explanation";throw i&&this.trackAIAction(i,"generate",a.debugInfo,1,t,l),i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",l,void 0,a.debugInfo),new Error(l)}let r=a.completed,s=a.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",a.debugInfo,1,t,s),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",s,void 0,a.debugInfo),u.info(`[generate] Generated action for "${t}": ${s}, goalAccomplished: ${a.completed}`),{success:r,details:s,actions:a.actionEntities,debugInfo:a.debugInfo}}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),o}}async run(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t);try{let o=this.getCompletedExecutionHistory();this.context.agentNote="";let a=i&&this.context.stepTracking?.artifactsDir,r=n?.onAction||a?c=>{if(c.type==="action"&&c.action_entity&&(n?.onAction?.(c.action_entity),a&&c.debugInfo)){let h=`${i}-step${c.step}`;this.saveDebugInfoToFiles(h,c.debugInfo,this.context.model)}}:void 0,s=await ze(t,e,this.agentServices,r,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:n?.abortSignal,maxSteps:n?.maxSteps});f.log(`Run task result: status=${s.status}, completed=${s.completed}, actions=${s.actionEntities?.length||0}`),this.collectTokenUsages(s.tokenUsages);let l=s.status==="success"&&s.completed,d=this.context.agentNote?.trim()||s.explanation||s.error||(l?"Step completed":"Step failed");if(i&&s.tokenUsages){let c={tokenUsages:s.tokenUsages};this.trackAIAction(i,"run",c,s.actionEntities?.length||1,t,d)}if(!l)throw new oo(d);if(n?.stmtUid&&s.actionEntities?.length){let c=s.actionEntities.at(-1);c&&(this._newActionEntities.set(n.stmtUid,c),f.log(`Stored resolved action entity for DRAFT stmtUid: ${n.stmtUid}`))}return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,void 0),this.addToExecutionHistory(`Run: "${t}"`,d),f.log(`Run result: success=${l}, details=${d}`),{success:l,details:d,actions:s.actionEntities}}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),this.addToExecutionHistory(`Run: "${t}"`,`Failed: ${o.message}`),o}}async step(e,t,i,n,o,a=!0,r){let s=Date.now();this.context.stepTracking&&await this.createStepResult(e,n,i),e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e),this.context.stepTracking&&(this.context.stepTracking.currentStepId=n),e=this.agentServices.validatePage(e);let l=e.url(),d=await this.captureDOMSnapshot(e),c=this.context.stepTracking?.captureVariables?Ii(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},h=this.context.stepTracking?.results[n]?.screenshot;try{u.info(`Executing step ${n}: ${i}`),this.addToExecutionHistory(i,""),this.context.agentNote="",e=this.agentServices.validatePage(e);let p=await t();e=this.agentServices.validatePage(e);let g=e.url(),b=await this.captureDOMSnapshot(e),k=this.context.stepTracking?.captureVariables?Ii(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking&&await this.updateStepResult(n,"success",""),this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let m=Date.now()-s,v=this.context.stepTracking.results[n]?.screenshot,A=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:m,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:g,domSnapshot:b||void 0,variables:k,screenshotPath:v,timestamp:A})}let y=this.context.agentNote;return(!y||y.trim()==="")&&(y="Execution successful"),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=y),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}catch(p){e=this.agentServices.validatePage(e);let g=a&&!this.context.isSelfHealing;if(g&&(this.context.stepTracking&&await this.updateStepResult(n,"failure",p.message),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=p.message)),!i||i.trim()==="")throw u.error("No description provided for self-healing"),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p;if(!g){if(u.info(`Failed to heal at step ${n}. ${i}`),this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let m=e.url(),v=await this.captureDOMSnapshot(e),A=this.context.stepTracking.captureVariables?Ii(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},x=Date.now()-s,E=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:x,status:"failure",errorMessage:p.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:m,domSnapshot:v||void 0,variables:A,timestamp:E})}throw this.context.stepTracking&&(await this.updateStepResult(n,void 0,void 0),this.context.stepTracking.currentStepId=void 0),p}this.context.isSelfHealing=!0,u.info(`Action failed at step ${n}. ${i}`),u.info(`with error: ${p.message}`);let b,k;if(this.context.autoDismissModal){u.info("Attempting modal dismissal before self-healing...");let m=await this.dismissModalIfPresent(e,i);if(u.info(`Modal dismissal result: ${m.details}`),m.modalDismissed){b=`[Auto-dismissed modal: ${m.details}]`,k=m.actions,u.info(`Modal dismissed, retrying original action for step ${n}`);try{let v=await t();return this.context.isSelfHealing=!1,this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=b+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(n,"success",b),this.context.stepTracking.results[n].dismissedModalActions=k,this.context.stepTracking.currentStepId=void 0),this.context.agentNote=b,v}catch(v){u.info(`Retry after modal dismissal failed: ${v.message}, falling back to self-healing`)}}}let y=r??Cm;u.info(`Calling execute() to self-heal (maxSteps: ${y})`);try{let m=await this.execute(e,i,n,!1,y);if(this.context.isSelfHealing=!1,!m.success)throw new Error(`Self-healing failed: ${m.details}`);let v=m.actions?.at(-1);o&&v&&(this._newActionEntities.set(o,v),u.info(`Stored new action entity for stmtUid: ${o} (last of ${m.actions?.length} actions)`));let A=e.url(),x=await this.captureDOMSnapshot(e),E=this.context.stepTracking?.captureVariables?Ii(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking){this.context.stepTracking.results[n].autoHealed=!0,this.context.stepTracking.results[n].healedAction=v,k&&(this.context.stepTracking.results[n].dismissedModalActions=k);let T=b||"";await this.updateStepResult(n,"success",T)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let T=Date.now()-s,C=this.context.stepTracking.results[n]?.screenshot,I=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{actionEntity:v,playwrightCode:m.actions?.map(L=>L.locator||""),llmPrompt:m.debugInfo?.userPrompt,llmResponse:m.debugInfo?.rawLlmResponse,llmReasoning:m.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(n),durationMs:T,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:A,domSnapshot:x||void 0,variables:E,screenshotPath:C,timestamp:I})}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 v=e.url(),A=await this.captureDOMSnapshot(e),x=this.context.stepTracking.captureVariables?Ii(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},E=Date.now()-s,T=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:E,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:v,domSnapshot:A||void 0,variables:x,timestamp:T})}throw this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}}}async extract(e,t,i,n){n&&this.context.stepTracking&&await this.createStepResult(e,n,`Extract ${t} into ${i}`);try{let o=`Extract ${t} and save to ${i}`,a=await this.execute(e,o,n);if(!a.success)throw new Error(`AI extraction failed: ${a.details}`);n&&this.context.stepTracking&&await this.updateStepResult(n,"success",`Extracted ${t} to ${i}`)}catch(o){throw n&&this.context.stepTracking&&await this.updateStepResult(n,"failure",o.message),o}}async getDOMText(e){let t=new ue(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains();return(await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n})).elementTree.clickableElementsToString()}async captureDOMSnapshot(e){if(!this.context.stepTracking?.captureStateTransitions||!this.context.stepTracking?.captureDom)return null;try{let t=new ue(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains(),o=await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n,highlightElements:!1,viewportExpansion:0});return{elementTreeText:o.elementTree.clickableElementsToString(),elementCount:o.selectorMap.size,timestamp:Date.now()}}catch(t){return u.warn("Failed to capture DOM snapshot:",t),null}}getConsoleLogsForStep(e){return this.context.stepTracking?.consoleLogs?this.context.stepTracking.consoleLogs.filter(t=>t.stepId===e).map(t=>({type:t.type,message:t.message,timestamp:t.timestamp})):[]}async waitUntilStable(e,t=3e3,i=1e3){return xc(e,t,i)}async waitUntilCondition(e,t,i=60,n){return kc(e,t,(o,a,r)=>this.evaluate(o,a,r),i,n)}async uploadFile(e,t,i={},n){return Ps(e,t,i,this.context,(o,a,r)=>this.execute(o,a,r),n)}async loginPage(e,t,i){let{LoginType:n}=await Promise.resolve().then(()=>(Ac(),Tc));if(u.info("Start login"),f.section("Login Flow"),f.log(`Site URL: ${t.site_url}`),f.log(`Account type: ${t.account.type}`),f.log(`Has cached actions: ${!!i?.cached_actions?.length}`),f.log(`Has validation exprs: ${!!i?.validation_exprs?.length}`),t.skip_verification)return u.info("Skipping login verification (skip_verification=true)"),{success:!0,page:e};(t.account.type===n.PASSWORD||t.account.type===n.OAUTH2)&&(this.context.variableStore.set("username",t.account.username,!0),this.context.variableStore.set("password",t.account.password,!0)),t.account.two_factor_auth_config?.type==="totp"&&this.context.variableStore.set("otp_secret_key",t.account.two_factor_auth_config.data,!0),u.info(`Navigating to: ${t.site_url}`),await e.goto(t.site_url),await this.waitUntilStable(e,1e4,3e3);let o=!!(t.use_ai_verification_for_login_check&&t.verification_hint?.trim()),a=o?`Check if the page is already signed in. Consider it signed in only when this verification statement is satisfied: ${t.verification_hint.trim()}`:void 0;if(o){f.log("Level 1: Checking if already logged in via AI verification hint..."),f.log(`Verification statement: ${a}`);try{if(await this.evaluate(e,a))return f.log("Level 1 SUCCESS: Already logged in via AI verification"),u.info("Login: Already logged in via AI verification"),{success:!0,page:e,storage_state:null,cached_actions:i?.cached_actions,validation_exprs:i?.validation_exprs,alreadyLoggedIn:!0};f.log("Level 1 FAILED: AI verification indicates not signed in, trying Level 2")}catch(l){f.log(`Level 1 ERROR: AI verification failed (${l.message}), trying Level 2`)}}else t.use_ai_verification_for_login_check&&!t.verification_hint?.trim()&&f.log("Level 1 SKIPPED: use_ai_verification_for_login_check is enabled but verification_hint is empty, falling back to cached validation expressions");if(!o&&i?.validation_exprs&&i.validation_exprs.length>0){if(f.log("Level 1: Checking if already logged in via storage state..."),f.log(`Validation expressions: ${JSON.stringify(i.validation_exprs)}`),await Ai(e,i.validation_exprs))return f.log("Level 1 SUCCESS: Already logged in via storage state"),u.info("Login: Already logged in via storage state"),{success:!0,page:e,storage_state:null,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs,alreadyLoggedIn:!0};f.log("Level 1 FAILED: Storage state validation failed, trying Level 2")}let r=!!(i?.validation_exprs&&i.validation_exprs.length>0);if(i?.cached_actions&&i.cached_actions.length>0&&(o||r)){f.log(`Level 2: Attempting cached login with ${i.cached_actions.length} actions`);try{if((await this.executeCachedLogin(e,i.cached_actions,{validationExprs:i.validation_exprs,aiVerificationStatement:a})).success){f.log("Level 2 SUCCESS: Cached login succeeded"),u.info("Login: Cached login succeeded");let l=await e.context().storageState();return{success:!0,page:e,storage_state:l,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs}}f.log("Level 2 FAILED: Cached login failed, trying Level 3")}catch(l){f.log(`Level 2 ERROR: ${l.message}, trying Level 3`)}}else i?.cached_actions&&i.cached_actions.length>0&&f.log("Level 2 SKIPPED: Cached actions exist but no verification method available, going to Level 3");let s=`First check if the page is already signed in. If it is, do nothing.
|
|
4518
|
+
If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,jm),n=!!(i.actions&&i.actions.length>0);return{success:i.success,modalDismissed:n,details:i.details||(n?"Modal dismissed":"No modal found"),actions:i.actions}}catch(i){return{success:!1,modalDismissed:!1,details:i.message||"Modal dismissal failed"}}}_getContext(){return this.context}setupDownloadTracking(e){if(u.info(`[Download Tracking] Setting up download tracking for page: ${e.url()}`),Rc(e)){u.info(`[Download Tracking] Skipping download tracking for blank tab: ${e.url()}`),e.close();return}e.on("download",async t=>{let i=t.suggestedFilename();u.info(`[Download Tracking] Download event detected! File: ${i}`),this.context.downloadStatus={filename:i,status:"inProgress",startTime:Date.now()},u.info(`[Download Tracking] Download status set to inProgress: ${JSON.stringify(this.context.downloadStatus)}`);try{let n=this.context.downloadDir||q.join(process.cwd(),"downloads");j.existsSync(n)||j.mkdirSync(n,{recursive:!0});let o=q.join(n,i);u.info(`[Download Tracking] Downloading file to: ${o}`),await t.saveAs(o),this.context.downloadStatus={filename:i,status:"completed",startTime:this.context.downloadStatus.startTime,filePath:o,timestamp:Date.now()},u.info(`[Download Tracking] Download completed: ${o}`),u.info(`[Download Tracking] Download status set to completed: ${JSON.stringify(this.context.downloadStatus)}`)}catch(n){this.context.downloadStatus={filename:i,status:"failed",startTime:this.context.downloadStatus.startTime,error:n.message,timestamp:Date.now()},u.error(`[Download Tracking] Download failed for ${i}: ${n.message}`)}})}setupDialogHandling(e){if(u.debug(`[Dialog Handling] setupDialogHandling called, isClosed=${e.isClosed()}, url=${e.url()}`),e.isClosed()){u.debug("[Dialog Handling] Skipping - page is closed");return}u.info(`[Dialog Handling] Setting up dialog handling for page: ${e.url()}`),e.on("dialog",async t=>{let i=t.type(),n=t.message();u.info(`[Dialog Handling] Dialog detected - type: ${i}, message: "${n}"`);let o=i==="beforeunload";try{o?await t.dismiss():await t.accept(),this.context.dialogStatus={type:i,message:n,response:o?"dismiss":"accept",timestamp:Date.now()},u.info(`[Dialog Handling] Dialog ${o?"dismissed":"accepted"} - type: ${i}, message: "${n}"`)}catch(a){u.warn(`[Dialog Handling] Failed to handle dialog (already dismissed?): ${a}`)}})}getRecentDownloadedFilePath(){return this.agentServices.getRecentDownloadedFilePath()}addNote(e){this.agentServices.addNote(e)}collectTokenUsages(e){let t;Array.isArray(e)?t=e:e?.tokenUsages&&(t=e.tokenUsages),t&&t.length>0?(this.context.tokenUsages||(this.context.tokenUsages=[]),this.context.tokenUsages.push(...t),u.debug(`[collectTokenUsages] Added ${t.length} token usage(s), total: ${this.context.tokenUsages.length}`)):u.debug("[collectTokenUsages] No token usages to collect (undefined or empty)")}trackAIAction(e,t,i,n=1,o,a){if(!e)return;let r=i?.tokenUsages||[];this.context.aiActionDetails||(this.context.aiActionDetails=[]);let s=this.context.aiActionDetails.find(l=>l.stepId===e&&l.actionType===t);s?(s.count+=n,r.length>0&&s.tokenUsages.push(...r),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),a&&(s.explanation=a)):this.context.aiActionDetails.push({stepId:e,actionType:t,count:n,tokenUsages:[...r],statement:o,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:a,elementTree:i?.elementTree,screenshotWithSom:i?.screenshotWithSom}),u.debug(`[trackAIAction] Tracked ${t} for step ${e}, count: ${n}`)}async assert(e,t,i){u.info(`Asserting statement: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),o=await Ve(t,e,this.agentServices,{executionHistory:n,useCleanScreenshotForAssertion:!0,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(o.debugInfo),this.context.lastActionDebugInfo=o.debugInfo;let a=o.explanation||o.error||"No explanation";if(i&&this.trackAIAction(i,"assert",o.debugInfo,1,t,a),this.context.agentNote=a,i&&this.context.stepTracking&&await this.updateStepResult(i,o.success?"success":"failure",a,void 0,o.debugInfo),!o.success)throw this.addToExecutionHistory(`Assert: "${t}"`,`Failed: ${a}`),new Error(`Assertion failed: ${a}`);return this.addToExecutionHistory(`Assert: "${t}"`,`Passed: ${a}`),!0}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async evaluate(e,t,i){u.info(`Evaluating condition: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),o=await Ve(t,e,this.agentServices,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(o.debugInfo),this.context.lastActionDebugInfo=o.debugInfo;let a=o.explanation||o.error||"No explanation";return i&&this.trackAIAction(i,"evaluate",o.debugInfo,1,t,a),this.context.agentNote=a,i&&this.context.stepTracking&&await this.updateStepResult(i,"success",a,void 0,o.debugInfo),o.success?(this.addToExecutionHistory(`Evaluate: "${t}"`,`Result: true - ${a}`),!0):(u.warn(`AI evaluation returned false/unknown: ${a}`),this.addToExecutionHistory(`Evaluate: "${t}"`,`Unknown/False: ${a}`),!1)}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async performAction(e,t){u.info(`Act: ${t}`);let i=this.getCompletedExecutionHistory(),n=await ze(t,e,this.agentServices,{executionHistory:i,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});if(this.collectTokenUsages(n.debugInfo),n.status!=="success"||n.actionEntities.length===0)return{success:!1,details:n.explanation||n.error||"Action failed"};let o=n.actionEntities[0]?.action_description||t;return this.addToExecutionHistory(t,o),{success:!0,details:n.explanation}}async execute(e,t,i,n,o){if(o!==void 0&&o<=0)throw new Error(`maxSteps must be >= 1, got ${o}`);let a=o!==void 0&&o>1;u.info(`Executing statement: ${t} (${a?`multi, maxSteps: ${o}`:"single"})`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t),e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e);try{let r=this.getCompletedExecutionHistory();this.context.agentNote="";let s,l;if(a){let c=i&&this.context.stepTracking?.artifactsDir?h=>{if(h.type==="action"&&h.debugInfo){let p=`${i}-step${h.step}`;this.saveDebugInfoToFiles(p,h.debugInfo,this.context.model)}}:void 0;if(s=await Xe(t,e,this.agentServices,c,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:o??zm}),l=s.completed,this.collectTokenUsages(s.tokenUsages),i&&s.tokenUsages){let h={tokenUsages:s.tokenUsages};this.trackAIAction(i,"execute",h,s.actionEntities?.length||1,t,s.explanation||"Multi-step execution completed")}}else if(e=this.agentServices.validatePage(e),s=await ze(t,e,this.agentServices,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n}),l=s.completed,this.collectTokenUsages(s.debugInfo),this.context.lastActionDebugInfo=s.debugInfo,i){let c=s.explanation||s.error||"No explanation";this.trackAIAction(i,"execute",s.debugInfo,1,t,c)}if(s.status!=="success"||s.actionEntities.length===0){let c=s.explanation||s.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",c,void 0,s.debugInfo),new Error(`Action failed: ${c}`)}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: "${t}"`,d),{success:!0,details:d,actions:s.actionEntities,debugInfo:s.debugInfo}}catch(r){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",r.message),this.addToExecutionHistory(`Execute: "${t}"`,`Failed: ${r.message}`),r}}async generate(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t);try{let o=this.getCompletedExecutionHistory(),a=await mt(t,e,this.agentServices,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n});if(this.collectTokenUsages(a.debugInfo),a.status!=="success"||a.actionEntities.length===0){let l=a.explanation||a.error||"No explanation";throw i&&this.trackAIAction(i,"generate",a.debugInfo,1,t,l),i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",l,void 0,a.debugInfo),new Error(l)}let r=a.completed,s=a.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",a.debugInfo,1,t,s),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",s,void 0,a.debugInfo),u.info(`[generate] Generated action for "${t}": ${s}, goalAccomplished: ${a.completed}`),{success:r,details:s,actions:a.actionEntities,debugInfo:a.debugInfo}}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),o}}async run(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t);try{let o=this.getCompletedExecutionHistory();this.context.agentNote="";let a=i&&this.context.stepTracking?.artifactsDir,r=n?.onAction||a?c=>{if(c.type==="action"&&c.action_entity&&(n?.onAction?.(c.action_entity),a&&c.debugInfo)){let h=`${i}-step${c.step}`;this.saveDebugInfoToFiles(h,c.debugInfo,this.context.model)}}:void 0,s=await Xe(t,e,this.agentServices,r,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:n?.abortSignal,maxSteps:n?.maxSteps});f.log(`Run task result: status=${s.status}, completed=${s.completed}, actions=${s.actionEntities?.length||0}`),this.collectTokenUsages(s.tokenUsages);let l=s.status==="success"&&s.completed,d=this.context.agentNote?.trim()||s.explanation||s.error||(l?"Step completed":"Step failed");if(i&&s.tokenUsages){let c={tokenUsages:s.tokenUsages};this.trackAIAction(i,"run",c,s.actionEntities?.length||1,t,d)}if(!l)throw new go(d);if(n?.stmtUid&&s.actionEntities?.length){let c=s.actionEntities.at(-1);c&&(this._newActionEntities.set(n.stmtUid,c),f.log(`Stored resolved action entity for DRAFT stmtUid: ${n.stmtUid}`))}return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,void 0),this.addToExecutionHistory(`Run: "${t}"`,d),f.log(`Run result: success=${l}, details=${d}`),{success:l,details:d,actions:s.actionEntities}}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),this.addToExecutionHistory(`Run: "${t}"`,`Failed: ${o.message}`),o}}async step(e,t,i,n,o,a=!0,r){let s=Date.now();this.context.stepTracking&&await this.createStepResult(e,n,i),e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e),this.context.stepTracking&&(this.context.stepTracking.currentStepId=n),e=this.agentServices.validatePage(e);let l=e.url(),d=await this.captureDOMSnapshot(e),c=this.context.stepTracking?.captureVariables?$i(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},h=this.context.stepTracking?.results[n]?.screenshot;try{u.info(`Executing step ${n}: ${i}`),this.addToExecutionHistory(i,""),this.context.agentNote="",e=this.agentServices.validatePage(e);let p=await t();e=this.agentServices.validatePage(e);let g=e.url(),b=await this.captureDOMSnapshot(e),k=this.context.stepTracking?.captureVariables?$i(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking&&await this.updateStepResult(n,"success",""),this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let m=Date.now()-s,x=this.context.stepTracking.results[n]?.screenshot,A=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:m,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:g,domSnapshot:b||void 0,variables:k,screenshotPath:x,timestamp:A})}let y=this.context.agentNote;return(!y||y.trim()==="")&&(y="Execution successful"),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=y),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}catch(p){e=this.agentServices.validatePage(e);let g=a&&!this.context.isSelfHealing;if(g&&(this.context.stepTracking&&await this.updateStepResult(n,"failure",p.message),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=p.message)),!i||i.trim()==="")throw u.error("No description provided for self-healing"),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p;if(!g){if(u.info(`Failed to heal at step ${n}. ${i}`),this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let m=e.url(),x=await this.captureDOMSnapshot(e),A=this.context.stepTracking.captureVariables?$i(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},v=Date.now()-s,E=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:v,status:"failure",errorMessage:p.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:m,domSnapshot:x||void 0,variables:A,timestamp:E})}throw this.context.stepTracking&&(await this.updateStepResult(n,void 0,void 0),this.context.stepTracking.currentStepId=void 0),p}this.context.isSelfHealing=!0,u.info(`Action failed at step ${n}. ${i}`),u.info(`with error: ${p.message}`);let b,k;if(this.context.autoDismissModal){u.info("Attempting modal dismissal before self-healing...");let m=await this.dismissModalIfPresent(e,i);if(u.info(`Modal dismissal result: ${m.details}`),m.modalDismissed){b=`[Auto-dismissed modal: ${m.details}]`,k=m.actions,u.info(`Modal dismissed, retrying original action for step ${n}`);try{let x=await t();return this.context.isSelfHealing=!1,this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=b+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(n,"success",b),this.context.stepTracking.results[n].dismissedModalActions=k,this.context.stepTracking.currentStepId=void 0),this.context.agentNote=b,x}catch(x){u.info(`Retry after modal dismissal failed: ${x.message}, falling back to self-healing`)}}}let y=r??Km;u.info(`Calling execute() to self-heal (maxSteps: ${y})`);try{let m=await this.execute(e,i,n,!1,y);if(this.context.isSelfHealing=!1,!m.success)throw new Error(`Self-healing failed: ${m.details}`);let x=m.actions?.at(-1);o&&x&&(this._newActionEntities.set(o,x),u.info(`Stored new action entity for stmtUid: ${o} (last of ${m.actions?.length} actions)`));let A=e.url(),v=await this.captureDOMSnapshot(e),E=this.context.stepTracking?.captureVariables?$i(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking){this.context.stepTracking.results[n].autoHealed=!0,this.context.stepTracking.results[n].healedAction=x,k&&(this.context.stepTracking.results[n].dismissedModalActions=k);let T=b||"";await this.updateStepResult(n,"success",T)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let T=Date.now()-s,C=this.context.stepTracking.results[n]?.screenshot,I=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{actionEntity:x,playwrightCode:m.actions?.map(L=>L.locator||""),llmPrompt:m.debugInfo?.userPrompt,llmResponse:m.debugInfo?.rawLlmResponse,llmReasoning:m.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(n),durationMs:T,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:A,domSnapshot:v||void 0,variables:E,screenshotPath:C,timestamp:I})}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 x=e.url(),A=await this.captureDOMSnapshot(e),v=this.context.stepTracking.captureVariables?$i(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},E=Date.now()-s,T=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:E,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:x,domSnapshot:A||void 0,variables:v,timestamp:T})}throw this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}}}async extract(e,t,i,n){n&&this.context.stepTracking&&await this.createStepResult(e,n,`Extract ${t} into ${i}`);try{let o=`Extract ${t} and save to ${i}`,a=await this.execute(e,o,n);if(!a.success)throw new Error(`AI extraction failed: ${a.details}`);n&&this.context.stepTracking&&await this.updateStepResult(n,"success",`Extracted ${t} to ${i}`)}catch(o){throw n&&this.context.stepTracking&&await this.updateStepResult(n,"failure",o.message),o}}async getDOMText(e){let t=new me(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains();return(await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n})).elementTree.clickableElementsToString()}async captureDOMSnapshot(e){if(!this.context.stepTracking?.captureStateTransitions||!this.context.stepTracking?.captureDom)return null;try{let t=new me(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains(),o=await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n,highlightElements:!1,viewportExpansion:0});return{elementTreeText:o.elementTree.clickableElementsToString(),elementCount:o.selectorMap.size,timestamp:Date.now()}}catch(t){return u.warn("Failed to capture DOM snapshot:",t),null}}getConsoleLogsForStep(e){return this.context.stepTracking?.consoleLogs?this.context.stepTracking.consoleLogs.filter(t=>t.stepId===e).map(t=>({type:t.type,message:t.message,timestamp:t.timestamp})):[]}async waitUntilStable(e,t=3e3,i=1e3){return $c(e,t,i)}async waitUntilCondition(e,t,i=60,n){return Lc(e,t,(o,a,r)=>this.evaluate(o,a,r),i,n)}async uploadFile(e,t,i={},n){return Us(e,t,i,this.context,(o,a,r)=>this.execute(o,a,r),n)}async loginPage(e,t,i){let{LoginType:n}=await Promise.resolve().then(()=>(Hc(),Fc));if(u.info("Start login"),f.section("Login Flow"),f.log(`Site URL: ${t.site_url}`),f.log(`Account type: ${t.account.type}`),f.log(`Has cached actions: ${!!i?.cached_actions?.length}`),f.log(`Has validation exprs: ${!!i?.validation_exprs?.length}`),t.skip_verification)return u.info("Skipping login verification (skip_verification=true)"),{success:!0,page:e};(t.account.type===n.PASSWORD||t.account.type===n.OAUTH2)&&(this.context.variableStore.set("username",t.account.username,!0),this.context.variableStore.set("password",t.account.password,!0)),t.account.two_factor_auth_config?.type==="totp"&&this.context.variableStore.set("otp_secret_key",t.account.two_factor_auth_config.data,!0),u.info(`Navigating to: ${t.site_url}`),await e.goto(t.site_url),await this.waitUntilStable(e,1e4,3e3);let o=!!(t.use_ai_verification_for_login_check&&t.verification_hint?.trim()),a=o?`Check if the page is already signed in. Consider it signed in only when this verification statement is satisfied: ${t.verification_hint.trim()}`:void 0;if(o){f.log("Level 1: Checking if already logged in via AI verification hint..."),f.log(`Verification statement: ${a}`);try{if(await this.evaluate(e,a))return f.log("Level 1 SUCCESS: Already logged in via AI verification"),u.info("Login: Already logged in via AI verification"),{success:!0,page:e,storage_state:null,cached_actions:i?.cached_actions,validation_exprs:i?.validation_exprs,alreadyLoggedIn:!0};f.log("Level 1 FAILED: AI verification indicates not signed in, trying Level 2")}catch(l){f.log(`Level 1 ERROR: AI verification failed (${l.message}), trying Level 2`)}}else t.use_ai_verification_for_login_check&&!t.verification_hint?.trim()&&f.log("Level 1 SKIPPED: use_ai_verification_for_login_check is enabled but verification_hint is empty, falling back to cached validation expressions");if(!o&&i?.validation_exprs&&i.validation_exprs.length>0){if(f.log("Level 1: Checking if already logged in via storage state..."),f.log(`Validation expressions: ${JSON.stringify(i.validation_exprs)}`),await Ci(e,i.validation_exprs))return f.log("Level 1 SUCCESS: Already logged in via storage state"),u.info("Login: Already logged in via storage state"),{success:!0,page:e,storage_state:null,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs,alreadyLoggedIn:!0};f.log("Level 1 FAILED: Storage state validation failed, trying Level 2")}let r=!!(i?.validation_exprs&&i.validation_exprs.length>0);if(i?.cached_actions&&i.cached_actions.length>0&&(o||r)){f.log(`Level 2: Attempting cached login with ${i.cached_actions.length} actions`);try{if((await this.executeCachedLogin(e,i.cached_actions,{validationExprs:i.validation_exprs,aiVerificationStatement:a})).success){f.log("Level 2 SUCCESS: Cached login succeeded"),u.info("Login: Cached login succeeded");let l=await e.context().storageState();return{success:!0,page:e,storage_state:l,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs}}f.log("Level 2 FAILED: Cached login failed, trying Level 3")}catch(l){f.log(`Level 2 ERROR: ${l.message}, trying Level 3`)}}else i?.cached_actions&&i.cached_actions.length>0&&f.log("Level 2 SKIPPED: Cached actions exist but no verification method available, going to Level 3");let s=`First check if the page is already signed in. If it is, do nothing.
|
|
4521
4519
|
Use your best judgement to determine if the page is signed in.
|
|
4522
4520
|
`;if(t.verification_hint&&(s+=`
|
|
4523
4521
|
Signed in verification hint: ${t.verification_hint}
|
|
@@ -4529,8 +4527,8 @@ If the page is not signed in, sign in with the OAuth provider "${l.provider_name
|
|
|
4529
4527
|
`}t.additional_prompt&&(s+=`
|
|
4530
4528
|
Additional instructions: ${t.additional_prompt}
|
|
4531
4529
|
`);try{f.log("Level 3: Attempting agent-based login"),f.log(`Login prompt:
|
|
4532
|
-
${s}`);let l=this.agentServices.knowledgeRetriever,d=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(f.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(k,y,m,v)=>await l(k,y,m,"login")),d=!0,f.log("Login knowledge retriever configured"));let c;try{if(c=await this.run(e,s,"login"),!c.success)return f.log("Level 3 FAILED: Agent login failed"),u.info("Login: Failed"),{success:!1,page:e}}finally{d&&l&&(this.agentServices.setKnowledgeRetriever(l),f.log("Restored original knowledge retriever"))}let h=await e.context().storageState(),p;if(o)f.log("Skipping validation locator generation (AI verification mode enabled)");else if(t.num_verification_exprs!==0)try{f.log("Generating validation locators for future login verification...");let k=await eo(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(y,m)=>this.run(y,m),async y=>this.getDOMText(y));k?(p=k,f.log(`Generated ${p.length} validation locator(s): ${JSON.stringify(p)}`)):f.log("Failed to generate validation locators, login will still succeed")}catch(k){f.log(`Error generating validation locators: ${k.message}`)}else f.log("Skipping validation locator generation (num_verification_exprs=0)");f.log("Level 3 SUCCESS: Agent login succeeded"),u.info("Login: Agent login succeeded");let g=c.actions||[],b=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:h,cached_actions:b,validation_exprs:p}}catch(l){return f.error(`Agent login failed: ${l.message}`),u.info("Login: Failed"),{success:!1,page:e}}}async executeCachedLogin(e,t,i){let n=(await Promise.resolve().then(()=>(ht(),ut))).default,o=new n;for(let a=0;a<t.length;a++){let r=t[a];f.log(`Executing cached action ${a+1}/${t.length}: ${r.action_description||r.action_data?.action_name}`);try{if(!r.action_data){f.log(`Action ${a+1} missing action_data, skipping`);continue}await o.execute(e,r,this.agentServices),await this.waitUntilStable(e,5e3)}catch(s){return f.error(`Cached action ${a+1} failed: ${s.message}`),{success:!1}}}return i?.aiVerificationStatement?(f.log("Verifying cached login result with AI verification statement"),await this.evaluate(e,i.aiVerificationStatement)?{success:!0}:{success:!1}):i?.validationExprs&&i.validationExprs.length>0?await Ai(e,i.validationExprs)?{success:!0}:{success:!1}:(f.log("Cached login cannot be verified: missing AI verification statement and validation expressions"),{success:!1})}getCompletedExecutionHistory(){if(!this.context.executionHistory||this.context.executionHistory.length===0)return[];let e=this.context.executionHistory[this.context.executionHistory.length-1];return!e[1]||e[1].trim()===""?this.context.executionHistory.slice(0,-1):this.context.executionHistory}addToExecutionHistory(e,t){this.context.executionHistory||(this.context.executionHistory=[]),this.context.executionHistory.push([e,t])}async createStepResult(e,t,i){if(this.context.stepTracking&&!this.context.stepTracking.results[t]){this.context.stepTracking.currentStepId=t,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(t);try{e=this.agentServices.validatePage(e),await this.waitUntilStable(e);let n={description:i,startTime:Date.now(),artifacts:[]};if(this.context.stepTracking.artifactsDir){let o=J.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));j.mkdirSync(o,{recursive:!0});let a=J.join(o,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:a}),n.screenshot=a}this.context.stepTracking.results[t]=n}catch(n){u.warn(`createStepResult failed for step ${t}: ${n}`),this.context.stepTracking.results[t]={description:i,startTime:Date.now(),artifacts:[]}}}}saveDebugInfoToFiles(e,t,i,n=0){let o={};if(!this.context.stepTracking?.artifactsDir)return u.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),o;let a=J.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(j.mkdirSync(a,{recursive:!0}),t.systemPrompt){let r=J.join(a,`system_prompt_${n}.txt`);j.writeFileSync(r,t.systemPrompt),o.system_prompt_path=r,u.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${r}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let r=J.join(a,`user_prompt_${n}.txt`);j.writeFileSync(r,t.userPrompt),o.user_prompt_path=r,u.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${r}`)}else{let r=t.userPrompt.map(d=>Array.isArray(d.content)?{...d,content:d.content.map(c=>c.type==="image"&&c.file?.startsWith("data:")?{...c,file:"[base64 image data stripped]"}:c)}:d),s=J.join(a,`messages_${n}.json`),l={system:t.systemPrompt,messages:r};j.writeFileSync(s,JSON.stringify(l,null,2)),o.messages_path=s,u.debug(`[saveDebugInfoToFiles] Saved messages to: ${s}`)}if(t.rawLlmResponse){let r=i?i.replace(/[\/\\:]/g,"-"):"llm",s=J.join(a,`${r}_response_${n}.txt`);j.writeFileSync(s,t.rawLlmResponse),o.response_path=s,u.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${s}`)}if(t.screenshotWithSom){let r=J.join(a,`screenshot_${n}.png`);j.writeFileSync(r,Buffer.from(t.screenshotWithSom,"base64")),o.screenshot_path=r,u.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${r}`)}if(t.reasoningContent){let r=J.join(a,`reasoning_${n}.txt`);j.writeFileSync(r,t.reasoningContent),o.reasoning_path=r,u.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${r}`)}u.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(o).length} artifacts for step ${e}`)}catch(r){u.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,r)}return o}async updateStepResult(e,t,i,n,o){if(!this.context.stepTracking)return;let a=this.context.stepTracking.results[e];if(a){if(t&&(a.status=t,this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(a.message=i),n&&a.artifacts.push(n),o){let r=o.tokenUsages?.[0]?.model,s=a.artifacts.length,l=this.saveDebugInfoToFiles(e,o,r,s);Object.keys(l).length>0&&a.artifacts.push(l)}a.duration=Date.now()-a.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(e,a)}}async writeExecutionResults(e,t){try{if(await j.promises.mkdir(e,{recursive:!0}),this.context.stepTracking?.results&&Object.keys(this.context.stepTracking.results).length>0){let i=J.join(e,"test-results.json");await j.promises.writeFile(i,JSON.stringify(this.context.stepTracking.results,null,2)),u.debug(`Test results written to: ${i}`)}if(t?.tokenUsages&&this.context.tokenUsages&&this.context.tokenUsages.length>0){let i=J.join(e,"token-usages.json");await j.promises.writeFile(i,JSON.stringify(this.context.tokenUsages,null,2)),u.debug(`Token usages written to: ${i}`)}if(this.context.aiActionDetails&&this.context.aiActionDetails.length>0){let i=J.join(e,"ai-actions.json");await j.promises.writeFile(i,JSON.stringify(this.context.aiActionDetails,null,2)),u.debug(`AI action details written to: ${i}`)}}catch(i){throw u.error("Failed to write execution results:",i),i}}}});function Dm(){let e=new Date,t=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(e),i=t.find(m=>m.type==="year").value,n=t.find(m=>m.type==="month").value,o=t.find(m=>m.type==="day").value,a=t.find(m=>m.type==="hour").value,r=t.find(m=>m.type==="minute").value,s=t.find(m=>m.type==="second").value,l=String(e.getMilliseconds()).padStart(3,"0"),d=`${i}-${n}-${o}T${a}:${r}:${s}.${l}`,c=e.toISOString().slice(0,-1),h=Date.parse(d+"Z"),p=Date.parse(c+"Z"),g=Math.round((p-h)/(1e3*60)),b=String(Math.floor(Math.abs(g)/60)).padStart(2,"0"),k=String(Math.abs(g)%60).padStart(2,"0"),y=g<=0?"+":"-";return`${i}-${n}-${o}T${a}:${r}:${s}.${l}${y}${b}:${k}`}function xa(e){let t=e.variableStore;return t.has("currentTime")||t.set("currentTime",Dm()),{model:e.model,variableStore:t,organizationId:e.organizationId,organizationSettings:e.organizationSettings,executionHistory:e.executionHistory||[],testDataDir:e.testDataDir,downloadDir:e.downloadDir,useNativeGenerator:e.useNativeGenerator,autoDismissModal:e.autoDismissModal,tokenUsages:[],aiActionDetails:[]}}var Ic=w(()=>{"use strict"});var Cc={};Be(Cc,{ActionHandler:()=>Pn,ActionHelper:()=>ki,Agent:()=>ya,AgentServices:()=>no,AgentStepEventTypes:()=>wa,AgentTaskFailedError:()=>oo,BrowserManager:()=>mc,DEFAULT_EVENT_LISTENER_LIMIT:()=>en,DomService:()=>ue,EVENT_LISTENER_CANDIDATE_SELECTORS:()=>Qi,HistoryTreeProcessor:()=>ws,INIT_SCRIPT:()=>pt,INTERACTION_EVENT_TYPES:()=>ot,INTERACTIVE_ROLES:()=>Nt,LogLevel:()=>Oo,LoginType:()=>Ei,MCPToolProvider:()=>ic,OpenAIToolProvider:()=>Hi,SDK_VERSION:()=>Om,ToolRegistry:()=>nt,TwoFactorAuthType:()=>da,VariableStore:()=>ua,WebAgent:()=>ya,configureSdk:()=>gr,createAgent:()=>Lm,createAgentContext:()=>xa,createToolRegistry:()=>ql,createToolRegistryWithCapabilities:()=>Zl,ensureToolsRegistered:()=>Yl,evaluateStatement:()=>je,executeStep:()=>Ke,exportMCPTools:()=>nc,filterInteractionListeners:()=>is,generateActionStep:()=>ct,getActionEntityLocatorInfo:()=>N,getBrowserCdpUrl:()=>Nn,getCapabilitySummary:()=>Ql,getFramePath:()=>Po,getModel:()=>fe,getPageInfo:()=>Dl,getPageWsUrl:()=>$l,getPlatformFromDeviceName:()=>gc,getProviderOptions:()=>we,getSdkConfig:()=>U,getToolRegistry:()=>Jl,injectUserFunction:()=>yo,isInteractionEventType:()=>ts,isInteractiveRole:()=>es,loadKnowledgeMappings:()=>vr,loadKnowledges:()=>xr,loadUserFunctions:()=>br,logger:()=>u,newBrowserContext:()=>Pl,parseSSEStream:()=>_r,parseSdkLogLevelFromEnv:()=>fr,pickBestLocator:()=>At,pickBestLocatorForElement:()=>zi,pickBestLocators:()=>$r,replaceVariables:()=>qn,runTask:()=>ze,setWindowBounds:()=>Rn,toolRegistry:()=>H});function Lm(e){let t=new ua,i=new Set(e.sensitiveKeys||[]);if(e.variables)for(let[o,a]of Object.entries(e.variables))t.set(o,a,i.has(o));let n=xa({model:e.model,variableStore:t,testDataDir:e.testDataDir,downloadDir:e.downloadDir});return new ya(n)}var Om,Pc=w(()=>{"use strict";yr();kr();Sr();ec();tc();ca();oc();ra();la();sa();pc();fc();wc();Mc();Gt();Zi();Ji();Wi();Gi();it();Mt();It();_e();St();Et();mn();Ue();Ot();Rt();at();Ft();Ht();to();de();fa();ga();wt();io();Te();gt();Ie();Ct();Pt();$t();ba();na();nn();on();an();rn();sn();ln();cn();dn();un();pn();gn();Ut();jt();Vt();Xt();Jt();qt();Zt();Qt();ei();ti();ii();oi();ai();ri();si();li();di();ui();mi();pi();gi();fi();wi();bi();yi();xi();vi();Sn();Yt();K();Ge();F();ie();rt();Cn();R();Ic();pe();Om="1.0.0"});var S,va,ao,ka,Ye,_a,Sa,Ea,ee,Ta,Ci,ro,Aa=w(()=>{"use strict";S=require("zod"),va=S.z.enum(["JS_CODE","AI_MODE"]),ao=S.z.object({type:va,expression:S.z.string()}),ka=S.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Ye=S.z.object({uid:S.z.string(),type:ka,comment:S.z.string().optional()}),_a=S.z.object({action_data:S.z.object({action_name:S.z.string(),kwargs:S.z.record(S.z.any()).optional(),args:S.z.array(S.z.any()).optional()}),action_description:S.z.string().optional(),url:S.z.string().optional(),xpath:S.z.string().nullable().optional(),locator:S.z.string().nullable().optional(),css_selector:S.z.string().nullable().optional(),unique_selector:S.z.string().nullable().optional(),element_index:S.z.number().nullable().optional(),frame_path:S.z.array(S.z.any()).optional(),artifacts:S.z.record(S.z.any()).optional(),feedback:S.z.string().optional(),original_browser_use_action:S.z.any().optional()}).passthrough(),Sa=Ye.extend({type:S.z.literal("DRAFT"),description:S.z.string()}),Ea=Ye.extend({type:S.z.literal("ACTION"),description:S.z.string(),action_entity:_a.optional(),locator:S.z.string().optional(),use_pure_vision:S.z.boolean().optional()}),ee=S.z.lazy(()=>S.z.union([Sa,Ea,Ye.extend({type:S.z.literal("STEP"),description:S.z.string().optional().default(""),statements:S.z.array(ee),reference_id:S.z.number().optional()}),Ye.extend({type:S.z.literal("IF_ELSE"),description:S.z.string().optional(),condition:ao,then:S.z.array(ee),else:S.z.array(ee).optional()}),Ye.extend({type:S.z.literal("WHILE_LOOP"),description:S.z.string().optional(),condition:ao,body:S.z.array(ee),timeout_ms:S.z.number().optional()})])),Ta=S.z.object({name:S.z.string(),statements:S.z.array(ee),teardown:S.z.array(ee).optional(),skip:S.z.union([S.z.boolean(),S.z.string()]).optional(),timeout:S.z.number().optional(),fail:S.z.union([S.z.boolean(),S.z.string()]).optional(),only:S.z.boolean().optional(),slow:S.z.boolean().optional()}),Ci=S.z.object({tests:S.z.array(Ta).min(1),beforeAll:S.z.array(ee).optional(),afterAll:S.z.array(ee).optional(),beforeEach:S.z.array(ee).optional(),afterEach:S.z.array(ee).optional()}),ro=S.z.object({comment:S.z.string().optional(),version:S.z.string().optional(),goal:S.z.string().optional(),url:S.z.string().optional(),baseURL:S.z.string().optional(),final_feedback:S.z.string().optional(),completed:S.z.boolean().optional(),success:S.z.boolean().optional(),statements:S.z.array(ee).optional(),teardown:S.z.array(ee).optional(),last_modified_at:S.z.string().optional(),testGroup:Ci.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"})});function Ia(e,t){let i={...t?.test_case_id!==void 0?{test_case_id:t.test_case_id}:{},...t?.name?{name:t.name}:{},goal:e.goal??"",url:e.url,base_url:e.baseURL,statements:(e.statements??[]).map(se)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(se)),i}function Oc(e,t){if(e.testGroup)return Ca(e,t);let i=Ia(e,t),n=new $.Document(i);return e.comment&&(n.commentBefore=e.comment),$c(n,e.statements??[]),e.teardown&&$c(n,e.teardown,"teardown"),n.toString(xt)}function $c(e,t,i="statements"){let n=e.contents;if(!n||!(0,$.isMap)(n))return;let o=n.get(i,!0);(0,$.isSeq)(o)&&Pi(o,t)}function Pi(e,t){for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=t[i],o=e.items[i];if(i>0&&(o.spaceBefore=!0),n.comment&&(i===0?e.commentBefore=n.comment:o.commentBefore=n.comment),(0,$.isMap)(o)){let a=o;if(n.type==="STEP"){let r=a.get("statements",!0);(0,$.isSeq)(r)&&Pi(r,n.statements)}else if(n.type==="IF_ELSE"){let r=a.get("THEN",!0);(0,$.isSeq)(r)&&Pi(r,n.then);let s=a.get("ELSE",!0);(0,$.isSeq)(s)&&n.else&&Pi(s,n.else)}else if(n.type==="WHILE_LOOP"){let r=a.get("DO",!0);(0,$.isSeq)(r)&&Pi(r,n.body)}}}}function Ca(e,t){let i=e.testGroup;if(!i)throw new Error("suiteToYaml requires a TestFlow with testGroup");let n={};t?.test_case_id!==void 0&&(n.test_case_id=t.test_case_id),t?.name&&(n.name=t.name),t?.tags&&t.tags.length>0&&(n.tags=t.tags),t?.use&&Object.keys(t.use).length>0&&(n.use=t.use);let o={};return e.baseURL&&(o.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(o.beforeAll=i.beforeAll.map(se)),i.beforeEach&&i.beforeEach.length>0&&(o.beforeEach=i.beforeEach.map(se)),i.afterEach&&i.afterEach.length>0&&(o.afterEach=i.afterEach.map(se)),i.afterAll&&i.afterAll.length>0&&(o.afterAll=i.afterAll.map(se)),o.tests=i.tests.map(a=>{let r={name:a.name};return a.skip!==void 0&&(r.skip=a.skip),a.timeout!==void 0&&(r.timeout=a.timeout),a.fail!==void 0&&(r.fail=a.fail),a.only!==void 0&&(r.only=a.only),a.slow!==void 0&&(r.slow=a.slow),r.statements=a.statements.map(se),a.teardown&&a.teardown.length>0&&(r.teardown=a.teardown.map(se)),r}),n.suite=o,(0,$.stringify)(n,xt)}function Nc(e){return e.map(t=>(0,$.stringify)(t,xt)).join(`---
|
|
4533
|
-
`)}function se(e){switch(e.type){case"DRAFT":return Nm(e);case"ACTION":return Rc(e);case"STEP":return Fm(e);case"IF_ELSE":return Hm(e);case"WHILE_LOOP":return Wm(e)}}function Nm(e){return{intent:e.description}}function Rc(e){let t=e.action_entity?.action_data?.action_name??e.action_entity?.action?.action_name,i=e.action_entity?.action_data?.kwargs??e.action_entity?.action?.kwargs;if(t==="verify"){let s=i?.statement;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l=i?.code;return typeof l=="string"?{VERIFY:s,js:l}:{VERIFY:s}}}if(t==="go_to_url"){let s=i?.url;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l={URL:s};return i?.new_tab===!0&&(l.new_tab=!0),typeof i?.timeout_seconds=="number"&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="js_action"){let s=i?.code;if(typeof s=="string"&&e.description)return{intent:e.description,js:s}}if(t==="ai_wait_until"){let s=i?.condition;if(typeof s=="string"){let l={WAIT_UNTIL:s};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="wait"){let s=i?.seconds,d={WAIT:e.description||`Wait ${s}s`};return typeof s=="number"&&(d.seconds=s),d}if(t==="js_code"){let s=i?.code;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{CODE:s}}if(!e.action_entity)return{intent:e.description};let n=e.action_entity.action_data??e.action_entity.action;if(!n)return{intent:e.description};let o={intent:e.description,action:n.action_name},a=e.locator??e.action_entity.locator;a&&(o.locator=a);let r=e.action_entity.xpath;if(r&&(o.xpath=r),e.use_pure_vision&&(o.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[s,l]of Object.entries(n.kwargs))o[s]=l;return n.args&&n.args.length>0&&(o.args=n.args),o}function Fc(e,t,i){let n={uid:"",type:"ACTION",description:t||e.action_description||"",action_entity:e,locator:i},o=Rc(n);if(typeof o=="object"&&o!==null){let a={...o};return delete a.intent,delete a.VERIFY,delete a.WAIT_UNTIL,delete a.WAIT,delete a.statement,Object.keys(a).length>0?(0,$.stringify)(a,xt).trim():""}return(0,$.stringify)(o,xt).trim()}function Hc(e){let t=(0,$.parse)(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object");if("VERIFY"in t){let c=String(t.VERIFY),h=typeof t.js=="string"?t.js:void 0;return{description:c,actionEntity:{action_description:c,action_data:{action_name:"verify",kwargs:{statement:c,...h?{code:h}:{}}}}}}if("URL"in t){let c=String(t.URL),h={url:c};return t.new_tab===!0&&(h.new_tab=!0),typeof t.timeout_seconds=="number"&&(h.timeout_seconds=t.timeout_seconds),{description:`Navigate to ${c}`,actionEntity:{action_description:`Navigate to ${c}`,action_data:{action_name:"go_to_url",kwargs:h}}}}if("CODE"in t){let c=String(t.CODE);return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:c}}}}}if("WAIT_UNTIL"in t){let c=String(t.WAIT_UNTIL),h={condition:c};return typeof t.timeout_seconds=="number"&&(h.timeout_seconds=t.timeout_seconds),{description:`Wait until ${c}`,actionEntity:{action_description:`Wait until ${c}`,action_data:{action_name:"ai_wait_until",kwargs:h}}}}if("WAIT"in t){let c=String(t.WAIT),h={};return typeof t.seconds=="number"&&(h.seconds=t.seconds),{description:c,actionEntity:{action_description:c,action_data:{action_name:"wait",kwargs:h}}}}let i=typeof t.intent=="string"?t.intent:void 0,n=typeof t.action=="string"?t.action:void 0,o=typeof t.locator=="string"?t.locator:void 0,a=typeof t.xpath=="string"?t.xpath:void 0,r=Array.isArray(t.frame_path)?t.frame_path:void 0,s=Array.isArray(t.args)?t.args:void 0,l={};for(let[c,h]of Object.entries(t))Rm.has(c)||(l[c]=h);return!n&&t.js?{description:i,actionEntity:{action_description:i||"",action_data:{action_name:"js_action",kwargs:{code:t.js}}}}:n?{actionEntity:{action_description:i||"",action_data:{action_name:n,kwargs:l,...s&&s.length>0?{args:s}:{}},...o?{locator:o}:{},...a?{xpath:a}:{},...r?{frame_path:r}:{}},description:i,locator:o}:{description:i,actionEntity:{action_description:i||""}}}function Fm(e){let t={STEP:e.description,statements:e.statements.map(se)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function Hm(e){let t={IF:Wc(e.condition),THEN:e.then.map(se)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(se)),t}function Wm(e){let t={WHILE:Wc(e.condition),DO:e.body.map(se)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function Wc(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function Bc(e){let t=(0,$.parseAllDocuments)(e),i;if(t.length>1||t.length===1&&!Array.isArray(t[0]?.toJSON()))i=t.map((n,o)=>n.errors.length>0?{__parseError:`Document ${o+1}: ${n.errors[0].message}`}:n.toJSON());else{let n;try{n=(0,$.parse)(e)}catch(o){throw new Error(`Invalid YAML: ${o instanceof Error?o.message:String(o)}`)}if(!Array.isArray(n))throw new Error("Expected a YAML array or multi-document YAML (separated by ---)");i=n}return i.map((n,o)=>{try{if(n&&typeof n=="object"&&"__parseError"in n)return{error:n.__parseError};if(!n||typeof n!="object")return{error:`Item ${o+1}: expected an object`};let a=n,r=typeof a.name=="string"&&a.name.trim()||void 0,s=typeof a.goal=="string"?a.goal.trim():"";if(!s)return{error:`Item ${o+1}: missing "goal" field`};if(Array.isArray(a.statements))try{let l=(0,$.stringify)(a,xt),d=Je(l);return{name:r,goal:d.goal??s,testFlow:d}}catch{}return{name:r,goal:s}}catch(a){return{error:`Item ${o+1}: ${a instanceof Error?a.message:String(a)}`}}})}function Gc(e){try{let t=(0,$.parse)(e);if(!t||typeof t!="object")return{};let i={};return typeof t.test_case_id=="number"&&Number.isFinite(t.test_case_id)&&(i.test_case_id=t.test_case_id),typeof t.template_id=="number"&&Number.isFinite(t.template_id)&&(i.template_id=t.template_id),typeof t.name=="string"&&t.name.trim()&&(i.name=t.name.trim()),i}catch{return{}}}function Ma(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(Ma);let t=e,i=Object.keys(t);if(i.length===1){let o=i[0];if(o.startsWith("{ ")&&o.endsWith(" }")&&t[o]===null)return`{{${o.slice(2,-2)}}}`}let n={};for(let[o,a]of Object.entries(t))n[o]=Ma(a);return n}function Je(e){if(e.length>Dc)throw new Error(`YAML input too large (${e.length} bytes, max ${Dc})`);let t=Ma((0,$.parse)(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return Bm(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:le(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=le(t.teardown));let n=ro.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let o=n.data;return Pa(e,o),o}function Bm(e){let t=e.suite;if(!t||typeof t!="object")throw new Error("Invalid suite: expected an object");let i=t.tests;if(!Array.isArray(i)||i.length===0)throw new Error('Suite must have a non-empty "tests" array');let o={tests:i.map(s=>{if(!s.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(s.statements)||s.statements.length===0)throw new Error(`Suite test "${s.name}" must have a non-empty "statements" array`);let l={name:s.name,statements:le(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=le(s.teardown)),s.skip!==void 0&&(l.skip=s.skip),typeof s.timeout=="number"&&(l.timeout=s.timeout),s.fail!==void 0&&(l.fail=s.fail),s.only===!0&&(l.only=!0),s.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(o.beforeAll=le(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(o.afterAll=le(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(o.beforeEach=le(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(o.afterEach=le(t.afterEach));let a=Ci.safeParse(o);if(!a.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(a.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:a.data}}function le(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(Gm)}function Gm(e){if(typeof e=="string")throw new Error(`Plain string statements are not supported. Use an object with a "desc" key instead. Example: { "desc": "${e}" }`);if(typeof e!="object"||e===null)throw new Error(`Invalid statement: expected object, got ${typeof e}`);let t=e;if("IF"in t)return Um(t);if("WHILE"in t)return Km(t);if("STEP"in t)return jm(t);if("VERIFY"in t){let i=t.VERIFY,n={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(n.code=t.js),{uid:(0,re.v4)(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:n}}}}if("URL"in t){let i=t.URL,n=t.new_tab===!0?!0:void 0,o=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,a={url:typeof i=="string"?i:String(i)};return n&&(a.new_tab=!0),o!==void 0&&(a.timeout_seconds=o),{uid:(0,re.v4)(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:a}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:(0,re.v4)(),type:"ACTION",description:`Wait until: ${i}`,action_entity:{action_description:`Wait until: ${i}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:typeof i=="string"?i:String(i),timeout_seconds:n}}}}}if("WAIT"in t){let i=t.WAIT,n=typeof t.seconds=="number"?t.seconds:3;return{uid:(0,re.v4)(),type:"ACTION",description:typeof i=="string"?i:`Wait ${n}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${n}s`,action_data:{action_name:"wait",kwargs:{seconds:n}}}}}if("CODE"in t){let i=t.CODE;if(i==null)throw new Error('CODE statement has no code. Use "CODE: |" followed by indented code on the next line.');return{uid:(0,re.v4)(),type:"ACTION",description:"Code block",action_entity:{action_description:"Code block",action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&("intent"in t||"desc"in t)&&!("VERIFY"in t)){let i=t.js,n=typeof t.intent=="string"?t.intent:typeof t.desc=="string"?t.desc:"";return{uid:(0,re.v4)(),type:"ACTION",description:n,action_entity:{action_description:n,action_data:{action_name:"js_action",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...n}=t;return Lc({...n,action:"function",functionName:i})}if("action"in t)return Lc(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:(0,re.v4)(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function Uc(e){if(typeof e!="string")throw new Error(`Condition must be a string, got ${typeof e}`);return e.startsWith("js:")?{type:"JS_CODE",expression:e.slice(3)}:{type:"AI_MODE",expression:e}}function Um(e){let t=Uc(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:(0,re.v4)(),type:"IF_ELSE",condition:t,then:le(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=le(e.ELSE)),n}function Km(e){let t=Uc(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:(0,re.v4)(),type:"WHILE_LOOP",condition:t,body:le(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function jm(e){let t=typeof e.STEP=="string"?e.STEP:"";if(!Array.isArray(e.statements))throw new Error("STEP requires a statements array");let i={uid:(0,re.v4)(),type:"STEP",description:t,statements:le(e.statements)};return typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),i}function Lc(e){let t=typeof e.action=="string"?e.action:String(e.action),i=typeof e.intent=="string"?e.intent:typeof e.desc=="string"?e.desc:"",n=typeof e.locator=="string"?e.locator:void 0,o=typeof e.xpath=="string"?e.xpath:void 0,a=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[d,c]of Object.entries(e))zm.has(d)||(r[d]=c);let s={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};n&&(s.locator=n),o&&(s.xpath=o);let l={uid:(0,re.v4)(),type:"ACTION",description:i,action_entity:s};return a&&(l.use_pure_vision=!0),l}function Pa(e,t){let i;try{i=(0,$.parseDocument)(e)}catch{return}let n=i.contents;if(!n||!(0,$.isMap)(n))return;if(i.commentBefore)t.comment=i.commentBefore;else{let l=n.items?.[0];l?.key&&l.key.commentBefore&&(t.comment=l.key.commentBefore)}let o=n,a=o.get("statements",!0);(0,$.isSeq)(a)&&t.statements&&yt(a,t.statements);let r=o.get("teardown",!0);(0,$.isSeq)(r)&&t.teardown&&yt(r,t.teardown)}function yt(e,t){e.commentBefore&&t.length>0&&(t[0].comment=e.commentBefore);for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=e.items[i];n.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=n.commentBefore);let o=t[i];if(o.type==="STEP"&&(0,$.isMap)(n)){let a=n.get("statements",!0);(0,$.isSeq)(a)&&yt(a,o.statements)}else if(o.type==="IF_ELSE"&&(0,$.isMap)(n)){let a=n.get("THEN",!0);(0,$.isSeq)(a)&&yt(a,o.then);let r=n.get("ELSE",!0);(0,$.isSeq)(r)&&o.else&&yt(r,o.else)}else if(o.type==="WHILE_LOOP"&&(0,$.isMap)(n)){let a=n.get("DO",!0);(0,$.isSeq)(a)&&yt(a,o.body)}}}var $,re,xt,Rm,Dc,zm,so=w(()=>{"use strict";Aa();$=require("yaml"),re=require("uuid");xt={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};Rm=new Set(["intent","action","locator","xpath","frame_path","args"]);Dc=1024*1024;zm=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});function $a(e,t){let i=[];t.version!=="1.0"&&i.push(`Unsupported patch version: ${t.version}`),(!Array.isArray(t.operations)||t.operations.length===0)&&i.push("Patch must have at least one operation");for(let n=0;n<t.operations.length;n++){let o=t.operations[n],a=`operations[${n}]`;switch(o.reason||i.push(`${a}: missing reason`),o.op){case"remove":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`);break}case"modify":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}case"insert":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),o.position!=="before"&&o.position!=="after"&&i.push(`${a}: position must be 'before' or 'after'`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}default:i.push(`${a}: unknown operation type "${o.op}"`)}}return{valid:i.length===0,errors:i}}function Da(e,t){let i=$a(e,t);if(!i.valid)throw new Error(`Invalid patch: ${i.errors.join("; ")}`);let n=[...e],o=t.operations.map((s,l)=>({...s,originalOrder:l})),a={remove:0,modify:1,insert:2},r=[...o].sort((s,l)=>s.index!==l.index?l.index-s.index:a[s.op]-a[l.op]);for(let s of r)switch(s.op){case"remove":n.splice(s.index,1);break;case"modify":n[s.index]=s.statement;break;case"insert":s.position==="before"?n.splice(s.index,0,s.statement):n.splice(s.index+1,0,s.statement);break}return n}function Kc(e,t){let i=(0,lo.parse)(e);if(!i||typeof i!="object")throw new Error("Invalid YAML: expected an object at root level");let n=i.statements;if(!Array.isArray(n))throw new Error('YAML must have a "statements" array');let o=Da(n,t);i.statements=o;let a=(0,lo.stringify)(i,{lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"});return Je(a),{modifiedYaml:a,modifiedStatements:o}}var lo,jc=w(()=>{"use strict";so();lo=require("yaml")});function La(e){for(let t of e){if(t.type==="STEP"&&t.reference_id)return!0;let i=Ae(t);for(let n of i)if(La(n.statements))return!0}return!1}function Xc(e){let t=new Set;function i(n){for(let o of n){o.type==="STEP"&&o.reference_id&&t.add(o.reference_id);let a=Ae(o);for(let r of a)i(r.statements)}}return i(e),Array.from(t)}function qc(e){if(!e?.statements||!Array.isArray(e.statements))return{};let t={};return Oe(e.statements,"main",t),e.teardown&&Array.isArray(e.teardown)&&Oe(e.teardown,"teardown",t),t}function Pe(e,t,i){let n=e+".",o=t.filter(([c])=>c===e||c.startsWith(n));if(o.length===0)return[];let a=[],r=new Set;for(let[c]of o){let h=c===e?"":c.slice(n.length);if(!h)continue;let p=h.split(".")[0];r.has(p)||r.add(p)}let s=Array.from(r);s.sort((c,h)=>{let p=/^\d+$/.test(c)?parseInt(c,10):-1,g=/^\d+$/.test(h)?parseInt(h,10):-1;return p>=0&&g>=0?p-g:c==="then"&&h==="else"?-1:c==="else"&&h==="then"||c==="body"?1:h==="body"?-1:c.localeCompare(h)});function l(c){return i[c]}function d(c){let h=c.match(/^(IF|WHILE)\s+([\s\S]+)$/);return{type:"AI_MODE",expression:(h?h[2].trim():c)||"true"}}for(let c of s){let h=e?`${e}.${c}`:c,p=l(h),g=p?.description??"",b=h;if(c==="then"){let x=`${e}.then`,E=`${e}.else`,T=Pe(x,t,i),C=Pe(E,t,i),I=l(e),L=I?d(I.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"IF_ELSE",condition:L,then:T,...C.length>0?{else:C}:{}});continue}if(c==="else")continue;if(c==="body"){let x=`${e}.body`,E=Pe(x,t,i),T=l(e),C=T?d(T.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"WHILE_LOOP",condition:C,body:E});continue}let k=`${e}.${c}`,y=t.some(([x])=>x.startsWith(k+".then.")||x===k+".then"),m=t.some(([x])=>x.startsWith(k+".else.")||x===k+".else"),v=t.some(([x])=>x.startsWith(k+".body.")||x===k+".body"),A=t.filter(([x])=>{if(!x.startsWith(k+"."))return!1;let T=x.slice(k.length+1).split(".")[0];return/^\d+$/.test(T)&&T!=="then"&&T!=="else"&&T!=="body"});if(y||m){let x=k+".then",E=k+".else",T=Pe(x,t,i),C=Pe(E,t,i),I=p?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:h,type:"IF_ELSE",condition:I,then:T,...C.length>0?{else:C}:{}})}else if(v){let x=k+".body",E=Pe(x,t,i),T=p?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:h,type:"WHILE_LOOP",condition:T,body:E})}else if(A.length>0){let x=Pe(k,t,i);a.push({uid:h,type:"STEP",description:g||"Group",statements:x})}else a.push({uid:h,type:"ACTION",description:g||"Action",action_entity:p?.action_entity})}return a}function Zc(e){let t=Object.entries(e),i=n=>{let o=n+".";return t.some(([r])=>r===n||r.startsWith(o))?Pe(n,t,e):[]};return{before:i("before"),main:i("main"),teardown:i("teardown"),after:i("after")}}var Ae,ne,$e,De,Le,$i,zc,Vc,Vm,Xm,Yc,Jc,Oe,co=w(()=>{"use strict";Ae=e=>{let t=[];switch(e.type){case"STEP":e.statements&&t.push({key:"statements",statements:e.statements});break;case"IF_ELSE":e.then&&t.push({key:"then",statements:e.then}),e.else&&t.push({key:"else",statements:e.else});break;case"WHILE_LOOP":e.body&&t.push({key:"body",statements:e.body});break}return t},ne=(e,t,i=void 0,n="root")=>{for(let o=0;o<e.length;o++){let a=e[o],r=a.uid;if(r===t)return{stableId:r,path:[o],statement:a,parent:i,containerKey:n,index:o};let s=Ae(a);for(let l of s){let d=ne(l.statements,t,a,l.key);if(d)return{...d,path:[o,l.key,...d.path]}}}return null},$e=(e,t,i)=>{let n=ne(e,t);if(!n)return null;let{statement:o,parent:a,containerKey:r,index:s}=n,l=null;switch(o.type){case"DRAFT":case"ACTION":l=De(e,n)||Le(e,n);break;case"STEP":if(o.statements&&o.statements.length>0)return o.statements[0];l=De(e,n)||Le(e,n);break;case"IF_ELSE":if(i===!0&&o.then&&o.then.length>0)return o.then[0];if(i===!1&&o.else&&o.else.length>0)return o.else[0];l=De(e,n)||Le(e,n);break;case"WHILE_LOOP":if(i===!0&&o.body&&o.body.length>0)return o.body[0];l=De(e,n)||Le(e,n);break;default:l=De(e,n)||Le(e,n);break}if(a&&a.type==="WHILE_LOOP"&&r==="body"){if(!l)return a;let d=ne(e,l.uid);if(!d||d.parent!==a)return a}return l},De=(e,t)=>{if(!t.parent)return e[t.index+1]||null;let n=Ae(t.parent).find(o=>o.key===t.containerKey);return n&&t.index+1<n.statements.length?n.statements[t.index+1]:null},Le=(e,t)=>{if(!t.parent)return null;let i=t.parent.uid,n=ne(e,i);return n?De(e,n)||Le(e,n):null},$i=e=>{let t=[],i=n=>{for(let o of n){t.push(o);let a=Ae(o);for(let r of a)i(r.statements)}};return i(e),t},zc=e=>{switch(e.type){case"DRAFT":case"ACTION":return!0;case"STEP":return!0;case"IF_ELSE":case"WHILE_LOOP":return!0;default:return!1}},Vc=(e,t,i)=>{if(!ne(e,t))return null;if(i===null){let s=[],l=t;for(;l!==null&&ne(e,l);)if(s.push(l),l=$e(e,l)?.uid||null,s.length>1e3)return null;return s}if(!ne(e,i))return null;if(t===i)return[];let a=[],r=t;for(;r&&r!==i;){let s=ne(e,r);if(!s)break;if(a.push(r),s.statement.type==="IF_ELSE"){let l=Vm(s.statement,i);l?r=$e(e,r,l==="then")?.uid||null:r=$e(e,r)?.uid||null}else s.statement.type==="WHILE_LOOP"?Xm(s.statement,i)?r=$e(e,r,!0)?.uid||null:r=$e(e,r,!1)?.uid||null:r=$e(e,r)?.uid||null;if(a.length>1e3)return null}return r===i?a:null},Vm=(e,t)=>{if(e.type!=="IF_ELSE")return null;let i=e;return i.then&&ne(i.then,t)?"then":i.else&&ne(i.else,t)?"else":null},Xm=(e,t)=>{if(e.type!=="WHILE_LOOP")return!1;let i=e;return!!(i.body&&ne(i.body,t))};Yc=e=>e.startsWith("ai_")?!0:["js_code","function","assert","verify","wait_for_download_complete","extract_activation_code","extract_email_content"].includes(e),Jc=e=>!["js_code","function","assert","ai_assert","verify","ai_extract","ai_wait_until","upload_file","login","extract_activation_code","extract_email_content","ai_step"].includes(e),Oe=(e,t,i)=>{e.forEach((n,o)=>{let a=`${t}.${o}`;n.type==="DRAFT"?i[a]={description:n.description||"Draft",action_entity:void 0}:n.type==="ACTION"?i[a]={description:n.description||"Action",action_entity:n.action_entity}:n.type==="STEP"&&n.statements?Oe(n.statements,a,i):n.type==="IF_ELSE"?(i[a]={description:"IF "+(n.condition?.expression||""),action_entity:void 0},n.then&&Oe(n.then,`${a}.then`,i),n.else&&Oe(n.else,`${a}.else`,i)):n.type==="WHILE_LOOP"&&(i[a]={description:"WHILE "+(n.condition?.expression||""),action_entity:void 0},n.body&&Oe(n.body,`${a}.body`,i))})}});function Na(e){let t=0,i=0;for(let n of e)if(n.type==="DRAFT")i++;else if(n.type==="ACTION"){let o=n.action_entity?.action_data?.action_name??"";Oa.has(o)||t++}return{action:t,draft:i}}function Jm(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function Qc(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function ed(e,t){let i=t?.coverageThreshold??Ym,n=[],o=[],a;try{a=Je(e)}catch(p){return{valid:!1,errors:[`Invalid YAML: ${p.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}a.goal||n.push('Missing required field: "goal"'),a.statements?.length||n.push('Missing required field: "statements"');let r=[...$i(a.statements??[]),...a.teardown?$i(a.teardown):[]],{action:s,draft:l}=Na(r),d="Hint: in YAML double-quoted strings, backslashes are escape characters \u2014 use \\\\/ instead of \\/ for regex, or use single quotes.";for(let p of r){if(p.type==="ACTION"){let g=p,b=g.action_entity?.action_data?.action_name??"";if(b==="js_code"||b==="js_action"||b==="verify"||b==="ai_assert"){let k=g.action_entity?.action_data?.kwargs?.code;if(typeof k=="string"){let y=Jm(k);if(y){let m=g.description||b;n.push(`Invalid JS in "${m}": ${y}. ${d}`)}}}}if(p.type==="IF_ELSE"){let g=p;if(g.condition.type==="JS_CODE"){let b=Qc(g.condition.expression);b&&n.push(`Invalid JS in IF condition "${g.condition.expression}": ${b}. ${d}`)}}if(p.type==="WHILE_LOOP"){let g=p;if(g.condition.type==="JS_CODE"){let b=Qc(g.condition.expression);b&&n.push(`Invalid JS in WHILE condition "${g.condition.expression}": ${b}. ${d}`)}}}let c=s+l,h=c>0?Math.round(s/c*100):0;return c>0&&h/100<i&&o.push(`Low action coverage: ${s}/${c} statements (${h}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:n.length===0,errors:n,warnings:o,stats:{total:c,action:s,draft:l,coverage:h}}}var Ym,Oa,td=w(()=>{"use strict";so();co();Ym=.5,Oa=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"])});var id,nd=w(()=>{"use strict";id=class{version;goal;url;constructor(e,t){this.version=e,this.goal=t.goal,this.url=t.url}generatePrelude(){let e=`// version ${this.version}
|
|
4530
|
+
${s}`);let l=this.agentServices.knowledgeRetriever,d=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(f.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(k,y,m,x)=>await l(k,y,m,"login")),d=!0,f.log("Login knowledge retriever configured"));let c;try{if(c=await this.run(e,s,"login"),!c.success)return f.log("Level 3 FAILED: Agent login failed"),u.info("Login: Failed"),{success:!1,page:e}}finally{d&&l&&(this.agentServices.setKnowledgeRetriever(l),f.log("Restored original knowledge retriever"))}let h=await e.context().storageState(),p;if(o)f.log("Skipping validation locator generation (AI verification mode enabled)");else if(t.num_verification_exprs!==0)try{f.log("Generating validation locators for future login verification...");let k=await uo(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(y,m)=>this.run(y,m),async y=>this.getDOMText(y));k?(p=k,f.log(`Generated ${p.length} validation locator(s): ${JSON.stringify(p)}`)):f.log("Failed to generate validation locators, login will still succeed")}catch(k){f.log(`Error generating validation locators: ${k.message}`)}else f.log("Skipping validation locator generation (num_verification_exprs=0)");f.log("Level 3 SUCCESS: Agent login succeeded"),u.info("Login: Agent login succeeded");let g=c.actions||[],b=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:h,cached_actions:b,validation_exprs:p}}catch(l){return f.error(`Agent login failed: ${l.message}`),u.info("Login: Failed"),{success:!1,page:e}}}async executeCachedLogin(e,t,i){let n=(await Promise.resolve().then(()=>(ft(),gt))).default,o=new n;for(let a=0;a<t.length;a++){let r=t[a];f.log(`Executing cached action ${a+1}/${t.length}: ${r.action_description||r.action_data?.action_name}`);try{if(!r.action_data){f.log(`Action ${a+1} missing action_data, skipping`);continue}await o.execute(e,r,this.agentServices),await this.waitUntilStable(e,5e3)}catch(s){return f.error(`Cached action ${a+1} failed: ${s.message}`),{success:!1}}}return i?.aiVerificationStatement?(f.log("Verifying cached login result with AI verification statement"),await this.evaluate(e,i.aiVerificationStatement)?{success:!0}:{success:!1}):i?.validationExprs&&i.validationExprs.length>0?await Ci(e,i.validationExprs)?{success:!0}:{success:!1}:(f.log("Cached login cannot be verified: missing AI verification statement and validation expressions"),{success:!1})}getCompletedExecutionHistory(){if(!this.context.executionHistory||this.context.executionHistory.length===0)return[];let e=this.context.executionHistory[this.context.executionHistory.length-1];return!e[1]||e[1].trim()===""?this.context.executionHistory.slice(0,-1):this.context.executionHistory}addToExecutionHistory(e,t){this.context.executionHistory||(this.context.executionHistory=[]),this.context.executionHistory.push([e,t])}async createStepResult(e,t,i){if(this.context.stepTracking&&!this.context.stepTracking.results[t]){this.context.stepTracking.currentStepId=t,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(t);try{e=this.agentServices.validatePage(e),await this.waitUntilStable(e);let n={description:i,startTime:Date.now(),artifacts:[]};if(this.context.stepTracking.artifactsDir){let o=q.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));j.mkdirSync(o,{recursive:!0});let a=q.join(o,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:a}),n.screenshot=a}this.context.stepTracking.results[t]=n}catch(n){u.warn(`createStepResult failed for step ${t}: ${n}`),this.context.stepTracking.results[t]={description:i,startTime:Date.now(),artifacts:[]}}}}saveDebugInfoToFiles(e,t,i,n=0){let o={};if(!this.context.stepTracking?.artifactsDir)return u.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),o;let a=q.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(j.mkdirSync(a,{recursive:!0}),t.systemPrompt){let r=q.join(a,`system_prompt_${n}.txt`);j.writeFileSync(r,t.systemPrompt),o.system_prompt_path=r,u.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${r}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let r=q.join(a,`user_prompt_${n}.txt`);j.writeFileSync(r,t.userPrompt),o.user_prompt_path=r,u.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${r}`)}else{let r=t.userPrompt.map(d=>Array.isArray(d.content)?{...d,content:d.content.map(c=>c.type==="image"&&c.file?.startsWith("data:")?{...c,file:"[base64 image data stripped]"}:c)}:d),s=q.join(a,`messages_${n}.json`),l={system:t.systemPrompt,messages:r};j.writeFileSync(s,JSON.stringify(l,null,2)),o.messages_path=s,u.debug(`[saveDebugInfoToFiles] Saved messages to: ${s}`)}if(t.rawLlmResponse){let r=i?i.replace(/[\/\\:]/g,"-"):"llm",s=q.join(a,`${r}_response_${n}.txt`);j.writeFileSync(s,t.rawLlmResponse),o.response_path=s,u.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${s}`)}if(t.screenshotWithSom){let r=q.join(a,`screenshot_${n}.png`);j.writeFileSync(r,Buffer.from(t.screenshotWithSom,"base64")),o.screenshot_path=r,u.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${r}`)}if(t.reasoningContent){let r=q.join(a,`reasoning_${n}.txt`);j.writeFileSync(r,t.reasoningContent),o.reasoning_path=r,u.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${r}`)}u.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(o).length} artifacts for step ${e}`)}catch(r){u.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,r)}return o}async updateStepResult(e,t,i,n,o){if(!this.context.stepTracking)return;let a=this.context.stepTracking.results[e];if(a){if(t&&(a.status=t,this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(a.message=i),n&&a.artifacts.push(n),o){let r=o.tokenUsages?.[0]?.model,s=a.artifacts.length,l=this.saveDebugInfoToFiles(e,o,r,s);Object.keys(l).length>0&&a.artifacts.push(l)}a.duration=Date.now()-a.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(e,a)}}async writeExecutionResults(e,t){try{if(await j.promises.mkdir(e,{recursive:!0}),this.context.stepTracking?.results&&Object.keys(this.context.stepTracking.results).length>0){let i=q.join(e,"test-results.json");await j.promises.writeFile(i,JSON.stringify(this.context.stepTracking.results,null,2)),u.debug(`Test results written to: ${i}`)}if(t?.tokenUsages&&this.context.tokenUsages&&this.context.tokenUsages.length>0){let i=q.join(e,"token-usages.json");await j.promises.writeFile(i,JSON.stringify(this.context.tokenUsages,null,2)),u.debug(`Token usages written to: ${i}`)}if(this.context.aiActionDetails&&this.context.aiActionDetails.length>0){let i=q.join(e,"ai-actions.json");await j.promises.writeFile(i,JSON.stringify(this.context.aiActionDetails,null,2)),u.debug(`AI action details written to: ${i}`)}}catch(i){throw u.error("Failed to write execution results:",i),i}}}});function Vm(){let e=new Date,t=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(e),i=t.find(m=>m.type==="year").value,n=t.find(m=>m.type==="month").value,o=t.find(m=>m.type==="day").value,a=t.find(m=>m.type==="hour").value,r=t.find(m=>m.type==="minute").value,s=t.find(m=>m.type==="second").value,l=String(e.getMilliseconds()).padStart(3,"0"),d=`${i}-${n}-${o}T${a}:${r}:${s}.${l}`,c=e.toISOString().slice(0,-1),h=Date.parse(d+"Z"),p=Date.parse(c+"Z"),g=Math.round((p-h)/(1e3*60)),b=String(Math.floor(Math.abs(g)/60)).padStart(2,"0"),k=String(Math.abs(g)%60).padStart(2,"0"),y=g<=0?"+":"-";return`${i}-${n}-${o}T${a}:${r}:${s}.${l}${y}${b}:${k}`}function Ia(e){let t=e.variableStore;return t.has("currentTime")||t.set("currentTime",Vm()),{model:e.model,computer_use_model:e.computer_use_model,variableStore:t,organizationId:e.organizationId,organizationSettings:e.organizationSettings,executionHistory:e.executionHistory||[],testDataDir:e.testDataDir,downloadDir:e.downloadDir,useNativeGenerator:e.useNativeGenerator,autoDismissModal:e.autoDismissModal,tokenUsages:[],aiActionDetails:[]}}var Bc=w(()=>{"use strict"});var Gc={};Ue(Gc,{ActionHandler:()=>Bn,ActionHelper:()=>Ei,Agent:()=>Ma,AgentServices:()=>po,AgentStepEventTypes:()=>Ta,AgentTaskFailedError:()=>go,BrowserManager:()=>Ec,DEFAULT_EVENT_LISTENER_LIMIT:()=>un,DomService:()=>me,EVENT_LISTENER_CANDIDATE_SELECTORS:()=>dn,HistoryTreeProcessor:()=>Is,INIT_SCRIPT:()=>bt,INTERACTION_EVENT_TYPES:()=>lt,INTERACTIVE_ROLES:()=>Ht,LogLevel:()=>Ko,LoginType:()=>Mi,MCPToolProvider:()=>mc,OpenAIToolProvider:()=>Qi,SDK_VERSION:()=>Ym,ToolRegistry:()=>st,TwoFactorAuthType:()=>ya,VariableStore:()=>xa,WebAgent:()=>Ma,configureSdk:()=>Er,createAgent:()=>Xm,createAgentContext:()=>Ia,createToolRegistry:()=>cc,createToolRegistryWithCapabilities:()=>dc,ensureToolsRegistered:()=>sc,evaluateStatement:()=>Ve,executeStep:()=>ze,exportMCPTools:()=>pc,filterInteractionListeners:()=>ps,generateActionStep:()=>mt,getActionEntityLocatorInfo:()=>N,getBrowserCdpUrl:()=>zn,getCapabilitySummary:()=>uc,getFramePath:()=>Wo,getModel:()=>be,getPageInfo:()=>jl,getPageWsUrl:()=>Kl,getPlatformFromDeviceName:()=>Ac,getProviderOptions:()=>ye,getSdkConfig:()=>G,getToolRegistry:()=>lc,injectUserFunction:()=>Io,isInteractionEventType:()=>ms,isInteractiveRole:()=>hs,loadKnowledgeMappings:()=>Pr,loadKnowledges:()=>Cr,loadUserFunctions:()=>Mr,logger:()=>u,newBrowserContext:()=>Ul,parseSSEStream:()=>Dr,parseSdkLogLevelFromEnv:()=>Tr,pickBestLocator:()=>Mt,pickBestLocatorForElement:()=>Ui,pickBestLocators:()=>Fr,replaceVariables:()=>co,runTask:()=>Xe,setWindowBounds:()=>Vn,toolRegistry:()=>H});function Xm(e){let t=new xa,i=new Set(e.sensitiveKeys||[]);if(e.variables)for(let[o,a]of Object.entries(e.variables))t.set(o,a,i.has(o));let n=Ia({model:e.model,variableStore:t,testDataDir:e.testDataDir,downloadDir:e.downloadDir});return new Ma(n)}var Ym,Uc=w(()=>{"use strict";Ir();$r();Lr();hc();ba();gc();fc();ga();wa();fa();Tc();Mc();Ic();Wc();jt();cn();sn();rt();Xi();Yi();nt();en();nn();Lt();Ot();Te();$t();Dt();_n();je();Ft();Wt();ct();Bt();Gt();ho();ie();Ea();Sa();vt();mo();Ie();yt();Ee();It();ot();Ct();Aa();ha();mn();pn();gn();fn();wn();bn();yn();xn();vn();Sn();En();zt();Xt();Jt();qt();Qt();ei();ti();ii();ni();oi();ai();si();li();ci();di();ui();mi();pi();fi();wi();bi();yi();xi();vi();ki();_i();Si();Ln();Zt();K();Ke();R();te();dt();Wn();F();Bc();fe();Ym="1.0.0"});function Ca(e){for(let t of e){if(t.type==="STEP"&&t.reference_id)return!0;let i=Ce(t);for(let n of i)if(Ca(n.statements))return!0}return!1}function zc(e){let t=new Set;function i(n){for(let o of n){o.type==="STEP"&&o.reference_id&&t.add(o.reference_id);let a=Ce(o);for(let r of a)i(r.statements)}}return i(e),Array.from(t)}function Yc(e){if(!e?.statements||!Array.isArray(e.statements))return{};let t={};return Re(e.statements,"main",t),e.teardown&&Array.isArray(e.teardown)&&Re(e.teardown,"teardown",t),t}function De(e,t,i){let n=e+".",o=t.filter(([c])=>c===e||c.startsWith(n));if(o.length===0)return[];let a=[],r=new Set;for(let[c]of o){let h=c===e?"":c.slice(n.length);if(!h)continue;let p=h.split(".")[0];r.has(p)||r.add(p)}let s=Array.from(r);s.sort((c,h)=>{let p=/^\d+$/.test(c)?parseInt(c,10):-1,g=/^\d+$/.test(h)?parseInt(h,10):-1;return p>=0&&g>=0?p-g:c==="then"&&h==="else"?-1:c==="else"&&h==="then"||c==="body"?1:h==="body"?-1:c.localeCompare(h)});function l(c){return i[c]}function d(c){let h=c.match(/^(IF|WHILE)\s+([\s\S]+)$/);return{type:"AI_MODE",expression:(h?h[2].trim():c)||"true"}}for(let c of s){let h=e?`${e}.${c}`:c,p=l(h),g=p?.description??"",b=h;if(c==="then"){let v=`${e}.then`,E=`${e}.else`,T=De(v,t,i),C=De(E,t,i),I=l(e),L=I?d(I.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"IF_ELSE",condition:L,then:T,...C.length>0?{else:C}:{}});continue}if(c==="else")continue;if(c==="body"){let v=`${e}.body`,E=De(v,t,i),T=l(e),C=T?d(T.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"WHILE_LOOP",condition:C,body:E});continue}let k=`${e}.${c}`,y=t.some(([v])=>v.startsWith(k+".then.")||v===k+".then"),m=t.some(([v])=>v.startsWith(k+".else.")||v===k+".else"),x=t.some(([v])=>v.startsWith(k+".body.")||v===k+".body"),A=t.filter(([v])=>{if(!v.startsWith(k+"."))return!1;let T=v.slice(k.length+1).split(".")[0];return/^\d+$/.test(T)&&T!=="then"&&T!=="else"&&T!=="body"});if(y||m){let v=k+".then",E=k+".else",T=De(v,t,i),C=De(E,t,i),I=p?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:h,type:"IF_ELSE",condition:I,then:T,...C.length>0?{else:C}:{}})}else if(x){let v=k+".body",E=De(v,t,i),T=p?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:h,type:"WHILE_LOOP",condition:T,body:E})}else if(A.length>0){let v=De(k,t,i);a.push({uid:h,type:"STEP",description:g||"Group",statements:v})}else a.push({uid:h,type:"ACTION",description:g||"Action",action_entity:p?.action_entity})}return a}function Jc(e){let t=Object.entries(e),i=n=>{let o=n+".";return t.some(([r])=>r===n||r.startsWith(o))?De(n,t,e):[]};return{before:i("before"),main:i("main"),teardown:i("teardown"),after:i("after")}}var Ce,re,Le,Oe,Ne,Di,Kc,jc,Jm,qm,Vc,Xc,Re,fo=w(()=>{"use strict";Ce=e=>{let t=[];switch(e.type){case"STEP":e.statements&&t.push({key:"statements",statements:e.statements});break;case"IF_ELSE":e.then&&t.push({key:"then",statements:e.then}),e.else&&t.push({key:"else",statements:e.else});break;case"WHILE_LOOP":e.body&&t.push({key:"body",statements:e.body});break}return t},re=(e,t,i=void 0,n="root")=>{for(let o=0;o<e.length;o++){let a=e[o],r=a.uid;if(r===t)return{stableId:r,path:[o],statement:a,parent:i,containerKey:n,index:o};let s=Ce(a);for(let l of s){let d=re(l.statements,t,a,l.key);if(d)return{...d,path:[o,l.key,...d.path]}}}return null},Le=(e,t,i)=>{let n=re(e,t);if(!n)return null;let{statement:o,parent:a,containerKey:r,index:s}=n,l=null;switch(o.type){case"DRAFT":case"ACTION":l=Oe(e,n)||Ne(e,n);break;case"STEP":if(o.statements&&o.statements.length>0)return o.statements[0];l=Oe(e,n)||Ne(e,n);break;case"IF_ELSE":if(i===!0&&o.then&&o.then.length>0)return o.then[0];if(i===!1&&o.else&&o.else.length>0)return o.else[0];l=Oe(e,n)||Ne(e,n);break;case"WHILE_LOOP":if(i===!0&&o.body&&o.body.length>0)return o.body[0];l=Oe(e,n)||Ne(e,n);break;default:l=Oe(e,n)||Ne(e,n);break}if(a&&a.type==="WHILE_LOOP"&&r==="body"){if(!l)return a;let d=re(e,l.uid);if(!d||d.parent!==a)return a}return l},Oe=(e,t)=>{if(!t.parent)return e[t.index+1]||null;let n=Ce(t.parent).find(o=>o.key===t.containerKey);return n&&t.index+1<n.statements.length?n.statements[t.index+1]:null},Ne=(e,t)=>{if(!t.parent)return null;let i=t.parent.uid,n=re(e,i);return n?Oe(e,n)||Ne(e,n):null},Di=e=>{let t=[],i=n=>{for(let o of n){t.push(o);let a=Ce(o);for(let r of a)i(r.statements)}};return i(e),t},Kc=e=>{switch(e.type){case"DRAFT":case"ACTION":return!0;case"STEP":return!0;case"IF_ELSE":case"WHILE_LOOP":return!0;default:return!1}},jc=(e,t,i)=>{if(!re(e,t))return null;if(i===null){let s=[],l=t;for(;l!==null&&re(e,l);)if(s.push(l),l=Le(e,l)?.uid||null,s.length>1e3)return null;return s}if(!re(e,i))return null;if(t===i)return[];let a=[],r=t;for(;r&&r!==i;){let s=re(e,r);if(!s)break;if(a.push(r),s.statement.type==="IF_ELSE"){let l=Jm(s.statement,i);l?r=Le(e,r,l==="then")?.uid||null:r=Le(e,r)?.uid||null}else s.statement.type==="WHILE_LOOP"?qm(s.statement,i)?r=Le(e,r,!0)?.uid||null:r=Le(e,r,!1)?.uid||null:r=Le(e,r)?.uid||null;if(a.length>1e3)return null}return r===i?a:null},Jm=(e,t)=>{if(e.type!=="IF_ELSE")return null;let i=e;return i.then&&re(i.then,t)?"then":i.else&&re(i.else,t)?"else":null},qm=(e,t)=>{if(e.type!=="WHILE_LOOP")return!1;let i=e;return!!(i.body&&re(i.body,t))};Vc=e=>e.startsWith("ai_")?!0:["js_code","function","assert","verify","wait_for_download_complete","extract_activation_code","extract_email_content"].includes(e),Xc=e=>!["js_code","function","assert","ai_assert","verify","ai_extract","ai_wait_until","upload_file","login","extract_activation_code","extract_email_content","ai_step"].includes(e),Re=(e,t,i)=>{e.forEach((n,o)=>{let a=`${t}.${o}`;n.type==="DRAFT"?i[a]={description:n.description||"Draft",action_entity:void 0}:n.type==="ACTION"?i[a]={description:n.description||"Action",action_entity:n.action_entity}:n.type==="STEP"&&n.statements?Re(n.statements,a,i):n.type==="IF_ELSE"?(i[a]={description:"IF "+(n.condition?.expression||""),action_entity:void 0},n.then&&Re(n.then,`${a}.then`,i),n.else&&Re(n.else,`${a}.else`,i)):n.type==="WHILE_LOOP"&&(i[a]={description:"WHILE "+(n.condition?.expression||""),action_entity:void 0},n.body&&Re(n.body,`${a}.body`,i))})}});var S,Pa,wo,$a,qe,Da,La,Oa,ne,Na,Li,bo,Ra=w(()=>{"use strict";S=require("zod"),Pa=S.z.enum(["JS_CODE","AI_MODE"]),wo=S.z.object({type:Pa,expression:S.z.string()}),$a=S.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),qe=S.z.object({uid:S.z.string(),type:$a,comment:S.z.string().optional()}),Da=S.z.object({action_data:S.z.object({action_name:S.z.string(),kwargs:S.z.record(S.z.any()).optional(),args:S.z.array(S.z.any()).optional()}),action_description:S.z.string().optional(),url:S.z.string().optional(),xpath:S.z.string().nullable().optional(),locator:S.z.string().nullable().optional(),css_selector:S.z.string().nullable().optional(),unique_selector:S.z.string().nullable().optional(),element_index:S.z.number().nullable().optional(),frame_path:S.z.array(S.z.any()).optional(),artifacts:S.z.record(S.z.any()).optional(),feedback:S.z.string().optional(),original_browser_use_action:S.z.any().optional()}).passthrough(),La=qe.extend({type:S.z.literal("DRAFT"),description:S.z.string()}),Oa=qe.extend({type:S.z.literal("ACTION"),description:S.z.string(),action_entity:Da.optional(),locator:S.z.string().optional(),use_pure_vision:S.z.boolean().optional()}),ne=S.z.lazy(()=>S.z.union([La,Oa,qe.extend({type:S.z.literal("STEP"),description:S.z.string().optional().default(""),statements:S.z.array(ne),reference_id:S.z.number().optional()}),qe.extend({type:S.z.literal("IF_ELSE"),description:S.z.string().optional(),condition:wo,then:S.z.array(ne),else:S.z.array(ne).optional()}),qe.extend({type:S.z.literal("WHILE_LOOP"),description:S.z.string().optional(),condition:wo,body:S.z.array(ne),timeout_ms:S.z.number().optional()})])),Na=S.z.object({name:S.z.string(),statements:S.z.array(ne),teardown:S.z.array(ne).optional(),skip:S.z.union([S.z.boolean(),S.z.string()]).optional(),timeout:S.z.number().optional(),fail:S.z.union([S.z.boolean(),S.z.string()]).optional(),only:S.z.boolean().optional(),slow:S.z.boolean().optional()}),Li=S.z.object({tests:S.z.array(Na).min(1),beforeAll:S.z.array(ne).optional(),afterAll:S.z.array(ne).optional(),beforeEach:S.z.array(ne).optional(),afterEach:S.z.array(ne).optional()}),bo=S.z.object({comment:S.z.string().optional(),version:S.z.string().optional(),goal:S.z.string().optional(),url:S.z.string().optional(),baseURL:S.z.string().optional(),final_feedback:S.z.string().optional(),completed:S.z.boolean().optional(),success:S.z.boolean().optional(),statements:S.z.array(ne).optional(),teardown:S.z.array(ne).optional(),last_modified_at:S.z.string().optional(),testGroup:Li.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"})});function Ha(e,t){let i={...t?.test_case_id!==void 0?{test_case_id:t.test_case_id}:{},...t?.name?{name:t.name}:{},goal:e.goal??"",url:e.url,base_url:e.baseURL,statements:(e.statements??[]).map(de)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(de)),i}function ed(e,t){if(e.testGroup)return Wa(e,t);let i=Ha(e,t),n=new $.Document(i);return e.comment&&(n.commentBefore=e.comment),qc(n,e.statements??[]),e.teardown&&qc(n,e.teardown,"teardown"),n.toString(St)}function qc(e,t,i="statements"){let n=e.contents;if(!n||!(0,$.isMap)(n))return;let o=n.get(i,!0);(0,$.isSeq)(o)&&Oi(o,t)}function Oi(e,t){for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=t[i],o=e.items[i];if(i>0&&(o.spaceBefore=!0),n.comment&&(i===0?e.commentBefore=n.comment:o.commentBefore=n.comment),(0,$.isMap)(o)){let a=o;if(n.type==="STEP"){let r=a.get("statements",!0);(0,$.isSeq)(r)&&Oi(r,n.statements)}else if(n.type==="IF_ELSE"){let r=a.get("THEN",!0);(0,$.isSeq)(r)&&Oi(r,n.then);let s=a.get("ELSE",!0);(0,$.isSeq)(s)&&n.else&&Oi(s,n.else)}else if(n.type==="WHILE_LOOP"){let r=a.get("DO",!0);(0,$.isSeq)(r)&&Oi(r,n.body)}}}}function Wa(e,t){let i=e.testGroup;if(!i)throw new Error("suiteToYaml requires a TestFlow with testGroup");let n={};t?.test_case_id!==void 0&&(n.test_case_id=t.test_case_id),t?.name&&(n.name=t.name),t?.tags&&t.tags.length>0&&(n.tags=t.tags),t?.use&&Object.keys(t.use).length>0&&(n.use=t.use);let o={};return e.baseURL&&(o.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(o.beforeAll=i.beforeAll.map(de)),i.beforeEach&&i.beforeEach.length>0&&(o.beforeEach=i.beforeEach.map(de)),i.afterEach&&i.afterEach.length>0&&(o.afterEach=i.afterEach.map(de)),i.afterAll&&i.afterAll.length>0&&(o.afterAll=i.afterAll.map(de)),o.tests=i.tests.map(a=>{let r={name:a.name};return a.skip!==void 0&&(r.skip=a.skip),a.timeout!==void 0&&(r.timeout=a.timeout),a.fail!==void 0&&(r.fail=a.fail),a.only!==void 0&&(r.only=a.only),a.slow!==void 0&&(r.slow=a.slow),r.statements=a.statements.map(de),a.teardown&&a.teardown.length>0&&(r.teardown=a.teardown.map(de)),r}),n.suite=o,(0,$.stringify)(n,St)}function td(e){return e.map(t=>(0,$.stringify)(t,St)).join(`---
|
|
4531
|
+
`)}function de(e){switch(e.type){case"DRAFT":return Zm(e);case"ACTION":return id(e);case"STEP":return ep(e);case"IF_ELSE":return tp(e);case"WHILE_LOOP":return ip(e)}}function Zm(e){return{intent:e.description}}function id(e){let t=e.action_entity?.action_data?.action_name??e.action_entity?.action?.action_name,i=e.action_entity?.action_data?.kwargs??e.action_entity?.action?.kwargs;if(t==="verify"){let s=i?.statement;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l=i?.code;return typeof l=="string"?{VERIFY:s,js:l}:{VERIFY:s}}}if(t==="go_to_url"){let s=i?.url;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l={URL:s};return i?.new_tab===!0&&(l.new_tab=!0),typeof i?.timeout_seconds=="number"&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="js_action"){let s=i?.code;if(typeof s=="string"&&e.description)return{intent:e.description,js:s}}if(t==="ai_wait_until"){let s=i?.condition;if(typeof s=="string"){let l={WAIT_UNTIL:s};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="wait"){let s=i?.seconds,d={WAIT:e.description||`Wait ${s}s`};return typeof s=="number"&&(d.seconds=s),d}if(t==="js_code"){let s=i?.code;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{CODE:s}}if(!e.action_entity)return{intent:e.description};let n=e.action_entity.action_data??e.action_entity.action;if(!n)return{intent:e.description};let o={intent:e.description,action:n.action_name},a=e.locator??e.action_entity.locator;a&&(o.locator=a);let r=e.action_entity.xpath;if(r&&(o.xpath=r),e.use_pure_vision&&(o.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[s,l]of Object.entries(n.kwargs))o[s]=l;return n.args&&n.args.length>0&&(o.args=n.args),o}function nd(e,t,i){let n={uid:"",type:"ACTION",description:t||e.action_description||"",action_entity:e,locator:i},o=id(n);if(typeof o=="object"&&o!==null){let a={...o};return delete a.intent,delete a.VERIFY,delete a.WAIT_UNTIL,delete a.WAIT,delete a.statement,Object.keys(a).length>0?(0,$.stringify)(a,St).trim():""}return(0,$.stringify)(o,St).trim()}function od(e){let t=(0,$.parse)(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object");if("VERIFY"in t){let c=String(t.VERIFY),h=typeof t.js=="string"?t.js:void 0;return{description:c,actionEntity:{action_description:c,action_data:{action_name:"verify",kwargs:{statement:c,...h?{code:h}:{}}}}}}if("URL"in t){let c=String(t.URL),h={url:c};return t.new_tab===!0&&(h.new_tab=!0),typeof t.timeout_seconds=="number"&&(h.timeout_seconds=t.timeout_seconds),{description:`Navigate to ${c}`,actionEntity:{action_description:`Navigate to ${c}`,action_data:{action_name:"go_to_url",kwargs:h}}}}if("CODE"in t){let c=String(t.CODE);return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:c}}}}}if("WAIT_UNTIL"in t){let c=String(t.WAIT_UNTIL),h={condition:c};return typeof t.timeout_seconds=="number"&&(h.timeout_seconds=t.timeout_seconds),{description:`Wait until ${c}`,actionEntity:{action_description:`Wait until ${c}`,action_data:{action_name:"ai_wait_until",kwargs:h}}}}if("WAIT"in t){let c=String(t.WAIT),h={};return typeof t.seconds=="number"&&(h.seconds=t.seconds),{description:c,actionEntity:{action_description:c,action_data:{action_name:"wait",kwargs:h}}}}let i=typeof t.intent=="string"?t.intent:void 0,n=typeof t.action=="string"?t.action:void 0,o=typeof t.locator=="string"?t.locator:void 0,a=typeof t.xpath=="string"?t.xpath:void 0,r=Array.isArray(t.frame_path)?t.frame_path:void 0,s=Array.isArray(t.args)?t.args:void 0,l={};for(let[c,h]of Object.entries(t))Qm.has(c)||(l[c]=h);return!n&&t.js?{description:i,actionEntity:{action_description:i||"",action_data:{action_name:"js_action",kwargs:{code:t.js}}}}:n?{actionEntity:{action_description:i||"",action_data:{action_name:n,kwargs:l,...s&&s.length>0?{args:s}:{}},...o?{locator:o}:{},...a?{xpath:a}:{},...r?{frame_path:r}:{}},description:i,locator:o}:{description:i,actionEntity:{action_description:i||""}}}function ep(e){let t={STEP:e.description,statements:e.statements.map(de)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function tp(e){let t={IF:ad(e.condition),THEN:e.then.map(de)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(de)),t}function ip(e){let t={WHILE:ad(e.condition),DO:e.body.map(de)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function ad(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function rd(e){let t=(0,$.parseAllDocuments)(e),i;if(t.length>1||t.length===1&&!Array.isArray(t[0]?.toJSON()))i=t.map((n,o)=>n.errors.length>0?{__parseError:`Document ${o+1}: ${n.errors[0].message}`}:n.toJSON());else{let n;try{n=(0,$.parse)(e)}catch(o){throw new Error(`Invalid YAML: ${o instanceof Error?o.message:String(o)}`)}if(!Array.isArray(n))throw new Error("Expected a YAML array or multi-document YAML (separated by ---)");i=n}return i.map((n,o)=>{try{if(n&&typeof n=="object"&&"__parseError"in n)return{error:n.__parseError};if(!n||typeof n!="object")return{error:`Item ${o+1}: expected an object`};let a=n,r=typeof a.name=="string"&&a.name.trim()||void 0,s=typeof a.goal=="string"?a.goal.trim():"";if(!s)return{error:`Item ${o+1}: missing "goal" field`};if(Array.isArray(a.statements))try{let l=(0,$.stringify)(a,St),d=Ze(l);return{name:r,goal:d.goal??s,testFlow:d}}catch{}return{name:r,goal:s}}catch(a){return{error:`Item ${o+1}: ${a instanceof Error?a.message:String(a)}`}}})}function sd(e){try{let t=(0,$.parse)(e);if(!t||typeof t!="object")return{};let i={};return typeof t.test_case_id=="number"&&Number.isFinite(t.test_case_id)&&(i.test_case_id=t.test_case_id),typeof t.template_id=="number"&&Number.isFinite(t.template_id)&&(i.template_id=t.template_id),typeof t.name=="string"&&t.name.trim()&&(i.name=t.name.trim()),i}catch{return{}}}function Fa(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(Fa);let t=e,i=Object.keys(t);if(i.length===1){let o=i[0];if(o.startsWith("{ ")&&o.endsWith(" }")&&t[o]===null)return`{{${o.slice(2,-2)}}}`}let n={};for(let[o,a]of Object.entries(t))n[o]=Fa(a);return n}function Ze(e){if(e.length>Zc)throw new Error(`YAML input too large (${e.length} bytes, max ${Zc})`);let t=Fa((0,$.parse)(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return np(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:ue(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=ue(t.teardown));let n=bo.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let o=n.data;return Ba(e,o),o}function np(e){let t=e.suite;if(!t||typeof t!="object")throw new Error("Invalid suite: expected an object");let i=t.tests;if(!Array.isArray(i)||i.length===0)throw new Error('Suite must have a non-empty "tests" array');let o={tests:i.map(s=>{if(!s.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(s.statements)||s.statements.length===0)throw new Error(`Suite test "${s.name}" must have a non-empty "statements" array`);let l={name:s.name,statements:ue(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=ue(s.teardown)),s.skip!==void 0&&(l.skip=s.skip),typeof s.timeout=="number"&&(l.timeout=s.timeout),s.fail!==void 0&&(l.fail=s.fail),s.only===!0&&(l.only=!0),s.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(o.beforeAll=ue(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(o.afterAll=ue(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(o.beforeEach=ue(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(o.afterEach=ue(t.afterEach));let a=Li.safeParse(o);if(!a.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(a.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:a.data}}function ue(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(op)}function op(e){if(typeof e=="string")throw new Error(`Plain string statements are not supported. Use an object with a "desc" key instead. Example: { "desc": "${e}" }`);if(typeof e!="object"||e===null)throw new Error(`Invalid statement: expected object, got ${typeof e}`);let t=e;if("IF"in t)return ap(t);if("WHILE"in t)return rp(t);if("STEP"in t)return sp(t);if("VERIFY"in t){let i=t.VERIFY,n={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(n.code=t.js),{uid:(0,ce.v4)(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:n}}}}if("URL"in t){let i=t.URL,n=t.new_tab===!0?!0:void 0,o=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,a={url:typeof i=="string"?i:String(i)};return n&&(a.new_tab=!0),o!==void 0&&(a.timeout_seconds=o),{uid:(0,ce.v4)(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:a}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:(0,ce.v4)(),type:"ACTION",description:`Wait until: ${i}`,action_entity:{action_description:`Wait until: ${i}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:typeof i=="string"?i:String(i),timeout_seconds:n}}}}}if("WAIT"in t){let i=t.WAIT,n=typeof t.seconds=="number"?t.seconds:3;return{uid:(0,ce.v4)(),type:"ACTION",description:typeof i=="string"?i:`Wait ${n}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${n}s`,action_data:{action_name:"wait",kwargs:{seconds:n}}}}}if("CODE"in t){let i=t.CODE;if(i==null)throw new Error('CODE statement has no code. Use "CODE: |" followed by indented code on the next line.');return{uid:(0,ce.v4)(),type:"ACTION",description:"Code block",action_entity:{action_description:"Code block",action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&("intent"in t||"desc"in t)&&!("VERIFY"in t)){let i=t.js,n=typeof t.intent=="string"?t.intent:typeof t.desc=="string"?t.desc:"";return{uid:(0,ce.v4)(),type:"ACTION",description:n,action_entity:{action_description:n,action_data:{action_name:"js_action",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...n}=t;return Qc({...n,action:"function",functionName:i})}if("action"in t)return Qc(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:(0,ce.v4)(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function ld(e){if(typeof e!="string")throw new Error(`Condition must be a string, got ${typeof e}`);return e.startsWith("js:")?{type:"JS_CODE",expression:e.slice(3)}:{type:"AI_MODE",expression:e}}function ap(e){let t=ld(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:(0,ce.v4)(),type:"IF_ELSE",condition:t,then:ue(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=ue(e.ELSE)),n}function rp(e){let t=ld(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:(0,ce.v4)(),type:"WHILE_LOOP",condition:t,body:ue(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function sp(e){let t=typeof e.STEP=="string"?e.STEP:"";if(!Array.isArray(e.statements))throw new Error("STEP requires a statements array");let i={uid:(0,ce.v4)(),type:"STEP",description:t,statements:ue(e.statements)};return typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),i}function Qc(e){let t=typeof e.action=="string"?e.action:String(e.action),i=typeof e.intent=="string"?e.intent:typeof e.desc=="string"?e.desc:"",n=typeof e.locator=="string"?e.locator:void 0,o=typeof e.xpath=="string"?e.xpath:void 0,a=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[d,c]of Object.entries(e))lp.has(d)||(r[d]=c);let s={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};n&&(s.locator=n),o&&(s.xpath=o);let l={uid:(0,ce.v4)(),type:"ACTION",description:i,action_entity:s};return a&&(l.use_pure_vision=!0),l}function Ba(e,t){let i;try{i=(0,$.parseDocument)(e)}catch{return}let n=i.contents;if(!n||!(0,$.isMap)(n))return;if(i.commentBefore)t.comment=i.commentBefore;else{let l=n.items?.[0];l?.key&&l.key.commentBefore&&(t.comment=l.key.commentBefore)}let o=n,a=o.get("statements",!0);(0,$.isSeq)(a)&&t.statements&&_t(a,t.statements);let r=o.get("teardown",!0);(0,$.isSeq)(r)&&t.teardown&&_t(r,t.teardown)}function _t(e,t){e.commentBefore&&t.length>0&&(t[0].comment=e.commentBefore);for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=e.items[i];n.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=n.commentBefore);let o=t[i];if(o.type==="STEP"&&(0,$.isMap)(n)){let a=n.get("statements",!0);(0,$.isSeq)(a)&&_t(a,o.statements)}else if(o.type==="IF_ELSE"&&(0,$.isMap)(n)){let a=n.get("THEN",!0);(0,$.isSeq)(a)&&_t(a,o.then);let r=n.get("ELSE",!0);(0,$.isSeq)(r)&&o.else&&_t(r,o.else)}else if(o.type==="WHILE_LOOP"&&(0,$.isMap)(n)){let a=n.get("DO",!0);(0,$.isSeq)(a)&&_t(a,o.body)}}}var $,ce,St,Qm,Zc,lp,yo=w(()=>{"use strict";Ra();$=require("yaml"),ce=require("uuid");St={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};Qm=new Set(["intent","action","locator","xpath","frame_path","args"]);Zc=1024*1024;lp=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});function Ua(e){let t=0,i=0;for(let n of e)if(n.type==="DRAFT")i++;else if(n.type==="ACTION"){let o=n.action_entity?.action_data?.action_name??"";Ga.has(o)||t++}return{action:t,draft:i}}function dp(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function cd(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function dd(e,t){let i=t?.coverageThreshold??cp,n=[],o=[],a;try{a=Ze(e)}catch(p){return{valid:!1,errors:[`Invalid YAML: ${p.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}a.goal||n.push('Missing required field: "goal"'),a.statements?.length||n.push('Missing required field: "statements"');let r=[...Di(a.statements??[]),...a.teardown?Di(a.teardown):[]],{action:s,draft:l}=Ua(r),d="Hint: in YAML double-quoted strings, backslashes are escape characters \u2014 use \\\\/ instead of \\/ for regex, or use single quotes.";for(let p of r){if(p.type==="ACTION"){let g=p,b=g.action_entity?.action_data?.action_name??"";if(b==="js_code"||b==="js_action"||b==="verify"||b==="ai_assert"){let k=g.action_entity?.action_data?.kwargs?.code;if(typeof k=="string"){let y=dp(k);if(y){let m=g.description||b;n.push(`Invalid JS in "${m}": ${y}. ${d}`)}}}}if(p.type==="IF_ELSE"){let g=p;if(g.condition.type==="JS_CODE"){let b=cd(g.condition.expression);b&&n.push(`Invalid JS in IF condition "${g.condition.expression}": ${b}. ${d}`)}}if(p.type==="WHILE_LOOP"){let g=p;if(g.condition.type==="JS_CODE"){let b=cd(g.condition.expression);b&&n.push(`Invalid JS in WHILE condition "${g.condition.expression}": ${b}. ${d}`)}}}let c=s+l,h=c>0?Math.round(s/c*100):0;return c>0&&h/100<i&&o.push(`Low action coverage: ${s}/${c} statements (${h}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:n.length===0,errors:n,warnings:o,stats:{total:c,action:s,draft:l,coverage:h}}}var cp,Ga,ud=w(()=>{"use strict";fo();yo();cp=.5,Ga=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"])});function hd(){return{version:"1.0",entries:{}}}function md(e,t){return{action_entity:e,updated_at:new Date().toISOString(),updated_by:{source:"runner",test_run_id:t}}}function pd(e,t){let i=t?.entries[e.uid],n=i?.action_entity??e.action_entity;return e.locator&&n?{...n,locator:e.locator}:i?i.action_entity:e.action_entity?e.action_entity:null}function gd(e,t,i,n){return e.entries[t]={action_entity:i,updated_at:new Date().toISOString(),updated_by:n},e}function fd(e,t){let i=e??{version:"1.0",entries:{}};for(let[n,o]of t)i.entries[n]=o;return i}function wd(e){return e?Object.keys(e.entries).length===0:!0}function bd(e){return e?Object.keys(e.entries).length:0}function yd(e,t){if(!t||Object.keys(t.entries).length===0)return e;let i=Ka(e.statements??[],t),n=e.teardown?Ka(e.teardown,t):void 0;return{...e,statements:i,teardown:n}}function Ka(e,t){return e.map(i=>up(i,t))}function up(e,t){if(e.type==="ACTION"){let o=e,a=t.entries[o.uid];return a?{...o,action_entity:a.action_entity}:o}let i=Ce(e);if(i.length===0)return e;let n={};for(let o of i)n[o.key]=Ka(o.statements,t);return{...e,...n}}var xd=w(()=>{"use strict";fo()});function ja(e,t){let i=[];t.version!=="1.0"&&i.push(`Unsupported patch version: ${t.version}`),(!Array.isArray(t.operations)||t.operations.length===0)&&i.push("Patch must have at least one operation");for(let n=0;n<t.operations.length;n++){let o=t.operations[n],a=`operations[${n}]`;switch(o.reason||i.push(`${a}: missing reason`),o.op){case"remove":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`);break}case"modify":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}case"insert":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),o.position!=="before"&&o.position!=="after"&&i.push(`${a}: position must be 'before' or 'after'`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}default:i.push(`${a}: unknown operation type "${o.op}"`)}}return{valid:i.length===0,errors:i}}function za(e,t){let i=ja(e,t);if(!i.valid)throw new Error(`Invalid patch: ${i.errors.join("; ")}`);let n=[...e],o=t.operations.map((s,l)=>({...s,originalOrder:l})),a={remove:0,modify:1,insert:2},r=[...o].sort((s,l)=>s.index!==l.index?l.index-s.index:a[s.op]-a[l.op]);for(let s of r)switch(s.op){case"remove":n.splice(s.index,1);break;case"modify":n[s.index]=s.statement;break;case"insert":s.position==="before"?n.splice(s.index,0,s.statement):n.splice(s.index+1,0,s.statement);break}return n}function vd(e,t){let i=(0,xo.parse)(e);if(!i||typeof i!="object")throw new Error("Invalid YAML: expected an object at root level");let n=i.statements;if(!Array.isArray(n))throw new Error('YAML must have a "statements" array');let o=za(n,t);i.statements=o;let a=(0,xo.stringify)(i,{lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"});return Ze(a),{modifiedYaml:a,modifiedStatements:o}}var xo,kd=w(()=>{"use strict";yo();xo=require("yaml")});var Va,Xa,_d,Sd=w(()=>{"use strict";Va=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(Va||{}),Xa=(e=>(e.JS_CODE="JS_CODE",e.AI_MODE="AI_MODE",e))(Xa||{}),_d=18e4});function Ed(e){return e?e.startsWith(pe)?"android":e.startsWith(ge)?"ios":"web":"web"}function Td(e){return e?e.startsWith(pe)||e.startsWith(ge):!1}function Ad(e){return!!e&&e.startsWith(pe)}function Md(e){return!!e&&e.startsWith(ge)}function Id(e){return e.startsWith(pe)?e.slice(pe.length):e.startsWith(ge)?e.slice(ge.length):e}function Cd(e){return`${pe}${e}`}function Pd(e){return`${ge}${e}`}function vo(e){return e?e.startsWith("http://")||e.startsWith("https://"):!1}function $d(e){return e?!vo(e):!1}function Ya(e){return e?vo(e)?["web"]:["android","ios"]:["web","android","ios"]}function Dd(e,t){if(!t)return!0;let i=Ya(t);return e==="desktop"||e==="mobile"?i.includes("web"):i.includes(e)}var pe,ge,ko=w(()=>{"use strict";pe="android:",ge="ios:"});function Ld(e){return e.startsWith(ge)?e:`${ge}${e}`}function Od(e){let t=e.iosVersion?` (iOS ${e.iosVersion})`:"";return e.deviceType==="simulator"?`${e.name}${t} - Simulator`:`${e.name}${t}`}function Nd(e){return!!(/^[0-9a-fA-F]{40}$/.test(e)||/^[0-9a-fA-F]{8}-[0-9a-fA-F]{16}$/.test(e))}var Rd=w(()=>{"use strict";ko()});var Ja,_o,qa,Za,Qa,er,tr,ir,nr,or,Qe,ar,Ni,rr,sr,Et,Fd,Ri,Hd,Wd,So,Bd,Gd,Ud,Kd,jd=w(()=>{"use strict";Ja="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",_o=112,qa=1920,Za=1080,Qa=1920,er=1080-_o,tr=1280,ir=720,nr=500,or=500,Qe="Desktop Chrome",ar=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(ar||{}),Ni={"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"}},rr=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(rr||{}),sr={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"]},Et=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),sr[e].map(n=>Ni[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Fd=()=>Object.keys(Ni),Ri=e=>Ni[e],Hd={desktop:{label:"Desktop",type:"desktop",devices:Et("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:Et("mobile")}},Wd={desktop:{label:"Desktop",type:"desktop",devices:Et("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:Et("mobile",!0)}},So=(e,t=!1)=>{let i={userAgent:Ja,viewport:{width:Qa,height:er},isMobile:!1,hasTouch:!1};if(!e||e===Qe)return i;let n=Ri(e);if(!n)return i;let{width:o,height:a}=n.viewport,r=Math.max(nr/o,1),s=Math.max(or/a,1),l=Math.max(r,s),d={width:Math.round(o*l),height:Math.round(a*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},Bd=e=>{let t={width:qa,height:Za};if(!e||e===Qe)return t;let i=So(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+_o}:t},Gd=e=>{let t={width:tr,height:ir};if(!e||e===Qe)return t;let i=So(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Ud=e=>!e||e===Qe?void 0:Ri(e)?.channel,Kd=e=>!e||e===Qe?"chromium":Ri(e)?.defaultBrowserType??"chromium"});var lr,cr,zd=w(()=>{"use strict";lr=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(lr||{}),cr=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(cr||{})});function Vd(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let r=a.startsWith("$")?a.slice(1):a,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o}var Xd=w(()=>{"use strict"});var Yd,Jd=w(()=>{"use strict";Yd=class{version;goal;url;constructor(e,t){this.version=e,this.goal=t.goal,this.url=t.url}generatePrelude(){let e=`// version ${this.version}
|
|
4534
4532
|
`,t=this.goal,i=this.url;e+=`// Navigate to the specified URL
|
|
4535
4533
|
const targetUrl = process.env.PLAYWRIGHT_STARTING_URL || '${i}';
|
|
4536
4534
|
if (targetUrl !== null) {
|
|
@@ -4544,4 +4542,4 @@ await page.waitForTimeout(2000);
|
|
|
4544
4542
|
`,e+=` // Goal:
|
|
4545
4543
|
`;let n=t.trim().split(`
|
|
4546
4544
|
`);for(let o of n)e+=` // ${o}
|
|
4547
|
-
`;return e}generatePostlude(){return""}}});function od(e){if(!e)return"desktop";for(let t of qm)if(t.test(e))return"mobile";return"desktop"}var qm,ad=w(()=>{"use strict";qm=[/iphone/i,/ipad/i,/android/i,/pixel/i,/galaxy/i,/mobile/i,/nexus/i,/blackberry/i,/kindle/i]});function rd(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let r=a.startsWith("$")?a.slice(1):a,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o}var sd=w(()=>{"use strict"});function ld(e){return e?e.startsWith(he)?"android":e.startsWith(me)?"ios":"web":"web"}function cd(e){return e?e.startsWith(he)||e.startsWith(me):!1}function dd(e){return!!e&&e.startsWith(he)}function ud(e){return!!e&&e.startsWith(me)}function hd(e){return e.startsWith(he)?e.slice(he.length):e.startsWith(me)?e.slice(me.length):e}function md(e){return`${he}${e}`}function pd(e){return`${me}${e}`}function uo(e){return e?e.startsWith("http://")||e.startsWith("https://"):!1}function gd(e){return e?!uo(e):!1}function Ra(e){return e?uo(e)?["web"]:["android","ios"]:["web","android","ios"]}function fd(e,t){if(!t)return!0;let i=Ra(t);return e==="desktop"||e==="mobile"?i.includes("web"):i.includes(e)}var he,me,ho=w(()=>{"use strict";he="android:",me="ios:"});function wd(e){return e.startsWith(me)?e:`${me}${e}`}function bd(e){let t=e.iosVersion?` (iOS ${e.iosVersion})`:"";return e.deviceType==="simulator"?`${e.name}${t} - Simulator`:`${e.name}${t}`}function yd(e){return!!(/^[0-9a-fA-F]{40}$/.test(e)||/^[0-9a-fA-F]{8}-[0-9a-fA-F]{16}$/.test(e))}var xd=w(()=>{"use strict";ho()});var Fa,mo,Ha,Wa,Ba,Ga,Ua,Ka,ja,za,qe,Va,Di,Xa,Ya,vt,vd,Li,kd,_d,po,Sd,Ed,Td,Ad,Md=w(()=>{"use strict";Fa="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",mo=112,Ha=1920,Wa=1080,Ba=1920,Ga=1080-mo,Ua=1280,Ka=720,ja=500,za=500,qe="Desktop Chrome",Va=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Va||{}),Di={"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"}},Xa=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Xa||{}),Ya={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"]},vt=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Ya[e].map(n=>Di[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},vd=()=>Object.keys(Di),Li=e=>Di[e],kd={desktop:{label:"Desktop",type:"desktop",devices:vt("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:vt("mobile")}},_d={desktop:{label:"Desktop",type:"desktop",devices:vt("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:vt("mobile",!0)}},po=(e,t=!1)=>{let i={userAgent:Fa,viewport:{width:Ba,height:Ga},isMobile:!1,hasTouch:!1};if(!e||e===qe)return i;let n=Li(e);if(!n)return i;let{width:o,height:a}=n.viewport,r=Math.max(ja/o,1),s=Math.max(za/a,1),l=Math.max(r,s),d={width:Math.round(o*l),height:Math.round(a*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},Sd=e=>{let t={width:Ha,height:Wa};if(!e||e===qe)return t;let i=po(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+mo}:t},Ed=e=>{let t={width:Ua,height:Ka};if(!e||e===qe)return t;let i=po(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Td=e=>!e||e===qe?void 0:Li(e)?.channel,Ad=e=>!e||e===qe?"chromium":Li(e)?.defaultBrowserType??"chromium"});var Ja,qa,Id=w(()=>{"use strict";Ja=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Ja||{}),qa=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(qa||{})});function Cd(){return{version:"1.0",entries:{}}}function Pd(e,t){return{action_entity:e,updated_at:new Date().toISOString(),updated_by:{source:"runner",test_run_id:t}}}function $d(e,t){let i=t?.entries[e.uid],n=i?.action_entity??e.action_entity;return e.locator&&n?{...n,locator:e.locator}:i?i.action_entity:e.action_entity?e.action_entity:null}function Dd(e,t,i,n){return e.entries[t]={action_entity:i,updated_at:new Date().toISOString(),updated_by:n},e}function Ld(e,t){let i=e??{version:"1.0",entries:{}};for(let[n,o]of t)i.entries[n]=o;return i}function Od(e){return e?Object.keys(e.entries).length===0:!0}function Nd(e){return e?Object.keys(e.entries).length:0}function Rd(e,t){if(!t||Object.keys(t.entries).length===0)return e;let i=Za(e.statements??[],t),n=e.teardown?Za(e.teardown,t):void 0;return{...e,statements:i,teardown:n}}function Za(e,t){return e.map(i=>Zm(i,t))}function Zm(e,t){if(e.type==="ACTION"){let o=e,a=t.entries[o.uid];return a?{...o,action_entity:a.action_entity}:o}let i=Ae(e);if(i.length===0)return e;let n={};for(let o of i)n[o.key]=Za(o.statements,t);return{...e,...n}}var Fd=w(()=>{"use strict";co()});var Qa,er,Hd,Wd=w(()=>{"use strict";Qa=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(Qa||{}),er=(e=>(e.JS_CODE="JS_CODE",e.AI_MODE="AI_MODE",e))(er||{}),Hd=18e4});var Bd,Ud=w(()=>{"use strict";Bd=class Gd{data={};sensitive=new Set;get(t){return this.data[t]}set(t,i,n=!1){this.data[t]=i,n?this.sensitive.add(t):this.sensitive.has(t)&&this.sensitive.delete(t)}getAll(){return{...this.data}}isSensitive(t){return this.sensitive.has(t)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(t){return this.sensitive.delete(t),delete this.data[t]}clear(){this.data={},this.sensitive.clear()}has(t){return t in this.data}get size(){return Object.keys(this.data).length}merge(t){for(let[i,n]of Object.entries(t.getAll()))this.set(i,n,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new Gd;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[o,a]of Object.entries(t.data))i.set(o,a,n.has(o))}return i}}});function Kd(e){return{copilot:e?.models?.copilot||tr,webagent:e?.models?.webagent||ir}}function jd(e){if(e){if(e.WEB_AGENT_MODEL)return e.WEB_AGENT_MODEL;if(e.ANTHROPIC_API_KEY)return nr;if(e.GOOGLE_API_KEY)return or;if(e.OPENAI_API_KEY)return ar}}var tr,ir,nr,or,ar,zd=w(()=>{"use strict";tr="claude-sonnet-4-6",ir="gemini-2.5-pro",nr="claude-haiku-4-5",or="gemini-3.1-flash-lite-preview",ar="gpt-5.4-mini"});var rr,Vd=w(()=>{"use strict";rr=(e=>(e.INITIALIZING="initializing",e.READY="ready",e.PROCESSING="processing",e.STOPPING="stopping",e.WAITING_USER="waiting_user",e.COMPLETED="completed",e.FAILED="failed",e))(rr||{})});function Xd(e){let t=e.trim();if(!t||t.startsWith("List of devices"))return null;let i=t.split(/\s+/);if(i.length<2)return null;let n=i[0],o=i[1],a="usb";return n.startsWith("emulator-")?a="emulator":n.includes(":")&&(a="wifi"),{id:n,state:o,connectionType:a}}function Yd(e){return e.startsWith(he)?e:`${he}${e}`}function Jd(e){return e.model?`${e.model} (${e.id})`:e.connectionType==="emulator"?`Android Emulator (${e.id})`:e.id}var qd=w(()=>{"use strict";ho()});var sr={};Be(sr,{ADDRESS_BAR_HEIGHT:()=>mo,ANDROID_DEVICE_PREFIX:()=>he,ActionEntitySchema:()=>_a,ActionSchema:()=>Ea,AgentStatus:()=>rr,BaseStatementSchema:()=>Ye,BrowserType:()=>Va,ConditionSchema:()=>ao,ConditionType:()=>er,ConditionTypeSchema:()=>va,DEFAULT_ANTHROPIC_MODEL:()=>nr,DEFAULT_COPILOT_MODEL:()=>tr,DEFAULT_DEVICE_NAME:()=>qe,DEFAULT_GOOGLE_MODEL:()=>or,DEFAULT_OPENAI_MODEL:()=>ar,DEFAULT_WEBAGENT_MODEL:()=>ir,DEFAULT_WHILE_LOOP_TIMEOUT_MS:()=>Hd,DEVICE_CATEGORIES:()=>Ya,DeviceType:()=>Xa,DraftSchema:()=>Sa,IOS_DEVICE_PREFIX:()=>me,LoginType:()=>Ja,MIN_WINDOW_HEIGHT:()=>za,MIN_WINDOW_WIDTH:()=>ja,NON_INTENT_ACTIONS:()=>Oa,NodeJSCodeCommon:()=>id,PLAYWRIGHT_DEVICES:()=>Di,RECORD_VIDEO_HEIGHT:()=>Ka,RECORD_VIDEO_WIDTH:()=>Ua,StatementSchema:()=>ee,StatementType:()=>Qa,StatementTypeSchema:()=>ka,TestFlowSchema:()=>ro,TestGroupEntrySchema:()=>Ta,TestGroupSchema:()=>Ci,TwoFactorAuthType:()=>qa,UI_DEVICE_CATEGORIES:()=>kd,UI_DEVICE_CATEGORIES_ELECTRON:()=>_d,USER_AGENT:()=>Fa,VIEWPORT_HEIGHT:()=>Ga,VIEWPORT_WIDTH:()=>Ba,VariableStore:()=>Bd,WINDOW_HEIGHT:()=>Wa,WINDOW_WIDTH:()=>Ha,actionEntityToYaml:()=>Fc,actionStepsMapToTestFlowSections:()=>Zc,allowPureVisionAction:()=>Jc,applyPatchToYaml:()=>Da,applyPatchToYamlString:()=>Kc,collectActionSteps:()=>Oe,countIntentStatements:()=>Na,createAndroidDeviceName:()=>md,createEmptyStore:()=>Cd,createIOSDeviceName:()=>pd,createRunnerStoreEntry:()=>Pd,extractActionStepsFromTestFlow:()=>qc,extractAndAttachComments:()=>Pa,extractDeviceIdentifier:()=>hd,extractYamlMetadata:()=>Gc,findNextAfterContainer:()=>Le,findNextSibling:()=>De,findNextStatement:()=>$e,findPathBetweenStatements:()=>Vc,findStatementPathById:()=>ne,getAllDeviceNames:()=>vd,getAllReferenceIds:()=>Xc,getAllStatementsInOrder:()=>$i,getAndroidDeviceDisplayName:()=>Jd,getBrowserWindowSize:()=>Sd,getCompatiblePlatforms:()=>Ra,getDeviceBrowserType:()=>Ad,getDeviceByName:()=>Li,getDeviceChannel:()=>Td,getDeviceOptions:()=>po,getDevicesByCategory:()=>vt,getIOSDeviceDisplayName:()=>bd,getLoginConfigPlatform:()=>od,getRecordVideoSize:()=>Ed,getStatementContainers:()=>Ae,getStoreSize:()=>Nd,getTestPlatformFromDeviceName:()=>ld,hasReferenceIds:()=>La,isAndroidDevice:()=>dd,isAppPackage:()=>gd,isDynamicAction:()=>Yc,isExecutableStatement:()=>zc,isIOSDevice:()=>ud,isNativeDevice:()=>cd,isPhysicalDeviceUDID:()=>yd,isPlatformCompatibleWithUrl:()=>fd,isStoreEmpty:()=>Od,isWebUrl:()=>uo,mergeActionEntitiesIntoTestFlow:()=>Rd,mergeStoreUpdates:()=>Ld,parseAdbDeviceLine:()=>Xd,parseYamlArrayItems:()=>Bc,replaceVariables:()=>rd,resolveActionEntity:()=>$d,resolveModelFromEnv:()=>jd,resolveModels:()=>Kd,suiteToYaml:()=>Ca,testFlowToYaml:()=>Oc,testFlowToYamlObject:()=>Ia,toAndroidDeviceName:()=>Yd,toIOSDeviceName:()=>wd,updateStoreEntry:()=>Dd,validatePatch:()=>$a,validateTestYaml:()=>ed,yamlObjectsToString:()=>Nc,yamlToActionEntity:()=>Hc,yamlToTestFlow:()=>Je});var lr=w(()=>{"use strict";jc();td();so();Aa();nd();ad();sd();xd();Md();Id();Fd();co();Wd();Ud();zd();Vd();qd();ho()});var tp={};Be(tp,{createTestContext:()=>ou,expect:()=>kt.expect,resolveAuthState:()=>iu,test:()=>ep});module.exports=du(tp);var Ne=W(require("path"),1),tu=W(require("fs"),1),kt=require("@playwright/test");var Q=W(require("fs"),1),Qe=W(require("path"),1),fo=require("crypto"),wo=require("os");function hr(e){return[`--disable-extensions-except=${e}`,`--load-extension=${e}`,"--no-first-run","--disable-default-apps"]}function mr(e){if(!Q.existsSync(e))return console.warn(`[fixture] extensionStorageState file not found: ${e}`),null;let t;try{t=JSON.parse(Q.readFileSync(e,"utf-8"))}catch(a){throw new Error(`[fixture] Failed to parse extensionStorageState at ${e}: ${a}`)}let i=t;if(!Array.isArray(i.cookies))return null;let n=(Date.now()+365*24*60*60*1e3)/1e3,o=i.cookies.filter(a=>a&&typeof a=="object"&&typeof a.name=="string"&&typeof a.domain=="string");return o.length<i.cookies.length&&console.warn(`[fixture] Skipped ${i.cookies.length-o.length} malformed cookies (missing name or domain)`),o.map(a=>({...a,expires:n}))}function pr(e){if(e){let i=Qe.resolve(process.cwd(),e),n=Qe.join((0,wo.tmpdir)(),`ext-profile-${(0,fo.randomUUID)()}`);if(Q.existsSync(i)){try{Q.cpSync(i,n,{recursive:!0})}catch(a){try{Q.rmSync(n,{recursive:!0,force:!0})}catch(r){console.warn("[fixture] Failed to clean up partial profile copy:",n,r)}throw new Error(`[fixture] Failed to copy extension profile from ${i}: ${a}`)}let o=Qe.join(n,"SingletonLock");Q.existsSync(o)&&Q.rmSync(o,{force:!0})}else Q.mkdirSync(n,{recursive:!0});return n}let t=Qe.join((0,wo.tmpdir)(),`ext-profile-${(0,fo.randomUUID)()}`);return Q.mkdirSync(t,{recursive:!0}),t}async function iu(e){let i=await import(Ne.resolve(process.cwd(),e.auth)),n=i.login||i.default;if(typeof n!="function")throw new Error(`auth module "${e.auth}" must export a login(args) function that returns a storageState file path`);let o=await n(e.args||{});if(typeof o!="string")throw new Error(`auth module "${e.auth}" login() must return a storageState file path (got ${typeof o})`);return o}function Zd(e){return!(!e||e==="off")}function nu(e,t){return!e||e==="off"?!1:e==="on"?!0:e==="retain-on-failure"?t.status!==t.expectedStatus:e==="on-first-retry"?t.retry>0:typeof e=="object"&&e!==null&&"mode"in e?nu(e.mode,t):!0}async function Qd(e,t,i){let n=nu(t,i);for(let o of e)try{if(n){let a=await o.path();await i.attach("video",{path:a,contentType:"video/webm"})}else await o.delete()}catch(a){console.warn("[fixture] Failed to process video:",a)}}var go;async function eu(){return go||(go=await Promise.resolve().then(()=>(Pc(),Cc)),go)}var Qm=new Set(["get","set","getAll","has","__variableStore"]);function ou(e){let t={__variableStore:e,get(i){return e.get(i)},set(i,n,o=!1){e.set(i,n,o)},getAll(){return e.getAll()}};return new Proxy(t,{get(i,n,o){if(n in i)return Reflect.get(i,n,o);if(typeof n=="string")return i.get(n)},set(i,n,o){return typeof n!="string"||Qm.has(n)?Reflect.set(i,n,o):(i.set(n,o),!0)},has(i,n){return n in i?!0:typeof n=="string"?e.has?.(n)??!1:!1}})}var ep=kt.test.extend({account:[void 0,{option:!0}],autoDismissModal:[!1,{option:!0}],extensionDir:[void 0,{option:!0}],userDataDir:[void 0,{option:!0}],extensionStorageState:[void 0,{option:!0}],context:async({browser:e,account:t,extensionDir:i,userDataDir:n,extensionStorageState:o},a,r)=>{if(i||n){if(t||r.project.use.auth)throw new Error('Cannot use both "extensionDir"/"userDataDir" and "auth" \u2014 persistent context tests manage their own context. Use extensionStorageState for authentication instead.');let l=r.project.use?.browserName;l&&l!=="chromium"&&console.warn(`[fixture] Persistent context requires Chromium but project is configured for "${l}". Forcing Chromium.`);let d=process.env.PLAYWRIGHT_HEADLESS==="true";i&&d&&console.warn("[fixture] PLAYWRIGHT_HEADLESS=true with extensionDir \u2014 Chrome extensions will not function in headless mode.");let c=pr(n),h=i?hr(Ne.resolve(process.cwd(),i)):[],p={...r.project.use},{storageState:g,account:b,extensionDir:k,userDataDir:y,extensionStorageState:m,autoDismissModal:v,video:A,...x}=p,E=Zd(A)?{dir:r.outputDir}:void 0,T;try{if(T=await kt.chromium.launchPersistentContext(c,{...x,headless:d,args:h,viewport:x.viewport??{width:1280,height:720},...E?{recordVideo:E}:{}}),o){let C=Ne.resolve(process.cwd(),o),I=mr(C);I&&await T.addCookies(I)}await a(T)}finally{let C=T?.pages().map(I=>I.video()).filter(I=>I!==null)??[];if(await T?.close().catch(I=>{console.warn("[fixture] Failed to close persistent context:",I)}),await Qd(C,A,r),!n)try{tu.rmSync(c,{recursive:!0,force:!0})}catch(I){console.warn("[fixture] Failed to clean up temp profile dir:",c,I)}}}else{let l={...r.project.use},d=r.project.use,c=d.auth?{auth:d.auth,args:d.args}:t;if(c){if(!c.auth)throw new Error("Auth is declared but missing the script path. Provide auth in playwright.config.ts: use: { auth: './auth.login.ts' }");l.storageState=await iu(c)}let h=l.video;Zd(h)&&!l.recordVideo&&(l.recordVideo={dir:r.outputDir});let p=await e.newContext(l);try{await a(p)}finally{let g=p.pages().map(b=>b.video()).filter(b=>b!==null);await p.close(),await Qd(g,h,r)}}},page:async({context:e},t)=>{let i=await e.newPage();await t(i)},testContext:async({},e,t)=>{let{VariableStore:i}=await eu(),n=new i,o=t.project.use.variables;if(o)for(let[r,s]of Object.entries(o))typeof s=="string"?n.set(r,s,!1):s&&typeof s=="object"&&"value"in s&&n.set(r,s.value,s.sensitive===!0);let a=ou(n);global.testContext=a,global.$=a,global.ctx=a,await e(a),delete global.testContext,delete global.$,delete global.ctx},$:async({testContext:e},t)=>{await t(e)},ctx:async({testContext:e},t)=>{await t(e)},agent:async({page:e,testContext:t,autoDismissModal:i},n,o)=>{let{WebAgent:a,createAgentContext:r,configureSdk:s,parseSdkLogLevelFromEnv:l}=await eu(),d=l();s({env:{GOOGLE_API_KEY:process.env.GOOGLE_API_KEY??"",ANTHROPIC_API_KEY:process.env.ANTHROPIC_API_KEY??"",OPENAI_API_KEY:process.env.OPENAI_API_KEY??""},...d!==void 0&&{logLevel:d}});let{resolveModelFromEnv:c}=await Promise.resolve().then(()=>(lr(),sr)),h=c(process.env);if(!h)throw new Error("No AI model configured. Set WEB_AGENT_MODEL, ANTHROPIC_API_KEY, or GOOGLE_API_KEY.");let p=t.__variableStore,g=r({model:h,variableStore:p,autoDismissModal:i}),b=Ne.join(o.outputDir,"artifacts");g.stepTracking={results:{},artifactsDir:b};let k=new a(g),y=e.context();k.agentServices.setupPageTracking(y),global.agent=k,await n(k),delete global.agent;try{let m=o.outputDir;await k.writeExecutionResults(m);let v=Ne.join(m,"test-results.json");await(await import("fs/promises")).stat(v).catch(()=>null)&&await o.attach("shiplight-results",{path:v,contentType:"application/json"})}catch(m){console.error("[Shiplight] Failed to attach step results:",m)}try{let m=k.getNewActionEntities();if(m.size>0&&o.status==="passed"){let{createEmptyStore:v,createRunnerStoreEntry:A}=await Promise.resolve().then(()=>(lr(),sr)),x=await import("fs/promises"),E=v();for(let[C,I]of m)E.entries[C]=A(I,0);let T=Ne.join(o.outputDir,"new-action-entities.json");await x.writeFile(T,JSON.stringify(E,null,2)),await o.attach("shiplight-new-action-entities",{path:T,contentType:"application/json"}),console.log(`[Shiplight] ${m.size} healed action entit${m.size===1?"y":"ies"} saved`)}}catch(m){console.warn("[Shiplight] Failed to persist new action entities:",m)}}});0&&(module.exports={createTestContext,expect,resolveAuthState,test});
|
|
4545
|
+
`;return e}generatePostlude(){return""}}});function qd(e){if(!e)return"desktop";for(let t of hp)if(t.test(e))return"mobile";return"desktop"}var hp,Zd=w(()=>{"use strict";hp=[/iphone/i,/ipad/i,/android/i,/pixel/i,/galaxy/i,/mobile/i,/nexus/i,/blackberry/i,/kindle/i]});var Qd,tu=w(()=>{"use strict";Qd=class eu{data={};sensitive=new Set;get(t){return this.data[t]}set(t,i,n=!1){this.data[t]=i,n?this.sensitive.add(t):this.sensitive.has(t)&&this.sensitive.delete(t)}getAll(){return{...this.data}}isSensitive(t){return this.sensitive.has(t)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(t){return this.sensitive.delete(t),delete this.data[t]}clear(){this.data={},this.sensitive.clear()}has(t){return t in this.data}get size(){return Object.keys(this.data).length}merge(t){for(let[i,n]of Object.entries(t.getAll()))this.set(i,n,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new eu;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[o,a]of Object.entries(t.data))i.set(o,a,n.has(o))}return i}}});function iu(e){return{copilot:e?.models?.copilot||dr,webagent:e?.models?.webagent||hr,computer_use:e?.models?.computer_use||ur}}function nu(e){if(e){if(e.WEB_AGENT_MODEL)return e.WEB_AGENT_MODEL;if(e.ANTHROPIC_API_KEY)return mr;if(e.GOOGLE_API_KEY)return pr;if(e.OPENAI_API_KEY)return gr}}var dr,ur,hr,mr,pr,gr,ou=w(()=>{"use strict";dr="claude-sonnet-4-6",ur="computer-use-preview",hr="gemini-2.5-pro",mr="claude-haiku-4-5",pr="gemini-3.1-flash-lite-preview",gr="gpt-5.4-mini"});var fr,au=w(()=>{"use strict";fr=(e=>(e.INITIALIZING="initializing",e.READY="ready",e.PROCESSING="processing",e.STOPPING="stopping",e.WAITING_USER="waiting_user",e.COMPLETED="completed",e.FAILED="failed",e))(fr||{})});function ru(e){let t=e.trim();if(!t||t.startsWith("List of devices"))return null;let i=t.split(/\s+/);if(i.length<2)return null;let n=i[0],o=i[1],a="usb";return n.startsWith("emulator-")?a="emulator":n.includes(":")&&(a="wifi"),{id:n,state:o,connectionType:a}}function su(e){return e.startsWith(pe)?e:`${pe}${e}`}function lu(e){return e.model?`${e.model} (${e.id})`:e.connectionType==="emulator"?`Android Emulator (${e.id})`:e.id}var cu=w(()=>{"use strict";ko()});var wr={};Ue(wr,{ADDRESS_BAR_HEIGHT:()=>_o,ANDROID_DEVICE_PREFIX:()=>pe,ActionEntitySchema:()=>Da,ActionSchema:()=>Oa,AgentStatus:()=>fr,BaseStatementSchema:()=>qe,BrowserType:()=>ar,ConditionSchema:()=>wo,ConditionType:()=>Xa,ConditionTypeSchema:()=>Pa,DEFAULT_ANTHROPIC_MODEL:()=>mr,DEFAULT_COMPUTER_USE_MODEL:()=>ur,DEFAULT_COPILOT_MODEL:()=>dr,DEFAULT_DEVICE_NAME:()=>Qe,DEFAULT_GOOGLE_MODEL:()=>pr,DEFAULT_OPENAI_MODEL:()=>gr,DEFAULT_WEBAGENT_MODEL:()=>hr,DEFAULT_WHILE_LOOP_TIMEOUT_MS:()=>_d,DEVICE_CATEGORIES:()=>sr,DeviceType:()=>rr,DraftSchema:()=>La,IOS_DEVICE_PREFIX:()=>ge,LoginType:()=>lr,MIN_WINDOW_HEIGHT:()=>or,MIN_WINDOW_WIDTH:()=>nr,NON_INTENT_ACTIONS:()=>Ga,NodeJSCodeCommon:()=>Yd,PLAYWRIGHT_DEVICES:()=>Ni,RECORD_VIDEO_HEIGHT:()=>ir,RECORD_VIDEO_WIDTH:()=>tr,StatementSchema:()=>ne,StatementType:()=>Va,StatementTypeSchema:()=>$a,TestFlowSchema:()=>bo,TestGroupEntrySchema:()=>Na,TestGroupSchema:()=>Li,TwoFactorAuthType:()=>cr,UI_DEVICE_CATEGORIES:()=>Hd,UI_DEVICE_CATEGORIES_ELECTRON:()=>Wd,USER_AGENT:()=>Ja,VIEWPORT_HEIGHT:()=>er,VIEWPORT_WIDTH:()=>Qa,VariableStore:()=>Qd,WINDOW_HEIGHT:()=>Za,WINDOW_WIDTH:()=>qa,actionEntityToYaml:()=>nd,actionStepsMapToTestFlowSections:()=>Jc,allowPureVisionAction:()=>Xc,applyPatchToYaml:()=>za,applyPatchToYamlString:()=>vd,collectActionSteps:()=>Re,countIntentStatements:()=>Ua,createAndroidDeviceName:()=>Cd,createEmptyStore:()=>hd,createIOSDeviceName:()=>Pd,createRunnerStoreEntry:()=>md,extractActionStepsFromTestFlow:()=>Yc,extractAndAttachComments:()=>Ba,extractDeviceIdentifier:()=>Id,extractYamlMetadata:()=>sd,findNextAfterContainer:()=>Ne,findNextSibling:()=>Oe,findNextStatement:()=>Le,findPathBetweenStatements:()=>jc,findStatementPathById:()=>re,getAllDeviceNames:()=>Fd,getAllReferenceIds:()=>zc,getAllStatementsInOrder:()=>Di,getAndroidDeviceDisplayName:()=>lu,getBrowserWindowSize:()=>Bd,getCompatiblePlatforms:()=>Ya,getDeviceBrowserType:()=>Kd,getDeviceByName:()=>Ri,getDeviceChannel:()=>Ud,getDeviceOptions:()=>So,getDevicesByCategory:()=>Et,getIOSDeviceDisplayName:()=>Od,getLoginConfigPlatform:()=>qd,getRecordVideoSize:()=>Gd,getStatementContainers:()=>Ce,getStoreSize:()=>bd,getTestPlatformFromDeviceName:()=>Ed,hasReferenceIds:()=>Ca,isAndroidDevice:()=>Ad,isAppPackage:()=>$d,isDynamicAction:()=>Vc,isExecutableStatement:()=>Kc,isIOSDevice:()=>Md,isNativeDevice:()=>Td,isPhysicalDeviceUDID:()=>Nd,isPlatformCompatibleWithUrl:()=>Dd,isStoreEmpty:()=>wd,isWebUrl:()=>vo,mergeActionEntitiesIntoTestFlow:()=>yd,mergeStoreUpdates:()=>fd,parseAdbDeviceLine:()=>ru,parseYamlArrayItems:()=>rd,replaceVariables:()=>Vd,resolveActionEntity:()=>pd,resolveModelFromEnv:()=>nu,resolveModels:()=>iu,suiteToYaml:()=>Wa,testFlowToYaml:()=>ed,testFlowToYamlObject:()=>Ha,toAndroidDeviceName:()=>su,toIOSDeviceName:()=>Ld,updateStoreEntry:()=>gd,validatePatch:()=>ja,validateTestYaml:()=>dd,yamlObjectsToString:()=>td,yamlToActionEntity:()=>od,yamlToTestFlow:()=>Ze});var br=w(()=>{"use strict";ud();xd();fo();kd();yo();Ra();Sd();Rd();jd();zd();Xd();Jd();Zd();tu();ou();au();cu();ko()});var gp={};Ue(gp,{createTestContext:()=>fu,expect:()=>Tt.expect,resolveAuthState:()=>pu,test:()=>pp});module.exports=ku(gp);var Fe=W(require("path"),1),mu=W(require("fs"),1),Tt=require("@playwright/test");var ee=W(require("fs"),1),tt=W(require("path"),1),To=require("crypto"),Ao=require("os");function kr(e){return[`--disable-extensions-except=${e}`,`--load-extension=${e}`,"--no-first-run","--disable-default-apps"]}function _r(e){if(!ee.existsSync(e))return console.warn(`[fixture] extensionStorageState file not found: ${e}`),null;let t;try{t=JSON.parse(ee.readFileSync(e,"utf-8"))}catch(a){throw new Error(`[fixture] Failed to parse extensionStorageState at ${e}: ${a}`)}let i=t;if(!Array.isArray(i.cookies))return null;let n=(Date.now()+365*24*60*60*1e3)/1e3,o=i.cookies.filter(a=>a&&typeof a=="object"&&typeof a.name=="string"&&typeof a.domain=="string");return o.length<i.cookies.length&&console.warn(`[fixture] Skipped ${i.cookies.length-o.length} malformed cookies (missing name or domain)`),o.map(a=>({...a,expires:n}))}function Sr(e){if(e){let i=tt.resolve(process.cwd(),e),n=tt.join((0,Ao.tmpdir)(),`ext-profile-${(0,To.randomUUID)()}`);if(ee.existsSync(i)){try{ee.cpSync(i,n,{recursive:!0})}catch(a){try{ee.rmSync(n,{recursive:!0,force:!0})}catch(r){console.warn("[fixture] Failed to clean up partial profile copy:",n,r)}throw new Error(`[fixture] Failed to copy extension profile from ${i}: ${a}`)}let o=tt.join(n,"SingletonLock");ee.existsSync(o)&&ee.rmSync(o,{force:!0})}else ee.mkdirSync(n,{recursive:!0});return n}let t=tt.join((0,Ao.tmpdir)(),`ext-profile-${(0,To.randomUUID)()}`);return ee.mkdirSync(t,{recursive:!0}),t}async function pu(e){let i=await import(Fe.resolve(process.cwd(),e.auth)),n=i.login||i.default;if(typeof n!="function")throw new Error(`auth module "${e.auth}" must export a login(args) function that returns a storageState file path`);let o=await n(e.args||{});if(typeof o!="string")throw new Error(`auth module "${e.auth}" login() must return a storageState file path (got ${typeof o})`);return o}function du(e){return!(!e||e==="off")}function gu(e,t){return!e||e==="off"?!1:e==="on"?!0:e==="retain-on-failure"?t.status!==t.expectedStatus:e==="on-first-retry"?t.retry>0:typeof e=="object"&&e!==null&&"mode"in e?gu(e.mode,t):!0}async function uu(e,t,i){let n=gu(t,i);for(let o of e)try{if(n){let a=await o.path();await i.attach("video",{path:a,contentType:"video/webm"})}else await o.delete()}catch(a){console.warn("[fixture] Failed to process video:",a)}}var Eo;async function hu(){return Eo||(Eo=await Promise.resolve().then(()=>(Uc(),Gc)),Eo)}var mp=new Set(["get","set","getAll","has","__variableStore"]);function fu(e){let t={__variableStore:e,get(i){return e.get(i)},set(i,n,o=!1){e.set(i,n,o)},getAll(){return e.getAll()}};return new Proxy(t,{get(i,n,o){if(n in i)return Reflect.get(i,n,o);if(typeof n=="string")return i.get(n)},set(i,n,o){return typeof n!="string"||mp.has(n)?Reflect.set(i,n,o):(i.set(n,o),!0)},has(i,n){return n in i?!0:typeof n=="string"?e.has?.(n)??!1:!1}})}var pp=Tt.test.extend({account:[void 0,{option:!0}],autoDismissModal:[!1,{option:!0}],extensionDir:[void 0,{option:!0}],userDataDir:[void 0,{option:!0}],extensionStorageState:[void 0,{option:!0}],context:async({browser:e,account:t,extensionDir:i,userDataDir:n,extensionStorageState:o},a,r)=>{if(i||n){if(t||r.project.use.auth)throw new Error('Cannot use both "extensionDir"/"userDataDir" and "auth" \u2014 persistent context tests manage their own context. Use extensionStorageState for authentication instead.');let l=r.project.use?.browserName;l&&l!=="chromium"&&console.warn(`[fixture] Persistent context requires Chromium but project is configured for "${l}". Forcing Chromium.`);let d=process.env.PLAYWRIGHT_HEADLESS==="true";i&&d&&console.warn("[fixture] PLAYWRIGHT_HEADLESS=true with extensionDir \u2014 Chrome extensions will not function in headless mode.");let c=Sr(n),h=i?kr(Fe.resolve(process.cwd(),i)):[],p={...r.project.use},{storageState:g,account:b,extensionDir:k,userDataDir:y,extensionStorageState:m,autoDismissModal:x,video:A,...v}=p,E=du(A)?{dir:r.outputDir}:void 0,T;try{if(T=await Tt.chromium.launchPersistentContext(c,{...v,headless:d,args:h,viewport:v.viewport??{width:1280,height:720},...E?{recordVideo:E}:{}}),o){let C=Fe.resolve(process.cwd(),o),I=_r(C);I&&await T.addCookies(I)}await a(T)}finally{let C=T?.pages().map(I=>I.video()).filter(I=>I!==null)??[];if(await T?.close().catch(I=>{console.warn("[fixture] Failed to close persistent context:",I)}),await uu(C,A,r),!n)try{mu.rmSync(c,{recursive:!0,force:!0})}catch(I){console.warn("[fixture] Failed to clean up temp profile dir:",c,I)}}}else{let l={...r.project.use},d=r.project.use,c=d.auth?{auth:d.auth,args:d.args}:t;if(c){if(!c.auth)throw new Error("Auth is declared but missing the script path. Provide auth in playwright.config.ts: use: { auth: './auth.login.ts' }");l.storageState=await pu(c)}let h=l.video;du(h)&&!l.recordVideo&&(l.recordVideo={dir:r.outputDir});let p=await e.newContext(l);try{await a(p)}finally{let g=p.pages().map(b=>b.video()).filter(b=>b!==null);await p.close(),await uu(g,h,r)}}},page:async({context:e},t)=>{let i=await e.newPage();await t(i)},testContext:async({},e,t)=>{let{VariableStore:i}=await hu(),n=new i,o=t.project.use.variables;if(o)for(let[r,s]of Object.entries(o))typeof s=="string"?n.set(r,s,!1):s&&typeof s=="object"&&"value"in s&&n.set(r,s.value,s.sensitive===!0);let a=fu(n);global.testContext=a,global.$=a,global.ctx=a,await e(a),delete global.testContext,delete global.$,delete global.ctx},$:async({testContext:e},t)=>{await t(e)},ctx:async({testContext:e},t)=>{await t(e)},agent:async({page:e,testContext:t,autoDismissModal:i},n,o)=>{let{WebAgent:a,createAgentContext:r,configureSdk:s,parseSdkLogLevelFromEnv:l}=await hu(),d=l();s({env:{GOOGLE_API_KEY:process.env.GOOGLE_API_KEY??"",ANTHROPIC_API_KEY:process.env.ANTHROPIC_API_KEY??"",OPENAI_API_KEY:process.env.OPENAI_API_KEY??""},...d!==void 0&&{logLevel:d}});let{resolveModelFromEnv:c}=await Promise.resolve().then(()=>(br(),wr)),h=c(process.env);if(!h)throw new Error("No AI model configured. Set WEB_AGENT_MODEL, ANTHROPIC_API_KEY, or GOOGLE_API_KEY.");let p=t.__variableStore,g=r({model:h,variableStore:p,autoDismissModal:i}),b=Fe.join(o.outputDir,"artifacts");g.stepTracking={results:{},artifactsDir:b};let k=new a(g),y=e.context();k.agentServices.setupPageTracking(y),global.agent=k,await n(k),delete global.agent;try{let m=o.outputDir;await k.writeExecutionResults(m);let x=Fe.join(m,"test-results.json");await(await import("fs/promises")).stat(x).catch(()=>null)&&await o.attach("shiplight-results",{path:x,contentType:"application/json"})}catch(m){console.error("[Shiplight] Failed to attach step results:",m)}try{let m=k.getNewActionEntities();if(m.size>0&&o.status==="passed"){let{createEmptyStore:x,createRunnerStoreEntry:A}=await Promise.resolve().then(()=>(br(),wr)),v=await import("fs/promises"),E=x();for(let[C,I]of m)E.entries[C]=A(I,0);let T=Fe.join(o.outputDir,"new-action-entities.json");await v.writeFile(T,JSON.stringify(E,null,2)),await o.attach("shiplight-new-action-entities",{path:T,contentType:"application/json"}),console.log(`[Shiplight] ${m.size} healed action entit${m.size===1?"y":"ies"} saved`)}}catch(m){console.warn("[Shiplight] Failed to persist new action entities:",m)}}});0&&(module.exports={createTestContext,expect,resolveAuthState,test});
|