shiplightai 0.1.47 → 0.1.49
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 +2 -2
- package/dist/cjs/fixture.cjs +74 -74
- package/dist/cjs/index.cjs +28 -28
- package/dist/cjs/reporter.cjs +65 -29
- package/dist/cli.js +167 -52
- package/dist/debugger-pw.js +3 -3
- package/dist/fixture.js +74 -74
- package/dist/index.js +30 -30
- package/dist/reporter.js +65 -29
- package/dist/static/assets/{index-ClD-Ul7O.js → index-ByMAsm4i.js} +2 -2
- package/dist/static/assets/{index-DP4PtPwQ.js → index-D0G607gU.js} +36 -34
- package/dist/static/index.html +1 -1
- package/package.json +6 -5
package/dist/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { createRequire as __createRequire } from "module";
|
|
2
2
|
const require = __createRequire(import.meta.url);
|
|
3
|
-
var bl=Object.defineProperty;var x=(e,t)=>()=>(e&&(t=e(e=0)),t);var dt=(e,t)=>{for(var i in t)bl(e,i,{get:t[i],enumerable:!0})};var
|
|
3
|
+
var bl=Object.defineProperty;var x=(e,t)=>()=>(e&&(t=e(e=0)),t);var dt=(e,t)=>{for(var i in t)bl(e,i,{get:t[i],enumerable:!0})};var Dn={};dt(Dn,{lookupActionStores:()=>Ec,updateActionStores:()=>Tc});function xo(){let e=process.env.SHIPLIGHT_API_TOKEN;return e?{apiUrl:process.env.SHIPLIGHT_API_URL||"https://api.shiplight.ai",apiToken:e}:null}async function Ec(e){let t=xo();if(!t||e.length===0)return new Map;try{let i=new AbortController,n=setTimeout(()=>i.abort(),2e3),a=await fetch(`${t.apiUrl}/action-entity-cache/lookup`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${t.apiToken}`},body:JSON.stringify({test_paths:e}),signal:i.signal});if(clearTimeout(n),!a.ok)return console.warn(`[shiplight] Cache lookup failed: HTTP ${a.status}`),new Map;let o=await a.json(),r=new Map;for(let[s,l]of Object.entries(o.stores??{}))r.set(s,l);return r}catch(i){return i instanceof Error&&i.name!=="AbortError"&&console.warn("[shiplight] Cache lookup error:",i.message),new Map}}async function Tc(e){let t=xo();if(!t||e.size===0)return 0;try{let i=new AbortController,n=setTimeout(()=>i.abort(),5e3),a={};for(let[s,l]of e)a[s]=l;let o=await fetch(`${t.apiUrl}/action-entity-cache/update`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${t.apiToken}`},body:JSON.stringify({stores:a}),signal:i.signal});return clearTimeout(n),o.ok?(await o.json()).updated??0:(console.warn(`[shiplight] Cache update failed: HTTP ${o.status}`),0)}catch(i){return i instanceof Error&&i.name!=="AbortError"&&console.warn("[shiplight] Cache update error:",i.message),0}}var Nn=x(()=>{"use strict"});function So(e){Hn.updateConfig(e)}function G(){return Hn.getConfig()}var Dc,Hn,yi,te=x(()=>{"use strict";Dc=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}},Hn=new Dc,yi=Hn});var Nc,Rc,u,R=x(()=>{"use strict";te();Nc=class{getLevel(){return yi.get("logLevel")}isStderrOnly(){return yi.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){yi.set("logLevel",e)}},Rc=new Nc,u=Rc});import{appendFileSync as Eo}from"fs";var Fc,w,ie=x(()=>{"use strict";te();Fc=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=G().agentLogPath;if(e)try{Eo(e,`
|
|
4
4
|
=== Agent Execution Log ===
|
|
5
5
|
Started: ${new Date().toISOString()}
|
|
6
6
|
|
|
@@ -13,7 +13,7 @@ ${e}`)}prompt(e,t){this.section("LLM Prompt"),this.log(`System Prompt:
|
|
|
13
13
|
${e}`),this.log(`
|
|
14
14
|
User Prompt:
|
|
15
15
|
${t}`)}response(e){this.log(`LLM Response:
|
|
16
|
-
${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}},w=new Fc});var xi,Hc,Wc,Uc,Bc,To,vi,Wn,Ao,Un,Bn,ge=x(()=>{"use strict";xi=Object.defineProperty,Hc=Object.getOwnPropertyDescriptor,Wc=Object.getOwnPropertyNames,Uc=Object.prototype.hasOwnProperty,Bc=(e,t,i)=>t in e?xi(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,To=(e,t)=>()=>(e&&(t=e(e=0)),t),vi=(e,t)=>{for(var i in t)xi(e,i,{get:t[i],enumerable:!0})},Wn=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of Wc(t))!Uc.call(e,a)&&a!==i&&xi(e,a,{get:()=>t[a],enumerable:!(n=Hc(t,a))||n.enumerable});return e},Ao=(e,t,i)=>(Wn(e,t,"default"),i&&Wn(i,t,"default")),Un=e=>Wn(xi({},"__esModule",{value:!0}),e),Bn=(e,t,i)=>Bc(e,typeof t!="symbol"?t+"":t,i)});function C(e,t){return t??e?.getActionSettings()?.action_timeout_ms??jn}function Gc(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function O(e,t){let i=Ne(t);return i?new Function("page",`return ${i}`)(e):null}async function Gn(e,t=[]){let i=e;for(let n of t){let a=await i.locator(n).elementHandle();if(!a)return null;let o=await a.contentFrame();if(await a.dispose(),!o)return null;i=o}return i}function jc(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 Kc(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function zc(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 Ne(e){let t=Kc(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=zc(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}var _i,pt,jn,fe,I,F=x(()=>{"use strict";ge();_i={};vi(_i,{ACTION_TIMEOUT:()=>jn,GOTO_TIMEOUT:()=>fe,LOCATOR_TIMEOUT:()=>pt,getActionTimeoutMs:()=>C,getFrameContext:()=>Gn,getLocator:()=>O,getMinimalActionEntity:()=>jc,getPageLocatorExpression:()=>Ne,sanitizeForComment:()=>Gc});I=To(()=>{pt=5e3,jn=1e4,fe=2e4})});async function Kn(e,t,i=[],n=[]){try{let a=await Gn(e,i);if(!a)return u.warn(`Could not find frame context for xpath: ${t}`),null;let o=null;if(n.length>0){let s=n[0];if(!s)return u.warn(`Missing shadow host xpath for element: ${t}`),null;let l=a.locator(`xpath=${$o(s)}`),c=Vc(t);if(o=await(c?l.locator(`css=${c}`):l.locator(`xpath=${$o(t)}`)).elementHandle({timeout:pt}),!o)return u.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await a.locator(`xpath=${t}`).elementHandle({timeout:pt}),!o)return u.warn(`Could not find element with xpath: ${t}`),null;let r=await a.evaluate(s=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(s):null,o);return await o.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(a){return u.error(`Error in pickBestLocator: ${a}`),null}}async function zn(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}}function $o(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function Vc(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),n=[];for(let a of i){let o=a.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!o)return null;let r=o[1].toLowerCase(),s=o[2]?`:nth-of-type(${o[2]})`:"";n.push(`${r}${s}`)}return n.join(" > ")}var Ue=x(()=>{"use strict";R();F();I()});async function gt(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:a}=await import("sharp"),o=a(n),{width:r=0,height:s=0}=await o.metadata();return w.log(`Screenshot actual: ${r}x${s}, viewport: ${t}x${i}`),(r!==t||s!==i?await o.resize(t,i).png().toBuffer():n).toString("base64")}async function ke(e,t,i){let n=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),a=n.asElement();if(!a)throw await n.dispose(),new Error(`No element found at (${t}, ${i})`);let o=await a.boundingBox();if(!o)throw await n.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(o.x+o.width/2),relative_y:i-(o.y+o.height/2),element:a}}async function ki(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(a=>{let o=[],r=a;for(;r&&r.nodeType===Node.ELEMENT_NODE;){let s=1,l=r.previousElementSibling;for(;l;)l.tagName===r.tagName&&s++,l=l.previousElementSibling;o.unshift(`${r.tagName.toLowerCase()}[${s}]`),r=r.parentElement}return o.length?`/${o.join("/")}`:null}).catch(()=>null),n=await zn(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function Si(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 Xe=x(()=>{"use strict";ie();Ue()});import{createGoogleGenerativeAI as Xc}from"@ai-sdk/google";import{createVertex as Yc}from"@ai-sdk/google-vertex";function Ei(){let e=(G().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function Io(e){let t=G().env||{};if(Ei()){let n=t.GOOGLE_CLOUD_PROJECT;if(!n)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let a=e==="gemini-3-flash-preview"?"global":t.GOOGLE_CLOUD_LOCATION;if(!a)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return u.debug(`Using Vertex AI provider: model=${e}, location=${a}`),Yc({project:n,location:a})(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}`),Xc({apiKey:i})(e)}function Co(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:Mo.MEDIA_RESOLUTION_HIGH},a;switch(t){case"gemini-3-flash-preview":a={...n};break;default:a={...i},e===1&&(a.mediaResolution=Mo.MEDIA_RESOLUTION_HIGH)}return Ei()?{vertex:a}:{google:a}}var Mo,Ye=x(()=>{"use strict";R();te();Mo={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});import{GoogleGenAI as Jc,Environment as qc}from"@google/genai";function we(e,t){return Math.round(e/1e3*t)}async function Qc(e,t,i,n,a){let o=null,r=null;try{switch(t){case"click_at":{let s=we(i.x,n),l=we(i.y,a),c=await ke(e,s,l);o={action_name:"click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"right_click_at":{let s=we(i.x,n),l=we(i.y,a),c=await ke(e,s,l);o={action_name:"right_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"double_click_at":{let s=we(i.x,n),l=we(i.y,a),c=await ke(e,s,l);o={action_name:"double_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"drag_and_drop":{let s=we(i.x,n),l=we(i.y,a),c=we(i.destination_x,n),d=we(i.destination_y,a),h=await ke(e,s,l);o={action_name:"drag_drop",kwargs:{relative_x:h.relative_x,relative_y:h.relative_y,delta_x:c-s,delta_y:d-l}},r=h.element;break}default:w.log(`Unsupported Gemini function: ${t}`)}}catch(s){w.error(`Error mapping Gemini action "${t}"`,s)}return{action_data:o,locatorInfo:await ki(e,r)}}async function Oo(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:a,viewportHeight:o,modelId:r}=e,s=r||ed,l=G(),c;if(Ei()){let y=l.env?.GOOGLE_CLOUD_PROJECT;if(!y)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let S=l.env?.GOOGLE_CLOUD_LOCATION??"global";c={vertexai:!0,project:y,location:S}}else{let y=l.env?.GOOGLE_API_KEY;if(!y)return{status:"error",error:"GOOGLE_API_KEY not found in SDK env config."};c={apiKey:y}}let d=new Jc(c);w.log(`Sending request to Gemini CUA (model=${s})...`);let h=await d.models.generateContent({model:s,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:qc.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:Zc}],temperature:.1}});w.log("Received response from Gemini CUA");let p=h.candidates?.[0];if(!p)return{status:"error",error:"No candidates in Gemini response"};let g=p.content?.parts?.find(y=>y.functionCall);if(!g)return{status:"error",reasoning:p.content?.parts?.filter(y=>y.text).map(y=>y.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:f,args:v}=g.functionCall;w.log(`Generated function call: ${f} with args ${JSON.stringify(v)}`),u.debug(`Generated function call: ${f} with args ${JSON.stringify(v)}`);let{action_data:b,locatorInfo:m}=await Qc(i,f,v,a,o);return b?{status:"success",actionEntity:Si(t,b,m),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${f}`}}var Po,Zc,ed,Ti=x(()=>{"use strict";Xe();ie();Ye();R();te();Po={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"]},Zc=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:Po},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:Po}];ed="gemini-3-flash-preview"});function Lo(e){return e!=null&&typeof e=="object"}function Je(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function Do(e){return typeof e=="string"?e:void 0}function td(e){let t,i;return Array.isArray(e)?(t=Je(e[0]),i=Je(e[1])):Lo(e)&&(t=Je(e.x),i=Je(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function No(e){if(!Lo(e))return{};let t=Array.isArray(e.path)?e.path.map(td).filter(i=>i!==null):void 0;return{type:Do(e.type),x:Je(e.x),y:Je(e.y),button:Do(e.button),path:t}}var Ai=x(()=>{"use strict"});import id from"openai";async function nd(e,t){let i=No(t),n=null,a=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let o=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",r=await ke(e,i.x,i.y);n={action_name:o,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},a=r.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let o=await ke(e,i.x,i.y);n={action_name:"double_click_by_coordinates",kwargs:{relative_x:o.relative_x,relative_y:o.relative_y}},a=o.element;break}case"drag":{if(!i.path||i.path.length<2)break;let o=i.path[0],r=i.path[i.path.length-1],s=await ke(e,o.x,o.y);n={action_name:"drag_drop",kwargs:{relative_x:s.relative_x,relative_y:s.relative_y,delta_x:r.x-o.x,delta_y:r.y-o.y}},a=s.element;break}}return{action_data:n,locatorInfo:await ki(e,a)}}async function Fo(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:a,modelId:o}=e,r=o||ad,s=await gt(i,n,a),l=G().env?.OPENAI_API_KEY;if(!l)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let c=new id({apiKey:l}),d=c.responses.create.bind(c.responses);w.log(`Sending request to OpenAI CUA (model=${r})...`);let h=[{role:"user",content:[{type:"input_text",text:t},{type:"input_image",detail:"original",image_url:`data:image/png;base64,${s}`}]}];async function p(m,y){let S={model:r,tools:[od],input:m,temperature:.1};return y&&(S.previous_response_id=y),d(S)}let g=await p(h,void 0),f;for(let m=0;m<Ro;m++){w.log(`Received response from OpenAI CUA (turn ${m+1})`);let y=g.output.find(A=>A.type==="computer_call");if(!y)return{status:"error",reasoning:g.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let S=y.actions??[];if(S.length>1&&w.log(`[openai CUA] dropping ${S.length-1} batched action(s); only the first is executed`),f=S[0],!f)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(f.type!=="screenshot")break;s=await gt(i,n,a);let E=[{type:"computer_call_output",call_id:y.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${s}`}}];g=await p(E,g.id)}if(!f)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(f.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${Ro} turns`};w.log(`Generated action: ${JSON.stringify(f)}`);let{action_data:v,locatorInfo:b}=await nd(i,f);return v?{status:"success",actionEntity:Si(t,v,b),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(f)}`}}var ad,od,Ro,$i=x(()=>{"use strict";Ai();Xe();ie();te();ad="gpt-5.4",od={type:"computer"},Ro=4});import{createOpenAI as rd}from"@ai-sdk/openai";function Ho(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}`:""}`),rd({apiKey:i,baseURL:n})(e)}function Wo(e){return{}}var ft=x(()=>{"use strict";R();te()});import{createAnthropic as sd}from"@ai-sdk/anthropic";import{createVertexAnthropic as ld}from"@ai-sdk/google-vertex/anthropic";function cd(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function Vn(e){return G().env?.[e]??process.env[e]}function dd(){return cd(Vn("ANTHROPIC_MODELS_USE_VERTEXAI"))}function Uo(e){if(dd()){let i=Vn("GOOGLE_CLOUD_PROJECT"),n=Vn("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}`),ld({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}`),sd({apiKey:t})(e)}function Xn(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var wt=x(()=>{"use strict";R();te()});function Go(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(ud.test(e))return"openai"}function Mi(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(hd.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function Se(e){let{provider:t,modelId:i}=Mi(e),n=t??Go(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 a=Bo[n];if(!a)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(Bo).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return a(i)}function Ee(e,t){let{provider:i,modelId:n}=Mi(e),a=i??Go(n);return a==="anthropic"||a==="vertex"?Xn(n):a==="openai"||a==="azure"?Wo(n):a==="bedrock"?n.startsWith("anthropic.")?Xn(n):{}:Co(t,n)}var ud,hd,Bo,Te=x(()=>{"use strict";ft();wt();Ye();ud=/^(gpt-|o\d|chatgpt-)/;hd=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);Bo={anthropic:Uo,google:Io,openai:Ho}});function pd(e){return e.startsWith("gemini-")?"google":"openai"}async function qe(e,t,i={}){let{page:n}=t,a=n.viewportSize();if(!a)return{status:"error",error:"Viewport size not available"};let{width:o,height:r}=a;w.log(`Viewport: ${o}x${r}`);let s=await gt(n,o,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:c}=Mi(l),d=pd(c),h=md[d];w.log(`Using CUA provider: ${d} (model: ${c})`);let p={statement:e,page:n,screenshotB64:s,viewportWidth:o,viewportHeight:r,modelId:c};try{return await h(p)}catch(g){return w.error(`CUA provider "${d}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var md,Ze=x(()=>{"use strict";Ti();$i();Xe();ie();Te();md={google:Oo,openai:Fo}});import{zodToJsonSchema as gd}from"zod-to-json-schema";function Ii(e){let t=gd(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 bt(t),t}function bt(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))bt(i)}e.type==="array"&&e.items&&bt(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(bt);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&bt(i)}}var yt=x(()=>{"use strict"});var Yn,Ci=x(()=>{"use strict";yt();Yn=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:Ii(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:Ii(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:Ii(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});function fd(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,a=[],o=0,r;for(;(r=n.exec(e))!==null;){let l=e.slice(o,r.index);l&&a.push({type:"text",text:l});let c=r[2];i.has(c)?a.push({type:"image",image:new URL(i.get(c))}):a.push({type:"text",text:r[0]}),o=r.index+r[0].length}let s=e.slice(o);return s&&a.push({type:"text",text:s}),a.length===0&&a.push({type:"text",text:e}),a}function wd(e){let t=[];for(let i of e){let n=i.content||"",a=i.images||[],o=fd(n,a);t.length>0&&o.length>0&&t.push({type:"text",text:`
|
|
16
|
+
${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}},w=new Fc});var xi,Hc,Wc,Uc,Bc,To,vi,Wn,Ao,Un,Bn,ge=x(()=>{"use strict";xi=Object.defineProperty,Hc=Object.getOwnPropertyDescriptor,Wc=Object.getOwnPropertyNames,Uc=Object.prototype.hasOwnProperty,Bc=(e,t,i)=>t in e?xi(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,To=(e,t)=>()=>(e&&(t=e(e=0)),t),vi=(e,t)=>{for(var i in t)xi(e,i,{get:t[i],enumerable:!0})},Wn=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of Wc(t))!Uc.call(e,a)&&a!==i&&xi(e,a,{get:()=>t[a],enumerable:!(n=Hc(t,a))||n.enumerable});return e},Ao=(e,t,i)=>(Wn(e,t,"default"),i&&Wn(i,t,"default")),Un=e=>Wn(xi({},"__esModule",{value:!0}),e),Bn=(e,t,i)=>Bc(e,typeof t!="symbol"?t+"":t,i)});function C(e,t){return t??e?.getActionSettings()?.action_timeout_ms??jn}function Gc(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function O(e,t){let i=Ne(t);return i?new Function("page",`return ${i}`)(e):null}async function Gn(e,t=[]){let i=e;for(let n of t){let a=await i.locator(n).elementHandle();if(!a)return null;let o=await a.contentFrame();if(await a.dispose(),!o)return null;i=o}return i}function jc(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 Kc(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function zc(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 Ne(e){let t=Kc(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=zc(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}var _i,pt,jn,fe,I,F=x(()=>{"use strict";ge();_i={};vi(_i,{ACTION_TIMEOUT:()=>jn,GOTO_TIMEOUT:()=>fe,LOCATOR_TIMEOUT:()=>pt,getActionTimeoutMs:()=>C,getFrameContext:()=>Gn,getLocator:()=>O,getMinimalActionEntity:()=>jc,getPageLocatorExpression:()=>Ne,sanitizeForComment:()=>Gc});I=To(()=>{pt=5e3,jn=1e4,fe=2e4})});async function Kn(e,t,i=[],n=[]){try{let a=await Gn(e,i);if(!a)return u.warn(`Could not find frame context for xpath: ${t}`),null;let o=null;if(n.length>0){let s=n[0];if(!s)return u.warn(`Missing shadow host xpath for element: ${t}`),null;let l=a.locator(`xpath=${$o(s)}`),c=Vc(t);if(o=await(c?l.locator(`css=${c}`):l.locator(`xpath=${$o(t)}`)).elementHandle({timeout:pt}),!o)return u.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await a.locator(`xpath=${t}`).elementHandle({timeout:pt}),!o)return u.warn(`Could not find element with xpath: ${t}`),null;let r=await a.evaluate(s=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(s):null,o);return await o.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(a){return u.error(`Error in pickBestLocator: ${a}`),null}}async function zn(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}}function $o(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function Vc(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),n=[];for(let a of i){let o=a.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!o)return null;let r=o[1].toLowerCase(),s=o[2]?`:nth-of-type(${o[2]})`:"";n.push(`${r}${s}`)}return n.join(" > ")}var Ue=x(()=>{"use strict";R();F();I()});async function gt(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:a}=await import("sharp"),o=a(n),{width:r=0,height:s=0}=await o.metadata();return w.log(`Screenshot actual: ${r}x${s}, viewport: ${t}x${i}`),(r!==t||s!==i?await o.resize(t,i).png().toBuffer():n).toString("base64")}async function ke(e,t,i){let n=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),a=n.asElement();if(!a)throw await n.dispose(),new Error(`No element found at (${t}, ${i})`);let o=await a.boundingBox();if(!o)throw await n.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(o.x+o.width/2),relative_y:i-(o.y+o.height/2),element:a}}async function ki(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(a=>{let o=[],r=a;for(;r&&r.nodeType===Node.ELEMENT_NODE;){let s=1,l=r.previousElementSibling;for(;l;)l.tagName===r.tagName&&s++,l=l.previousElementSibling;o.unshift(`${r.tagName.toLowerCase()}[${s}]`),r=r.parentElement}return o.length?`/${o.join("/")}`:null}).catch(()=>null),n=await zn(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function Si(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 Xe=x(()=>{"use strict";ie();Ue()});import{createGoogleGenerativeAI as Xc}from"@ai-sdk/google";import{createVertex as Yc}from"@ai-sdk/google-vertex";function Ei(){let e=(G().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function Io(e){let t=G().env||{};if(Ei()){let n=t.GOOGLE_CLOUD_PROJECT;if(!n)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let a=e==="gemini-3-flash-preview"?"global":t.GOOGLE_CLOUD_LOCATION;if(!a)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return u.debug(`Using Vertex AI provider: model=${e}, location=${a}`),Yc({project:n,location:a})(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}`),Xc({apiKey:i})(e)}function Co(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:Mo.MEDIA_RESOLUTION_HIGH},a;switch(t){case"gemini-3-flash-preview":a={...n};break;default:a={...i},e===1&&(a.mediaResolution=Mo.MEDIA_RESOLUTION_HIGH)}return Ei()?{vertex:a}:{google:a}}var Mo,Ye=x(()=>{"use strict";R();te();Mo={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});import{GoogleGenAI as Jc,Environment as qc}from"@google/genai";function we(e,t){return Math.round(e/1e3*t)}async function Qc(e,t,i,n,a){let o=null,r=null;try{switch(t){case"click_at":{let s=we(i.x,n),l=we(i.y,a),c=await ke(e,s,l);o={action_name:"click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"right_click_at":{let s=we(i.x,n),l=we(i.y,a),c=await ke(e,s,l);o={action_name:"right_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"double_click_at":{let s=we(i.x,n),l=we(i.y,a),c=await ke(e,s,l);o={action_name:"double_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"drag_and_drop":{let s=we(i.x,n),l=we(i.y,a),c=we(i.destination_x,n),d=we(i.destination_y,a),h=await ke(e,s,l);o={action_name:"drag_drop",kwargs:{relative_x:h.relative_x,relative_y:h.relative_y,delta_x:c-s,delta_y:d-l}},r=h.element;break}default:w.log(`Unsupported Gemini function: ${t}`)}}catch(s){w.error(`Error mapping Gemini action "${t}"`,s)}return{action_data:o,locatorInfo:await ki(e,r)}}async function Oo(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:a,viewportHeight:o,modelId:r}=e,s=r||ed,l=G(),c;if(Ei()){let y=l.env?.GOOGLE_CLOUD_PROJECT;if(!y)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let S=l.env?.GOOGLE_CLOUD_LOCATION??"global";c={vertexai:!0,project:y,location:S}}else{let y=l.env?.GOOGLE_API_KEY;if(!y)return{status:"error",error:"GOOGLE_API_KEY not found in SDK env config."};c={apiKey:y}}let d=new Jc(c);w.log(`Sending request to Gemini CUA (model=${s})...`);let h=await d.models.generateContent({model:s,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:qc.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:Zc}],temperature:.1}});w.log("Received response from Gemini CUA");let p=h.candidates?.[0];if(!p)return{status:"error",error:"No candidates in Gemini response"};let g=p.content?.parts?.find(y=>y.functionCall);if(!g)return{status:"error",reasoning:p.content?.parts?.filter(y=>y.text).map(y=>y.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:f,args:v}=g.functionCall;w.log(`Generated function call: ${f} with args ${JSON.stringify(v)}`),u.debug(`Generated function call: ${f} with args ${JSON.stringify(v)}`);let{action_data:b,locatorInfo:m}=await Qc(i,f,v,a,o);return b?{status:"success",actionEntity:Si(t,b,m),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${f}`}}var Po,Zc,ed,Ti=x(()=>{"use strict";Xe();ie();Ye();R();te();Po={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"]},Zc=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:Po},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:Po}];ed="gemini-3-flash-preview"});function Do(e){return e!=null&&typeof e=="object"}function Je(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function Lo(e){return typeof e=="string"?e:void 0}function td(e){let t,i;return Array.isArray(e)?(t=Je(e[0]),i=Je(e[1])):Do(e)&&(t=Je(e.x),i=Je(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function No(e){if(!Do(e))return{};let t=Array.isArray(e.path)?e.path.map(td).filter(i=>i!==null):void 0;return{type:Lo(e.type),x:Je(e.x),y:Je(e.y),button:Lo(e.button),path:t}}var Ai=x(()=>{"use strict"});import id from"openai";async function nd(e,t){let i=No(t),n=null,a=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let o=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",r=await ke(e,i.x,i.y);n={action_name:o,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},a=r.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let o=await ke(e,i.x,i.y);n={action_name:"double_click_by_coordinates",kwargs:{relative_x:o.relative_x,relative_y:o.relative_y}},a=o.element;break}case"drag":{if(!i.path||i.path.length<2)break;let o=i.path[0],r=i.path[i.path.length-1],s=await ke(e,o.x,o.y);n={action_name:"drag_drop",kwargs:{relative_x:s.relative_x,relative_y:s.relative_y,delta_x:r.x-o.x,delta_y:r.y-o.y}},a=s.element;break}}return{action_data:n,locatorInfo:await ki(e,a)}}async function Fo(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:a,modelId:o}=e,r=o||ad,s=await gt(i,n,a),l=G().env?.OPENAI_API_KEY;if(!l)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let c=new id({apiKey:l}),d=c.responses.create.bind(c.responses);w.log(`Sending request to OpenAI CUA (model=${r})...`);let h=[{role:"user",content:[{type:"input_text",text:t},{type:"input_image",detail:"original",image_url:`data:image/png;base64,${s}`}]}];async function p(m,y){let S={model:r,tools:[od],input:m,temperature:.1};return y&&(S.previous_response_id=y),d(S)}let g=await p(h,void 0),f;for(let m=0;m<Ro;m++){w.log(`Received response from OpenAI CUA (turn ${m+1})`);let y=g.output.find(A=>A.type==="computer_call");if(!y)return{status:"error",reasoning:g.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let S=y.actions??[];if(S.length>1&&w.log(`[openai CUA] dropping ${S.length-1} batched action(s); only the first is executed`),f=S[0],!f)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(f.type!=="screenshot")break;s=await gt(i,n,a);let E=[{type:"computer_call_output",call_id:y.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${s}`,detail:"original"}}];g=await p(E,g.id)}if(!f)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(f.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${Ro} turns`};w.log(`Generated action: ${JSON.stringify(f)}`);let{action_data:v,locatorInfo:b}=await nd(i,f);return v?{status:"success",actionEntity:Si(t,v,b),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(f)}`}}var ad,od,Ro,$i=x(()=>{"use strict";Ai();Xe();ie();te();ad="gpt-5.4",od={type:"computer"},Ro=4});import{createOpenAI as rd}from"@ai-sdk/openai";function Ho(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}`:""}`),rd({apiKey:i,baseURL:n})(e)}function Wo(e){return{}}var ft=x(()=>{"use strict";R();te()});import{createAnthropic as sd}from"@ai-sdk/anthropic";import{createVertexAnthropic as ld}from"@ai-sdk/google-vertex/anthropic";function cd(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function Vn(e){return G().env?.[e]??process.env[e]}function dd(){return cd(Vn("ANTHROPIC_MODELS_USE_VERTEXAI"))}function Uo(e){if(dd()){let i=Vn("GOOGLE_CLOUD_PROJECT"),n=Vn("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}`),ld({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}`),sd({apiKey:t})(e)}function Xn(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var wt=x(()=>{"use strict";R();te()});function Go(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(ud.test(e))return"openai"}function Mi(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(hd.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function Se(e){let{provider:t,modelId:i}=Mi(e),n=t??Go(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 a=Bo[n];if(!a)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(Bo).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return a(i)}function Ee(e,t){let{provider:i,modelId:n}=Mi(e),a=i??Go(n);return a==="anthropic"||a==="vertex"?Xn(n):a==="openai"||a==="azure"?Wo(n):a==="bedrock"?n.startsWith("anthropic.")?Xn(n):{}:Co(t,n)}var ud,hd,Bo,Te=x(()=>{"use strict";ft();wt();Ye();ud=/^(gpt-|o\d|chatgpt-)/;hd=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);Bo={anthropic:Uo,google:Io,openai:Ho}});function pd(e){return e.startsWith("gemini-")?"google":"openai"}async function qe(e,t,i={}){let{page:n}=t,a=n.viewportSize();if(!a)return{status:"error",error:"Viewport size not available"};let{width:o,height:r}=a;w.log(`Viewport: ${o}x${r}`);let s=await gt(n,o,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:c}=Mi(l),d=pd(c),h=md[d];w.log(`Using CUA provider: ${d} (model: ${c})`);let p={statement:e,page:n,screenshotB64:s,viewportWidth:o,viewportHeight:r,modelId:c};try{return await h(p)}catch(g){return w.error(`CUA provider "${d}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var md,Ze=x(()=>{"use strict";Ti();$i();Xe();ie();Te();md={google:Oo,openai:Fo}});import{zodToJsonSchema as gd}from"zod-to-json-schema";function Ii(e){let t=gd(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 bt(t),t}function bt(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))bt(i)}e.type==="array"&&e.items&&bt(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(bt);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&bt(i)}}var yt=x(()=>{"use strict"});var Yn,Ci=x(()=>{"use strict";yt();Yn=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:Ii(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:Ii(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:Ii(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});function fd(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,a=[],o=0,r;for(;(r=n.exec(e))!==null;){let l=e.slice(o,r.index);l&&a.push({type:"text",text:l});let c=r[2];i.has(c)?a.push({type:"image",image:new URL(i.get(c))}):a.push({type:"text",text:r[0]}),o=r.index+r[0].length}let s=e.slice(o);return s&&a.push({type:"text",text:s}),a.length===0&&a.push({type:"text",text:e}),a}function wd(e){let t=[];for(let i of e){let n=i.content||"",a=i.images||[],o=fd(n,a);t.length>0&&o.length>0&&t.push({type:"text",text:`
|
|
17
17
|
|
|
18
18
|
`}),t.push(...o)}return t}function Pi(e,t=jo){if(t){let i=wd(e);if(i.length===0)return[];let n={type:"text",text:`
|
|
19
19
|
|
|
@@ -135,22 +135,22 @@ To use them, write Jinja-like template syntax: {{ placeholder_name }}
|
|
|
135
135
|
`}if(n&&n.length>0){let g=yd(n);p+=`
|
|
136
136
|
`+g}return p+=`
|
|
137
137
|
Based on the above information, please determine the right action to accomplish the task.
|
|
138
|
-
`,d.push({type:"text",text:p}),d}var Oi=x(()=>{"use strict";xt()});function
|
|
138
|
+
`,d.push({type:"text",text:p}),d}var Oi=x(()=>{"use strict";xt()});function Li(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 vt=x(()=>{"use strict"});async function xd(e){let t=e.context().pages(),i=null,n=[];for(let o=0;o<t.length;o++){let r=t[o];r===e&&(i=o);let s="(title unavailable)";try{s=await Promise.race([r.title(),new Promise((c,d)=>setTimeout(()=>d(new Error("timeout")),1e3))])}catch{}let l=`Tab ${o}: ${r.url()}`;s&&(l+=` - ${s.slice(0,50)}`),n.push(l)}let a=n.length>0?n.join(`
|
|
139
139
|
`):"";return{currentTabText:i!==null?`Current tab: ${i}
|
|
140
|
-
`:"",tabsText:a}}async function vd(e,t){let{currentTabText:i,tabsText:n}=await xd(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function
|
|
140
|
+
`:"",tabsText:a}}async function vd(e,t){let{currentTabText:i,tabsText:n}=await xd(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function Di(e,t){let{page:i,domService:n,agentServices:a}=e,o=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},r=a.getInteractiveClassNames(),s=a.getIframeFallbackDomains(),{domState:l,screenshotBase64:c,slicedScreenshotsBase64:d}=await n.getClickableElementsWithScreenshot(i,{interactiveClassNames:r,playwrightFrameFallbackDomains:s,useCleanScreenshot:o.useCleanScreenshot,useSlicedScreenshots:o.useSlicedScreenshots,resizeSlicedScreenshots:o.resizeSlicedScreenshots,useAccessibilityTree:o.useAccessibilityTree,actionIntent:o.actionIntent}),h=l.elementTree.clickableElementsToString(),p=await vd(i,h);return d&&(p.slicedScreenshotsBase64=d),{domTree:h,screenshotBase64:c,slicedScreenshotsBase64:d,domState:l,pageContext:p}}var _t=x(()=>{"use strict"});import{z as he}from"zod";var Jn,H,Ae=x(()=>{"use strict";Jn=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 a=t?.description,o={...t};delete o.description;let r=n.schema.parse(o),s={...i,actionDescription:a};return await n.execute(r,s)}catch(a){if(a instanceof he.ZodError){let o=a.issues.map(r=>`${r.path.join(".")}: ${r.message}`).join(", ");return{success:!1,error:`Invalid arguments for tool '${e}': ${o}`,actionEntity:{action_description:t?.description||`${e} (validation failed)`,action_data:{action_name:e,kwargs:t},feedback:`Validation error: ${o}`}}}throw a}}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(a=>i.has(a.name));return this.buildUnionSchemaFromTools(n,t)}buildUnionSchemaFromTools(e,t=!1){if(e.length===0)return he.object({done:he.any()});let i=e.map(r=>{let s=r.schema;if(t&&s instanceof he.ZodObject){let l=s._def.shape();s=he.object({...l,description:he.string().describe("Semantic, human-readable description of the action")})}if(s instanceof he.ZodObject){let l=s._def.shape();Object.keys(l).length===0&&(s=he.object({_empty:he.boolean().optional()}))}return he.object({[r.name]:s})});if(i.length===1)return i[0];let[n,a,...o]=i;return he.union([n,a,...o])}},H=new Jn});async function W(e,t){if(t<0)return;let{page:i,domService:n}=e;return(e.domState||await n.getClickableElements(i)).selectorMap.get(t)}function _d(e){let t=e.split("/").filter(a=>a);if(t.length===0)return"*";let i=t[t.length-1],n=i.match(/^(\w+)(?:\[(\d+)\])?$/);if(n){let[,a,o]=n;return o?`${a}:nth-of-type(${o})`:a}return i}function kd(e,t=!0){try{let i=_d(e.xpath);if(e.attributes.class&&t){let a=/^[a-zA-Z_][a-zA-Z0-9_-]*$/,o=e.attributes.class.split(/\s+/);for(let r of o)r.trim()&&a.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(a=>n.add(a));for(let[a,o]of Object.entries(e.attributes)){if(a==="class"||!a.trim()||!n.has(a))continue;let r=a.replace(/:/g,"\\:");if(o==="")i+=`[${r}]`;else if(/["'<>`\n\r\t]/.test(o)){let s=o;o.includes(`
|
|
141
141
|
`)&&(s=o.split(`
|
|
142
|
-
`)[0]),s=s.replace(/\s+/g," ").trim();let l=s.replace(/"/g,'\\"');i+=`[${r}*="${l}"]`}else i+=`[${r}="${o}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function Sd(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 kd(e,!1)}function Xo(e){let t=[],i=e;for(;i&&i.parent!==null;){let o=i.parent;t.push(o),i=o}t.reverse();let n=[],a=t.filter(o=>o.tagName==="iframe");for(let o of a){let r=Sd(o);u.debug("[frame-path] iframe attrs:",JSON.stringify(o.attributes),"\u2192",r),n.push(r)}return n}async function
|
|
142
|
+
`)[0]),s=s.replace(/\s+/g," ").trim();let l=s.replace(/"/g,'\\"');i+=`[${r}*="${l}"]`}else i+=`[${r}="${o}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function Sd(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 kd(e,!1)}function Xo(e){let t=[],i=e;for(;i&&i.parent!==null;){let o=i.parent;t.push(o),i=o}t.reverse();let n=[],a=t.filter(o=>o.tagName==="iframe");for(let o of a){let r=Sd(o);u.debug("[frame-path] iframe attrs:",JSON.stringify(o.attributes),"\u2192",r),n.push(r)}return n}async function D(e,t){let i=null,n=Xo(t);return t.xpath&&(i=await Kn(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var j=x(()=>{"use strict";Ue();R()});import{generateText as Ed,Output as Td}from"ai";import{z as Ni}from"zod";function Ad(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 $d(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 Md(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,a=$d(n);if(a)return{type:"image",file:a};let 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 Yo(e,t,i={}){let{page:n,agentServices:a}=t,o=a.getModel(),r=i.temperature??0,s=a.retrieveKnowledges(e).catch(X=>(w.log(`Failed to retrieve knowledges: ${X.message}`),[])),l=a.isSlicedScreenshotsEnabled(),c=a.isResizeSlicedScreenshotsEnabled(),d=a.isKnowledgeImagesEnabled(),h=a.isAccessibilityTreeEnabled(),p=a.isActionIntentFilteringEnabled(),g=p?Ad(e):"all";p&&g!=="all"&&w.log(`Action intent filtering: detected '${g}' intent from statement`);let{screenshotBase64:f,domState:v,pageContext:b}=await Di(t,{useSlicedScreenshots:l,resizeSlicedScreenshots:c,useAccessibilityTree:h,actionIntent:g});t.domState=v;let m=new Yn(H).getToolDefinitions().map(X=>{let Ge=X.function;return`${Ge.name}: ${Ge.description}
|
|
143
143
|
Parameters: ${JSON.stringify(Ge.parameters,null,2)}`}).join(`
|
|
144
144
|
|
|
145
|
-
`),y=zo(m),S=await s,E=Vo(b,e,t.variables,t.executionHistory,S.length>0?S:void 0,f,l,void 0,d,t.sensitiveKeys),A=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(X=>{X.role==="user"?A.push({role:"user",content:X.content}):X.role==="assistant"&&A.push({role:"assistant",content:X.content})}),A.push({role:"user",content:E});let M=Md(A),
|
|
145
|
+
`),y=zo(m),S=await s,E=Vo(b,e,t.variables,t.executionHistory,S.length>0?S:void 0,f,l,void 0,d,t.sensitiveKeys),A=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(X=>{X.role==="user"?A.push({role:"user",content:X.content}):X.role==="assistant"&&A.push({role:"assistant",content:X.content})}),A.push({role:"user",content:E});let M=Md(A),L=H.buildActionUnionSchema(),N=Ni.object({thought:Ni.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:Ni.string().describe("Detailed description of the action to be performed").optional().default(""),action:L,completes_instruction:Ni.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),P=Array.isArray(E)?E.filter(X=>X.type==="image").length:0,V=Ee(o,P),ee=await Ed({model:Se(o),system:y,messages:A,temperature:r,output:Td.object({schema:N}),providerOptions:V}),xe=ee.reasoningText;u.info(`Action Generation Reasoning: ${xe}`);let z=ee.output,Y=JSON.stringify(z,null,2);u.info(`Generate Action Raw Output: ${Y}`);let ve=[],Fe=Li(ee.usage,o);Fe&&ve.push(Fe);let Pe={systemPrompt:y,userPrompt:M,rawLlmResponse:Y,tokenUsages:ve},Oe=z.thought||"",Le=z.description||"",U=z.action||{},J=z.completes_instruction||!1;if(!U||Object.keys(U).length===0)return{status:"error",reasoning:Oe||Le||"No action generated",goalAccomplished:J,error:"Agent did not generate any action",debugInfo:Pe};let q=Object.keys(U)[0];if(q==="done")return{status:"error",reasoning:Oe||Le||"Task marked as done",goalAccomplished:J,error:"Agent indicated task is done without generating an action",debugInfo:Pe};if(q==="perform_accurate_operation")return await qe(e,t,i);if(!J){let X="Can't complete the instruction in one action";return{status:"error",reasoning:Oe||Le||X,goalAccomplished:!1,error:X,debugInfo:Pe}}let le=U[q]||{},Pa={};if(typeof le.element_index=="number"){let X=le.element_index;if(X<0)return{status:"error",reasoning:Oe||Le||"No action generated",goalAccomplished:J,error:"Agent did not generate any action",debugInfo:Pe};let Ge=v.selectorMap.get(X);Ge&&(Pa=await D(n,Ge))}let Oa=Le;return q==="verify"&&(Oa=e,le.statement=e),{status:"success",actionEntity:{...Pa,action_description:Oa||Oe||`${q}(${JSON.stringify(le)})`,action_data:{action_name:q,kwargs:le}},reasoning:Oe||Le,goalAccomplished:J,debugInfo:Pe}}var Ri=x(()=>{"use strict";Ze();Ci();Oi();vt();_t();Ae();ie();Te();j();R()});import{generateText as Id,Output as Cd}from"ai";import{z as Fi}from"zod";function Pd(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 qn(e,t,i={}){return i.usePureVision?qe(e,t,i):Yo(e,t,i)}function Ld(){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 Dd(){return`# Role
|
|
146
146
|
You are an experienced QA person for web applications.
|
|
147
147
|
You are tasked to verify the validity of a given statement based on the screenshot and element tree of a web page.
|
|
148
|
-
`}async function Jo(e,t,i={}){let{page:n,executionHistory:a}=t,o=t.agentServices.getModel();try{let r=t.agentServices.isSlicedScreenshotsEnabled(),s=t.agentServices.isResizeSlicedScreenshotsEnabled(),l=t.agentServices.isKnowledgeImagesEnabled(),c=t.agentServices.isAccessibilityTreeEnabled(),{domTree:d,screenshotBase64:h,slicedScreenshotsBase64:p,domState:g,pageContext:f}=await
|
|
148
|
+
`}async function Jo(e,t,i={}){let{page:n,executionHistory:a}=t,o=t.agentServices.getModel();try{let r=t.agentServices.isSlicedScreenshotsEnabled(),s=t.agentServices.isResizeSlicedScreenshotsEnabled(),l=t.agentServices.isKnowledgeImagesEnabled(),c=t.agentServices.isAccessibilityTreeEnabled(),{domTree:d,screenshotBase64:h,slicedScreenshotsBase64:p,domState:g,pageContext:f}=await Di(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:r,resizeSlicedScreenshots:s,useAccessibilityTree:c});t.domState=g;let v="";a&&a.length>0&&(v=`
|
|
149
149
|
# Previous actions in this session:
|
|
150
150
|
${a.map(([U,J],q)=>`${q+1}. Action: ${U}
|
|
151
151
|
Result: ${J}`).join(`
|
|
152
152
|
`)}
|
|
153
|
-
`);let{dateString:b,timeString:m}=
|
|
153
|
+
`);let{dateString:b,timeString:m}=Ld(),y=`
|
|
154
154
|
# User statement
|
|
155
155
|
"${e}"
|
|
156
156
|
|
|
@@ -179,11 +179,11 @@ ${v}
|
|
|
179
179
|
|
|
180
180
|
Today is ${b}. Current local time is ${m}.
|
|
181
181
|
Based on the above information, please determine if the statement is true.
|
|
182
|
-
`,A=await t.agentServices.retrieveKnowledges(e),M=[{type:"text",text:y}],
|
|
182
|
+
`,A=await t.agentServices.retrieveKnowledges(e),M=[{type:"text",text:y}],L=0;if(r&&p&&p.length>0)for(let U of p)M.push({type:"image",image:U}),L++;else M.push({type:"image",image:h}),L=1;if(A&&A.length>0){let U=Pi(A,l);M.push(...U)}M.push({type:"text",text:E});let N=A?Ko(A,l):0,P=L+N,V=Ee(o,P),ee=Dd(),xe=await Id({model:Se(o),system:ee,messages:[{role:"user",content:M}],output:Cd.object({schema:Od}),temperature:0,providerOptions:V}),{conclusion:z,explanation:Y}=xe.output,ve=JSON.stringify(xe.output,null,2),Fe=[],Pe=Li(xe.usage,o);Pe&&Fe.push(Pe);let Oe=[{role:"user",content:M.map(U=>{if(U.type==="text")return{type:"text",text:U.text};if(U.type==="image"){let J=U.image,q=Pd(J);if(q)return{type:"image",file:q};let le=typeof J=="string"?J:"";return{type:"image",file:le.startsWith("data:")?le:`data:image/png;base64,${le}`}}return{type:"text",text:"[unknown content type]"}})}],Le={systemPrompt:ee,userPrompt:Oe,rawLlmResponse:ve,screenshotWithSom:h,tokenUsages:Fe,retrievedKnowledges:A&&A.length>0?A:void 0,elementTree:d};return{success:z==="true",explanation:Y,debugInfo:Le}}catch(r){return{success:!1,error:r.message}}}var Od,Hi=x(()=>{"use strict";Ri();Ze();vt();_t();xt();Te();Od=Fi.object({screenshotDescription:Fi.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
|
|
183
183
|
and a description of their location: formatting example: [12] A red button with text "Submit", next to [11]
|
|
184
184
|
[45] A modal dialog titled "Confirmation",
|
|
185
185
|
in the center of the screen`),explanation:Fi.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:Fi.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function Zo(){let{default:e}=await import("sharp");return e}async function Zn(e,t){let i=await Zo(),n=await i(e).metadata(),a=n.width||0,o=n.height||0;if(a===0||o===0)throw new Error("Invalid image dimensions");let r=o,s=0,l=Math.floor((a-r)/2),c=Math.max(0,a-r),d=(f,v)=>{let b=i(e).extract({left:f,top:0,width:v,height:r});return t?.resize&&(b=b.resize(qo,qo)),b.png().toBuffer()},[h,p,g]=await Promise.all([d(s,Math.min(r,a)),d(l,Math.min(r,a-l)),d(c,Math.min(r,a-c))]);return[h,p,g]}async function Qo(e){let t=(await Zo())(e),i=await t.metadata(),n=i.width||0,a=i.height||0;if(n===0||a===0)throw new Error("Invalid image dimensions");let{data:o}=await t.grayscale().raw().toBuffer({resolveWithObject:!0}),r=[];for(let s=0;s<a;s++){r[s]=[];for(let l=0;l<n;l++)r[s][l]=o[s*n+l]}return{pixels:r,width:n,height:a}}var qo,kt=x(()=>{"use strict";qo=768});var Qn,ea,ta,ia,St=x(()=>{"use strict";Qn=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),ea=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),ta=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],ia=500});function er(e,t){return e.length>t?e.slice(0,t)+"...":e}var Et=x(()=>{"use strict"});var tr,ir,Tt=x(()=>{"use strict";tr=["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"],ir={"react-flow__(\\S+)":"$1"}});var nr,At,$e,Qe=x(()=>{"use strict";Et();Tt();nr=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},At=class extends nr{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}},$e=class Wi extends nr{constructor(t,i,n,a,o,r=!1,s=!1,l=!1,c=!1,d=!1,h=!1,p=null,g=null,f=null,v=null,b=[],m=null){super(o,m),this.tagName=t,this.xpath=i,this.attributes=n,this.children=a,this.isInteractive=r,this.isScrollable=s,this.markAsClickable=l,this.isTopElement=c,this.isInViewport=d,this.shadowRoot=h,this.highlightIndex=p,this.viewportCoordinates=g,this.pageCoordinates=f,this.viewportInfo=v,this.isNew=null,this.shadowHostXPaths=b}getAllTextTillNextClickableElement(t=-1){let i=[],n=(a,o)=>{if(!(t!==-1&&o>t)&&!(a instanceof Wi&&a!==this&&a.highlightIndex!==null)){if(a instanceof At)i.push(a.text);else if(a instanceof Wi)for(let r of a.children)n(r,o+1)}};return n(this,0),i.join(`
|
|
186
|
-
`).trim()}clickableElementsToString(t){let i=t?.includeAttributes??tr,n=t?.includeClassesWithRename??ir,a=[],o=(r,s)=>{let l=s,c=" ".repeat(s);if(r instanceof Wi){if(r.highlightIndex!==null){l+=1;let d=r.isScrollable?"":r.getAllTextTillNextClickableElement(),h=null;if(i.length>0){let m={};for(let E of Object.keys(r.attributes))if(i.includes(E)){let A=r.attributes[E].trim();A!==""&&(m[E]=A)}let y=i.filter(E=>E in m);if(y.length>1){let E=new Set,A={};for(let M of y){let
|
|
186
|
+
`).trim()}clickableElementsToString(t){let i=t?.includeAttributes??tr,n=t?.includeClassesWithRename??ir,a=[],o=(r,s)=>{let l=s,c=" ".repeat(s);if(r instanceof Wi){if(r.highlightIndex!==null){l+=1;let d=r.isScrollable?"":r.getAllTextTillNextClickableElement(),h=null;if(i.length>0){let m={};for(let E of Object.keys(r.attributes))if(i.includes(E)){let A=r.attributes[E].trim();A!==""&&(m[E]=A)}let y=i.filter(E=>E in m);if(y.length>1){let E=new Set,A={};for(let M of y){let L=m[M];L.length>5&&(L in A?E.add(M):A[L]=M)}for(let M of E)delete m[M]}r.tagName===m.role&&delete m.role;let S=["aria-label","placeholder","title"];for(let E of S)m[E]&&m[E].trim().toLowerCase()===d.trim().toLowerCase()&&delete m[E];Object.keys(m).length>0&&(h=Object.entries(m).map(([E,A])=>`${E}=${er(A,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 y of m)for(let[S,E]of Object.entries(n))try{let A=new RegExp(`^${S}$`);if(y.match(A)){let M=y.replace(A,E);M&&g.push(M);break}}catch{continue}}let f=r.isScrollable?" (SCROLLABLE)":"",v=r.markAsClickable?" (CLICKABLE)":"",b=`${c}${p}${f}${v}<${r.tagName}`;if(g.length>0&&(b+=` ${g.join(" ")}`),h&&(b+=` ${h}`),d){let m=d.trim();h||(b+=" "),b+=`>${m}`}else h||(b+=" ");b+=" />",a.push(b)}else{let d=["data-testid","data-test-id"].filter(h=>r.attributes[h]);d.length>0&&(l+=1,a.push(`${c}<${r.tagName} ${d.map(h=>`${h}="${r.attributes[h]}"`).join(" ")} />`))}for(let d of r.children)o(d,l)}else if(r instanceof At){if(r.hasParentWithHighlightIndex())return;r.parent&&r.parent.isVisible&&r.parent.isTopElement&&a.push(`${c}${r.text}`)}};return o(this,0),a.join(`
|
|
187
187
|
`)}}});function Fd(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var Nd,Rd,be,Be=x(()=>{"use strict";kt();St();Qe();R();Nd=`(
|
|
188
188
|
args = {
|
|
189
189
|
doHighlightElements: true,
|
|
@@ -4084,34 +4084,34 @@ Based on the above information, please determine if the statement is true.
|
|
|
4084
4084
|
} : null,
|
|
4085
4085
|
clientRects: clientRectsArray
|
|
4086
4086
|
};
|
|
4087
|
-
}`,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=ia){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),a=ta.join(","),{nodeIds:o}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:a});u.debug(`\u{1F50D} Checking ${Math.min(o.length,t)} elements for event listeners`);for(let r of o.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}),c=l.filter(d=>ea.has(d.type));if(c.length>0){let{node:d}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:d.backendNodeId,eventTypes:c.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 $e("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),n=0;for(let a of e){let o=a.axNode.role?.value||"",r=a.axNode.name?.value||"",s=["button","link","menuitem","tab","switch"].includes(o),l=new $e(a.tagName,a.xpath,a.attributes,[],a.isVisible,!0,o==="scrollbar",s,a.isTopElement,a.isInViewport,!1,n,a.boundingRect?{topLeft:{x:a.boundingRect.x,y:a.boundingRect.y},topRight:{x:a.boundingRect.x+a.boundingRect.width,y:a.boundingRect.y},bottomLeft:{x:a.boundingRect.x,y:a.boundingRect.y+a.boundingRect.height},bottomRight:{x:a.boundingRect.x+a.boundingRect.width,y:a.boundingRect.y+a.boundingRect.height},center:{x:a.boundingRect.x+a.boundingRect.width/2,y:a.boundingRect.y+a.boundingRect.height/2},width:a.boundingRect.width,height:a.boundingRect.height}:null,null,null,[],i);if(r){let c=new At(r,!0,l);l.children.push(c)}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:a})=>{let o="playwright-highlight-container",r=document.getElementById(o);r||(r=document.createElement("div"),r.id=o,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 c=a[l%a.length],d=s.boundingRect,h=document.createElement("div");h.style.position="fixed",h.style.border=`1px solid ${c}`,h.style.backgroundColor="transparent",h.style.pointerEvents="none",h.style.boxSizing="border-box",h.style.top=`${d.y}px`,h.style.left=`${d.x}px`,h.style.width=`${d.width}px`,h.style.height=`${d.height}px`,r.appendChild(h);let p=document.createElement("div");p.style.position="fixed",p.style.background=c,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,d.y-16),f=Math.max(0,Math.min(d.x+d.width-20,window.innerWidth-25));p.style.top=`${g}px`,p.style.left=`${f}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(a=>a()),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 a=n.url();if(!(!a.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(a,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(c=>l.hostname.includes(c))}catch{return!1}},n=e.url(),a=new URL(n).hostname,o=e.frames(),r=[];for(let s of o){let l=s.url();try{let c=new URL(l).hostname;c&&c!==a&&!t.includes(l)&&!i(l)&&r.push(l)}catch{continue}}return r}async buildDomTree(e,t,i,n,a,o,r,s,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(Fd(e.url()))return[new $e("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let c={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:a,alwaysHighlightFileInput:r,sameRectIoUThreshold:s,actionIntent:l,domTreeRoot:this.domTreeRoot};u.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let d,h=null;if(this.useDomTreeTs&&t)try{let b={...c,phase:"boxes",grayscaleImage:null},m=await e.evaluate(({code:D,argsObj:N})=>new Function("return "+D)()(N),{code:this.jsCode,argsObj:b});u.debug(`\u{1F4E6} Phase 1: Drew ${m.elementData?.length||0} bounding boxes`);let y=await e.screenshot({type:"png",fullPage:!1});u.debug("\u{1F4F8} Captured screenshot with bounding boxes");let S=performance.now(),E=await Qo(y);h=E.pixels;let A=Math.round(performance.now()-S);u.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${E.width}x${E.height}) in ${A}ms`);let M={...c,phase:"labels",grayscaleImage:h,elementData:m.elementData};d=await e.evaluate(({code:D,argsObj:N})=>new Function("return "+D)()(N),{code:this.jsCode,argsObj:M}),d.map=m.map,d.rootId=m.rootId,d.highlightCount=m.highlightCount,d.perfMetrics=m.perfMetrics,u.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(b){u.warn("Two-phase rendering failed, falling back to legacy mode:",b.message),h=null;let m={...c,grayscaleImage:null};d=await e.evaluate(({code:y,argsObj:S})=>new Function("return "+y)()(S),{code:this.jsCode,argsObj:m}),u.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{d=await e.evaluate(({code:b,argsObj:m})=>new Function("return "+b)()(m),{code:this.jsCode,argsObj:c}),u.debug("\u2705 JavaScript DOM analysis completed")}catch(b){throw u.error("Error evaluating JavaScript:",b.message),b}if(!d||typeof d!="object")throw u.error("JavaScript returned invalid result:",d),new Error("JavaScript DOM analysis returned invalid result");if(!d.map||!d.rootId)throw u.error("JavaScript result missing map or rootId:",JSON.stringify(d,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(l!=="all"&&d.highlightCount===0){u.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let b={...c,actionIntent:"all"};d=await e.evaluate(({code:m,argsObj:y})=>new Function("return "+m)()(y),{code:this.jsCode,argsObj:b})}let p=Object.entries(d.map).filter(([,b])=>b.tagName==="iframe");u.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${p.length}`);for(let[b,m]of p){let y=m;u.debug(`\u{1F50D} [ext-iframe] iframe node id=${b} src=${y.attributes?.src} inaccessibleFrame=${y.inaccessibleFrame}`)}let g=e.frames();u.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let b of g)u.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${b.url()}`);let f=[];for(let[b,m]of Object.entries(d.map)){let y=m;this.shouldProcessWithPlaywrightFrameFallback(y,o)&&f.push({nodeId:b,src:y.attributes.src})}if(u.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${f.length}`),f.length>0){u.debug(`\u{1F50C} Found ${f.length} inaccessible iframe(s) for Playwright fallback, processing`);let b=-1;for(let m of Object.values(d.map)){let y=m;y.highlightIndex!=null&&(b=Math.max(b,y.highlightIndex))}u.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${b}`);for(let m=0;m<f.length;m++){let{nodeId:y,src:S}=f[m];u.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${m}]: ${S}`);let E=N=>{try{let P=new URL(N);if(P.protocol==="chrome-extension:"&&P.hostname)return`chrome-extension://${P.hostname}`;let V=P.origin;return V==="null"?null:V}catch{return null}},A=E(S);u.debug(`\u{1F50D} [ext-iframe] iframe src origin=${A??"null"}`);let M=null,D=e.frames().find(N=>{let P=N.url();if(P===S)return M="exact",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${P}`),!0;let V=E(P);return u.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${P} origin=${V??"null"} vs srcOrigin=${A??"null"}`),A&&V===A?(M="origin",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${P}`),!0):!1});if(!D){u.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${S}`),u.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(N=>N.url()).join(", ")}`);continue}u.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${S} (frame url: ${D.url()})`);try{let N={...c,initialHighlightIndex:b+1,domTreeRoot:"body"};u.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${N.initialHighlightIndex}`);let P=await D.evaluate(({code:z,argsObj:Y})=>new Function("return "+z)()(Y),{code:this.jsCode,argsObj:N});if(u.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(P?.map??{}).length} rootId=${P?.rootId}`),!P?.map||!P.rootId){u.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let V=Object.values(P.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 Y=z;u.debug(`\u{1F50D} [ext-iframe] - <${Y.tagName}> highlightIndex=${Y.highlightIndex} text="${Y.children?.length?"...":""}"`)}for(let z of Object.values(P.map)){let Y=z;Y.highlightIndex!=null&&(b=Math.max(b,Y.highlightIndex))}let ee=`ext_${m}_`;for(let[z,Y]of Object.entries(P.map)){let ve={...Y};ve.children&&(ve.children=ve.children.map(Fe=>`${ee}${Fe}`)),d.map[`${ee}${z}`]=ve}let xe=d.map[y];xe?(xe.children=[...xe.children||[],`${ee}${P.rootId}`],u.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${y}`)):u.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${y} not found in map`),u.debug(`\u2705 Merged fallback iframe content from: ${S}`)}catch(N){u.warn(`Failed to process fallback iframe ${S}:`,N)}}}if(d&&d.perfMetrics){let b=d.perfMetrics.nodeMetrics?.totalNodes??0,m=0;if(d.map)for(let S of Object.values(d.map))typeof S=="object"&&S!==null&&S.isInteractive&&m++;let y=e.url().length>50?e.url().slice(0,50)+"...":e.url();u.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${y} interactive=${m}/${b}`)}u.debug("\u{1F504} Starting TypeScript DOM tree construction...");let v=await this.constructDomTree(d);return u.debug("\u2705 TypeScript DOM tree construction completed"),v}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,a=new Map,o=new Map;for(let[s,l]of Object.entries(t)){let[c,d]=this.parseNode(l);c!==null&&(a.set(s,c),o.set(s,d),c instanceof $e&&c.highlightIndex!==null&&n.set(c.highlightIndex,c))}for(let[s,l]of o){let c=a.get(s);if(c instanceof $e)for(let d of l){let h=a.get(d);h&&(h.parent=c,c.children.push(h))}}let r=a.get(i);if(!r||!(r instanceof $e))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 At(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 $e(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),a=e.children||[];return[n,a]}}});var ar,Ui=x(()=>{"use strict";F();I();ar=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.keys;if(!a||typeof a!="string")throw new Error("Missing or invalid keys for send keys on element action");let o=O(e,t),r=C(i,t.action_data?.kwargs?.timeout_ms);if(o)await o.press(a,{timeout:r}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=Ne(e);if(!t){let a=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(a)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",n=C();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});import{z as Hd}from"zod";var or,Jw,Bi=x(()=>{"use strict";or=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},Jw=Hd.object({})});var rr,Gi=x(()=>{"use strict";F();I();rr=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 a=O(e,t);if(a){await a.waitFor({state:"attached",timeout:C(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,s=o.y+n.kwargs.relative_y+o.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 sr,ji=x(()=>{"use strict";sr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.code;if(!a)throw new Error("Missing code for js_action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 js_action requires an agent reference");await new Function("page","agent",`
|
|
4087
|
+
}`,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=ia){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),a=ta.join(","),{nodeIds:o}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:a});u.debug(`\u{1F50D} Checking ${Math.min(o.length,t)} elements for event listeners`);for(let r of o.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}),c=l.filter(d=>ea.has(d.type));if(c.length>0){let{node:d}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:d.backendNodeId,eventTypes:c.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 $e("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),n=0;for(let a of e){let o=a.axNode.role?.value||"",r=a.axNode.name?.value||"",s=["button","link","menuitem","tab","switch"].includes(o),l=new $e(a.tagName,a.xpath,a.attributes,[],a.isVisible,!0,o==="scrollbar",s,a.isTopElement,a.isInViewport,!1,n,a.boundingRect?{topLeft:{x:a.boundingRect.x,y:a.boundingRect.y},topRight:{x:a.boundingRect.x+a.boundingRect.width,y:a.boundingRect.y},bottomLeft:{x:a.boundingRect.x,y:a.boundingRect.y+a.boundingRect.height},bottomRight:{x:a.boundingRect.x+a.boundingRect.width,y:a.boundingRect.y+a.boundingRect.height},center:{x:a.boundingRect.x+a.boundingRect.width/2,y:a.boundingRect.y+a.boundingRect.height/2},width:a.boundingRect.width,height:a.boundingRect.height}:null,null,null,[],i);if(r){let c=new At(r,!0,l);l.children.push(c)}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:a})=>{let o="playwright-highlight-container",r=document.getElementById(o);r||(r=document.createElement("div"),r.id=o,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 c=a[l%a.length],d=s.boundingRect,h=document.createElement("div");h.style.position="fixed",h.style.border=`1px solid ${c}`,h.style.backgroundColor="transparent",h.style.pointerEvents="none",h.style.boxSizing="border-box",h.style.top=`${d.y}px`,h.style.left=`${d.x}px`,h.style.width=`${d.width}px`,h.style.height=`${d.height}px`,r.appendChild(h);let p=document.createElement("div");p.style.position="fixed",p.style.background=c,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,d.y-16),f=Math.max(0,Math.min(d.x+d.width-20,window.innerWidth-25));p.style.top=`${g}px`,p.style.left=`${f}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(a=>a()),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 a=n.url();if(!(!a.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(a,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(c=>l.hostname.includes(c))}catch{return!1}},n=e.url(),a=new URL(n).hostname,o=e.frames(),r=[];for(let s of o){let l=s.url();try{let c=new URL(l).hostname;c&&c!==a&&!t.includes(l)&&!i(l)&&r.push(l)}catch{continue}}return r}async buildDomTree(e,t,i,n,a,o,r,s,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(Fd(e.url()))return[new $e("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let c={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:a,alwaysHighlightFileInput:r,sameRectIoUThreshold:s,actionIntent:l,domTreeRoot:this.domTreeRoot};u.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let d,h=null;if(this.useDomTreeTs&&t)try{let b={...c,phase:"boxes",grayscaleImage:null},m=await e.evaluate(({code:L,argsObj:N})=>new Function("return "+L)()(N),{code:this.jsCode,argsObj:b});u.debug(`\u{1F4E6} Phase 1: Drew ${m.elementData?.length||0} bounding boxes`);let y=await e.screenshot({type:"png",fullPage:!1});u.debug("\u{1F4F8} Captured screenshot with bounding boxes");let S=performance.now(),E=await Qo(y);h=E.pixels;let A=Math.round(performance.now()-S);u.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${E.width}x${E.height}) in ${A}ms`);let M={...c,phase:"labels",grayscaleImage:h,elementData:m.elementData};d=await e.evaluate(({code:L,argsObj:N})=>new Function("return "+L)()(N),{code:this.jsCode,argsObj:M}),d.map=m.map,d.rootId=m.rootId,d.highlightCount=m.highlightCount,d.perfMetrics=m.perfMetrics,u.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(b){u.warn("Two-phase rendering failed, falling back to legacy mode:",b.message),h=null;let m={...c,grayscaleImage:null};d=await e.evaluate(({code:y,argsObj:S})=>new Function("return "+y)()(S),{code:this.jsCode,argsObj:m}),u.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{d=await e.evaluate(({code:b,argsObj:m})=>new Function("return "+b)()(m),{code:this.jsCode,argsObj:c}),u.debug("\u2705 JavaScript DOM analysis completed")}catch(b){throw u.error("Error evaluating JavaScript:",b.message),b}if(!d||typeof d!="object")throw u.error("JavaScript returned invalid result:",d),new Error("JavaScript DOM analysis returned invalid result");if(!d.map||!d.rootId)throw u.error("JavaScript result missing map or rootId:",JSON.stringify(d,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(l!=="all"&&d.highlightCount===0){u.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let b={...c,actionIntent:"all"};d=await e.evaluate(({code:m,argsObj:y})=>new Function("return "+m)()(y),{code:this.jsCode,argsObj:b})}let p=Object.entries(d.map).filter(([,b])=>b.tagName==="iframe");u.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${p.length}`);for(let[b,m]of p){let y=m;u.debug(`\u{1F50D} [ext-iframe] iframe node id=${b} src=${y.attributes?.src} inaccessibleFrame=${y.inaccessibleFrame}`)}let g=e.frames();u.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let b of g)u.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${b.url()}`);let f=[];for(let[b,m]of Object.entries(d.map)){let y=m;this.shouldProcessWithPlaywrightFrameFallback(y,o)&&f.push({nodeId:b,src:y.attributes.src})}if(u.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${f.length}`),f.length>0){u.debug(`\u{1F50C} Found ${f.length} inaccessible iframe(s) for Playwright fallback, processing`);let b=-1;for(let m of Object.values(d.map)){let y=m;y.highlightIndex!=null&&(b=Math.max(b,y.highlightIndex))}u.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${b}`);for(let m=0;m<f.length;m++){let{nodeId:y,src:S}=f[m];u.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${m}]: ${S}`);let E=N=>{try{let P=new URL(N);if(P.protocol==="chrome-extension:"&&P.hostname)return`chrome-extension://${P.hostname}`;let V=P.origin;return V==="null"?null:V}catch{return null}},A=E(S);u.debug(`\u{1F50D} [ext-iframe] iframe src origin=${A??"null"}`);let M=null,L=e.frames().find(N=>{let P=N.url();if(P===S)return M="exact",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${P}`),!0;let V=E(P);return u.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${P} origin=${V??"null"} vs srcOrigin=${A??"null"}`),A&&V===A?(M="origin",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${P}`),!0):!1});if(!L){u.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${S}`),u.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(N=>N.url()).join(", ")}`);continue}u.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${S} (frame url: ${L.url()})`);try{let N={...c,initialHighlightIndex:b+1,domTreeRoot:"body"};u.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${N.initialHighlightIndex}`);let P=await L.evaluate(({code:z,argsObj:Y})=>new Function("return "+z)()(Y),{code:this.jsCode,argsObj:N});if(u.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(P?.map??{}).length} rootId=${P?.rootId}`),!P?.map||!P.rootId){u.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let V=Object.values(P.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 Y=z;u.debug(`\u{1F50D} [ext-iframe] - <${Y.tagName}> highlightIndex=${Y.highlightIndex} text="${Y.children?.length?"...":""}"`)}for(let z of Object.values(P.map)){let Y=z;Y.highlightIndex!=null&&(b=Math.max(b,Y.highlightIndex))}let ee=`ext_${m}_`;for(let[z,Y]of Object.entries(P.map)){let ve={...Y};ve.children&&(ve.children=ve.children.map(Fe=>`${ee}${Fe}`)),d.map[`${ee}${z}`]=ve}let xe=d.map[y];xe?(xe.children=[...xe.children||[],`${ee}${P.rootId}`],u.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${y}`)):u.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${y} not found in map`),u.debug(`\u2705 Merged fallback iframe content from: ${S}`)}catch(N){u.warn(`Failed to process fallback iframe ${S}:`,N)}}}if(d&&d.perfMetrics){let b=d.perfMetrics.nodeMetrics?.totalNodes??0,m=0;if(d.map)for(let S of Object.values(d.map))typeof S=="object"&&S!==null&&S.isInteractive&&m++;let y=e.url().length>50?e.url().slice(0,50)+"...":e.url();u.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${y} interactive=${m}/${b}`)}u.debug("\u{1F504} Starting TypeScript DOM tree construction...");let v=await this.constructDomTree(d);return u.debug("\u2705 TypeScript DOM tree construction completed"),v}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,a=new Map,o=new Map;for(let[s,l]of Object.entries(t)){let[c,d]=this.parseNode(l);c!==null&&(a.set(s,c),o.set(s,d),c instanceof $e&&c.highlightIndex!==null&&n.set(c.highlightIndex,c))}for(let[s,l]of o){let c=a.get(s);if(c instanceof $e)for(let d of l){let h=a.get(d);h&&(h.parent=c,c.children.push(h))}}let r=a.get(i);if(!r||!(r instanceof $e))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 At(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 $e(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),a=e.children||[];return[n,a]}}});var ar,Ui=x(()=>{"use strict";F();I();ar=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.keys;if(!a||typeof a!="string")throw new Error("Missing or invalid keys for send keys on element action");let o=O(e,t),r=C(i,t.action_data?.kwargs?.timeout_ms);if(o)await o.press(a,{timeout:r}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=Ne(e);if(!t){let a=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(a)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",n=C();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});import{z as Hd}from"zod";var or,Yw,Bi=x(()=>{"use strict";or=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},Yw=Hd.object({})});var rr,Gi=x(()=>{"use strict";F();I();rr=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 a=O(e,t);if(a){await a.waitFor({state:"attached",timeout:C(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,s=o.y+n.kwargs.relative_y+o.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 sr,ji=x(()=>{"use strict";sr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.code;if(!a)throw new Error("Missing code for js_action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 js_action requires an agent reference");await new Function("page","agent",`
|
|
4088
4088
|
return (async () => {
|
|
4089
4089
|
${a}
|
|
4090
4090
|
})();
|
|
4091
4091
|
`)(e,o)}transpile(e){let t=e.action_data?.kwargs?.code;return t?t.split(`
|
|
4092
|
-
`):["// Skipping js_action: missing code"]}}});import{z as lr}from"zod";var cr,
|
|
4092
|
+
`):["// Skipping js_action: missing code"]}}});import{z as lr}from"zod";var cr,ab,Ki=x(()=>{"use strict";cr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.code;if(!a)throw new Error("Missing code for js_code action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 js_code requires an agent reference");await new Function("page","agent",`
|
|
4093
4093
|
return (async () => {
|
|
4094
4094
|
${a}
|
|
4095
4095
|
})();
|
|
4096
4096
|
`)(e,o)}transpile(e){let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
|
|
4097
|
-
`);for(let a of n)i.push(` ${a}`);return i.push("}"),i}},
|
|
4097
|
+
`);for(let a of n)i.push(` ${a}`);return i.push("}"),i}},ab=lr.object({code:lr.string().describe("JavaScript code to execute in the browser context")})});var dr,zi=x(()=>{"use strict";F();I();dr=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 a=O(e,t);if(a){await a.waitFor({state:"attached",timeout:C(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,s=o.y+n.kwargs.relative_y+o.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 ur,Vi=x(()=>{"use strict";F();I();ur=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 a=O(e,t);if(a){await a.waitFor({state:"attached",timeout:C(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,s=o.y+n.kwargs.relative_y+o.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 hr,Xi=x(()=>{"use strict";F();I();hr=class{async execute(e,t,i){let n=i.getActionSettings().drag_drop_steps??10,a=t.action_data;if(!a)throw new Error("Action data not found");let o=a.kwargs,r=[o.coord_source_x,o.coord_source_y],s=[o.coord_target_x,o.coord_target_y];if(typeof o.relative_x=="number"&&typeof o.relative_y=="number"&&typeof o.delta_x=="number"&&typeof o.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:C(i,t.action_data?.kwargs?.timeout_ms)});let c=await(await l).boundingBox();if(!c)throw new Error("Could not get bounding box for drag_drop element");let d=c.x+o.relative_x+c.width/2,h=c.y+o.relative_y+c.height/2,p=d+o.delta_x,g=h+o.delta_y;await e.mouse.move(d,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,c]=r,[d,h]=s;await e.mouse.move(l,c),await e.mouse.down(),n>0?await e.mouse.move(d,h,{steps:n}):await e.mouse.move(d,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(a=>` ${a},`),"});"]}}});var mr,Yi=x(()=>{"use strict";mr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=this.generateFunctionCallCode(n.kwargs);if(!a)throw new Error("Missing function name for function action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 FunctionAction requires an agent reference");await new Function("page","agent",`
|
|
4098
4098
|
return (async () => {
|
|
4099
4099
|
${a}
|
|
4100
4100
|
})();
|
|
4101
|
-
`)(e,o)}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"],a=["undefined","null","true","false"],o=i.map(r=>n.includes(r)||a.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${o.join(", ")})`}}});var Ji=x(()=>{"use strict";Qe()});var pr,et=x(()=>{"use strict";pr=(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))(pr||{})});var tt={};dt(tt,{evaluateStatement:()=>at,executeAction:()=>$t,executeStep:()=>nt,generateActionStep:()=>Mt,runTask:()=>ot});var it=x(()=>{"use strict";It();Hi();Ri();Ze();Ti();$i();Ai();Xe();Ci();Oi();vt();_t();Ae();yt();xt();Ji();Be();kt();St();Qe();Et();Tt();ie();Te();ft();wt();Ye();j();Ue();R();te();et();F();ge()});import{z as gr}from"zod";var fr,
|
|
4101
|
+
`)(e,o)}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"],a=["undefined","null","true","false"],o=i.map(r=>n.includes(r)||a.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${o.join(", ")})`}}});var Ji=x(()=>{"use strict";Qe()});var pr,et=x(()=>{"use strict";pr=(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))(pr||{})});var tt={};dt(tt,{evaluateStatement:()=>at,executeAction:()=>$t,executeStep:()=>nt,generateActionStep:()=>Mt,runTask:()=>ot});var it=x(()=>{"use strict";It();Hi();Ri();Ze();Ti();$i();Ai();Xe();Ci();Oi();vt();_t();Ae();yt();xt();Ji();Be();kt();St();Qe();Et();Tt();ie();Te();ft();wt();Ye();j();Ue();R();te();et();F();ge()});import{z as gr}from"zod";var fr,iy,qi=x(()=>{"use strict";fr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.statement;if(!a)throw new Error("Missing statement for ai_action");let o=n.kwargs.use_pure_vision,{executeStep:r}=await Promise.resolve().then(()=>(it(),tt)),s=await r(a,e,i,{usePureVision:o});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),a=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${n}, '${t||""}', ${a});`]}},iy=gr.object({statement:gr.string().describe('The action to perform (e.g., "click the submit button")')})});import{z as wr}from"zod";var br,ry,Zi=x(()=>{"use strict";br=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.statement;if(!a)throw new Error("Missing statement for ai_step");let{runTask:o}=await Promise.resolve().then(()=>(it(),tt)),r=await o(a,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"]}},ry=wr.object({statement:wr.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});import{z as na}from"zod";function xr(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:Wd,async execute(i,n){let{condition:a,timeout_seconds:o=60}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Wait until: ${a}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:a,timeout_seconds:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Condition met: ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Wait until: ${a} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:a,timeout_seconds:o}},feedback:l.message}}}}})}var yr,Wd,Ct=x(()=>{"use strict";yr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.condition;if(!a)throw new Error("Missing condition for ai_wait_until");let o=(n.kwargs.timeout_seconds||60)*1e3,r=5e3,s=Date.now(),{evaluateStatement:l}=await Promise.resolve().then(()=>(it(),tt));for(;Date.now()-s<o;){if((await l(a,e,i,{})).success)return;await e.waitForTimeout(r)}throw new Error(`Timeout waiting for condition: ${a}`)}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"]}},Wd=na.object({condition:na.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:na.number().positive().optional().describe("Timeout in seconds (default: 60)")})});import{z as Qi}from"zod";async function Ud(e,t,i,n){return{...await D(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function vr(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 kr(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:Bd,usesElementIndex:!0,async execute(i,n){let{element_index:a,option:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let c=await W(n,a);if(!c)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:vr(l||`Select option in dropdown ${a}`,{index:a,option:o})};let d=await Ud(c,r,o,l);return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Selected option "${o}" in dropdown ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:vr(`Select option in dropdown ${a}`,{index:a,option:o})}}}})}var _r,Bd,Pt=x(()=>{"use strict";j();F();I();_r=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.text||n.kwargs.option,o=O(e,t),r=C(i,t.action_data?.kwargs?.timeout_ms);if(o&&a)await o.selectOption(a,{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},`),"});"]}};Bd=Qi.object({element_index:Qi.number().int().describe("Index of the dropdown/select element"),option:Qi.string().describe("Option value, label, or index to select"),timeout_ms:Qi.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as en}from"zod";async function Gd(e,t,i,n){return{...await D(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function aa(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 Er(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">).
|
|
4102
4102
|
|
|
4103
4103
|
IMPORTANT: ONLY use this action for input elements that have type="date" attribute (native HTML date picker).
|
|
4104
4104
|
Do NOT use it for custom/non-native date pickers
|
|
4105
4105
|
|
|
4106
|
-
The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:jd,usesElementIndex:!0,async execute(i,n){let{element_index:a,date:o}=i,{page:r,agentServices:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Date picker element with index ${a} not found`,actionEntity:aa(`Set date to ${o} on element ${a}`,{index:a,date:o})};let c=l.attributes.type;if(c!=="date")return{success:!1,error:`Element ${a} is not a native date picker (type="${c}"). This action only works with <input type="date">.`,actionEntity:aa(`Set date to ${o} on element ${a}`,{index:a,date:o})};let d=await Gd(`Set date to ${o} on element ${a}`,l,r,o);return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Set date to ${o} on element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:aa(`Set date to ${o} on element ${a}`,{index:a,date:o})}}}})}var Sr,jd,Ot=x(()=>{"use strict";j();F();I();Sr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.date;if(!a)throw new Error("Date value is required");if(!/^\d{4}-\d{2}-\d{2}$/.test(a))throw new Error(`Invalid date format: ${a}. Expected format: YYYY-MM-DD (e.g., 2024-03-15)`);let o=i.replaceVariables(String(a)),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(o,{timeout:C(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},`),"});"]}};jd=en.object({element_index:en.number().int().describe("Index of the native date picker input element"),date:en.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:en.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Tr}from"zod";function $r(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:Kd,async execute(i,n){let a=i.tab_index,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Switch to tab ${a}`,action_data:{action_name:"switch_tab",kwargs:{page_id:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Switched to tab ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Switch to tab ${a}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:a}},feedback:l.message}}}}})}var Ar,Kd,Dt=x(()=>{"use strict";Ar=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.page_id??n.kwargs.tab_index??0;if(typeof a=="number"){let o=e.context().pages(),r=a===-1?o.length-1:a;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} } },`,"});"]}},Kd=Tr.object({tab_index:Tr.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});import zd from"fs";import Vd from"path";async function Mr(e,t,i,n,a,o){let r=Array.isArray(t)?t:[t];if(r.length===0)throw new Error("No file paths provided for upload");let s=r.map(d=>{if(d.startsWith("/")||d.match(/^[A-Za-z]:\\/))return d;let h=n.testDataDir||process.cwd();return Vd.join(h,d)});u.info(`Uploading files: ${s.join(", ")}`);let l=i.timeout||2e4,c={useFileInput:i.useFileInput||!1,timeout:l};if(i.selector&&typeof i.selector!="string"){let d=i.selector;await tn(e,d,s,c);return}if(i.selector&&typeof i.selector=="string"){let d=i.selector,h=(d.startsWith("xpath="),e.locator(d));await tn(e,h,s,c);return}if(a){let d=r.map(p=>`"${p}"`).join(", "),h="";i.targetDescription?h=`Upload ${d} to ${i.targetDescription}`:h=`Upload ${d}`,u.info(`Using AI to handle file upload: ${h}`),await a(e,h,o)}else throw new Error("No selector provided and AI action execution is not available")}async function tn(e,t,i,n){let{useFileInput:a,timeout:o,mockShowOpenFilePicker:r}=n;if(r){u.info("Using mockShowOpenFilePicker approach");let s=i.map(l=>({path:l,buffer:new Uint8Array(zd.readFileSync(l))}));await e.evaluate(l=>{window.__pw_showOpenFilePicker_mock_files=l},s),await t.click({timeout:o}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(a)u.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:o}),await e.waitForTimeout(3e3);else{u.info("Using file chooser approach");let s=e.waitForEvent("filechooser",{timeout:o});s.catch(()=>{}),await t.click({timeout:o}),await(await s).setFiles(i),await e.waitForTimeout(3e3)}u.info(`Successfully uploaded ${i.length} file(s)`)}var Lt=x(()=>{"use strict";R()});import{z as Re}from"zod";async function Xd(e,t,i={},n){return{...await L(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function Ir(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 Pr(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:Yd,usesElementIndex:!0,async execute(i,n){let{element_index:a,paths:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let c=await W(n,a);if(!c)return{success:!1,error:`File input element with index ${a} not found`,actionEntity:Ir(l||`Upload file to element ${a}`,{index:a,paths:o})};let d=await Xd(c,r,{paths:o},l);return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Uploaded file to element ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:Ir(l||`Upload file to element ${a}`,{index:a,paths:o})}}}})}var Cr,Yd,Dy,Nt=x(()=>{"use strict";Lt();j();F();I();Cr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=[];if(n.kwargs.paths?a=Array.isArray(n.kwargs.paths)?n.kwargs.paths:[n.kwargs.paths]:n.kwargs.path&&(a=Array.isArray(n.kwargs.path)?n.kwargs.path:[n.kwargs.path]),a.length===0)throw new Error("No file paths provided for upload_file action");await i.downloadTestDataFiles(a);let o=a.map(c=>i.getTestDataFilePath(c)),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 tn(e,r,o,{useFileInput:s,timeout:C(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(a=>` ${a},`),"});"]}};Yd=Re.object({element_index:Re.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:Re.string().describe("Paths to the files to upload"),timeout_ms:Re.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});Dy=Re.object({element_index:Re.number().int().describe("Index of the file input element"),paths:Re.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:Re.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Or}from"zod";function Lr(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:Jd,async execute(i,n){let{seconds:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Wait ${a} seconds`,action_data:{action_name:"wait",kwargs:{seconds:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Waited ${a} seconds`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Wait ${a} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:a}},feedback:l.message}}}}})}var Dr,Jd,Rt=x(()=>{"use strict";Dr=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});`]}},Jd=Or.object({seconds:Or.number().positive().describe("Number of seconds to wait")})});import{z as Nr}from"zod";function Fr(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:qd,async execute(i,n){let{timeout_seconds:a=10}=i,{page:o,agentServices:r}=n;try{let s={action_description:`Wait for download to complete (timeout: ${a}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:a}}};return await t.execute(o,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:a}},feedback:s.message}}}}})}var Rr,qd,Ft=x(()=>{"use strict";Rr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,a)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},qd=Nr.object({timeout_seconds:Nr.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});import{z as Hr}from"zod";function Wr(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:Zd,async execute(i,n){let{keys:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Press keys "${a}"`,action_data:{action_name:"press",kwargs:{keys:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Pressed keys "${a}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Press keys "${a}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:a}},feedback:l.message}}}}})}var oa,Zd,Ht=x(()=>{"use strict";oa=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)});`]}},Zd=Hr.object({keys:Hr.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.")})});import{z as Qd}from"zod";function Br(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:eu,async execute(i,n){let{page:a,agentServices:o}=n;try{let r={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await t.execute(a,r,o),{success:!0,actionEntity:r,message:`Reloaded ${a.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 Ur,eu,Wt=x(()=>{"use strict";F();I();Ur=class{async execute(e,t){await e.reload({timeout:fe}),await e.waitForLoadState("load",{timeout:fe}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},eu=Qd.object({})});import{z as ra}from"zod";async function tu(e,t,i,n,a={}){return{...await L(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Gr(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 jr(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:iu,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Gr(`Right-click element ${a}`,"right_click",{index:a})};let c=s||`Right-click element ${a}`,d=await tu("right_click",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Right-clicked element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:Gr(`Right-click element ${a}`,"right_click",{index:a})}}}})}var sa,iu,Ut=x(()=>{"use strict";j();F();I();sa=class{async execute(e,t,i){let n=O(e,t),a=C(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({button:"right",timeout:a});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},`),"});"]}};iu=ra.object({element_index:ra.number().int().describe("Index of the element to right-click"),timeout_ms:ra.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as la}from"zod";function zr(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:nu,async execute(i,n){let{name:a,value:o}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Save variable "${a}" = "${o}"`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Saved variable "${a}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Save variable "${a}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}},feedback:l.message}}}}})}var Kr,nu,Bt=x(()=>{"use strict";Kr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.name,o=n.kwargs.value;if(!a||o===void 0)throw new Error("Missing variable name or value for save_variable");a.startsWith("$")&&(a=a.slice(1)),i.saveVariable(a,o)}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)} } },`,"});"]}},nu=la.object({name:la.string().describe("Variable name to save"),value:la.string().describe("Value to save in the variable")})});import{z as ca}from"zod";async function au(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function ou(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function Vr(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:ru,async execute(i,n){let{down:a,num_pages:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let c=l||`Scroll ${a?"down":"up"} ${o} page(s)`,d=await au("scroll",c,{down:a,num_pages:o});return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Scrolled ${a?"down":"up"} ${o} page(s)`}}catch(c){return{success:!1,error:c.message,actionEntity:ou(l||`Scroll ${a?"down":"up"} ${o} page(s)`,"scroll",{down:a,num_pages:o})}}}})}var Gt,ru,jt=x(()=>{"use strict";Gt=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,a=i.kwargs.num_pages??1,o=n?1:-1;await e.evaluate(`window.scrollBy(0, window.innerHeight * ${a} * ${o})`)}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)})');`]}};ru=ca.object({down:ca.boolean().describe("True to scroll down, False to scroll up"),num_pages:ca.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});import{z as Kt}from"zod";async function su(e,t,i,n,a={}){return{...await L(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Xr(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Jr(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:lu,usesElementIndex:!0,async execute(i,n){let{element_index:a,delta_x:o,delta_y:r}=i,{page:s,agentServices:l}=n;try{let c=await W(n,a);if(!c)return{success:!1,error:`Element with index ${a} not found`,actionEntity:Xr(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})};let d=await su("scroll_on_element",`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,c,s,{delta_x:o,delta_y:r});return await t.execute(s,d,l),{success:!0,actionEntity:d,message:`Scrolled on element ${a} horizontally: ${o}px, vertically: ${r}px`}}catch(c){return{success:!1,error:c.message,actionEntity:Xr(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})}}}})}var Yr,lu,zt=x(()=>{"use strict";j();F();I();Yr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.delta_x||0,o=n.kwargs.delta_y||0,r=O(e,t),s=C(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:s}),await e.mouse.wheel(a,o);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Ne(e);if(!t){let a=e.action_data?.kwargs?.delta_x||0,o=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${a}, delta_y: ${o} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,n=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${C()} });`,`await page.mouse.wheel(${i}, ${n});`]}};lu=Kt.object({element_index:Kt.number().int().describe("Index of the scrollable element"),delta_x:Kt.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:Kt.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:Kt.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as qr}from"zod";function Qr(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:cu,async execute(i,n){let{text:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Scroll to text "${a}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Scrolled to text "${a}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Scroll to text "${a}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:a}},feedback:l.message}}}}})}var Zr,cu,Vt=x(()=>{"use strict";Zr=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();`]}},cu=qr.object({text:qr.string().describe("Text to scroll to on the page")})});import{z as es}from"zod";async function du(e,t,i){return{...await L(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function ts(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 ns(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:uu,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:ts(s||`Get options from dropdown ${a}`,{index:a})};let c=await du(l,o,s);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:c.feedback||"No options found"}}catch(l){return{success:!1,error:l.message,actionEntity:ts(s||`Get options from dropdown ${a}`,{index:a})}}}})}var is,uu,Xt=x(()=>{"use strict";j();is=class{async execute(e,t,i){if(!t.xpath)throw new Error("XPath not found in action entity");let n=[];for(let a of e.frames())try{let o=await a.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(o){let r=[];for(let s of o.options){let l=JSON.stringify(s.text);r.push(`${s.index}: text=${l}`)}n.push(...r)}}catch{}if(n.length>0){let a=n.join(`
|
|
4106
|
+
The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:jd,usesElementIndex:!0,async execute(i,n){let{element_index:a,date:o}=i,{page:r,agentServices:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Date picker element with index ${a} not found`,actionEntity:aa(`Set date to ${o} on element ${a}`,{index:a,date:o})};let c=l.attributes.type;if(c!=="date")return{success:!1,error:`Element ${a} is not a native date picker (type="${c}"). This action only works with <input type="date">.`,actionEntity:aa(`Set date to ${o} on element ${a}`,{index:a,date:o})};let d=await Gd(`Set date to ${o} on element ${a}`,l,r,o);return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Set date to ${o} on element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:aa(`Set date to ${o} on element ${a}`,{index:a,date:o})}}}})}var Sr,jd,Ot=x(()=>{"use strict";j();F();I();Sr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.date;if(!a)throw new Error("Date value is required");if(!/^\d{4}-\d{2}-\d{2}$/.test(a))throw new Error(`Invalid date format: ${a}. Expected format: YYYY-MM-DD (e.g., 2024-03-15)`);let o=i.replaceVariables(String(a)),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(o,{timeout:C(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},`),"});"]}};jd=en.object({element_index:en.number().int().describe("Index of the native date picker input element"),date:en.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:en.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Tr}from"zod";function $r(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:Kd,async execute(i,n){let a=i.tab_index,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Switch to tab ${a}`,action_data:{action_name:"switch_tab",kwargs:{page_id:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Switched to tab ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Switch to tab ${a}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:a}},feedback:l.message}}}}})}var Ar,Kd,Lt=x(()=>{"use strict";Ar=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.page_id??n.kwargs.tab_index??0;if(typeof a=="number"){let o=e.context().pages(),r=a===-1?o.length-1:a;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} } },`,"});"]}},Kd=Tr.object({tab_index:Tr.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});import zd from"fs";import Vd from"path";async function Mr(e,t,i,n,a,o){let r=Array.isArray(t)?t:[t];if(r.length===0)throw new Error("No file paths provided for upload");let s=r.map(d=>{if(d.startsWith("/")||d.match(/^[A-Za-z]:\\/))return d;let h=n.testDataDir||process.cwd();return Vd.join(h,d)});u.info(`Uploading files: ${s.join(", ")}`);let l=i.timeout||2e4,c={useFileInput:i.useFileInput||!1,timeout:l};if(i.selector&&typeof i.selector!="string"){let d=i.selector;await tn(e,d,s,c);return}if(i.selector&&typeof i.selector=="string"){let d=i.selector,h=(d.startsWith("xpath="),e.locator(d));await tn(e,h,s,c);return}if(a){let d=r.map(p=>`"${p}"`).join(", "),h="";i.targetDescription?h=`Upload ${d} to ${i.targetDescription}`:h=`Upload ${d}`,u.info(`Using AI to handle file upload: ${h}`),await a(e,h,o)}else throw new Error("No selector provided and AI action execution is not available")}async function tn(e,t,i,n){let{useFileInput:a,timeout:o,mockShowOpenFilePicker:r}=n;if(r){u.info("Using mockShowOpenFilePicker approach");let s=i.map(l=>({path:l,buffer:new Uint8Array(zd.readFileSync(l))}));await e.evaluate(l=>{window.__pw_showOpenFilePicker_mock_files=l},s),await t.click({timeout:o}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(a)u.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:o}),await e.waitForTimeout(3e3);else{u.info("Using file chooser approach");let s=e.waitForEvent("filechooser",{timeout:o});s.catch(()=>{}),await t.click({timeout:o}),await(await s).setFiles(i),await e.waitForTimeout(3e3)}u.info(`Successfully uploaded ${i.length} file(s)`)}var Dt=x(()=>{"use strict";R()});import{z as Re}from"zod";async function Xd(e,t,i={},n){return{...await D(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function Ir(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 Pr(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:Yd,usesElementIndex:!0,async execute(i,n){let{element_index:a,paths:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let c=await W(n,a);if(!c)return{success:!1,error:`File input element with index ${a} not found`,actionEntity:Ir(l||`Upload file to element ${a}`,{index:a,paths:o})};let d=await Xd(c,r,{paths:o},l);return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Uploaded file to element ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:Ir(l||`Upload file to element ${a}`,{index:a,paths:o})}}}})}var Cr,Yd,Oy,Nt=x(()=>{"use strict";Dt();j();F();I();Cr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=[];if(n.kwargs.paths?a=Array.isArray(n.kwargs.paths)?n.kwargs.paths:[n.kwargs.paths]:n.kwargs.path&&(a=Array.isArray(n.kwargs.path)?n.kwargs.path:[n.kwargs.path]),a.length===0)throw new Error("No file paths provided for upload_file action");await i.downloadTestDataFiles(a);let o=a.map(c=>i.getTestDataFilePath(c)),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 tn(e,r,o,{useFileInput:s,timeout:C(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(a=>` ${a},`),"});"]}};Yd=Re.object({element_index:Re.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:Re.string().describe("Paths to the files to upload"),timeout_ms:Re.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});Oy=Re.object({element_index:Re.number().int().describe("Index of the file input element"),paths:Re.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:Re.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Or}from"zod";function Dr(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:Jd,async execute(i,n){let{seconds:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Wait ${a} seconds`,action_data:{action_name:"wait",kwargs:{seconds:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Waited ${a} seconds`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Wait ${a} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:a}},feedback:l.message}}}}})}var Lr,Jd,Rt=x(()=>{"use strict";Lr=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});`]}},Jd=Or.object({seconds:Or.number().positive().describe("Number of seconds to wait")})});import{z as Nr}from"zod";function Fr(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:qd,async execute(i,n){let{timeout_seconds:a=10}=i,{page:o,agentServices:r}=n;try{let s={action_description:`Wait for download to complete (timeout: ${a}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:a}}};return await t.execute(o,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:a}},feedback:s.message}}}}})}var Rr,qd,Ft=x(()=>{"use strict";Rr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,a)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},qd=Nr.object({timeout_seconds:Nr.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});import{z as Hr}from"zod";function Wr(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:Zd,async execute(i,n){let{keys:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Press keys "${a}"`,action_data:{action_name:"press",kwargs:{keys:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Pressed keys "${a}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Press keys "${a}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:a}},feedback:l.message}}}}})}var oa,Zd,Ht=x(()=>{"use strict";oa=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)});`]}},Zd=Hr.object({keys:Hr.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.")})});import{z as Qd}from"zod";function Br(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:eu,async execute(i,n){let{page:a,agentServices:o}=n;try{let r={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await t.execute(a,r,o),{success:!0,actionEntity:r,message:`Reloaded ${a.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 Ur,eu,Wt=x(()=>{"use strict";F();I();Ur=class{async execute(e,t){await e.reload({timeout:fe}),await e.waitForLoadState("load",{timeout:fe}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},eu=Qd.object({})});import{z as ra}from"zod";async function tu(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Gr(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 jr(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:iu,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Gr(`Right-click element ${a}`,"right_click",{index:a})};let c=s||`Right-click element ${a}`,d=await tu("right_click",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Right-clicked element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:Gr(`Right-click element ${a}`,"right_click",{index:a})}}}})}var sa,iu,Ut=x(()=>{"use strict";j();F();I();sa=class{async execute(e,t,i){let n=O(e,t),a=C(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({button:"right",timeout:a});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},`),"});"]}};iu=ra.object({element_index:ra.number().int().describe("Index of the element to right-click"),timeout_ms:ra.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as la}from"zod";function zr(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:nu,async execute(i,n){let{name:a,value:o}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Save variable "${a}" = "${o}"`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Saved variable "${a}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Save variable "${a}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}},feedback:l.message}}}}})}var Kr,nu,Bt=x(()=>{"use strict";Kr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.name,o=n.kwargs.value;if(!a||o===void 0)throw new Error("Missing variable name or value for save_variable");a.startsWith("$")&&(a=a.slice(1)),i.saveVariable(a,o)}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)} } },`,"});"]}},nu=la.object({name:la.string().describe("Variable name to save"),value:la.string().describe("Value to save in the variable")})});import{z as ca}from"zod";async function au(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function ou(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function Vr(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:ru,async execute(i,n){let{down:a,num_pages:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let c=l||`Scroll ${a?"down":"up"} ${o} page(s)`,d=await au("scroll",c,{down:a,num_pages:o});return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Scrolled ${a?"down":"up"} ${o} page(s)`}}catch(c){return{success:!1,error:c.message,actionEntity:ou(l||`Scroll ${a?"down":"up"} ${o} page(s)`,"scroll",{down:a,num_pages:o})}}}})}var Gt,ru,jt=x(()=>{"use strict";Gt=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,a=i.kwargs.num_pages??1,o=n?1:-1;await e.evaluate(`window.scrollBy(0, window.innerHeight * ${a} * ${o})`)}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)})');`]}};ru=ca.object({down:ca.boolean().describe("True to scroll down, False to scroll up"),num_pages:ca.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});import{z as Kt}from"zod";async function su(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Xr(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Jr(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:lu,usesElementIndex:!0,async execute(i,n){let{element_index:a,delta_x:o,delta_y:r}=i,{page:s,agentServices:l}=n;try{let c=await W(n,a);if(!c)return{success:!1,error:`Element with index ${a} not found`,actionEntity:Xr(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})};let d=await su("scroll_on_element",`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,c,s,{delta_x:o,delta_y:r});return await t.execute(s,d,l),{success:!0,actionEntity:d,message:`Scrolled on element ${a} horizontally: ${o}px, vertically: ${r}px`}}catch(c){return{success:!1,error:c.message,actionEntity:Xr(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})}}}})}var Yr,lu,zt=x(()=>{"use strict";j();F();I();Yr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.delta_x||0,o=n.kwargs.delta_y||0,r=O(e,t),s=C(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:s}),await e.mouse.wheel(a,o);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Ne(e);if(!t){let a=e.action_data?.kwargs?.delta_x||0,o=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${a}, delta_y: ${o} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,n=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${C()} });`,`await page.mouse.wheel(${i}, ${n});`]}};lu=Kt.object({element_index:Kt.number().int().describe("Index of the scrollable element"),delta_x:Kt.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:Kt.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:Kt.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as qr}from"zod";function Qr(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:cu,async execute(i,n){let{text:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Scroll to text "${a}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Scrolled to text "${a}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Scroll to text "${a}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:a}},feedback:l.message}}}}})}var Zr,cu,Vt=x(()=>{"use strict";Zr=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();`]}},cu=qr.object({text:qr.string().describe("Text to scroll to on the page")})});import{z as es}from"zod";async function du(e,t,i){return{...await D(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function ts(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 ns(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:uu,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:ts(s||`Get options from dropdown ${a}`,{index:a})};let c=await du(l,o,s);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:c.feedback||"No options found"}}catch(l){return{success:!1,error:l.message,actionEntity:ts(s||`Get options from dropdown ${a}`,{index:a})}}}})}var is,uu,Xt=x(()=>{"use strict";j();is=class{async execute(e,t,i){if(!t.xpath)throw new Error("XPath not found in action entity");let n=[];for(let a of e.frames())try{let o=await a.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(o){let r=[];for(let s of o.options){let l=JSON.stringify(s.text);r.push(`${s.index}: text=${l}`)}n.push(...r)}}catch{}if(n.length>0){let a=n.join(`
|
|
4107
4107
|
`);a+=`
|
|
4108
|
-
Use the exact text string in select_dropdown_option`,i.addNote(a)}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},`),"});"]}};uu=es.object({element_index:es.number().int().describe("Index of the dropdown/select element")})});import{z as hu}from"zod";function os(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:mu,async execute(i,n){let{page:a,agentServices:o,actionDescription:r}=n;try{let s={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(a,s,o),{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 as,mu,Yt=x(()=>{"use strict";F();I();as=class{async execute(e,t){await e.goBack({timeout:fe}),await e.waitForLoadState("load",{timeout:fe}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},mu=hu.object({})});import{z as nn}from"zod";function rs(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:pu,async execute(i,n){let{url:a,new_tab:o,timeout_seconds:r}=i,{page:s,agentServices:l,actionDescription:c}=n,d={url:a,new_tab:o??!1};r!==void 0&&(d.timeout_seconds=r);let h=r?` (timeout: ${r}s)`:"";try{let p=o?`Open ${a} in new tab`:`Navigate to ${a}`,g={action_description:c||p,action_data:{action_name:"go_to_url",kwargs:d}};return await t.execute(s,g,l),{success:!0,actionEntity:g,message:(o?`Opened ${a} in new tab`:`Navigated to ${a}`)+h}}catch(p){let g=o?`Open ${a} in new tab`:`Navigate to ${a}`;return{success:!1,error:p.message,actionEntity:{action_description:(c||g)+" (failed)",action_data:{action_name:"go_to_url",kwargs:d},feedback:p.message}}}}})}var da,pu,Jt=x(()=>{"use strict";F();I();da=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.url;if(!a)throw new Error("Missing URL for go_to_url action");let o=n.kwargs.new_tab===!0,r=i.replaceVariables(String(a));if(r.startsWith("/")){let c=e.url(),d=null;try{let h=new URL(c);h.origin&&h.origin!=="null"&&(d=h.origin)}catch{}d&&(r=d+r)}let s=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:fe,l=e;o&&(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,a=[`url: ${JSON.stringify(t)}`];return i&&a.push("new_tab: true"),n&&a.push(`timeout_seconds: ${n}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${a.join(", ")} } },`,"});"]}},pu=nn.object({url:nn.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:nn.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:nn.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});import{z as ua}from"zod";async function gu(e,t,i,n,a={}){return{...await L(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function ss(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 ls(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:fu,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:ss(`Hover element ${a}`,"hover",{index:a})};let c=s||`Hover over element ${a}`,d=await gu("hover",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Hovered over element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:ss(`Hover element ${a}`,"hover",{index:a})}}}})}var ha,fu,qt=x(()=>{"use strict";j();F();I();ha=class{async execute(e,t,i){let n=O(e,t),a=C(i,t.action_data?.kwargs?.timeout_ms);if(n){await n.waitFor({state:"attached",timeout:a});let o=await n.elementHandle();if(!o)throw new Error("Unable to obtain element handle for hover action");let r=await o.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},`),"});"]}};fu=ua.object({element_index:ua.number().int().describe("Index of the element to hover over"),timeout_ms:ua.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as an}from"zod";async function wu(e,t,i,n,a={}){return{...await L(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function cs(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 ds(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:bu,usesElementIndex:!0,async execute(i,n){let{element_index:a,text:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let c=await W(n,a);if(!c)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:cs(l||`Input text to element ${a}`,"input_text",{index:a,text:o})};let d=l||`Input text to element ${a}`,h=await wu("input_text",d,c,r,{text:o});return await t.execute(r,h,s),{success:!0,actionEntity:h,message:`Input text to element ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:cs(`Input text to element ${a}`,"input_text",{index:a,text:o})}}}})}var ma,bu,Zt=x(()=>{"use strict";j();F();I();ma=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.text??n.kwargs.value??"",o=i.replaceVariables(String(a)),r=O(e,t),s=C(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(c=>{c.value&&(c.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(o,{delay:l}):await e.keyboard.type(o)}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},`),"});"]}};bu=an.object({element_index:an.number().int().describe("Index of the input element"),text:an.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:an.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as us}from"zod";function ms(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:yu,async execute(i,n){let{index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Close tab ${a}`,action_data:{action_name:"close_tab",kwargs:{page_id:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Closed tab ${a}`}}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 hs,yu,Qt=x(()=>{"use strict";hs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.page_id??n.kwargs.index;if(a===void 0&&(a=e.context().pages().indexOf(e)),typeof a=="number"){if(a===0)throw new Error("Cannot close the first tab (page_id 0). Skipping close_tab action.");i&&await i.closeTab(a)}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} } },`,"});"]}},yu=us.object({index:us.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});import{z as pa}from"zod";function gs(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:xu,async execute(i,n){let{page:a,agentServices:o}=n;try{let r={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await t.execute(a,r,o),{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 ps,xu,ei=x(()=>{"use strict";ps=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},xu=pa.object({success:pa.boolean().describe("Whether the task was completed successfully"),summary:pa.string().describe("Summary of what was accomplished or why it failed")})});import{z as ga}from"zod";async function vu(e,t,i,n,a={}){return{...await L(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function fs(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 ws(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:_u,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:fs(`Double-click element ${a}`,"double_click",{index:a})};let c=s||`Double-click element ${a}`,d=await vu("double_click",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Double-clicked element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:fs(`Double-click element ${a}`,"double_click",{index:a})}}}})}var fa,_u,ti=x(()=>{"use strict";j();F();I();fa=class{async execute(e,t,i){let n=O(e,t),a=C(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.dblclick({timeout:a});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},`),"});"]}};_u=ga.object({element_index:ga.number().int().describe("Index of the element to double-click"),timeout_ms:ga.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as bs}from"zod";function xs(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:ku,async execute(i,n){let{otp_secret_key:a}=i,{page:o,agentServices:r}=n;try{let s={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:a}}};return await t.execute(o,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:a}},feedback:s.message}}}}})}var ys,ku,ii=x(()=>{"use strict";ys=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.otp_secret_key;if(!a)throw new Error("Missing otp_secret_key for generate_2fa_code");let o=i.replaceVariables(String(a)),r=await i.generate2faCode(o);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)} } },`,"});"]}},ku=bs.object({otp_secret_key:bs.string().describe("The OTP secret key to generate the 2FA code from")})});import{parse as Su}from"@babel/parser";function vs(e){if(!e.trim())return!1;try{return Su(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var on=x(()=>{"use strict"});import{z as _s}from"zod";import*as Eu from"playwright/test";import{default as Tu}from"playwright/test";function ks(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:Au,async execute(i,n){let{statement:a}=i,{page:o,agentServices:r}=n;try{let s={action_description:`${a}`,action_data:{action_name:"verify",kwargs:{statement:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Assertion verified: ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Verify: ${a} (failed)`,action_data:{action_name:"verify",kwargs:{statement:a}},feedback:s.message}}}},availability:{openai:!0,mcp:!0}})}var wa,rn,Au,ni=x(()=>{"use strict";on();R();ge();wa={};vi(wa,{default:()=>Tu});Ao(wa,Eu);rn=class{async execute(e,t,i){let n=t.action_data?.kwargs,a=typeof n?.code=="string",o=a?n?.statement||t.action_description:t.action_description||n?.statement;if(a&&o){let d=Date.now();try{await this.executeJSAssertion(e,n.code,i),u.info(`[VERIFY:JS] \u2713 ${((Date.now()-d)/1e3).toFixed(1)}s: ${o}`),i.addNote(`Assertion passed: ${o}`);return}catch(h){let p=((Date.now()-d)/1e3).toFixed(1);u.info(`[VERIFY:JS\u2192AI] JS failed ${p}s (${h instanceof Error?h.message:String(h)}), falling back to AI: ${o}`)}}else if(a){let d=Date.now();await this.executeJSAssertion(e,n.code,i),u.info(`[VERIFY:JS] \u2713 ${((Date.now()-d)/1e3).toFixed(1)}s: ${o||"js-only"}`),i.addNote(`Assertion passed: ${o||"js-only"}`);return}if(!o)throw new Error("Missing statement or code for verify action");let r=Date.now();u.info(`[VERIFY:AI] Evaluating: ${o}`);let{evaluateStatement:s}=await Promise.resolve().then(()=>(it(),tt)),l=await s(o,e,i,{useCleanScreenshotForAssertion:!0}),c=l.explanation||l.error||(l.success?`Assertion passed: ${o}`:"Assertion failed");if(i.addNote(c),!l.success)throw u.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`),new Error(l.error||l.explanation||"Assertion failed");u.info(`[VERIFY:AI] \u2713 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`)}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",`
|
|
4108
|
+
Use the exact text string in select_dropdown_option`,i.addNote(a)}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},`),"});"]}};uu=es.object({element_index:es.number().int().describe("Index of the dropdown/select element")})});import{z as hu}from"zod";function os(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:mu,async execute(i,n){let{page:a,agentServices:o,actionDescription:r}=n;try{let s={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(a,s,o),{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 as,mu,Yt=x(()=>{"use strict";F();I();as=class{async execute(e,t){await e.goBack({timeout:fe}),await e.waitForLoadState("load",{timeout:fe}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},mu=hu.object({})});import{z as nn}from"zod";function rs(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:pu,async execute(i,n){let{url:a,new_tab:o,timeout_seconds:r}=i,{page:s,agentServices:l,actionDescription:c}=n,d={url:a,new_tab:o??!1};r!==void 0&&(d.timeout_seconds=r);let h=r?` (timeout: ${r}s)`:"";try{let p=o?`Open ${a} in new tab`:`Navigate to ${a}`,g={action_description:c||p,action_data:{action_name:"go_to_url",kwargs:d}};return await t.execute(s,g,l),{success:!0,actionEntity:g,message:(o?`Opened ${a} in new tab`:`Navigated to ${a}`)+h}}catch(p){let g=o?`Open ${a} in new tab`:`Navigate to ${a}`;return{success:!1,error:p.message,actionEntity:{action_description:(c||g)+" (failed)",action_data:{action_name:"go_to_url",kwargs:d},feedback:p.message}}}}})}var da,pu,Jt=x(()=>{"use strict";F();I();da=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.url;if(!a)throw new Error("Missing URL for go_to_url action");let o=n.kwargs.new_tab===!0,r=i.replaceVariables(String(a));if(r.startsWith("/")){let c=e.url(),d=null;try{let h=new URL(c);h.origin&&h.origin!=="null"&&(d=h.origin)}catch{}d&&(r=d+r)}let s=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:fe,l=e;o&&(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,a=[`url: ${JSON.stringify(t)}`];return i&&a.push("new_tab: true"),n&&a.push(`timeout_seconds: ${n}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${a.join(", ")} } },`,"});"]}},pu=nn.object({url:nn.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:nn.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:nn.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});import{z as ua}from"zod";async function gu(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function ss(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 ls(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:fu,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:ss(`Hover element ${a}`,"hover",{index:a})};let c=s||`Hover over element ${a}`,d=await gu("hover",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Hovered over element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:ss(`Hover element ${a}`,"hover",{index:a})}}}})}var ha,fu,qt=x(()=>{"use strict";j();F();I();ha=class{async execute(e,t,i){let n=O(e,t),a=C(i,t.action_data?.kwargs?.timeout_ms);if(n){await n.waitFor({state:"attached",timeout:a});let o=await n.elementHandle();if(!o)throw new Error("Unable to obtain element handle for hover action");let r=await o.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},`),"});"]}};fu=ua.object({element_index:ua.number().int().describe("Index of the element to hover over"),timeout_ms:ua.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as an}from"zod";async function wu(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function cs(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 ds(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:bu,usesElementIndex:!0,async execute(i,n){let{element_index:a,text:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let c=await W(n,a);if(!c)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:cs(l||`Input text to element ${a}`,"input_text",{index:a,text:o})};let d=l||`Input text to element ${a}`,h=await wu("input_text",d,c,r,{text:o});return await t.execute(r,h,s),{success:!0,actionEntity:h,message:`Input text to element ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:cs(`Input text to element ${a}`,"input_text",{index:a,text:o})}}}})}var ma,bu,Zt=x(()=>{"use strict";j();F();I();ma=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.text??n.kwargs.value??"",o=i.replaceVariables(String(a)),r=O(e,t),s=C(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(c=>{c.value&&(c.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(o,{delay:l}):await e.keyboard.type(o)}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},`),"});"]}};bu=an.object({element_index:an.number().int().describe("Index of the input element"),text:an.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:an.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as us}from"zod";function ms(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:yu,async execute(i,n){let{index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Close tab ${a}`,action_data:{action_name:"close_tab",kwargs:{page_id:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Closed tab ${a}`}}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 hs,yu,Qt=x(()=>{"use strict";hs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.page_id??n.kwargs.index;if(a===void 0&&(a=e.context().pages().indexOf(e)),typeof a=="number"){if(a===0)throw new Error("Cannot close the first tab (page_id 0). Skipping close_tab action.");i&&await i.closeTab(a)}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} } },`,"});"]}},yu=us.object({index:us.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});import{z as pa}from"zod";function gs(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:xu,async execute(i,n){let{page:a,agentServices:o}=n;try{let r={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await t.execute(a,r,o),{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 ps,xu,ei=x(()=>{"use strict";ps=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},xu=pa.object({success:pa.boolean().describe("Whether the task was completed successfully"),summary:pa.string().describe("Summary of what was accomplished or why it failed")})});import{z as ga}from"zod";async function vu(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function fs(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 ws(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:_u,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:fs(`Double-click element ${a}`,"double_click",{index:a})};let c=s||`Double-click element ${a}`,d=await vu("double_click",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Double-clicked element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:fs(`Double-click element ${a}`,"double_click",{index:a})}}}})}var fa,_u,ti=x(()=>{"use strict";j();F();I();fa=class{async execute(e,t,i){let n=O(e,t),a=C(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.dblclick({timeout:a});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},`),"});"]}};_u=ga.object({element_index:ga.number().int().describe("Index of the element to double-click"),timeout_ms:ga.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as bs}from"zod";function xs(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:ku,async execute(i,n){let{otp_secret_key:a}=i,{page:o,agentServices:r}=n;try{let s={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:a}}};return await t.execute(o,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:a}},feedback:s.message}}}}})}var ys,ku,ii=x(()=>{"use strict";ys=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.otp_secret_key;if(!a)throw new Error("Missing otp_secret_key for generate_2fa_code");let o=i.replaceVariables(String(a)),r=await i.generate2faCode(o);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)} } },`,"});"]}},ku=bs.object({otp_secret_key:bs.string().describe("The OTP secret key to generate the 2FA code from")})});import{parse as Su}from"@babel/parser";function vs(e){if(!e.trim())return!1;try{return Su(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var on=x(()=>{"use strict"});import{z as _s}from"zod";import*as Eu from"playwright/test";import{default as Tu}from"playwright/test";function ks(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:Au,async execute(i,n){let{statement:a}=i,{page:o,agentServices:r}=n;try{let s={action_description:`${a}`,action_data:{action_name:"verify",kwargs:{statement:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Assertion verified: ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Verify: ${a} (failed)`,action_data:{action_name:"verify",kwargs:{statement:a}},feedback:s.message}}}},availability:{openai:!0,mcp:!0}})}var wa,rn,Au,ni=x(()=>{"use strict";on();R();ge();wa={};vi(wa,{default:()=>Tu});Ao(wa,Eu);rn=class{async execute(e,t,i){let n=t.action_data?.kwargs,a=typeof n?.code=="string",o=a?n?.statement||t.action_description:t.action_description||n?.statement;if(a&&o){let d=Date.now();try{await this.executeJSAssertion(e,n.code,i),u.info(`[VERIFY:JS] \u2713 ${((Date.now()-d)/1e3).toFixed(1)}s: ${o}`),i.addNote(`Assertion passed: ${o}`);return}catch(h){let p=((Date.now()-d)/1e3).toFixed(1);u.info(`[VERIFY:JS\u2192AI] JS failed ${p}s (${h instanceof Error?h.message:String(h)}), falling back to AI: ${o}`)}}else if(a){let d=Date.now();await this.executeJSAssertion(e,n.code,i),u.info(`[VERIFY:JS] \u2713 ${((Date.now()-d)/1e3).toFixed(1)}s: ${o||"js-only"}`),i.addNote(`Assertion passed: ${o||"js-only"}`);return}if(!o)throw new Error("Missing statement or code for verify action");let r=Date.now();u.info(`[VERIFY:AI] Evaluating: ${o}`);let{evaluateStatement:s}=await Promise.resolve().then(()=>(it(),tt)),l=await s(o,e,i,{useCleanScreenshotForAssertion:!0}),c=l.explanation||l.error||(l.success?`Assertion passed: ${o}`:"Assertion failed");if(i.addNote(c),!l.success)throw u.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`),new Error(l.error||l.explanation||"Assertion failed");u.info(`[VERIFY:AI] \u2713 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`)}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
4109
|
return (async () => {
|
|
4110
4110
|
${t}
|
|
4111
4111
|
})();
|
|
4112
4112
|
`)(e,wa.expect,n)}catch(a){throw new Error(`Assertion failed: ${a instanceof Error?a.message:String(a)}`)}}transpile(e,t){let i=e.action_data?.kwargs,n=typeof i?.code=="string",a=n?i?.statement||e.action_description:e.action_description||i?.statement,o=JSON.stringify(t||"");if(n){let r=i.code;if(!vs(r))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(r)});`];if(a){let s=r.split(`
|
|
4113
4113
|
`),l=JSON.stringify(a);return["{ const _t = Date.now(); try {",...s.map(c=>` ${c}`),` 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}, ${o});`,"} }"]}return r.split(`
|
|
4114
|
-
`)}return a?[`await agent.assert(page, ${JSON.stringify(a)}, ${o});`]:["// Skipping verify: missing statement or code"]}},Au=_s.object({statement:_s.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});import{z as ba}from"zod";function Es(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:$u,async execute(i,n){let{element_description:a,variable_name:o}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Extract ${a} to ${o}`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Extracted ${a} to ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Extract ${a} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}},feedback:l.message}}}},availability:{openai:!1,mcp:!0}})}var Ss,$u,ai=x(()=>{"use strict";Ss=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.element_description,o=n.kwargs.variable_name;if(!a||!o)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${a} and save to ${o}`,{executeStep:s}=await Promise.resolve().then(()=>(it(),tt)),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 a=JSON.stringify(i),o=JSON.stringify(n);return[`await agent.extract(page, ${a}, ${o}, '${t||""}');`]}},$u=ba.object({element_description:ba.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:ba.string().describe("Name of the variable to store the extracted value")})});import{z as ya}from"zod";async function Mu(e,t,i,n,a={}){return{...await L(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Ts(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 $s(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:Iu,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:Ts(s||`Clear element ${a}`,"clear_input",{index:a})};let c=s||`Clear element ${a}`,d=await Mu("clear_input",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Cleared element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:Ts(`Clear element ${a}`,"clear_input",{index:a})}}}})}var As,Iu,oi=x(()=>{"use strict";j();F();I();As=class{async execute(e,t,i){let n=O(e,t),a=C(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a}),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},`),"});"]}};Iu=ya.object({element_index:ya.number().int().describe("Index of the input element to clear"),timeout_ms:ya.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as xa}from"zod";async function Cu(e,t,i,n,a={}){return{...await L(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Ms(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 Is(e,t){e.register({name:"click",description:"Click an interactive element.",schema:Pu,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Ms(`Click element ${a}`,"click",{index:a})};let c=s||`Click element ${a}`,d=await Cu("click",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Clicked element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:Ms(`Click element ${a}`,"click",{index:a})}}}})}var sn,Pu,ri=x(()=>{"use strict";j();F();I();sn=class{async execute(e,t,i){let n=O(e,t),a=C(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a});else throw new Error("No locator found for click action")}transpile(e){let t=Ne(e);if(!t)return['await agent.execAction("click", page, {});'];let i=C();return[`await ${t}.click({ timeout: ${i} });`]}};Pu=xa.object({element_index:xa.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:xa.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});var Ou,Du,ln,cn=x(()=>{"use strict";Ou=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Du=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],ln=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:Ou.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,a=i.variable_name;return n&&a?`Extract ${n} and save to ${a}`: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:!Du.includes(t)}}});var va,_a,ka,Sa=x(()=>{"use strict";Ui();Bi();Gi();ji();Ki();zi();Vi();Xi();Yi();qi();Zi();Ct();Pt();Ot();Dt();Nt();Rt();Ft();Ht();Wt();Ut();Bt();jt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();oi();ri();cn();F();ge();va=class T{static registerAction(t,i){T.actions.set(t,i)}constructor(){T.initialized||(this.registerBuiltinActions(),T.initialized=!0)}registerBuiltinActions(){T.registerAction("go_to_url",new da),T.registerAction("go_back",new as),T.registerAction("reload_page",new Ur),T.registerAction("close_tab",new hs),T.registerAction("switch_tab",new Ar),T.registerAction("click",new sn),T.registerAction("hover",new ha),T.registerAction("right_click",new sa),T.registerAction("double_click",new fa),T.registerAction("click_by_coordinates",new dr),T.registerAction("right_click_by_coordinates",new rr),T.registerAction("double_click_by_coordinates",new ur),T.registerAction("drag_drop",new hr),T.registerAction("input_text",new ma),T.registerAction("clear_input",new As),T.registerAction("press",new oa),T.registerAction("send_keys_on_element",new ar),T.registerAction("scroll_on_element",new Yr),T.registerAction("scroll_to_text",new Zr),T.registerAction("scroll",new Gt),T.registerAction("upload_file",new Cr),T.registerAction("wait_for_download_complete",new Rr),T.registerAction("get_dropdown_options",new is),T.registerAction("select_dropdown_option",new _r),T.registerAction("set_date_for_native_date_picker",new Sr),T.registerAction("verify",new rn),T.registerAction("ai_action",new fr),T.registerAction("ai_extract",new Ss),T.registerAction("ai_step",new br),T.registerAction("ai_wait_until",new yr),T.registerAction("generate_2fa_code",new ys),T.registerAction("wait",new Dr),T.registerAction("wait_for_page_ready",new or),T.registerAction("save_variable",new Kr),T.registerAction("js_code",new cr),T.registerAction("js_action",new sr),T.registerAction("function",new mr),T.registerAction("done",new ps),T.registerAction("click_element",new sn),T.registerAction("click_element_by_index",new sn),T.registerAction("hover_element_by_index",new ha),T.registerAction("right_click_on_element",new sa),T.registerAction("double_click_on_element",new fa),T.registerAction("scroll_down",new Gt),T.registerAction("scroll_up",new Gt),T.registerAction("scroll_element",new Gt),T.registerAction("send_keys",new oa),T.registerAction("open_tab",new da),T.registerAction("fill",new ma),T.registerAction("ai_assert",new rn),T.registerAction("assert",new rn)}getAction(t){return T.actions.get(t)}hasAction(t){return T.actions.has(t)}getActionNames(){return Array.from(T.actions.keys())}async execute(t,i,n){if(!n)throw new Error("AgentServices not found");let a=i.action_data?.action_name;if(!a)throw new Error("Action name not found in action_data");let o=this.getAction(a);if(!o)throw new Error(`Unknown action: ${a}`);await o.execute(t,i,n)}transpile(t,i,n){let{sanitizeForComment:a}=(I(),Un(_i)),o=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(ln.isAiAction(t))return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);",...l];let c=JSON.stringify(o),d=l.map(g=>` ${g}`),h=ln.canSelfHeal(t),p=n?JSON.stringify(n):"undefined";return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...d,`}, ${c}, '${i}', ${p}, ${h});`]}transpileUncachedAction(t,i,n=!1,a=!1,o){let{sanitizeForComment:r}=(I(),Un(_i));if(!t)return[`// ${i}: Skipping - no description`];let s=JSON.stringify(t);if(a){let l=o?`, { stmtUid: ${JSON.stringify(o)} }`:"";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});`]}};va.actions=new Map,va.initialized=!1;_a=va,ka=_a});var rt={};dt(rt,{ActionHandler:()=>_a,default:()=>ka});var st=x(()=>{"use strict";Sa();Ui();Bi();Gi();ji();Ki();zi();Vi();Xi();Yi();qi();Zi();Ct();Pt();Ot();Dt();Nt();Rt();Ft();Ht();Wt();Ut();Bt();jt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();oi();ri();on();Lt();j();Ue();R();te();et();cn();F();ge()});import{z as si}from"zod";function dn(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
|
|
4114
|
+
`)}return a?[`await agent.assert(page, ${JSON.stringify(a)}, ${o});`]:["// Skipping verify: missing statement or code"]}},Au=_s.object({statement:_s.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});import{z as ba}from"zod";function Es(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:$u,async execute(i,n){let{element_description:a,variable_name:o}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Extract ${a} to ${o}`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Extracted ${a} to ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Extract ${a} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}},feedback:l.message}}}},availability:{openai:!1,mcp:!0}})}var Ss,$u,ai=x(()=>{"use strict";Ss=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.element_description,o=n.kwargs.variable_name;if(!a||!o)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${a} and save to ${o}`,{executeStep:s}=await Promise.resolve().then(()=>(it(),tt)),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 a=JSON.stringify(i),o=JSON.stringify(n);return[`await agent.extract(page, ${a}, ${o}, '${t||""}');`]}},$u=ba.object({element_description:ba.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:ba.string().describe("Name of the variable to store the extracted value")})});import{z as ya}from"zod";async function Mu(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Ts(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 $s(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:Iu,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:Ts(s||`Clear element ${a}`,"clear_input",{index:a})};let c=s||`Clear element ${a}`,d=await Mu("clear_input",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Cleared element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:Ts(`Clear element ${a}`,"clear_input",{index:a})}}}})}var As,Iu,oi=x(()=>{"use strict";j();F();I();As=class{async execute(e,t,i){let n=O(e,t),a=C(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a}),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},`),"});"]}};Iu=ya.object({element_index:ya.number().int().describe("Index of the input element to clear"),timeout_ms:ya.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as xa}from"zod";async function Cu(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Ms(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 Is(e,t){e.register({name:"click",description:"Click an interactive element.",schema:Pu,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Ms(`Click element ${a}`,"click",{index:a})};let c=s||`Click element ${a}`,d=await Cu("click",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Clicked element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:Ms(`Click element ${a}`,"click",{index:a})}}}})}var sn,Pu,ri=x(()=>{"use strict";j();F();I();sn=class{async execute(e,t,i){let n=O(e,t),a=C(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a});else throw new Error("No locator found for click action")}transpile(e){let t=Ne(e);if(!t)return['await agent.execAction("click", page, {});'];let i=C();return[`await ${t}.click({ timeout: ${i} });`]}};Pu=xa.object({element_index:xa.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:xa.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});var Ou,Lu,ln,cn=x(()=>{"use strict";Ou=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Lu=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],ln=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:Ou.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,a=i.variable_name;return n&&a?`Extract ${n} and save to ${a}`: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:!Lu.includes(t)}}});var va,_a,ka,Sa=x(()=>{"use strict";Ui();Bi();Gi();ji();Ki();zi();Vi();Xi();Yi();qi();Zi();Ct();Pt();Ot();Lt();Nt();Rt();Ft();Ht();Wt();Ut();Bt();jt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();oi();ri();cn();F();ge();va=class T{static registerAction(t,i){T.actions.set(t,i)}constructor(){T.initialized||(this.registerBuiltinActions(),T.initialized=!0)}registerBuiltinActions(){T.registerAction("go_to_url",new da),T.registerAction("go_back",new as),T.registerAction("reload_page",new Ur),T.registerAction("close_tab",new hs),T.registerAction("switch_tab",new Ar),T.registerAction("click",new sn),T.registerAction("hover",new ha),T.registerAction("right_click",new sa),T.registerAction("double_click",new fa),T.registerAction("click_by_coordinates",new dr),T.registerAction("right_click_by_coordinates",new rr),T.registerAction("double_click_by_coordinates",new ur),T.registerAction("drag_drop",new hr),T.registerAction("input_text",new ma),T.registerAction("clear_input",new As),T.registerAction("press",new oa),T.registerAction("send_keys_on_element",new ar),T.registerAction("scroll_on_element",new Yr),T.registerAction("scroll_to_text",new Zr),T.registerAction("scroll",new Gt),T.registerAction("upload_file",new Cr),T.registerAction("wait_for_download_complete",new Rr),T.registerAction("get_dropdown_options",new is),T.registerAction("select_dropdown_option",new _r),T.registerAction("set_date_for_native_date_picker",new Sr),T.registerAction("verify",new rn),T.registerAction("ai_action",new fr),T.registerAction("ai_extract",new Ss),T.registerAction("ai_step",new br),T.registerAction("ai_wait_until",new yr),T.registerAction("generate_2fa_code",new ys),T.registerAction("wait",new Lr),T.registerAction("wait_for_page_ready",new or),T.registerAction("save_variable",new Kr),T.registerAction("js_code",new cr),T.registerAction("js_action",new sr),T.registerAction("function",new mr),T.registerAction("done",new ps),T.registerAction("click_element",new sn),T.registerAction("click_element_by_index",new sn),T.registerAction("hover_element_by_index",new ha),T.registerAction("right_click_on_element",new sa),T.registerAction("double_click_on_element",new fa),T.registerAction("scroll_down",new Gt),T.registerAction("scroll_up",new Gt),T.registerAction("scroll_element",new Gt),T.registerAction("send_keys",new oa),T.registerAction("open_tab",new da),T.registerAction("fill",new ma),T.registerAction("ai_assert",new rn),T.registerAction("assert",new rn)}getAction(t){return T.actions.get(t)}hasAction(t){return T.actions.has(t)}getActionNames(){return Array.from(T.actions.keys())}async execute(t,i,n){if(!n)throw new Error("AgentServices not found");let a=i.action_data?.action_name;if(!a)throw new Error("Action name not found in action_data");let o=this.getAction(a);if(!o)throw new Error(`Unknown action: ${a}`);await o.execute(t,i,n)}transpile(t,i,n){let{sanitizeForComment:a}=(I(),Un(_i)),o=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(ln.isAiAction(t))return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);",...l];let c=JSON.stringify(o),d=l.map(g=>` ${g}`),h=ln.canSelfHeal(t),p=n?JSON.stringify(n):"undefined";return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...d,`}, ${c}, '${i}', ${p}, ${h});`]}transpileUncachedAction(t,i,n=!1,a=!1,o){let{sanitizeForComment:r}=(I(),Un(_i));if(!t)return[`// ${i}: Skipping - no description`];let s=JSON.stringify(t);if(a){let l=o?`, { stmtUid: ${JSON.stringify(o)} }`:"";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});`]}};va.actions=new Map,va.initialized=!1;_a=va,ka=_a});var rt={};dt(rt,{ActionHandler:()=>_a,default:()=>ka});var st=x(()=>{"use strict";Sa();Ui();Bi();Gi();ji();Ki();zi();Vi();Xi();Yi();qi();Zi();Ct();Pt();Ot();Lt();Nt();Rt();Ft();Ht();Wt();Ut();Bt();jt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();oi();ri();on();Dt();j();Ue();R();te();et();cn();F();ge()});import{z as si}from"zod";function dn(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
|
|
4115
4115
|
${e.stepHistory.slice(-3).map(l=>{let c=`${l.outcome.success?"\u2713":"\u2717"} Step ${l.stepNumber}: ${l.goal}`;if(l.actions.length>1)l.actions.forEach((d,h)=>{let p=d.action_description||"Unknown action";c+=`
|
|
4116
4116
|
\u2192 Action ${h+1}: ${p}`});else if(l.actions.length===1){let d=l.actions[0]?.action_description||"Unknown action";c+=`
|
|
4117
4117
|
\u2192 ${d}`}if(!l.outcome.success&&l.outcome.error){let d=l.outcome.error.substring(0,100);c+=`
|
|
@@ -4140,7 +4140,7 @@ This is your last step. You MUST use the "done" action now.
|
|
|
4140
4140
|
- If the task is incomplete or partially complete, set success=false
|
|
4141
4141
|
- Include everything you've accomplished in the done action's text field
|
|
4142
4142
|
- No other actions are allowed on this step
|
|
4143
|
-
`.trim()}function
|
|
4143
|
+
`.trim()}function Du(){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 si.ZodObject){let a=i.schema.shape,o=[];Object.keys(a).forEach(r=>{let s=a[r],l="any";s instanceof si.ZodNumber?l="number":s instanceof si.ZodString?l="string":s instanceof si.ZodBoolean?l="boolean":s instanceof si.ZodEnum&&(l=s._def.values.map(c=>`"${c}"`).join(" | ")),o.push(`${r}: ${l}`)}),n=`{${o.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(`
|
|
4144
4144
|
`)}function un(e,t={}){if(e)return e;let{useThinking:i=!0,useMemory:n=!0,useEvaluation:a=!0,useMultiAction:o=!0}=t,r=a?`
|
|
4145
4145
|
1. **Evaluate Previous Step**: After each action, evaluate whether the previous goal was accomplished:
|
|
4146
4146
|
- "success: <reason>" if the goal was fully achieved
|
|
@@ -4248,7 +4248,7 @@ CRITICAL: Detect when you are stuck and stop immediately:
|
|
|
4248
4248
|
|
|
4249
4249
|
When stuck, call \`done\` with success=false and explain what happened.
|
|
4250
4250
|
|
|
4251
|
-
${
|
|
4251
|
+
${Du()}
|
|
4252
4252
|
## Reasoning Rules
|
|
4253
4253
|
|
|
4254
4254
|
Use the \`thinking\` field to reason about each step:
|
|
@@ -4300,7 +4300,7 @@ ${g.join(`
|
|
|
4300
4300
|
`,n+=`- Use the EXACT placeholder name as shown above
|
|
4301
4301
|
`,n+=`- Do NOT use the actual value directly in the action
|
|
4302
4302
|
`,n+=`- The values shown are for context only to help you understand what data is available
|
|
4303
|
-
`,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 lt=x(()=>{"use strict"});async function Wu(e,t){let i=new Set,n=Date.now(),a=new Set(["document","stylesheet","image","font","script","iframe"]),o=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(!a.has(p)||s(g))return;let f=h.headers();f.purpose==="prefetch"||["video","audio"].includes(f["sec-fetch-dest"])||(i.add(h),n=Date.now())},c=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(v=>g.includes(v))){i.delete(p);return}if(![...o].some(v=>g.startsWith(v))){i.delete(p);return}let f=h.headers()["content-length"];if(f)try{if(parseInt(f,10)>5*1024*1024){i.delete(p);return}}catch{}i.delete(p),n=Date.now()},d=Date.now()-Hu;for(let h of await e.requests()){let p=h.resourceType(),g=h.url(),f=h.timing();a.has(p)&&!s(g)&&f.responseEnd===-1&&f.startTime>=d&&(i.add(h),n=Date.now())}u.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",c);try{let h=Date.now(),p=Fu;for(;;){await new Promise(f=>setTimeout(f,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",c)}}async function Me(e,t=Ru,i=Nu){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),Wu(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 a=Date.now()-n,o=Math.max(i-a,0);o>0&&await new Promise(r=>setTimeout(r,o))}var Nu,Ru,Fu,Hu,Ie=x(()=>{"use strict";lt();R();Nu=.5*1e3,Ru=30*1e3,Fu=1*1e3,Hu=3*1e3});import{generateText as Uu}from"ai";function Bu(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 Ds(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 a=i.maxSteps??15,o=3,r=t.agentServices.getModel(),s=t.domService||new be(t.agentServices.getDomServiceOptions()),l={...t,domService:s};w.init(),w.section("Task Execution Started"),w.log(`Task: ${e}`),w.log(`Max steps: ${a}`),w.log(`Model: ${r}`);let c={currentStep:0,maxSteps:a,consecutiveFailures:0,maxFailures:o,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},d=[],h=un(i.customPrompt),p=new mn(h);w.log(`System prompt length: ${h.length} chars`);let g=!1,f="",v=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:a});c.currentStep<a;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");c.currentStep++;let b=Date.now();w.section(`Step ${c.currentStep}/${a}`),w.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:c.currentStep});try{w.log("Waiting for page to stabilize..."),await Me(l.page),w.log("Page stabilized")}catch{w.log("Page stabilization timed out, continuing anyway")}let m;try{w.log("Preparing context (DOM + screenshot)...");let D=l.agentServices.getInteractiveClassNames(),N=l.agentServices.getIframeFallbackDomains();m=await Os(l.page,l.domService,D,N),w.log("Context prepared")}catch(D){if(D.message.includes("Execution context was destroyed")){w.log("Page navigating, waiting for load..."),await Me(l.page);let N=l.agentServices.getInteractiveClassNames(),P=l.agentServices.getIframeFallbackDomains();m=await Os(l.page,l.domService,N,P)}else throw w.error("Error preparing context",D),D}p.addStateMessage(e,m.currentUrl,m.domTree,m.screenshotBase64,c,{isFinalStep:c.currentStep===a-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let y=await ju(p,r,i,m.screenshotBase64);if(y.tokenUsages&&y.tokenUsages.length>0&&d.push(...y.tokenUsages),!y.stepOutput){if(w.error("Failed to get valid LLM response"),c.consecutiveFailures++,c.consecutiveFailures>=o){f="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let S=y.stepOutput;Xu(c.currentStep,a,S);let E=await zu(S,l,m.domState,c.currentStep,i.onEvent,m.screenshotBase64,y.debugInfo);v.push(...E.actionEntities);let A=Vu(c.currentStep,S,E,c,b,y.debugInfo,y.tokenUsages),M=Date.now()-b;if(i.onEvent?.({type:"step_complete",step:c.currentStep,duration:M}),c.consecutiveFailures>=o){w.error(`Too many consecutive failures (${c.consecutiveFailures}), stopping`),f=`Reached the maximum allowed consecutive failures. Most recent error: ${c.lastFailReason}`;break}if(E.doneResult){g=E.doneResult.success,f=E.doneResult.summary;break}if(E.completesInstruction){g=!0,f="Instruction completed";break}}return c.currentStep>=a&&!g&&(f="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:c.currentStep,duration:Date.now()-n}),w.log(`Build success result: summary=${f}, completed=${g}, actions=${v.length}, tokens=${d.length}`),Yu(c,v,g,f,n,d,r)}catch(b){let m=b.message;return w.error(`Task execution failed: ${m}`,b),i.onEvent?.({type:"error",error:m,recoverable:!1}),Ju(c,m,n,d,r)}}async function Os(e,t,i,n){let{domState:a,screenshotBase64:o}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n}),r=a.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:r,screenshotBase64:o,domState:a}}function Gu(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,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 ju(e,t,i,n){let a=i.temperature??0,{system:o,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=Ee(t,s),c={model:Se(t),system:o,messages:r,temperature:a,providerOptions:l},d=3;for(let h=0;h<d;h++)try{let p=Date.now();w.log(`Calling LLM (${t})...`);let g=await Uu(c),f=Date.now()-p,v=g,b=v.usage;w.llmCall(t,f,b);let m=v.reasoningText;m&&(w.thinking(m),i.onEvent?.({type:"thinking",text:m})),e.addAssistantMessage(g.text);let y={systemPrompt:o,userPrompt:Gu(r),rawLlmResponse:g.text,reasoningContent:m,screenshotWithSom:n},S=[],E=Bu(b,t);E&&S.push(E);let A=Ku(g.text);if(!A)if(h<d-1){w.log(`Attempt ${h+1}/${d}: 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(M=>setTimeout(M,i.retryDelay||1e3));continue}else return w.error("All parsing attempts failed"),{stepOutput:null,debugInfo:y,tokenUsages:S};return{stepOutput:A,debugInfo:y,tokenUsages:S}}catch(p){if(h<d-1){w.log(`Attempt ${h+1}/${d}: LLM call failed (${p.message}), retrying...`),await new Promise(g=>setTimeout(g,i.retryDelay||1e3));continue}else throw w.error("All LLM call attempts failed",p),p}return{stepOutput:null}}function Ku(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 w.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return w.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return w.error("Action missing required field: action_name"),null;if(!n.description)return w.error("Action missing required field: description"),null}return i}catch(i){return w.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),w.error(`Parse error: ${i.message}`),null}}async function zu(e,t,i,n,a,o,r){let s=[],l=!0,c=null;w.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let d=null,h={...t,domState:i},p=o;for(let g of e.actions){if(g.action_name==="done"){d={success:g.kwargs.success??!0,summary:g.kwargs.summary||g.kwargs.text||"Task completed"};break}let f={},v=g.kwargs?.element_index??g.kwargs?.index;if(typeof v=="number"){let m=i.selectorMap.get(v);m&&(f=await L(t.page,m))}let b={...f,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"&&(b=m.actionEntity);let y=await h.agentServices.getCurrentPage();if(y&&(h.page=y,t.page=h.page),m?.success===!1){l=!1,w.log("Action failed, stopping execution of remaining actions in this step"),c=m.error||"Action execution failed";break}s.push(b),a?.({type:"action",action_entity:b,step:n,debugInfo:r})}catch(m){l=!1,c=m.message,w.error(`Action execution failed: ${m.message}`);break}}return{allSuccess:l,failReason:c,actionEntities:s,doneResult:d,completesInstruction:e.completes_instruction??!1}}function Vu(e,t,i,n,a,o,r){let s={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:a,duration:Date.now()-a,outcome:{success:i.allSuccess},debugInfo:o,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 Xu(e,t,i){if(w.log(`Step ${e}/${t}`),i.thinking&&w.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&w.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&w.log(`Memory: ${i.memory}`),w.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];w.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else w.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,a)=>{w.log(` ${a+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function Yu(e,t,i,n,a,o,r){let s=o.reduce((d,h)=>d+h.prompt_tokens,0),l=o.reduce((d,h)=>d+h.completion_tokens,0),c=o.reduce((d,h)=>d+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()-a,model:r,successfulSteps:e.stepHistory.filter(d=>d.outcome.success).length,failedSteps:e.stepHistory.filter(d=>!d.outcome.success).length,promptTokens:s,completionTokens:l,totalTokens:c,tokenUsages:o}}}function Ju(e,t,i,n,a){let o=n.reduce((l,c)=>l+c.prompt_tokens,0),r=n.reduce((l,c)=>l+c.completion_tokens,0),s=n.reduce((l,c)=>l+c.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:a,successfulSteps:e.stepHistory.filter(l=>l.outcome.success).length,failedSteps:e.stepHistory.filter(l=>!l.outcome.success).length,promptTokens:o,completionTokens:r,totalTokens:s,tokenUsages:n}}}var Ls=x(()=>{"use strict";Ea();hn();Ae();Be();ie();Ie();Te();j()});var Ns={};dt(Ns,{TaskMessageManager:()=>mn,formatFinalStepWarning:()=>Cs,formatTaskContext:()=>dn,getBrowserTaskJSONPrompt:()=>un,runTaskLoop:()=>Ds});var Rs=x(()=>{"use strict";Ls();Ea();hn();Ae();Ji();Be();kt();St();Qe();Et();Tt();ie();Ie();lt();Te();ft();wt();Ye();j();Ue();R();te();et();F();ge()});async function $t(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 a=await H.execute(i,n,t),o=a?.success!==!1,r=a?.error||a?.message;return{success:o,error:o?void 0:r}}else{let{page:a,agentServices:o}=t;return await(await qu()).execute(a,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function qu(){if(pn)return pn;let e=await Promise.resolve().then(()=>(st(),rt));return pn=new e.default,pn}async function Mt(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new be(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await qn(r,o,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 nt(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new be(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await qn(r,o,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:c,goalAccomplished:d,debugInfo:h}=s,p=await $t(l,o);return p.success?(c&&i.addNote(c),{status:"success",completed:d||!1,actionEntities:[l],explanation:c,debugInfo:h}):{status:"error",completed:!1,actionEntities:[l],error:p.error||"Action execution failed",debugInfo:h}}async function at(e,t,i,n={}){let a={page:t,agentServices:i,domService:new be(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},o=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),Jo(o,a,n)}async function ot(e,t,i,n,a={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>(Rs(),Ns)),r=n?l=>{n(l)}:void 0,s=await o(e,{page:t,agentServices:i,domService:void 0,executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},{maxSteps:a.maxSteps,onEvent:r,abortSignal:a.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 pn,It=x(()=>{"use strict";Hi();Ae();Be();pn=null});import{z as k}from"zod";import"yaml";import"uuid";import"yaml";import"uuid";function Ta(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=o=>{let r=o.startsWith("$")?o.slice(1):o,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},a=e;return a=a.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(o,r)=>{let s=n(r.trim());return s!==void 0?s:o}),a=a.replace(/<secret>\$?([\w-]+)<\/secret>/g,(o,r)=>{let s=n(r);return s!==void 0?s:o}),a=a.replace(/\$\{([^}]+)\}/g,(o,r)=>{let s=n(r.trim());return s!==void 0?s:o}),a=a.replace(/\$([a-zA-Z_]\w*)/g,(o,r)=>{let s=n(r);return s!==void 0?s:o}),a}var tl,iS,il,rh,sh,fn,nS,aS,wn,nl,al,lh,el,ch,li,dh,uh,hh,se,mh,ph,rS,wS,ct=x(()=>{"use strict";ge();tl=112,iS=1080-tl,il=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(il||{}),rh={"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"}},sh={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"]},fn=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),sh[e].map(n=>rh[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},nS={desktop:{label:"Desktop",type:"desktop",devices:fn("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:fn("mobile")}},aS={desktop:{label:"Desktop",type:"desktop",devices:fn("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:fn("mobile",!0)}},wn=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(wn||{}),nl=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(nl||{});al=class ol{constructor(){Bn(this,"data",{}),Bn(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 ol;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[a,o]of Object.entries(t.data))i.set(a,o,n.has(a))}return i}},lh=k.enum(["JS_CODE","AI_MODE"]),el=k.object({type:lh,expression:k.string()}),ch=k.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),li=k.object({uid:k.string(),type:ch,comment:k.string().optional()}),dh=k.object({action_data:k.object({action_name:k.string(),kwargs:k.record(k.any()).optional(),args:k.array(k.any()).optional()}),action_description:k.string().optional(),url:k.string().optional(),xpath:k.string().nullable().optional(),locator:k.string().nullable().optional(),css_selector:k.string().nullable().optional(),unique_selector:k.string().nullable().optional(),element_index:k.number().nullable().optional(),frame_path:k.array(k.any()).optional(),artifacts:k.record(k.any()).optional(),feedback:k.string().optional(),original_browser_use_action:k.any().optional()}).passthrough(),uh=li.extend({type:k.literal("DRAFT"),description:k.string()}),hh=li.extend({type:k.literal("ACTION"),description:k.string(),action_entity:dh.optional(),locator:k.string().optional(),use_pure_vision:k.boolean().optional()}),se=k.lazy(()=>k.union([uh,hh,li.extend({type:k.literal("STEP"),description:k.string().optional().default(""),statements:k.array(se),reference_id:k.number().optional()}),li.extend({type:k.literal("IF_ELSE"),description:k.string().optional(),condition:el,then:k.array(se),else:k.array(se).optional()}),li.extend({type:k.literal("WHILE_LOOP"),description:k.string().optional(),condition:el,body:k.array(se),timeout_ms:k.number().optional()})])),mh=k.object({name:k.string(),statements:k.array(se),teardown:k.array(se).optional(),skip:k.union([k.boolean(),k.string()]).optional(),timeout:k.number().optional(),fail:k.union([k.boolean(),k.string()]).optional(),only:k.boolean().optional(),slow:k.boolean().optional()}),ph=k.object({tests:k.array(mh).min(1),beforeAll:k.array(se).optional(),afterAll:k.array(se).optional(),beforeEach:k.array(se).optional(),afterEach:k.array(se).optional()}),rS=k.object({comment:k.string().optional(),version:k.string().optional(),goal:k.string().optional(),url:k.string().optional(),baseURL:k.string().optional(),final_feedback:k.string().optional(),completed:k.boolean().optional(),success:k.boolean().optional(),statements:k.array(se).optional(),teardown:k.array(se).optional(),last_modified_at:k.string().optional(),testGroup:ph.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"}),wS=1024*1024});async function rl(e,t){let i=Object.getPrototypeOf(async()=>{}).constructor,n=`
|
|
4303
|
+
`,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 lt=x(()=>{"use strict"});async function Wu(e,t){let i=new Set,n=Date.now(),a=new Set(["document","stylesheet","image","font","script","iframe"]),o=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(!a.has(p)||s(g))return;let f=h.headers();f.purpose==="prefetch"||["video","audio"].includes(f["sec-fetch-dest"])||(i.add(h),n=Date.now())},c=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(v=>g.includes(v))){i.delete(p);return}if(![...o].some(v=>g.startsWith(v))){i.delete(p);return}let f=h.headers()["content-length"];if(f)try{if(parseInt(f,10)>5*1024*1024){i.delete(p);return}}catch{}i.delete(p),n=Date.now()},d=Date.now()-Hu;for(let h of await e.requests()){let p=h.resourceType(),g=h.url(),f=h.timing();a.has(p)&&!s(g)&&f.responseEnd===-1&&f.startTime>=d&&(i.add(h),n=Date.now())}u.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",c);try{let h=Date.now(),p=Fu;for(;;){await new Promise(f=>setTimeout(f,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",c)}}async function Me(e,t=Ru,i=Nu){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),Wu(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 a=Date.now()-n,o=Math.max(i-a,0);o>0&&await new Promise(r=>setTimeout(r,o))}var Nu,Ru,Fu,Hu,Ie=x(()=>{"use strict";lt();R();Nu=.5*1e3,Ru=30*1e3,Fu=1*1e3,Hu=3*1e3});import{generateText as Uu}from"ai";function Bu(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 Ls(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 a=i.maxSteps??15,o=3,r=t.agentServices.getModel(),s=t.domService||new be(t.agentServices.getDomServiceOptions()),l={...t,domService:s};w.init(),w.section("Task Execution Started"),w.log(`Task: ${e}`),w.log(`Max steps: ${a}`),w.log(`Model: ${r}`);let c={currentStep:0,maxSteps:a,consecutiveFailures:0,maxFailures:o,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},d=[],h=un(i.customPrompt),p=new mn(h);w.log(`System prompt length: ${h.length} chars`);let g=!1,f="",v=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:a});c.currentStep<a;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");c.currentStep++;let b=Date.now();w.section(`Step ${c.currentStep}/${a}`),w.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:c.currentStep});try{w.log("Waiting for page to stabilize..."),await Me(l.page),w.log("Page stabilized")}catch{w.log("Page stabilization timed out, continuing anyway")}let m;try{w.log("Preparing context (DOM + screenshot)...");let L=l.agentServices.getInteractiveClassNames(),N=l.agentServices.getIframeFallbackDomains();m=await Os(l.page,l.domService,L,N),w.log("Context prepared")}catch(L){if(L.message.includes("Execution context was destroyed")){w.log("Page navigating, waiting for load..."),await Me(l.page);let N=l.agentServices.getInteractiveClassNames(),P=l.agentServices.getIframeFallbackDomains();m=await Os(l.page,l.domService,N,P)}else throw w.error("Error preparing context",L),L}p.addStateMessage(e,m.currentUrl,m.domTree,m.screenshotBase64,c,{isFinalStep:c.currentStep===a-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let y=await ju(p,r,i,m.screenshotBase64);if(y.tokenUsages&&y.tokenUsages.length>0&&d.push(...y.tokenUsages),!y.stepOutput){if(w.error("Failed to get valid LLM response"),c.consecutiveFailures++,c.consecutiveFailures>=o){f="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let S=y.stepOutput;Xu(c.currentStep,a,S);let E=await zu(S,l,m.domState,c.currentStep,i.onEvent,m.screenshotBase64,y.debugInfo);v.push(...E.actionEntities);let A=Vu(c.currentStep,S,E,c,b,y.debugInfo,y.tokenUsages),M=Date.now()-b;if(i.onEvent?.({type:"step_complete",step:c.currentStep,duration:M}),c.consecutiveFailures>=o){w.error(`Too many consecutive failures (${c.consecutiveFailures}), stopping`),f=`Reached the maximum allowed consecutive failures. Most recent error: ${c.lastFailReason}`;break}if(E.doneResult){g=E.doneResult.success,f=E.doneResult.summary;break}if(E.completesInstruction){g=!0,f="Instruction completed";break}}return c.currentStep>=a&&!g&&(f="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:c.currentStep,duration:Date.now()-n}),w.log(`Build success result: summary=${f}, completed=${g}, actions=${v.length}, tokens=${d.length}`),Yu(c,v,g,f,n,d,r)}catch(b){let m=b.message;return w.error(`Task execution failed: ${m}`,b),i.onEvent?.({type:"error",error:m,recoverable:!1}),Ju(c,m,n,d,r)}}async function Os(e,t,i,n){let{domState:a,screenshotBase64:o}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n}),r=a.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:r,screenshotBase64:o,domState:a}}function Gu(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,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 ju(e,t,i,n){let a=i.temperature??0,{system:o,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=Ee(t,s),c={model:Se(t),system:o,messages:r,temperature:a,providerOptions:l},d=3;for(let h=0;h<d;h++)try{let p=Date.now();w.log(`Calling LLM (${t})...`);let g=await Uu(c),f=Date.now()-p,v=g,b=v.usage;w.llmCall(t,f,b);let m=v.reasoningText;m&&(w.thinking(m),i.onEvent?.({type:"thinking",text:m})),e.addAssistantMessage(g.text);let y={systemPrompt:o,userPrompt:Gu(r),rawLlmResponse:g.text,reasoningContent:m,screenshotWithSom:n},S=[],E=Bu(b,t);E&&S.push(E);let A=Ku(g.text);if(!A)if(h<d-1){w.log(`Attempt ${h+1}/${d}: 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(M=>setTimeout(M,i.retryDelay||1e3));continue}else return w.error("All parsing attempts failed"),{stepOutput:null,debugInfo:y,tokenUsages:S};return{stepOutput:A,debugInfo:y,tokenUsages:S}}catch(p){if(h<d-1){w.log(`Attempt ${h+1}/${d}: LLM call failed (${p.message}), retrying...`),await new Promise(g=>setTimeout(g,i.retryDelay||1e3));continue}else throw w.error("All LLM call attempts failed",p),p}return{stepOutput:null}}function Ku(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 w.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return w.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return w.error("Action missing required field: action_name"),null;if(!n.description)return w.error("Action missing required field: description"),null}return i}catch(i){return w.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),w.error(`Parse error: ${i.message}`),null}}async function zu(e,t,i,n,a,o,r){let s=[],l=!0,c=null;w.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let d=null,h={...t,domState:i},p=o;for(let g of e.actions){if(g.action_name==="done"){d={success:g.kwargs.success??!0,summary:g.kwargs.summary||g.kwargs.text||"Task completed"};break}let f={},v=g.kwargs?.element_index??g.kwargs?.index;if(typeof v=="number"){let m=i.selectorMap.get(v);m&&(f=await D(t.page,m))}let b={...f,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"&&(b=m.actionEntity);let y=await h.agentServices.getCurrentPage();if(y&&(h.page=y,t.page=h.page),m?.success===!1){l=!1,w.log("Action failed, stopping execution of remaining actions in this step"),c=m.error||"Action execution failed";break}s.push(b),a?.({type:"action",action_entity:b,step:n,debugInfo:r})}catch(m){l=!1,c=m.message,w.error(`Action execution failed: ${m.message}`);break}}return{allSuccess:l,failReason:c,actionEntities:s,doneResult:d,completesInstruction:e.completes_instruction??!1}}function Vu(e,t,i,n,a,o,r){let s={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:a,duration:Date.now()-a,outcome:{success:i.allSuccess},debugInfo:o,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 Xu(e,t,i){if(w.log(`Step ${e}/${t}`),i.thinking&&w.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&w.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&w.log(`Memory: ${i.memory}`),w.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];w.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else w.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,a)=>{w.log(` ${a+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function Yu(e,t,i,n,a,o,r){let s=o.reduce((d,h)=>d+h.prompt_tokens,0),l=o.reduce((d,h)=>d+h.completion_tokens,0),c=o.reduce((d,h)=>d+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()-a,model:r,successfulSteps:e.stepHistory.filter(d=>d.outcome.success).length,failedSteps:e.stepHistory.filter(d=>!d.outcome.success).length,promptTokens:s,completionTokens:l,totalTokens:c,tokenUsages:o}}}function Ju(e,t,i,n,a){let o=n.reduce((l,c)=>l+c.prompt_tokens,0),r=n.reduce((l,c)=>l+c.completion_tokens,0),s=n.reduce((l,c)=>l+c.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:a,successfulSteps:e.stepHistory.filter(l=>l.outcome.success).length,failedSteps:e.stepHistory.filter(l=>!l.outcome.success).length,promptTokens:o,completionTokens:r,totalTokens:s,tokenUsages:n}}}var Ds=x(()=>{"use strict";Ea();hn();Ae();Be();ie();Ie();Te();j()});var Ns={};dt(Ns,{TaskMessageManager:()=>mn,formatFinalStepWarning:()=>Cs,formatTaskContext:()=>dn,getBrowserTaskJSONPrompt:()=>un,runTaskLoop:()=>Ls});var Rs=x(()=>{"use strict";Ds();Ea();hn();Ae();Ji();Be();kt();St();Qe();Et();Tt();ie();Ie();lt();Te();ft();wt();Ye();j();Ue();R();te();et();F();ge()});async function $t(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 a=await H.execute(i,n,t),o=a?.success!==!1,r=a?.error||a?.message;return{success:o,error:o?void 0:r}}else{let{page:a,agentServices:o}=t;return await(await qu()).execute(a,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function qu(){if(pn)return pn;let e=await Promise.resolve().then(()=>(st(),rt));return pn=new e.default,pn}async function Mt(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new be(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await qn(r,o,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 nt(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new be(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await qn(r,o,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:c,goalAccomplished:d,debugInfo:h}=s,p=await $t(l,o);return p.success?(c&&i.addNote(c),{status:"success",completed:d||!1,actionEntities:[l],explanation:c,debugInfo:h}):{status:"error",completed:!1,actionEntities:[l],error:p.error||"Action execution failed",debugInfo:h}}async function at(e,t,i,n={}){let a={page:t,agentServices:i,domService:new be(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},o=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),Jo(o,a,n)}async function ot(e,t,i,n,a={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>(Rs(),Ns)),r=n?l=>{n(l)}:void 0,s=await o(e,{page:t,agentServices:i,domService:void 0,executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},{maxSteps:a.maxSteps,onEvent:r,abortSignal:a.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 pn,It=x(()=>{"use strict";Hi();Ae();Be();pn=null});import"uuid";import{z as k}from"zod";import"yaml";import"uuid";import"yaml";function Ta(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=o=>{let r=o.startsWith("$")?o.slice(1):o,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},a=e;return a=a.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(o,r)=>{let s=n(r.trim());return s!==void 0?s:o}),a=a.replace(/<secret>\$?([\w-]+)<\/secret>/g,(o,r)=>{let s=n(r);return s!==void 0?s:o}),a=a.replace(/\$\{([^}]+)\}/g,(o,r)=>{let s=n(r.trim());return s!==void 0?s:o}),a=a.replace(/\$([a-zA-Z_]\w*)/g,(o,r)=>{let s=n(r);return s!==void 0?s:o}),a}var tl,tS,il,rh,sh,fn,iS,nS,wn,nl,al,lh,el,ch,li,dh,uh,hh,se,mh,ph,sS,bS,ct=x(()=>{"use strict";ge();tl=112,tS=1080-tl,il=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(il||{}),rh={"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"}},sh={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"]},fn=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),sh[e].map(n=>rh[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},iS={desktop:{label:"Desktop",type:"desktop",devices:fn("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:fn("mobile")}},nS={desktop:{label:"Desktop",type:"desktop",devices:fn("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:fn("mobile",!0)}},wn=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(wn||{}),nl=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(nl||{}),al=class ol{constructor(){Bn(this,"data",{}),Bn(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 ol;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[a,o]of Object.entries(t.data))i.set(a,o,n.has(a))}return i}},lh=k.enum(["JS_CODE","AI_MODE"]),el=k.object({type:lh,expression:k.string()}),ch=k.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),li=k.object({uid:k.string(),type:ch,comment:k.string().optional()}),dh=k.object({action_data:k.object({action_name:k.string(),kwargs:k.record(k.any()).optional(),args:k.array(k.any()).optional()}),action_description:k.string().optional(),url:k.string().optional(),xpath:k.string().nullable().optional(),locator:k.string().nullable().optional(),css_selector:k.string().nullable().optional(),unique_selector:k.string().nullable().optional(),element_index:k.number().nullable().optional(),frame_path:k.array(k.any()).optional(),artifacts:k.record(k.any()).optional(),feedback:k.string().optional(),original_browser_use_action:k.any().optional()}).passthrough(),uh=li.extend({type:k.literal("DRAFT"),description:k.string()}),hh=li.extend({type:k.literal("ACTION"),description:k.string(),action_entity:dh.optional(),locator:k.string().optional(),use_pure_vision:k.boolean().optional()}),se=k.lazy(()=>k.union([uh,hh,li.extend({type:k.literal("STEP"),description:k.string().optional().default(""),statements:k.array(se),reference_id:k.number().optional()}),li.extend({type:k.literal("IF_ELSE"),description:k.string().optional(),condition:el,then:k.array(se),else:k.array(se).optional()}),li.extend({type:k.literal("WHILE_LOOP"),description:k.string().optional(),condition:el,body:k.array(se),timeout_ms:k.number().optional()})])),mh=k.object({name:k.string(),statements:k.array(se),teardown:k.array(se).optional(),skip:k.union([k.boolean(),k.string()]).optional(),timeout:k.number().optional(),fail:k.union([k.boolean(),k.string()]).optional(),only:k.boolean().optional(),slow:k.boolean().optional()}),ph=k.object({tests:k.array(mh).min(1),beforeAll:k.array(se).optional(),afterAll:k.array(se).optional(),beforeEach:k.array(se).optional(),afterEach:k.array(se).optional()}),sS=k.object({comment:k.string().optional(),version:k.string().optional(),goal:k.string().optional(),url:k.string().optional(),baseURL:k.string().optional(),final_feedback:k.string().optional(),completed:k.boolean().optional(),success:k.boolean().optional(),statements:k.array(se).optional(),teardown:k.array(se).optional(),last_modified_at:k.string().optional(),testGroup:ph.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"}),bS=1024*1024});async function rl(e,t){let i=Object.getPrototypeOf(async()=>{}).constructor,n=`
|
|
4304
4304
|
return await (${t});
|
|
4305
4305
|
`;return await new i("page",n)(e)}async function ci(e,t,i){let n=[],a=[];for(let o of t){let r=!1;try{let s=`page.${o}`;w.log(`Checking element existence: ${s}`),n.push(`Checking element existence: ${s}`);try{await rl(e,`${s}.waitFor({ state: 'attached', timeout: ${bh} })`),w.log(`Element is attached: ${s}`),n.push(`Element is attached: ${s}`),r=!0}catch{await rl(e,`${s}.count()`)>0?(w.log(`Element found (snapshot): ${s}`),n.push(`Element found (snapshot): ${s}`),r=!0):(w.log(`Element not found: ${s}`),n.push(`Element not found: ${s}`),r=!1)}}catch(s){w.log(`Error checking element: ${s.message}`),n.push(`Error checking element: ${s.message}`),r=!1}if(a.push(r),!r&&i)break}return{successResults:a,logs:n}}async function Aa(e,t,i=!0){let{successResults:n,logs:a}=await ci(e,t,i);return{success:n.length===t.length&&n.every(o=>o),logs:a}}async function di(e,t){if(!t||t.length===0)return w.log("No validation expressions provided, cannot validate login"),!1;w.log(`Validating login with ${t.length} expression(s)`);let{success:i,logs:n}=await Aa(e,t,!0);return i?w.log("All validation expressions passed"):w.log(`Validation failed: ${n.join(", ")}`),i}async function $a(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(),a=await n.newPage();return await a.goto(t),await Me(a,yh),{context:n,page:a,close:async()=>{await a.close(),await n.close()}}}async function Ma(e,t,i,n,a,o){let r=`
|
|
4306
4306
|
Based on the current page status, generate ${a} Playwright locators in JavaScript code that can
|
|
@@ -4358,20 +4358,20 @@ ${p.join(`
|
|
|
4358
4358
|
|
|
4359
4359
|
`,h.some(g=>g)){w.log(`Locator validation on unsigned-in page failed (some passed when should fail). Results: ${JSON.stringify(h)}`),w.log(`Validation logs:
|
|
4360
4360
|
${p.join(`
|
|
4361
|
-
`)}`);continue}}return w.log("Generated validation locators passed dual validation"),d}catch(d){w.log(`Failed to generate validation expressions (attempt ${c+1}/${s}): ${d.message}`)}return w.log("Failed to generate valid locators after max retries"),null}finally{o&&await o.close()}}var bh,yh,yn=x(()=>{"use strict";ie();Ie();bh=5e3,yh=1e4});var pl={};dt(pl,{LoginType:()=>wn,checkLocators:()=>ci,createUnsignedInContext:()=>$a,generateAndValidateLoginLocators:()=>bn,generateValidationLocators:()=>Ma,validateLogin:()=>di,validateLoginLocators:()=>Aa});var gl=x(()=>{"use strict";yn();ie();ct();Ie();lt();R();te();et();ge()});import*as ko from"fs";import*as We from"path";import Ic from"dotenv";import{defineConfig as Cc}from"@playwright/test";import{readFileSync as wo,statSync as yc,existsSync as bo}from"fs";import{resolve as Dn,relative as xc}from"path";import{globSync as vc}from"glob";import{z as _}from"zod";var Da=_.enum(["JS_CODE","AI_MODE"]),xn=_.object({type:Da,expression:_.string()}),La=_.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),je=_.object({uid:_.string(),type:La,comment:_.string().optional()}),Na=_.object({action_data:_.object({action_name:_.string(),kwargs:_.record(_.any()).optional(),args:_.array(_.any()).optional()}),action_description:_.string().optional(),url:_.string().optional(),xpath:_.string().nullable().optional(),locator:_.string().nullable().optional(),css_selector:_.string().nullable().optional(),unique_selector:_.string().nullable().optional(),element_index:_.number().nullable().optional(),frame_path:_.array(_.any()).optional(),artifacts:_.record(_.any()).optional(),feedback:_.string().optional(),original_browser_use_action:_.any().optional()}).passthrough(),Ra=je.extend({type:_.literal("DRAFT"),description:_.string()}),Fa=je.extend({type:_.literal("ACTION"),description:_.string(),action_entity:Na.optional(),locator:_.string().optional(),use_pure_vision:_.boolean().optional()}),ne=_.lazy(()=>_.union([Ra,Fa,je.extend({type:_.literal("STEP"),description:_.string().optional().default(""),statements:_.array(ne),reference_id:_.number().optional()}),je.extend({type:_.literal("IF_ELSE"),description:_.string().optional(),condition:xn,then:_.array(ne),else:_.array(ne).optional()}),je.extend({type:_.literal("WHILE_LOOP"),description:_.string().optional(),condition:xn,body:_.array(ne),timeout_ms:_.number().optional()})])),Ha=_.object({name:_.string(),statements:_.array(ne),teardown:_.array(ne).optional(),skip:_.union([_.boolean(),_.string()]).optional(),timeout:_.number().optional(),fail:_.union([_.boolean(),_.string()]).optional(),only:_.boolean().optional(),slow:_.boolean().optional()}),mi=_.object({tests:_.array(Ha).min(1),beforeAll:_.array(ne).optional(),afterAll:_.array(ne).optional(),beforeEach:_.array(ne).optional(),afterEach:_.array(ne).optional()}),vn=_.object({comment:_.string().optional(),version:_.string().optional(),goal:_.string().optional(),url:_.string().optional(),baseURL:_.string().optional(),final_feedback:_.string().optional(),completed:_.boolean().optional(),success:_.boolean().optional(),statements:_.array(ne).optional(),teardown:_.array(ne).optional(),last_modified_at:_.string().optional(),testGroup:mi.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"});import{stringify as yl,parse as xl,parseAllDocuments as Ph,parseDocument as vl,Document as _l,isMap as ze,isSeq as de}from"yaml";import{v4 as ce}from"uuid";function Ga(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(oe)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(oe)),i}var ja={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};function kn(e,t){if(e.testGroup)return Ka(e,t);let i=Ga(e,t),n=new _l(i);return e.comment&&(n.commentBefore=e.comment),Wa(n,e.statements??[]),e.teardown&&Wa(n,e.teardown,"teardown"),n.toString(ja)}function Wa(e,t,i="statements"){let n=e.contents;if(!n||!ze(n))return;let a=n.get(i,!0);de(a)&&ut(a,t)}function ut(e,t){for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=t[i],a=e.items[i];if(i>0&&(a.spaceBefore=!0),n.comment&&(i===0?e.commentBefore=n.comment:a.commentBefore=n.comment),ze(a)){let o=a;if(n.type==="STEP"){let r=o.get("statements",!0);de(r)&&ut(r,n.statements)}else if(n.type==="IF_ELSE"){let r=o.get("THEN",!0);de(r)&&ut(r,n.then);let s=o.get("ELSE",!0);de(s)&&n.else&&ut(s,n.else)}else if(n.type==="WHILE_LOOP"){let r=o.get("DO",!0);de(r)&&ut(r,n.body)}}}}function Ka(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 a={};return e.baseURL&&(a.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(a.beforeAll=i.beforeAll.map(oe)),i.beforeEach&&i.beforeEach.length>0&&(a.beforeEach=i.beforeEach.map(oe)),i.afterEach&&i.afterEach.length>0&&(a.afterEach=i.afterEach.map(oe)),i.afterAll&&i.afterAll.length>0&&(a.afterAll=i.afterAll.map(oe)),a.tests=i.tests.map(o=>{let r={name:o.name};return o.skip!==void 0&&(r.skip=o.skip),o.timeout!==void 0&&(r.timeout=o.timeout),o.fail!==void 0&&(r.fail=o.fail),o.only!==void 0&&(r.only=o.only),o.slow!==void 0&&(r.slow=o.slow),r.statements=o.statements.map(oe),o.teardown&&o.teardown.length>0&&(r.teardown=o.teardown.map(oe)),r}),n.suite=a,yl(n,ja)}function oe(e){switch(e.type){case"DRAFT":return kl(e);case"ACTION":return Sl(e);case"STEP":return El(e);case"IF_ELSE":return Tl(e);case"WHILE_LOOP":return Al(e)}}function kl(e){return{intent:e.description}}function Sl(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,c={WAIT:e.description||`Wait ${s}s`};return typeof s=="number"&&(c.seconds=s),c}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 a={intent:e.description,action:n.action_name},o=e.locator??e.action_entity.locator;o&&(a.locator=o);let r=e.action_entity.xpath;if(r&&(a.xpath=r),e.use_pure_vision&&(a.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[s,l]of Object.entries(n.kwargs))a[s]=l;return n.args&&n.args.length>0&&(a.args=n.args),a}function El(e){let t={STEP:e.description,statements:e.statements.map(oe)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function Tl(e){let t={IF:za(e.condition),THEN:e.then.map(oe)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(oe)),t}function Al(e){let t={WHILE:za(e.condition),DO:e.body.map(oe)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function za(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function _n(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(_n);let t=e,i=Object.keys(t);if(i.length===1){let a=i[0];if(a.startsWith("{ ")&&a.endsWith(" }")&&t[a]===null)return`{{${a.slice(2,-2)}}}`}let n={};for(let[a,o]of Object.entries(t))n[a]=_n(o);return n}var Ua=1024*1024;function me(e){if(e.length>Ua)throw new Error(`YAML input too large (${e.length} bytes, max ${Ua})`);let t=_n(xl(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return $l(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:re(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=re(t.teardown));let n=vn.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let a=n.data;return Xa(e,a),a}function $l(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 a={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:re(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=re(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&&(a.beforeAll=re(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(a.afterAll=re(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(a.beforeEach=re(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(a.afterEach=re(t.afterEach));let o=mi.safeParse(a);if(!o.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(o.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:o.data}}function re(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(Ml)}function Ml(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 Il(t);if("WHILE"in t)return Cl(t);if("STEP"in t)return Pl(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:ce(),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,a=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,o={url:typeof i=="string"?i:String(i)};return n&&(o.new_tab=!0),a!==void 0&&(o.timeout_seconds=a),{uid:ce(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:o}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:ce(),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:ce(),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:ce(),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:ce(),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 Ba({...n,action:"function",functionName:i})}if("action"in t)return Ba(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:ce(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function Va(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 Il(e){let t=Va(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:ce(),type:"IF_ELSE",condition:t,then:re(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=re(e.ELSE)),n}function Cl(e){let t=Va(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:ce(),type:"WHILE_LOOP",condition:t,body:re(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function Pl(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:ce(),type:"STEP",description:t,statements:re(e.statements)};return typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),i}var Ol=new Set(["action","intent","desc","locator","xpath","use_pure_vision"]);function Ba(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,a=typeof e.xpath=="string"?e.xpath:void 0,o=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[c,d]of Object.entries(e))Ol.has(c)||(r[c]=d);let s={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};n&&(s.locator=n),a&&(s.xpath=a);let l={uid:ce(),type:"ACTION",description:i,action_entity:s};return o&&(l.use_pure_vision=!0),l}function Xa(e,t){let i;try{i=vl(e)}catch{return}let n=i.contents;if(!n||!ze(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 a=n,o=a.get("statements",!0);de(o)&&t.statements&&Ke(o,t.statements);let r=a.get("teardown",!0);de(r)&&t.teardown&&Ke(r,t.teardown)}function Ke(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 a=t[i];if(a.type==="STEP"&&ze(n)){let o=n.get("statements",!0);de(o)&&Ke(o,a.statements)}else if(a.type==="IF_ELSE"&&ze(n)){let o=n.get("THEN",!0);de(o)&&Ke(o,a.then);let r=n.get("ELSE",!0);de(r)&&a.else&&Ke(r,a.else)}else if(a.type==="WHILE_LOOP"&&ze(n)){let o=n.get("DO",!0);de(o)&&Ke(o,a.body)}}}import{parse as Rh,stringify as Fh}from"yaml";var Sn=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};var pi=e=>{let t=[],i=n=>{for(let a of n){t.push(a);let o=Sn(a);for(let r of o)i(r.statements)}};return i(e),t};var Dl=.5,Ja=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"]);function qa(e){let t=0,i=0;for(let n of e)if(n.type==="DRAFT")i++;else if(n.type==="ACTION"){let a=n.action_entity?.action_data?.action_name??"";Ja.has(a)||t++}return{action:t,draft:i}}function Ll(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function Ya(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function En(e,t){let i=t?.coverageThreshold??Dl,n=[],a=[],o;try{o=me(e)}catch(p){return{valid:!1,errors:[`Invalid YAML: ${p.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}o.goal||n.push('Missing required field: "goal"'),o.statements?.length||n.push('Missing required field: "statements"');let r=[...pi(o.statements??[]),...o.teardown?pi(o.teardown):[]],{action:s,draft:l}=qa(r),c="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,f=g.action_entity?.action_data?.action_name??"";if(f==="js_code"||f==="js_action"||f==="verify"||f==="ai_assert"){let v=g.action_entity?.action_data?.kwargs?.code;if(typeof v=="string"){let b=Ll(v);if(b){let m=g.description||f;n.push(`Invalid JS in "${m}": ${b}. ${c}`)}}}}if(p.type==="IF_ELSE"){let g=p;if(g.condition.type==="JS_CODE"){let f=Ya(g.condition.expression);f&&n.push(`Invalid JS in IF condition "${g.condition.expression}": ${f}. ${c}`)}}if(p.type==="WHILE_LOOP"){let g=p;if(g.condition.type==="JS_CODE"){let f=Ya(g.condition.expression);f&&n.push(`Invalid JS in WHILE condition "${g.condition.expression}": ${f}. ${c}`)}}}let d=s+l,h=d>0?Math.round(s/d*100):0;return d>0&&h/100<i&&a.push(`Low action coverage: ${s}/${d} 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:a,stats:{total:d,action:s,draft:l,coverage:h}}}function Tn(){return{version:"1.0",entries:{}}}import{v4 as Vh}from"uuid";var ue=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(ue||{});var An=18e4;var Za=112;var Rl=1080-Za;var Qa={"Blackberry PlayBook":{name:"Blackberry PlayBook",userAgent:"Mozilla/5.0 (PlayBook; U; RIM Tablet OS 2.1.0; en-US) AppleWebKit/536.2+ (KHTML like Gecko) Version/26.0 Safari/536.2+",screen:{width:600,height:1024},viewport:{width:600,height:1024},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"BlackBerry Z30":{name:"BlackBerry Z30",userAgent:"Mozilla/5.0 (BB10; Touch) AppleWebKit/537.10+ (KHTML, like Gecko) Version/26.0 Mobile Safari/537.10+",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note 3":{name:"Galaxy Note 3",userAgent:"Mozilla/5.0 (Linux; U; Android 4.3; en-us; SM-N900T Build/JSS15J) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note II":{name:"Galaxy Note II",userAgent:"Mozilla/5.0 (Linux; U; Android 4.1; en-us; GT-N7100 Build/JRO03C) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S III":{name:"Galaxy S III",userAgent:"Mozilla/5.0 (Linux; U; Android 4.0; en-us; GT-I9300 Build/IMM76D) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S5":{name:"Galaxy S5",userAgent:"Mozilla/5.0 (Linux; Android 5.0; SM-G900P Build/LRX21T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S8":{name:"Galaxy S8",userAgent:"Mozilla/5.0 (Linux; Android 7.0; SM-G950U Build/NRD90M) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:740},viewport:{width:360,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S9+":{name:"Galaxy S9+",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; SM-G965U Build/R16NW) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:320,height:658},viewport:{width:320,height:658},deviceScaleFactor:4.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S24":{name:"Galaxy S24",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-S921U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:780},viewport:{width:360,height:780},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy A55":{name:"Galaxy A55",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-A556B) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:480,height:1040},viewport:{width:480,height:1040},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S4":{name:"Galaxy Tab S4",userAgent:"Mozilla/5.0 (Linux; Android 8.1.0; SM-T837A) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:712,height:1138},viewport:{width:712,height:1138},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S9":{name:"Galaxy Tab S9",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-X710) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:640,height:1024},viewport:{width:640,height:1024},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"iPad (gen 5)":{name:"iPad (gen 5)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 6)":{name:"iPad (gen 6)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 7)":{name:"iPad (gen 7)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:810,height:1080},viewport:{width:810,height:1080},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 11)":{name:"iPad (gen 11)",userAgent:"Mozilla/5.0 (iPad; CPU OS 18_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/604.1",screen:{width:656,height:944},viewport:{width:656,height:944},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Mini":{name:"iPad Mini",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Pro 11":{name:"iPad Pro 11",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:834,height:1194},viewport:{width:834,height:1194},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6":{name:"iPhone 6",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6 Plus":{name:"iPhone 6 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7":{name:"iPhone 7",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7 Plus":{name:"iPhone 7 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8":{name:"iPhone 8",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8 Plus":{name:"iPhone 8 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE":{name:"iPhone SE",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 10_3_1 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/14E304 Safari/602.1",screen:{width:320,height:568},viewport:{width:320,height:568},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE (3rd gen)":{name:"iPhone SE (3rd gen)",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 18_5 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/602.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone X":{name:"iPhone X",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:812},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone XR":{name:"iPhone XR",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:896},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11":{name:"iPhone 11",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro":{name:"iPhone 11 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:635},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro Max":{name:"iPhone 11 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12":{name:"iPhone 12",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro":{name:"iPhone 12 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro Max":{name:"iPhone 12 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Mini":{name:"iPhone 12 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13":{name:"iPhone 13",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro":{name:"iPhone 13 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro Max":{name:"iPhone 13 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Mini":{name:"iPhone 13 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14":{name:"iPhone 14",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Plus":{name:"iPhone 14 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro":{name:"iPhone 14 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:660},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro Max":{name:"iPhone 14 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15":{name:"iPhone 15",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Plus":{name:"iPhone 15 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro":{name:"iPhone 15 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro Max":{name:"iPhone 15 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Kindle Fire HDX":{name:"Kindle Fire HDX",userAgent:"Mozilla/5.0 (Linux; U; en-us; KFAPWI Build/JDQ39) AppleWebKit/535.19 (KHTML, like Gecko) Silk/3.13 Safari/535.19 Silk-Accelerated=true",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"LG Optimus L70":{name:"LG Optimus L70",userAgent:"Mozilla/5.0 (Linux; U; Android 4.4.2; en-us; LGMS323 Build/KOT49I.MS32310c) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:1.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 550":{name:"Microsoft Lumia 550",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 550) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 950":{name:"Microsoft Lumia 950",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 950) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:4,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 10":{name:"Nexus 10",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 10 Build/MOB31T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 4":{name:"Nexus 4",userAgent:"Mozilla/5.0 (Linux; Android 4.4.2; Nexus 4 Build/KOT49H) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5":{name:"Nexus 5",userAgent:"Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5X":{name:"Nexus 5X",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 5X Build/OPR4.170623.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6":{name:"Nexus 6",userAgent:"Mozilla/5.0 (Linux; Android 7.1.1; Nexus 6 Build/N6F26U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6P":{name:"Nexus 6P",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 6P Build/OPP3.170518.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 7":{name:"Nexus 7",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 7 Build/MOB30X) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:600,height:960},viewport:{width:600,height:960},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia Lumia 520":{name:"Nokia Lumia 520",userAgent:"Mozilla/5.0 (compatible; MSIE 10.0; Windows Phone 8.0; Trident/6.0; IEMobile/10.0; ARM; Touch; NOKIA; Lumia 520)",screen:{width:320,height:533},viewport:{width:320,height:533},deviceScaleFactor:1.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia N9":{name:"Nokia N9",userAgent:"Mozilla/5.0 (MeeGo; NokiaN9) AppleWebKit/534.13 (KHTML, like Gecko) NokiaBrowser/8.5.0 Mobile Safari/534.13",screen:{width:480,height:854},viewport:{width:480,height:854},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Pixel 2":{name:"Pixel 2",userAgent:"Mozilla/5.0 (Linux; Android 8.0; Pixel 2 Build/OPD3.170816.012) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:731},viewport:{width:411,height:731},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 2 XL":{name:"Pixel 2 XL",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Pixel 2 XL Build/OPD1.170816.004) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:823},viewport:{width:411,height:823},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 3":{name:"Pixel 3",userAgent:"Mozilla/5.0 (Linux; Android 9; Pixel 3 Build/PQ1A.181105.017.A1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:786},viewport:{width:393,height:786},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4":{name:"Pixel 4",userAgent:"Mozilla/5.0 (Linux; Android 10; Pixel 4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:353,height:745},viewport:{width:353,height:745},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4a (5G)":{name:"Pixel 4a (5G)",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 4a (5G)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:892},viewport:{width:412,height:765},deviceScaleFactor:2.63,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 5":{name:"Pixel 5",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:851},viewport:{width:393,height:727},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 7":{name:"Pixel 7",userAgent:"Mozilla/5.0 (Linux; Android 14; Pixel 7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:915},viewport:{width:412,height:839},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Moto G4":{name:"Moto G4",userAgent:"Mozilla/5.0 (Linux; Android 7.0; Moto G (4)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Desktop Chrome HiDPI":{name:"Desktop Chrome HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge HiDPI":{name:"Desktop Edge HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Firefox HiDPI":{name:"Desktop Firefox HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"},"Desktop Safari":{name:"Desktop Safari",userAgent:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Safari/605.1.15",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"webkit"},"Desktop Chrome":{name:"Desktop Chrome",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome Medium Resolution":{name:"Desktop Chrome Medium Resolution",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome (Branded)":{name:"Desktop Chrome (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Chrome Medium Resolution (Branded)":{name:"Desktop Chrome Medium Resolution (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Edge":{name:"Desktop Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge (Branded)":{name:"Desktop Edge (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Edge Medium Resolution (Branded)":{name:"Desktop Edge Medium Resolution (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Firefox":{name:"Desktop Firefox",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"}};var eo={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"]},ht=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),eo[e].map(n=>Qa[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))};var Fl={desktop:{label:"Desktop",type:"desktop",devices:ht("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:ht("mobile")}},Hl={desktop:{label:"Desktop",type:"desktop",devices:ht("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:ht("mobile",!0)}};import{stringify as Ul}from"yaml";import{createHash as oc}from"crypto";import{parse as rc,stringify as uo}from"yaml";import{readFileSync as sc}from"fs";import{resolve as ho,dirname as lc}from"path";import{parse as ao,stringify as cc}from"yaml";import{readFileSync as yg,writeFileSync as fc,mkdirSync as wc}from"fs";import{dirname as bc}from"path";var Mn=5e3;function _e(e){return e.replace(/\\/g,"\\\\").replace(/'/g,"\\'").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/\t/g,"\\t")}function B(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function Bl(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Gl(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 fi(e){let t=Bl(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Gl(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}var jl=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Kl=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"];function to(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:jl.includes(t)}function zl(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!Kl.includes(t)}var Z=new Map;function $(e,t){Z.set(e,t)}function Vl(e){return Z.get(e)}function He(e,t,i=[]){let n=[...i];return t.locator?n.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&n.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&n.push(`frame_path: ${JSON.stringify(t.frame_path)}`),n.length===0?[`await agent.execAction("${e}", page, {});`]:[`await agent.execAction("${e}", page, {`,...n.map(a=>` ${a},`),"});"]}$("click",e=>{let t=fi(e);if(!t)return['await agent.execAction("click", page, {});'];let i=e.action_data?.kwargs?.timeout_ms??Mn;return[`await ${t}.click({ timeout: ${i} });`]});$("click_element",Z.get("click"));$("click_element_by_index",Z.get("click"));$("double_click",e=>He("double_click",e));$("double_click_on_element",Z.get("double_click"));$("right_click",e=>He("right_click",e));$("right_click_on_element",Z.get("right_click"));$("hover",e=>He("hover",e));$("hover_element_by_index",Z.get("hover"));$("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return He("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("fill",Z.get("input_text"));$("clear_input",e=>He("clear_input",e));$("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});$("send_keys",Z.get("press"));$("send_keys_on_element",e=>{let t=fi(e),i=e.action_data?.kwargs?.keys||"";if(!t)return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(i)} } },`,"});"];let n=e.action_data?.kwargs?.timeout_ms??Mn;return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]});$("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return He("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("scroll",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)})');`]});$("scroll_down",Z.get("scroll"));$("scroll_up",Z.get("scroll"));$("scroll_element",Z.get("scroll"));$("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});$("scroll_on_element",e=>He("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));$("go_to_url",e=>{let t=e.action_data?.kwargs?.url||"";return e.action_data?.kwargs?.new_tab===!0?['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)}, new_tab: true } },`,"});"]:['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)} } },`,"});"]});$("open_tab",Z.get("go_to_url"));$("go_back",()=>['await agent.execAction("go_back", page, {});']);$("reload_page",()=>['await agent.execAction("reload_page", page, {});']);$("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);$("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);$("verify",(e,t)=>{let i=e.action_data?.kwargs,n=typeof i?.code=="string",a=n?i?.statement||e.action_description:e.action_description||i?.statement;if(n&&a){let r=i.code.split(`
|
|
4361
|
+
`)}`);continue}}return w.log("Generated validation locators passed dual validation"),d}catch(d){w.log(`Failed to generate validation expressions (attempt ${c+1}/${s}): ${d.message}`)}return w.log("Failed to generate valid locators after max retries"),null}finally{o&&await o.close()}}var bh,yh,yn=x(()=>{"use strict";ie();Ie();bh=5e3,yh=1e4});var pl={};dt(pl,{LoginType:()=>wn,checkLocators:()=>ci,createUnsignedInContext:()=>$a,generateAndValidateLoginLocators:()=>bn,generateValidationLocators:()=>Ma,validateLogin:()=>di,validateLoginLocators:()=>Aa});var gl=x(()=>{"use strict";yn();ie();ct();Ie();lt();R();te();et();ge()});import*as ko from"fs";import*as We from"path";import Ic from"dotenv";import{defineConfig as Cc}from"@playwright/test";import{readFileSync as wo,statSync as yc,existsSync as bo}from"fs";import{resolve as Ln,relative as xc}from"path";import{globSync as vc}from"glob";import{v4 as Ph}from"uuid";import{z as _}from"zod";var La=_.enum(["JS_CODE","AI_MODE"]),xn=_.object({type:La,expression:_.string()}),Da=_.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),je=_.object({uid:_.string(),type:Da,comment:_.string().optional()}),Na=_.object({action_data:_.object({action_name:_.string(),kwargs:_.record(_.any()).optional(),args:_.array(_.any()).optional()}),action_description:_.string().optional(),url:_.string().optional(),xpath:_.string().nullable().optional(),locator:_.string().nullable().optional(),css_selector:_.string().nullable().optional(),unique_selector:_.string().nullable().optional(),element_index:_.number().nullable().optional(),frame_path:_.array(_.any()).optional(),artifacts:_.record(_.any()).optional(),feedback:_.string().optional(),original_browser_use_action:_.any().optional()}).passthrough(),Ra=je.extend({type:_.literal("DRAFT"),description:_.string()}),Fa=je.extend({type:_.literal("ACTION"),description:_.string(),action_entity:Na.optional(),locator:_.string().optional(),use_pure_vision:_.boolean().optional()}),ne=_.lazy(()=>_.union([Ra,Fa,je.extend({type:_.literal("STEP"),description:_.string().optional().default(""),statements:_.array(ne),reference_id:_.number().optional()}),je.extend({type:_.literal("IF_ELSE"),description:_.string().optional(),condition:xn,then:_.array(ne),else:_.array(ne).optional()}),je.extend({type:_.literal("WHILE_LOOP"),description:_.string().optional(),condition:xn,body:_.array(ne),timeout_ms:_.number().optional()})])),Ha=_.object({name:_.string(),statements:_.array(ne),teardown:_.array(ne).optional(),skip:_.union([_.boolean(),_.string()]).optional(),timeout:_.number().optional(),fail:_.union([_.boolean(),_.string()]).optional(),only:_.boolean().optional(),slow:_.boolean().optional()}),mi=_.object({tests:_.array(Ha).min(1),beforeAll:_.array(ne).optional(),afterAll:_.array(ne).optional(),beforeEach:_.array(ne).optional(),afterEach:_.array(ne).optional()}),vn=_.object({comment:_.string().optional(),version:_.string().optional(),goal:_.string().optional(),url:_.string().optional(),baseURL:_.string().optional(),final_feedback:_.string().optional(),completed:_.boolean().optional(),success:_.boolean().optional(),statements:_.array(ne).optional(),teardown:_.array(ne).optional(),last_modified_at:_.string().optional(),testGroup:mi.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"});import{stringify as yl,parse as xl,parseAllDocuments as Fh,parseDocument as vl,Document as _l,isMap as ze,isSeq as de}from"yaml";import{v4 as ce}from"uuid";function Ga(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(oe)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(oe)),i}var ja={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};function kn(e,t){if(e.testGroup)return Ka(e,t);let i=Ga(e,t),n=new _l(i);return e.comment&&(n.commentBefore=e.comment),Wa(n,e.statements??[]),e.teardown&&Wa(n,e.teardown,"teardown"),n.toString(ja)}function Wa(e,t,i="statements"){let n=e.contents;if(!n||!ze(n))return;let a=n.get(i,!0);de(a)&&ut(a,t)}function ut(e,t){for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=t[i],a=e.items[i];if(i>0&&(a.spaceBefore=!0),n.comment&&(i===0?e.commentBefore=n.comment:a.commentBefore=n.comment),ze(a)){let o=a;if(n.type==="STEP"){let r=o.get("statements",!0);de(r)&&ut(r,n.statements)}else if(n.type==="IF_ELSE"){let r=o.get("THEN",!0);de(r)&&ut(r,n.then);let s=o.get("ELSE",!0);de(s)&&n.else&&ut(s,n.else)}else if(n.type==="WHILE_LOOP"){let r=o.get("DO",!0);de(r)&&ut(r,n.body)}}}}function Ka(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 a={};return e.baseURL&&(a.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(a.beforeAll=i.beforeAll.map(oe)),i.beforeEach&&i.beforeEach.length>0&&(a.beforeEach=i.beforeEach.map(oe)),i.afterEach&&i.afterEach.length>0&&(a.afterEach=i.afterEach.map(oe)),i.afterAll&&i.afterAll.length>0&&(a.afterAll=i.afterAll.map(oe)),a.tests=i.tests.map(o=>{let r={name:o.name};return o.skip!==void 0&&(r.skip=o.skip),o.timeout!==void 0&&(r.timeout=o.timeout),o.fail!==void 0&&(r.fail=o.fail),o.only!==void 0&&(r.only=o.only),o.slow!==void 0&&(r.slow=o.slow),r.statements=o.statements.map(oe),o.teardown&&o.teardown.length>0&&(r.teardown=o.teardown.map(oe)),r}),n.suite=a,yl(n,ja)}function oe(e){switch(e.type){case"DRAFT":return kl(e);case"ACTION":return Sl(e);case"STEP":return El(e);case"IF_ELSE":return Tl(e);case"WHILE_LOOP":return Al(e)}}function kl(e){return{intent:e.description}}function Sl(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,c={WAIT:e.description||`Wait ${s}s`};return typeof s=="number"&&(c.seconds=s),c}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 a={intent:e.description,action:n.action_name},o=e.locator??e.action_entity.locator;o&&(a.locator=o);let r=e.action_entity.xpath;if(r&&(a.xpath=r),e.use_pure_vision&&(a.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[s,l]of Object.entries(n.kwargs))a[s]=l;return n.args&&n.args.length>0&&(a.args=n.args),a}function El(e){let t={STEP:e.description,statements:e.statements.map(oe)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function Tl(e){let t={IF:za(e.condition),THEN:e.then.map(oe)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(oe)),t}function Al(e){let t={WHILE:za(e.condition),DO:e.body.map(oe)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function za(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function _n(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(_n);let t=e,i=Object.keys(t);if(i.length===1){let a=i[0];if(a.startsWith("{ ")&&a.endsWith(" }")&&t[a]===null)return`{{${a.slice(2,-2)}}}`}let n={};for(let[a,o]of Object.entries(t))n[a]=_n(o);return n}var Ua=1024*1024;function me(e){if(e.length>Ua)throw new Error(`YAML input too large (${e.length} bytes, max ${Ua})`);let t=_n(xl(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return $l(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:re(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=re(t.teardown));let n=vn.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let a=n.data;return Xa(e,a),a}function $l(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 a={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:re(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=re(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&&(a.beforeAll=re(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(a.afterAll=re(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(a.beforeEach=re(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(a.afterEach=re(t.afterEach));let o=mi.safeParse(a);if(!o.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(o.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:o.data}}function re(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(Ml)}function Ml(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 Il(t);if("WHILE"in t)return Cl(t);if("STEP"in t)return Pl(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:ce(),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,a=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,o={url:typeof i=="string"?i:String(i)};return n&&(o.new_tab=!0),a!==void 0&&(o.timeout_seconds=a),{uid:ce(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:o}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:ce(),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:ce(),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:ce(),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:ce(),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 Ba({...n,action:"function",functionName:i})}if("action"in t)return Ba(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:ce(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function Va(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 Il(e){let t=Va(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:ce(),type:"IF_ELSE",condition:t,then:re(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=re(e.ELSE)),n}function Cl(e){let t=Va(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:ce(),type:"WHILE_LOOP",condition:t,body:re(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function Pl(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:ce(),type:"STEP",description:t,statements:re(e.statements)};return typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),i}var Ol=new Set(["action","intent","desc","locator","xpath","use_pure_vision"]);function Ba(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,a=typeof e.xpath=="string"?e.xpath:void 0,o=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[c,d]of Object.entries(e))Ol.has(c)||(r[c]=d);let s={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};n&&(s.locator=n),a&&(s.xpath=a);let l={uid:ce(),type:"ACTION",description:i,action_entity:s};return o&&(l.use_pure_vision=!0),l}function Xa(e,t){let i;try{i=vl(e)}catch{return}let n=i.contents;if(!n||!ze(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 a=n,o=a.get("statements",!0);de(o)&&t.statements&&Ke(o,t.statements);let r=a.get("teardown",!0);de(r)&&t.teardown&&Ke(r,t.teardown)}function Ke(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 a=t[i];if(a.type==="STEP"&&ze(n)){let o=n.get("statements",!0);de(o)&&Ke(o,a.statements)}else if(a.type==="IF_ELSE"&&ze(n)){let o=n.get("THEN",!0);de(o)&&Ke(o,a.then);let r=n.get("ELSE",!0);de(r)&&a.else&&Ke(r,a.else)}else if(a.type==="WHILE_LOOP"&&ze(n)){let o=n.get("DO",!0);de(o)&&Ke(o,a.body)}}}import{parse as Gh,stringify as jh}from"yaml";var Sn=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};var pi=e=>{let t=[],i=n=>{for(let a of n){t.push(a);let o=Sn(a);for(let r of o)i(r.statements)}};return i(e),t};var Ll=.5,Ja=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"]);function qa(e){let t=0,i=0;for(let n of e)if(n.type==="DRAFT")i++;else if(n.type==="ACTION"){let a=n.action_entity?.action_data?.action_name??"";Ja.has(a)||t++}return{action:t,draft:i}}function Dl(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function Ya(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function En(e,t){let i=t?.coverageThreshold??Ll,n=[],a=[],o;try{o=me(e)}catch(p){return{valid:!1,errors:[`Invalid YAML: ${p.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}o.goal||n.push('Missing required field: "goal"'),o.statements?.length||n.push('Missing required field: "statements"');let r=[...pi(o.statements??[]),...o.teardown?pi(o.teardown):[]],{action:s,draft:l}=qa(r),c="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,f=g.action_entity?.action_data?.action_name??"";if(f==="js_code"||f==="js_action"||f==="verify"||f==="ai_assert"){let v=g.action_entity?.action_data?.kwargs?.code;if(typeof v=="string"){let b=Dl(v);if(b){let m=g.description||f;n.push(`Invalid JS in "${m}": ${b}. ${c}`)}}}}if(p.type==="IF_ELSE"){let g=p;if(g.condition.type==="JS_CODE"){let f=Ya(g.condition.expression);f&&n.push(`Invalid JS in IF condition "${g.condition.expression}": ${f}. ${c}`)}}if(p.type==="WHILE_LOOP"){let g=p;if(g.condition.type==="JS_CODE"){let f=Ya(g.condition.expression);f&&n.push(`Invalid JS in WHILE condition "${g.condition.expression}": ${f}. ${c}`)}}}let d=s+l,h=d>0?Math.round(s/d*100):0;return d>0&&h/100<i&&a.push(`Low action coverage: ${s}/${d} 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:a,stats:{total:d,action:s,draft:l,coverage:h}}}var Za=112;var Rl=1080-Za;var Qa={"Blackberry PlayBook":{name:"Blackberry PlayBook",userAgent:"Mozilla/5.0 (PlayBook; U; RIM Tablet OS 2.1.0; en-US) AppleWebKit/536.2+ (KHTML like Gecko) Version/26.0 Safari/536.2+",screen:{width:600,height:1024},viewport:{width:600,height:1024},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"BlackBerry Z30":{name:"BlackBerry Z30",userAgent:"Mozilla/5.0 (BB10; Touch) AppleWebKit/537.10+ (KHTML, like Gecko) Version/26.0 Mobile Safari/537.10+",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note 3":{name:"Galaxy Note 3",userAgent:"Mozilla/5.0 (Linux; U; Android 4.3; en-us; SM-N900T Build/JSS15J) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note II":{name:"Galaxy Note II",userAgent:"Mozilla/5.0 (Linux; U; Android 4.1; en-us; GT-N7100 Build/JRO03C) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S III":{name:"Galaxy S III",userAgent:"Mozilla/5.0 (Linux; U; Android 4.0; en-us; GT-I9300 Build/IMM76D) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S5":{name:"Galaxy S5",userAgent:"Mozilla/5.0 (Linux; Android 5.0; SM-G900P Build/LRX21T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S8":{name:"Galaxy S8",userAgent:"Mozilla/5.0 (Linux; Android 7.0; SM-G950U Build/NRD90M) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:740},viewport:{width:360,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S9+":{name:"Galaxy S9+",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; SM-G965U Build/R16NW) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:320,height:658},viewport:{width:320,height:658},deviceScaleFactor:4.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S24":{name:"Galaxy S24",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-S921U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:780},viewport:{width:360,height:780},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy A55":{name:"Galaxy A55",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-A556B) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:480,height:1040},viewport:{width:480,height:1040},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S4":{name:"Galaxy Tab S4",userAgent:"Mozilla/5.0 (Linux; Android 8.1.0; SM-T837A) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:712,height:1138},viewport:{width:712,height:1138},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S9":{name:"Galaxy Tab S9",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-X710) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:640,height:1024},viewport:{width:640,height:1024},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"iPad (gen 5)":{name:"iPad (gen 5)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 6)":{name:"iPad (gen 6)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 7)":{name:"iPad (gen 7)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:810,height:1080},viewport:{width:810,height:1080},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 11)":{name:"iPad (gen 11)",userAgent:"Mozilla/5.0 (iPad; CPU OS 18_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/604.1",screen:{width:656,height:944},viewport:{width:656,height:944},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Mini":{name:"iPad Mini",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Pro 11":{name:"iPad Pro 11",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:834,height:1194},viewport:{width:834,height:1194},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6":{name:"iPhone 6",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6 Plus":{name:"iPhone 6 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7":{name:"iPhone 7",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7 Plus":{name:"iPhone 7 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8":{name:"iPhone 8",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8 Plus":{name:"iPhone 8 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE":{name:"iPhone SE",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 10_3_1 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/14E304 Safari/602.1",screen:{width:320,height:568},viewport:{width:320,height:568},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE (3rd gen)":{name:"iPhone SE (3rd gen)",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 18_5 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/602.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone X":{name:"iPhone X",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:812},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone XR":{name:"iPhone XR",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:896},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11":{name:"iPhone 11",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro":{name:"iPhone 11 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:635},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro Max":{name:"iPhone 11 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12":{name:"iPhone 12",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro":{name:"iPhone 12 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro Max":{name:"iPhone 12 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Mini":{name:"iPhone 12 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13":{name:"iPhone 13",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro":{name:"iPhone 13 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro Max":{name:"iPhone 13 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Mini":{name:"iPhone 13 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14":{name:"iPhone 14",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Plus":{name:"iPhone 14 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro":{name:"iPhone 14 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:660},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro Max":{name:"iPhone 14 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15":{name:"iPhone 15",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Plus":{name:"iPhone 15 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro":{name:"iPhone 15 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro Max":{name:"iPhone 15 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Kindle Fire HDX":{name:"Kindle Fire HDX",userAgent:"Mozilla/5.0 (Linux; U; en-us; KFAPWI Build/JDQ39) AppleWebKit/535.19 (KHTML, like Gecko) Silk/3.13 Safari/535.19 Silk-Accelerated=true",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"LG Optimus L70":{name:"LG Optimus L70",userAgent:"Mozilla/5.0 (Linux; U; Android 4.4.2; en-us; LGMS323 Build/KOT49I.MS32310c) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:1.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 550":{name:"Microsoft Lumia 550",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 550) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 950":{name:"Microsoft Lumia 950",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 950) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:4,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 10":{name:"Nexus 10",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 10 Build/MOB31T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 4":{name:"Nexus 4",userAgent:"Mozilla/5.0 (Linux; Android 4.4.2; Nexus 4 Build/KOT49H) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5":{name:"Nexus 5",userAgent:"Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5X":{name:"Nexus 5X",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 5X Build/OPR4.170623.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6":{name:"Nexus 6",userAgent:"Mozilla/5.0 (Linux; Android 7.1.1; Nexus 6 Build/N6F26U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6P":{name:"Nexus 6P",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 6P Build/OPP3.170518.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 7":{name:"Nexus 7",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 7 Build/MOB30X) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:600,height:960},viewport:{width:600,height:960},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia Lumia 520":{name:"Nokia Lumia 520",userAgent:"Mozilla/5.0 (compatible; MSIE 10.0; Windows Phone 8.0; Trident/6.0; IEMobile/10.0; ARM; Touch; NOKIA; Lumia 520)",screen:{width:320,height:533},viewport:{width:320,height:533},deviceScaleFactor:1.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia N9":{name:"Nokia N9",userAgent:"Mozilla/5.0 (MeeGo; NokiaN9) AppleWebKit/534.13 (KHTML, like Gecko) NokiaBrowser/8.5.0 Mobile Safari/534.13",screen:{width:480,height:854},viewport:{width:480,height:854},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Pixel 2":{name:"Pixel 2",userAgent:"Mozilla/5.0 (Linux; Android 8.0; Pixel 2 Build/OPD3.170816.012) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:731},viewport:{width:411,height:731},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 2 XL":{name:"Pixel 2 XL",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Pixel 2 XL Build/OPD1.170816.004) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:823},viewport:{width:411,height:823},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 3":{name:"Pixel 3",userAgent:"Mozilla/5.0 (Linux; Android 9; Pixel 3 Build/PQ1A.181105.017.A1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:786},viewport:{width:393,height:786},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4":{name:"Pixel 4",userAgent:"Mozilla/5.0 (Linux; Android 10; Pixel 4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:353,height:745},viewport:{width:353,height:745},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4a (5G)":{name:"Pixel 4a (5G)",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 4a (5G)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:892},viewport:{width:412,height:765},deviceScaleFactor:2.63,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 5":{name:"Pixel 5",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:851},viewport:{width:393,height:727},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 7":{name:"Pixel 7",userAgent:"Mozilla/5.0 (Linux; Android 14; Pixel 7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:915},viewport:{width:412,height:839},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Moto G4":{name:"Moto G4",userAgent:"Mozilla/5.0 (Linux; Android 7.0; Moto G (4)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Desktop Chrome HiDPI":{name:"Desktop Chrome HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge HiDPI":{name:"Desktop Edge HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Firefox HiDPI":{name:"Desktop Firefox HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"},"Desktop Safari":{name:"Desktop Safari",userAgent:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Safari/605.1.15",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"webkit"},"Desktop Chrome":{name:"Desktop Chrome",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome Medium Resolution":{name:"Desktop Chrome Medium Resolution",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome (Branded)":{name:"Desktop Chrome (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Chrome Medium Resolution (Branded)":{name:"Desktop Chrome Medium Resolution (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Edge":{name:"Desktop Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge (Branded)":{name:"Desktop Edge (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Edge Medium Resolution (Branded)":{name:"Desktop Edge Medium Resolution (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Firefox":{name:"Desktop Firefox",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"}};var eo={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"]},ht=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),eo[e].map(n=>Qa[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))};var Fl={desktop:{label:"Desktop",type:"desktop",devices:ht("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:ht("mobile")}},Hl={desktop:{label:"Desktop",type:"desktop",devices:ht("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:ht("mobile",!0)}};function Tn(){return{version:"1.0",entries:{}}}var ue=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(ue||{});var An=18e4;import{stringify as Ul}from"yaml";import{createHash as oc}from"crypto";import{parse as rc,stringify as uo}from"yaml";import{readFileSync as sc}from"fs";import{resolve as ho,dirname as lc}from"path";import{parse as ao,stringify as cc}from"yaml";import{readFileSync as bg,writeFileSync as fc,mkdirSync as wc}from"fs";import{dirname as bc}from"path";var Mn=5e3;function _e(e){return e.replace(/\\/g,"\\\\").replace(/'/g,"\\'").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/\t/g,"\\t")}function B(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function Bl(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Gl(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 fi(e){let t=Bl(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Gl(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}var jl=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Kl=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"];function to(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:jl.includes(t)}function zl(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!Kl.includes(t)}var Z=new Map;function $(e,t){Z.set(e,t)}function Vl(e){return Z.get(e)}function He(e,t,i=[]){let n=[...i];return t.locator?n.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&n.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&n.push(`frame_path: ${JSON.stringify(t.frame_path)}`),n.length===0?[`await agent.execAction("${e}", page, {});`]:[`await agent.execAction("${e}", page, {`,...n.map(a=>` ${a},`),"});"]}$("click",e=>{let t=fi(e);if(!t)return['await agent.execAction("click", page, {});'];let i=e.action_data?.kwargs?.timeout_ms??Mn;return[`await ${t}.click({ timeout: ${i} });`]});$("click_element",Z.get("click"));$("click_element_by_index",Z.get("click"));$("double_click",e=>He("double_click",e));$("double_click_on_element",Z.get("double_click"));$("right_click",e=>He("right_click",e));$("right_click_on_element",Z.get("right_click"));$("hover",e=>He("hover",e));$("hover_element_by_index",Z.get("hover"));$("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return He("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("fill",Z.get("input_text"));$("clear_input",e=>He("clear_input",e));$("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});$("send_keys",Z.get("press"));$("send_keys_on_element",e=>{let t=fi(e),i=e.action_data?.kwargs?.keys||"";if(!t)return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(i)} } },`,"});"];let n=e.action_data?.kwargs?.timeout_ms??Mn;return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]});$("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return He("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("scroll",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)})');`]});$("scroll_down",Z.get("scroll"));$("scroll_up",Z.get("scroll"));$("scroll_element",Z.get("scroll"));$("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});$("scroll_on_element",e=>He("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));$("go_to_url",e=>{let t=e.action_data?.kwargs?.url||"";return e.action_data?.kwargs?.new_tab===!0?['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)}, new_tab: true } },`,"});"]:['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)} } },`,"});"]});$("open_tab",Z.get("go_to_url"));$("go_back",()=>['await agent.execAction("go_back", page, {});']);$("reload_page",()=>['await agent.execAction("reload_page", page, {});']);$("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);$("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);$("verify",(e,t)=>{let i=e.action_data?.kwargs,n=typeof i?.code=="string",a=n?i?.statement||e.action_description:e.action_description||i?.statement;if(n&&a){let r=i.code.split(`
|
|
4362
4362
|
`),s=JSON.stringify(a);return["{ const _t = Date.now(); try {",...r.map(l=>` ${l}`),` console.log(\`[VERIFY:JS] \u2713 \${((Date.now()-_t)/1000).toFixed(1)}s: ${s}\`);`,"} 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: ${s}\`);`,` await agent.assert(page, ${s}, ${JSON.stringify(t||"")});`,"} }"]}return n?i.code.split(`
|
|
4363
4363
|
`):a?[`await agent.assert(page, ${JSON.stringify(a)}, ${JSON.stringify(t||"")});`]:["// Skipping verify: missing statement or code"]});$("ai_assert",Z.get("verify"));$("assert",Z.get("verify"));$("ai_action",(e,t)=>{let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let n=JSON.stringify(i),a=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${n}, '${t||""}', ${a});`]});$("ai_step",(e,t)=>{let i=e.action_data?.kwargs?.statement;return i?[`await agent.run(page, ${JSON.stringify(i)}, '${t||""}');`]:["// Skipping ai_step: missing statement"]});$("ai_extract",(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 a=JSON.stringify(i),o=JSON.stringify(n);return[`await agent.extract(page, ${a}, ${o}, '${t||""}');`]});$("ai_wait_until",(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"]});$("save_variable",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)} } },`,"});"]});$("js_code",e=>{let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
|
|
4364
4364
|
`);for(let a of n)i.push(` ${a}`);return i.push("}"),i});$("function",(e,t,i)=>{let n=e.action_data?.kwargs||{},a=n.functionName;if(a&&a.includes("#")){let[r,s]=a.split("#");if(r&&s){let l=r.replace(/\.(ts|js|mjs)$/,""),c=`import { ${s} } from '${l}';`;i?.imports?.add(c);let d={...n,functionName:s},h=io(d);return h?[h.endsWith(";")?h:`${h};`]:["// Skipping function: invalid export pattern"]}}let o=io(n);return o?[o.endsWith(";")?o:`${o};`]:["// Skipping function: missing functionName"]});$("generate_2fa_code",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)} } },`,"});"]});$("upload_file",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(a=>` ${a},`),"});"]});$("wait_for_download_complete",e=>['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]);$("switch_tab",e=>['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]);$("close_tab",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} } },`,"});"]});$("set_date_for_native_date_picker",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},`),"});"]});$("done",()=>["// Done - no action needed"]);$("js_action",e=>{let t=e.action_data?.kwargs?.code;return t?t.split(`
|
|
4365
4365
|
`):["// Skipping js_action: missing code"]});function io(e){let t=e.functionName;if(!t)return null;let i=Array.isArray(e.args)?e.args.map(String):[];if(i.length===0)return`await ${t}()`;let n=["page","testContext","request","agent"],a=["undefined","null","true","false"],o=i.map(r=>n.includes(r)||a.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${o.join(", ")})`}function pe(e,t,i,n="main"){let a=[];for(let o=0;o<e.length;o++){let r=e[o],s=`${n}.${o}`,l=Xl(r,t,s,i);l.length>0&&(a.push(...l),o<e.length-1&&a.push(""))}return a}function Xl(e,t,i,n){let a=" ".repeat(t);switch(e.type){case"DRAFT":return Yl(e,t,i,n);case"ACTION":return Jl(e,t,i,n);case"STEP":return ql(e,t,i,n);case"IF_ELSE":return Zl(e,t,i,n);case"WHILE_LOOP":return Ql(e,t,i,n);default:return[`${a}// Unknown statement type: ${e.type}`]}}function Yl(e,t,i,n){let a=" ".repeat(t),o=e.description?.trim()||"";if(!o)return[`${a}// ${i}: Skipping - no description`];if(n.noAgent)return[`${a}// ${i}: ${B(o)}`,`${a}// DRAFT: ${B(o)} (requires agent - skipped in hook)`];let r=JSON.stringify(o);return[`${a}// ${i}: ${B(o)}`,`${a}// \u26A0 DRAFT: AI-resolved at runtime (~5-10s). Add a locator to make this <1s.`,`${a}page = agent.agentServices.validatePage(page);`,`${a}await agent.run(page, ${r}, '${i}');`]}function Jl(e,t,i,n){let a=" ".repeat(t),o=e.description,r=e.uid,l=n.actionEntityStore?.entries[e.uid]?.action_entity??e.action_entity;if(!l){if(!o)return[`${a}// ${i}: Skipping - no description`];if(n.noAgent)return[`${a}// ${i}: ${B(o)}`,`${a}// DRAFT: ${B(o)} (requires agent - skipped in hook)`];let S=JSON.stringify(o),E=!!e.use_pure_vision;return[`${a}// ${i}: ${B(o)}`,`${a}// \u26A0 DRAFT: AI-resolved at runtime (~5-10s). Add a locator to make this <1s.`,`${a}page = agent.agentServices.validatePage(page);`,`${a}await agent.execute(page, ${S}, '${i}', ${E});`]}let c=e.locator?{...l,locator:e.locator}:l;o&&o!==c.action_description&&(c={...c,action_description:o});let d=c.action_data?.action_name||"",h=c.action_description||"",p=Vl(d);if(!p)return[`${a}// ${i}: Unknown action: ${d}`];let g={imports:n.imports},f=p(c,i,g);if(n.noAgent){if(to(c))return[`${a}// ${i}: ${B(h)}`,`${a}// AI action: ${B(h)} (requires agent - skipped in hook)`];let S=ec(c,d,a,i);return S||[`${a}// ${i}: ${B(h)}`,...f.map(E=>`${a}${E}`)]}if(to(c))return[`${a}// ${i}: ${B(h)}`,`${a}page = agent.agentServices.validatePage(page);`,...f.map(S=>`${a}${S}`)];let v=JSON.stringify(h),b=f.map(S=>`${a} ${S}`),m=zl(c),y=r?`'${r}'`:"undefined";return[`${a}// ${i}: ${B(h)}`,`${a}page = agent.agentServices.validatePage(page);`,`${a}await agent.step(page, async () => {`,...b,`${a}}, ${v}, '${i}', ${y}, ${m});`]}function ql(e,t,i,n){let a=" ".repeat(t),o=[];e.description&&e.description.trim()&&o.push(`${a}// Step: ${B(e.description)}`);let r=pe(e.statements,t,n,i);return o.push(...r),o}function Zl(e,t,i,n){let a=" ".repeat(t),o=[];if(o.push(`${a}// ${i}: Conditional check`),e.condition.type==="JS_CODE")o.push(`${a}if (${e.condition.expression}) {`);else{o.push(`${a}// AI Condition: ${B(e.condition.expression)}`);let s=JSON.stringify(e.condition.expression);o.push(`${a}if (await agent.evaluate(page, ${s}, "${i}")) {`)}let r=pe(e.then,t+1,n,`${i}.then`);if(o.push(...r),e.else&&e.else.length>0){o.push(`${a}} else {`);let s=pe(e.else,t+1,n,`${i}.else`);o.push(...s)}return o.push(`${a}}`),o}function Ql(e,t,i,n){let a=" ".repeat(t),o=[];o.push(`${a}// ${i}: Loop`);let r=e.timeout_ms??An,s=r/1e3,l=e.timeout_ms?`While loop exceeded timeout of ${s}s`:`While loop exceeded default timeout of ${s}s`,c=`loop_${i.replace(/\./g,"_")}`;if(o.push(`${a}const ${c}_start = Date.now();`),o.push(`${a}const ${c}_timeout = ${r};`),o.push(`${a}const ${c}_check = () => {`),o.push(`${a} if (Date.now() - ${c}_start > ${c}_timeout) {`),o.push(`${a} throw new Error('${l}');`),o.push(`${a} }`),o.push(`${a} return true;`),o.push(`${a}};`),e.condition.type==="JS_CODE")o.push(`${a}while (${c}_check() && (${e.condition.expression})) {`);else{o.push(`${a}// AI Loop Condition: ${B(e.condition.expression)}`);let h=JSON.stringify(e.condition.expression);o.push(`${a}while (${c}_check() && await agent.evaluate(page, ${h}, "${i}")) {`)}let d=pe(e.body,t+1,n,`${i}.body`);return o.push(...d),o.push(`${a}}`),o}function ec(e,t,i,n){let a=e.action_description||"",o=e.action_data?.kwargs||{},r=o.timeout_ms??Mn;switch(t){case"go_to_url":case"open_tab":{let s=o.url||"";return[`${i}// ${n}: ${B(a)}`,`${i}await page.goto(${JSON.stringify(s)}, { waitUntil: 'domcontentloaded' });`]}case"go_back":return[`${i}// ${n}: ${B(a)}`,`${i}await page.goBack();`];case"go_forward":return[`${i}// ${n}: ${B(a)}`,`${i}await page.goForward();`];case"input_text":{let s=o.text||"",l=fi(e);return l?[`${i}// ${n}: ${B(a)}`,`${i}await ${l}.fill(${JSON.stringify(s)}, { timeout: ${r} });`]:null}case"select_dropdown_option":{let s=o.text||o.label||"",l=fi(e);return l?[`${i}// ${n}: ${B(a)}`,`${i}await ${l}.selectOption({ label: ${JSON.stringify(s)} }, { timeout: ${r} });`]:null}default:return null}}function tc(e,t){let i=[],n=t?.version||"unknown";i.push(`// @generated by shiplightai v${n}`),i.push(...lo()),i.push(""),t?.use&&Object.keys(t.use).length>0&&(i.push(`test.use(${JSON.stringify(t.use,null,2)});`),i.push(""));let a=new Set,o={imports:a,actionEntityStore:t?.actionEntityStore};t?.beforeEach&&t.beforeEach.length>0&&(i.push(...no("beforeEach",t.beforeEach,o)),i.push(""));let r=t?.timeout||t?.skip!==void 0||t?.fail!==void 0||t?.only||t?.slow?{timeout:t.timeout,skip:t.skip,fail:t.fail,only:t.only,slow:t.slow}:void 0;if(t?.parameters&&t.parameters.length>0){let s=t?.testName||e.goal||"Generated test",l=$n(t?.tags);for(let c of t.parameters){let d=so(e,c.values);i.push(...bi(d,`${l}${_e(s)} [${_e(c.name)}]`,o,0,r)),i.push("")}}else{let s=t?.testName||e.goal||"Generated test",l=$n(t?.tags);i.push(...bi(e,`${l}${_e(s)}`,o,0,r))}return t?.afterEach&&t.afterEach.length>0&&(i.push(""),i.push(...no("afterEach",t.afterEach,o))),co(i,a),i.join(`
|
|
4366
4366
|
`)}function ic(e,t){let i=[],n=t?.version||"unknown";i.push(`// @generated by shiplightai v${n}`),i.push(...lo()),i.push(""),t?.use&&Object.keys(t.use).length>0&&(i.push(`test.use(${JSON.stringify(t.use,null,2)});`),i.push(""));let a=new Set,o={imports:a,actionEntityStore:t?.actionEntityStore},r=t?.testName||"Test Suite",s=$n(t?.tags);i.push(`test.describe.serial('${s}${_e(r)}', () => {`),e.beforeAll&&e.beforeAll.length>0&&(i.push(...gi("beforeAll",e.beforeAll,o,1)),i.push("")),e.beforeEach&&e.beforeEach.length>0&&(i.push(...gi("beforeEach",e.beforeEach,o,1)),i.push(""));for(let c=0;c<e.tests.length;c++){let d=e.tests[c],h=d.timeout||d.skip!==void 0||d.fail!==void 0||d.only||d.slow?{timeout:d.timeout,skip:d.skip,fail:d.fail,only:d.only,slow:d.slow}:void 0;if(d.parameters&&d.parameters.length>0)for(let p of d.parameters){let g=so(d.testFlow,p.values);i.push(...bi(g,`${_e(d.name)} [${_e(p.name)}]`,o,1,h)),i.push("")}else i.push(...bi(d.testFlow,_e(d.name),o,1,h)),(c<e.tests.length-1||e.afterEach||e.afterAll)&&i.push("")}return e.afterEach&&e.afterEach.length>0&&(i.push(...gi("afterEach",e.afterEach,o,1)),i.push("")),e.afterAll&&e.afterAll.length>0&&i.push(...gi("afterAll",e.afterAll,o,1)),i.push("});"),co(i,a),i.join(`
|
|
4367
|
-
`)}function $n(e){return e&&e.length>0?e.map(t=>`@${t}`).join(" ")+" ":""}var nc=["testContext","request"];function wi(e){let t=new Set;function i(n){for(let a of n)switch(a.type){case ue.ACTION:{let r=a.action_entity?.action_data?.kwargs;if(r?.args&&Array.isArray(r.args))for(let s of r.args)typeof s=="string"&&nc.includes(s)&&t.add(s);break}case ue.STEP:i(a.statements);break;case ue.IF_ELSE:{let o=a;i(o.then),o.else&&i(o.else);break}case ue.WHILE_LOOP:i(a.body);break}}return i(e),t}function ac(e){let t=wi(e.statements??[]);if(e.teardown)for(let i of wi(e.teardown))t.add(i);return t}function In(e){return`{ ${["page","agent",...Array.from(e).sort()].join(", ")} }`}function bi(e,t,i,n=0,a){let o=" ".repeat(n),r=[],s=ac(e),l=In(s),c=a?.only?"test.only":"test";r.push(`${o}${c}('${t}', async (${l}) => {`),a?.skip===!0?r.push(`${o} test.skip();`):typeof a?.skip=="string"&&r.push(`${o} test.skip(true, '${_e(a.skip)}');`),a?.fail===!0?r.push(`${o} test.fail();`):typeof a?.fail=="string"&&r.push(`${o} test.fail(true, '${_e(a.fail)}');`),a?.slow&&r.push(`${o} test.slow();`),a?.timeout&&r.push(`${o} test.setTimeout(${a.timeout});`);let d=e.teardown&&e.teardown.length>0,h=n+1;if(d){if(r.push(`${o} try {`),e.statements&&e.statements.length>0){r.push(`${o} // Test steps`);let g=pe(e.statements,h+1,i);r.push(...g)}r.push(`${o} } finally {`),r.push(`${o} // Teardown`);let p=pe(e.teardown,h+1,i,"teardown");r.push(...p),r.push(`${o} }`)}else if(e.statements&&e.statements.length>0){r.push(`${o} // Test steps`);let p=pe(e.statements,h,i);r.push(...p)}return r.push(`${o}});`),r}function no(e,t,i){let n=[],a=ro(t),o=wi(a),r=In(o);return n.push(`test.${e}(async (${r}) => {`),n.push(...pe(a,1,i,e)),n.push("});"),n}function gi(e,t,i,n){let a=" ".repeat(n),o=[],r=ro(t);if(e==="beforeAll"||e==="afterAll"){let l={...i,noAgent:!0};o.push(`${a}test.${e}(async ({ browser }, workerInfo) => {`),o.push(`${a} const page = await browser.newPage({ baseURL: workerInfo.project.use.baseURL });`),o.push(...pe(r,n+1,l,e)),o.push(`${a} await page.close();`),o.push(`${a}});`)}else{let l=wi(r),c=In(l);o.push(`${a}test.${e}(async (${c}) => {`),o.push(...pe(r,n+1,i,e)),o.push(`${a}});`)}return o}function ro(e){let i=Ul({goal:"_hook",statements:e});return me(i).statements??[]}function so(e,t){let i=kn(e);for(let[n,a]of Object.entries(t))i=i.split(`<<${n}>>`).join(String(a));return me(i)}function lo(){return["import { test, expect } from 'shiplightai/fixture';"]}function co(e,t){if(t.size>0){let i=0;for(let a=0;a<e.length;a++)e[a].startsWith("import ")&&(i=a+1);let n=Array.from(t);e.splice(i,0,...n)}}var oo=5;function mo(e,t){let i={expandingPaths:new Set([ho(t)]),depth:0,referencedPaths:new Set},n={...e};Array.isArray(n.statements)&&(n.statements=
|
|
4367
|
+
`)}function $n(e){return e&&e.length>0?e.map(t=>`@${t}`).join(" ")+" ":""}var nc=["testContext","request"];function wi(e){let t=new Set;function i(n){for(let a of n)switch(a.type){case ue.ACTION:{let r=a.action_entity?.action_data?.kwargs;if(r?.args&&Array.isArray(r.args))for(let s of r.args)typeof s=="string"&&nc.includes(s)&&t.add(s);break}case ue.STEP:i(a.statements);break;case ue.IF_ELSE:{let o=a;i(o.then),o.else&&i(o.else);break}case ue.WHILE_LOOP:i(a.body);break}}return i(e),t}function ac(e){let t=wi(e.statements??[]);if(e.teardown)for(let i of wi(e.teardown))t.add(i);return t}function In(e){return`{ ${["page","agent",...Array.from(e).sort()].join(", ")} }`}function bi(e,t,i,n=0,a){let o=" ".repeat(n),r=[],s=ac(e),l=In(s),c=a?.only?"test.only":"test";r.push(`${o}${c}('${t}', async (${l}) => {`),a?.skip===!0?r.push(`${o} test.skip();`):typeof a?.skip=="string"&&r.push(`${o} test.skip(true, '${_e(a.skip)}');`),a?.fail===!0?r.push(`${o} test.fail();`):typeof a?.fail=="string"&&r.push(`${o} test.fail(true, '${_e(a.fail)}');`),a?.slow&&r.push(`${o} test.slow();`),a?.timeout&&r.push(`${o} test.setTimeout(${a.timeout});`);let d=e.teardown&&e.teardown.length>0,h=n+1;if(d){if(r.push(`${o} try {`),e.statements&&e.statements.length>0){r.push(`${o} // Test steps`);let g=pe(e.statements,h+1,i);r.push(...g)}r.push(`${o} } finally {`),r.push(`${o} // Teardown`);let p=pe(e.teardown,h+1,i,"teardown");r.push(...p),r.push(`${o} }`)}else if(e.statements&&e.statements.length>0){r.push(`${o} // Test steps`);let p=pe(e.statements,h,i);r.push(...p)}return r.push(`${o}});`),r}function no(e,t,i){let n=[],a=ro(t),o=wi(a),r=In(o);return n.push(`test.${e}(async (${r}) => {`),n.push(...pe(a,1,i,e)),n.push("});"),n}function gi(e,t,i,n){let a=" ".repeat(n),o=[],r=ro(t);if(e==="beforeAll"||e==="afterAll"){let l={...i,noAgent:!0};o.push(`${a}test.${e}(async ({ browser }, workerInfo) => {`),o.push(`${a} const page = await browser.newPage({ baseURL: workerInfo.project.use.baseURL });`),o.push(...pe(r,n+1,l,e)),o.push(`${a} await page.close();`),o.push(`${a}});`)}else{let l=wi(r),c=In(l);o.push(`${a}test.${e}(async (${c}) => {`),o.push(...pe(r,n+1,i,e)),o.push(`${a}});`)}return o}function ro(e){let i=Ul({goal:"_hook",statements:e});return me(i).statements??[]}function so(e,t){let i=kn(e);for(let[n,a]of Object.entries(t))i=i.split(`<<${n}>>`).join(String(a));return me(i)}function lo(){return["import { test, expect } from 'shiplightai/fixture';"]}function co(e,t){if(t.size>0){let i=0;for(let a=0;a<e.length;a++)e[a].startsWith("import ")&&(i=a+1);let n=Array.from(t);e.splice(i,0,...n)}}var oo=5;function mo(e,t){let i={expandingPaths:new Set([ho(t)]),depth:0,referencedPaths:new Set},n={...e};Array.isArray(n.statements)&&(n.statements=De(n.statements,t,i)),Array.isArray(n.teardown)&&(n.teardown=De(n.teardown,t,i));for(let a of["beforeAll","afterAll","beforeEach","afterEach"])Array.isArray(n[a])&&(n[a]=De(n[a],t,i));return{doc:n,referencedTemplatePaths:Array.from(i.referencedPaths)}}function De(e,t,i){let n=[];for(let a of e)if(dc(a)){let o=uc(a,t,i);n.push(...o)}else n.push(hc(a,t,i));return n}function dc(e){return typeof e=="object"&&e!==null&&typeof e.template=="string"}function uc(e,t,i){if(i.depth>=oo)throw new Error(`Template expansion exceeded maximum depth of ${oo}. Check for deeply nested or circular template references.`);let n=ho(lc(t),e.template);if(i.expandingPaths.has(n))throw new Error(`Circular template reference detected: ${n} is already being expanded. Stack: ${Array.from(i.expandingPaths).join(" \u2192 ")} \u2192 ${n}`);i.referencedPaths.add(n);let a;try{a=sc(n,"utf-8")}catch(d){throw new Error(`Failed to read template file: ${n} (referenced from ${t}): ${d.message}`)}let o=ao(a);if(!o||typeof o!="object")throw new Error(`Invalid template file: ${n} \u2014 expected a YAML object`);let r=o.params||[],s=e.params||{};for(let d of r)if(!(d in s))throw new Error(`Template ${e.template} requires param "${d}" but it was not provided. Required params: [${r.join(", ")}]`);let l=o.statements;if(!Array.isArray(l))throw new Error(`Template ${e.template} must have a "statements" array`);if(Object.keys(s).length>0){let h=cc(l);for(let[p,g]of Object.entries(s))h=h.split(`<<${p}>>`).join(String(g));l=ao(h)}let c={expandingPaths:new Set([...i.expandingPaths,n]),depth:i.depth+1,referencedPaths:i.referencedPaths};return De(l,n,c)}function hc(e,t,i){if(typeof e!="object"||e===null)return e;let n={...e};return Array.isArray(n.statements)&&(n.statements=De(n.statements,t,i)),Array.isArray(n.THEN)&&(n.THEN=De(n.THEN,t,i)),Array.isArray(n.ELSE)&&(n.ELSE=De(n.ELSE,t,i)),Array.isArray(n.DO)&&(n.DO=De(n.DO,t,i)),n}var Cn=class extends Error{constructor(e){super(e),this.name="YamlValidationError"}};function Pn(e,t){let i=rc(e),n=i?.name,a=i?.tags,o=i?.use;if(i&&(i.name!==void 0||i.tags!==void 0||i.use!==void 0)&&(delete i.name,delete i.tags,delete i.use),i?.suite){if(i.goal||i.statements)throw new Cn('YAML file cannot have both "suite" and top-level "goal"/"statements". Use either suite format or single-test format.');return pc(i,n,a,o,t)}return mc(i,n,a,o,t)}function mc(e,t,i,n,a){let o=e?.beforeEach,r=e?.afterEach,s=po(e?.parameters),l=e?.timeout,c=e?.skip,d=e?.fail,h=e?.only,p=e?.slow;if(e&&(delete e.beforeEach,delete e.afterEach,delete e.parameters,delete e.timeout,delete e.skip,delete e.fail,delete e.only,delete e.slow),e?.url)throw new Cn(`The "url" field is not supported in local YAML tests. Use "base_url: ${e.url}" and add "- URL: /" as the first statement instead.`);e&&!e.goal&&t&&(e.goal=t);let g=[];if(a&&e&&typeof e=="object"){let b=mo(e,a);e=b.doc,g=b.referencedTemplatePaths}let f=uo(e),v=me(f);return a&&(Ve(v.statements??[],a,"main"),v.teardown&&Ve(v.teardown,a,"teardown")),{testFlow:v,name:t,tags:i,use:n,beforeEach:o,afterEach:r,parameters:s,timeout:l,skip:c,fail:d,only:h,slow:p,referencedTemplatePaths:g}}function pc(e,t,i,n,a){let o=e.suite;if(!Array.isArray(o.tests)||o.tests.length===0)throw new Error('Suite must have a non-empty "tests" array.');let r=o.beforeAll,s=o.afterAll,l=o.beforeEach,c=o.afterEach,d=[],h=o.tests.map(f=>{if(!f.name)throw new Error('Each test in a suite must have a "name" field.');if(!Array.isArray(f.statements)||f.statements.length===0)throw new Error(`Suite test "${f.name}" must have a non-empty "statements" array.`);let v={goal:f.name,statements:f.statements};f.teardown&&(v.teardown=f.teardown);let b=[],m=v;if(a&&typeof v=="object"){let A=mo(v,a);m=A.doc,b=A.referencedTemplatePaths,d.push(...b)}let y=uo(m),S=me(y),E=po(f.parameters);return{testFlow:S,name:f.name,tags:Array.isArray(f.tags)?f.tags:void 0,parameters:E,timeout:f.timeout,skip:f.skip,fail:f.fail,only:f.only,slow:f.slow}}),p=o.base_url,g=p?{...n,baseURL:p}:n;return{suite:{beforeAll:r,afterAll:s,beforeEach:l,afterEach:c,tests:h},name:t,tags:i,use:g,referencedTemplatePaths:d}}function po(e){if(!(!Array.isArray(e)||e.length===0))return e.map((t,i)=>{if(!t.name)throw new Error(`Parameter set at index ${i} must have a "name" field.`);if(!t.values||typeof t.values!="object")throw new Error(`Parameter set "${t.name}" must have a "values" object.`);return{name:t.name,values:t.values}})}function Ve(e,t,i){for(let n=0;n<e.length;n++){let a=e[n],o=`${i}.${n}`,r=a.description||"";if(a.uid=gc(t,o,r),a.type===ue.STEP)Ve(a.statements,t,o);else if(a.type===ue.IF_ELSE){let s=a;Ve(s.then,t,`${o}.then`),s.else&&Ve(s.else,t,`${o}.else`)}else a.type===ue.WHILE_LOOP&&Ve(a.body,t,`${o}.body`)}}function gc(e,t,i){let n=oc("sha256").update(`${e}:${t}:${i}`).digest("hex");return`${n.slice(0,8)}-${n.slice(8,12)}-${n.slice(12,16)}-${n.slice(16,20)}-${n.slice(20,32)}`}function go(e,t,i){let n=/\btemplate:\s/.test(e),a=/^suite:/m.test(e),o=n||a?null:En(e);if(o&&!o.valid)return{valid:!1,errors:o.errors,warnings:[],stats:o.stats};let r,s,l=[];try{let c=i?.parsed??Pn(e,t);l=c.referencedTemplatePaths;let d={version:i?.version,actionEntityStore:i?.actionEntityStore},h=c.testFlow?.baseURL?{...c.use,baseURL:c.testFlow.baseURL}:c.use;c.suite?r=ic(c.suite,{...d,testName:c.name,tags:c.tags,use:c.use}):r=tc(c.testFlow,{...d,testName:c.name,tags:c.tags,use:h,beforeEach:c.beforeEach,afterEach:c.afterEach,parameters:c.parameters,timeout:c.timeout,skip:c.skip,fail:c.fail,only:c.only,slow:c.slow});let p=r.split(`
|
|
4368
4368
|
`).filter(g=>!g.startsWith("import ")).join(`
|
|
4369
|
-
`);new Function(p),s=t.replace(/\.test\.yaml$/,".yaml.spec.ts"),wc(bc(s),{recursive:!0}),fc(s,r)}catch(c){let d=c instanceof Cn?"":c.message.includes("Unexpected token")?" This usually means a YAML escaping issue \u2014 in double-quoted strings, use \\\\/ instead of \\/ for regex patterns, or use single quotes / block scalars.":" This may indicate a transpiler bug \u2014 please report it.";return{valid:!1,errors:[`Transpilation failed: ${c.message}.${d}`],warnings:[],stats:o?.stats??{total:0,action:0,draft:0,coverage:0},referencedTemplatePaths:l}}return{valid:!0,errors:[],warnings:o?.warnings??[],stats:o?.stats??{total:0,action:0,draft:0,coverage:0},specFile:s,referencedTemplatePaths:l}}var On="0.1.
|
|
4370
|
-
`,1)[0]!==_c)return!1;let n=fo(e);for(let a of t)if(fo(a)>n)return!1;return!0}function Sc(e){let t=process.argv.slice(2),i=[],n=
|
|
4369
|
+
`);new Function(p),s=t.replace(/\.test\.yaml$/,".yaml.spec.ts"),wc(bc(s),{recursive:!0}),fc(s,r)}catch(c){let d=c instanceof Cn?"":c.message.includes("Unexpected token")?" This usually means a YAML escaping issue \u2014 in double-quoted strings, use \\\\/ instead of \\/ for regex patterns, or use single quotes / block scalars.":" This may indicate a transpiler bug \u2014 please report it.";return{valid:!1,errors:[`Transpilation failed: ${c.message}.${d}`],warnings:[],stats:o?.stats??{total:0,action:0,draft:0,coverage:0},referencedTemplatePaths:l}}return{valid:!0,errors:[],warnings:o?.warnings??[],stats:o?.stats??{total:0,action:0,draft:0,coverage:0},specFile:s,referencedTemplatePaths:l}}var On="0.1.49";function fo(e){try{return yc(e).mtimeMs}catch{return 0}}var _c=`// @generated by shiplightai v${On}`;function kc(e,t){if(!bo(e)||wo(e,"utf-8").split(`
|
|
4370
|
+
`,1)[0]!==_c)return!1;let n=fo(e);for(let a of t)if(fo(a)>n)return!1;return!0}function Sc(e){let t=process.argv.slice(2),i=[],n=Ln(e);for(let a of t){if(a.startsWith("-"))continue;let o=a.endsWith(".yaml.spec.ts")?a.replace(/\.yaml\.spec\.ts$/,".test.yaml"):a;if(!o.endsWith(".test.yaml"))continue;let r=Ln(e,o);bo(r)&&i.push(r.startsWith(n)?r.slice(n.length+1):o)}return i.length>0?i:null}function yo(e){let t=Sc(e.cwd),i=t??vc("**/*.test.yaml",{cwd:e.cwd,ignore:["**/node_modules/**"]}),n=[];for(let a of i){let o=Ln(e.cwd,a),r=o.replace(/\.test\.yaml$/,".yaml.spec.ts"),s=wo(o,"utf-8");try{let l=Pn(s,o),c=xc(e.cwd,o),d=e.actionEntityStores?.get(c)??e.actionEntityStores?.get("*");if(!(d&&Object.keys(d.entries).length>0)&&kc(r,[o,...l.referencedTemplatePaths]))continue;let p=go(s,o,{version:On,actionEntityStore:d,parsed:l});if(!p.valid)throw new Error(p.errors.join("; "))}catch(l){console.error(`[shiplight] Failed to transpile ${a}:`,l),n.push({file:a,error:l})}}if(n.length>0){let a=`[shiplight] Transpilation failed for ${n.length} file(s):
|
|
4371
4371
|
`+n.map(o=>` - ${o.file}`).join(`
|
|
4372
|
-
`);if(t)throw new Error(a);console.warn(a+" (skipped)")}}import*as ae from"fs";import*as mt from"path";import{globSync as Ac}from"glob";function _o(e){return process.env.CI&&process.env.SHIPLIGHT_API_TOKEN?new Fn:new Rn(e)}var $c=".shiplight/action-cache";function vo(e){return e.replace(/\//g,"__")+".json"}function Mc(e){return e.replace(/\.json$/,"").replace(/__/g,"/")}var Rn=class{constructor(t){this.cwd=t;this.cacheDir=mt.join(t,$c)}isCloud=!1;cacheDir;async lookup(t){let i=new Map;if(t.length===0||!ae.existsSync(this.cacheDir))return i;for(let n of t){let a=mt.join(this.cacheDir,vo(n));try{if(ae.existsSync(a)){let o=ae.readFileSync(a,"utf-8");i.set(n,JSON.parse(o))}}catch{}}return i}async update(t){if(t.size===0)return 0;ae.mkdirSync(this.cacheDir,{recursive:!0});let i=0;for(let[n,a]of t)try{let o=mt.join(this.cacheDir,vo(n)),r=Tn();if(ae.existsSync(o))try{r=JSON.parse(ae.readFileSync(o,"utf-8"))}catch{}let s={...r,entries:{...r.entries,...a.entries}};ae.writeFileSync(o,JSON.stringify(s,null,2)),i++}catch{}return i}loadAll(){if(!ae.existsSync(this.cacheDir))return;let t=Ac("*.json",{cwd:this.cacheDir});if(t.length===0)return;let i=new Map,n=0;for(let a of t)try{let o=ae.readFileSync(mt.join(this.cacheDir,a),"utf-8"),r=JSON.parse(o),s=Mc(a);i.set(s,r),n+=Object.keys(r.entries??{}).length}catch{}if(i.size!==0)return console.log(`[shiplight] Cache: loaded ${n} cached action entit${n===1?"y":"ies"} for ${i.size} test file${i.size!==1?"s":""}`),i}},Fn=class{isCloud=!0;async lookup(t){let{lookupActionStores:i}=await Promise.resolve().then(()=>(Nn(),
|
|
4372
|
+
`);if(t)throw new Error(a);console.warn(a+" (skipped)")}}import*as ae from"fs";import*as mt from"path";import{globSync as Ac}from"glob";function _o(e){return process.env.CI&&process.env.SHIPLIGHT_API_TOKEN?new Fn:new Rn(e)}var $c=".shiplight/action-cache";function vo(e){return e.replace(/\//g,"__")+".json"}function Mc(e){return e.replace(/\.json$/,"").replace(/__/g,"/")}var Rn=class{constructor(t){this.cwd=t;this.cacheDir=mt.join(t,$c)}isCloud=!1;cacheDir;async lookup(t){let i=new Map;if(t.length===0||!ae.existsSync(this.cacheDir))return i;for(let n of t){let a=mt.join(this.cacheDir,vo(n));try{if(ae.existsSync(a)){let o=ae.readFileSync(a,"utf-8");i.set(n,JSON.parse(o))}}catch{}}return i}async update(t){if(t.size===0)return 0;ae.mkdirSync(this.cacheDir,{recursive:!0});let i=0;for(let[n,a]of t)try{let o=mt.join(this.cacheDir,vo(n)),r=Tn();if(ae.existsSync(o))try{r=JSON.parse(ae.readFileSync(o,"utf-8"))}catch{}let s={...r,entries:{...r.entries,...a.entries}};ae.writeFileSync(o,JSON.stringify(s,null,2)),i++}catch{}return i}loadAll(){if(!ae.existsSync(this.cacheDir))return;let t=Ac("*.json",{cwd:this.cacheDir});if(t.length===0)return;let i=new Map,n=0;for(let a of t)try{let o=ae.readFileSync(mt.join(this.cacheDir,a),"utf-8"),r=JSON.parse(o),s=Mc(a);i.set(s,r),n+=Object.keys(r.entries??{}).length}catch{}if(i.size!==0)return console.log(`[shiplight] Cache: loaded ${n} cached action entit${n===1?"y":"ies"} for ${i.size} test file${i.size!==1?"s":""}`),i}},Fn=class{isCloud=!0;async lookup(t){let{lookupActionStores:i}=await Promise.resolve().then(()=>(Nn(),Dn));return i(t)}async update(t){let{updateActionStores:i}=await Promise.resolve().then(()=>(Nn(),Dn));return i(t)}loadAll(){}};function Pc(e={}){e.dotenv!==!1&&Lc(e.scanDir||process.cwd());let t=e.scanDir||process.cwd(),n=_o(t).loadAll();return yo({cwd:t,actionEntityStores:n}),e.apiKey&&(process.env.__SHIPLIGHT_API_KEY=e.apiKey),{reporter:[["list"],["shiplightai/reporter",{outputFolder:"shiplight-report",open:"never",reportToCloud:e.reportToCloud,apiKey:e.apiKey}]]}}function Oc(e,...t){return Cc(e,...t)}function Lc(e){let t=[],i=We.resolve(e),n=We.resolve(process.cwd());for(;;){let a=We.join(i,".env");if(ko.existsSync(a)&&t.push(a),i===n)break;let o=We.dirname(i);if(o===i)break;i=o}for(let a of t)Ic.config({path:a})}R();R();It();Ze();import{z as Fs}from"zod";var Zu=Fs.object({instruction:Fs.string().describe('The instruction of the operation to perform. Can only include one operation. Do not inlcude element indexes just describe the element, e.g. "select the text "Hello, world!" in "Hello, world!""')});function Hs(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:Zu,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,a={page:i.page,agentServices:i.agentServices,domService:i.domService},o=await qe(n,a,{});if(o.status==="error"||!o.actionEntity)return{success:!1,actionEntity:{action_description:n,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:n}}},error:o.error||"Failed to generate action"};let{actionEntity:r}=o,s=await $t(r,a);return{success:s.success,actionEntity:r,message:s.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:s.error}}})}Te();R();import{generateText as Qu}from"ai";import{convert as eh}from"html-to-text";async function th(e,t,i){let{apiKey:n,domain:a}=e;if(!n||!a)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let o=[];try{let r=`https://api.mailgun.net/v3/${a}/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 d=new Date(Date.now()-6e5);s.begin=Math.floor(d.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 d=await l.text();throw new Error(`Mailgun events API error: ${d}`)}let c=(await l.json()).items||[];for(let d of c.slice(0,10)){if(d.event!=="accepted")continue;let h=(d.storage||{}).url;if(u.info(`message_url: ${h}`),!h){let f=(d.message||{}).headers||{},v=f.subject||"",b=f.from||"",m=f.to||"";if(i.from_email&&!b.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!m.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!v.toLowerCase().includes(i.subject.toLowerCase()))continue;o.push({subject:v,from:b,to:m,date:new Date(d.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:f["message-id"]||""});continue}let p=h.split("/"),g=p[p.length-1];if(u.info(`Storage key: ${g}`),g){let f=`https://api.mailgun.net/v3/domains/${a}/messages/${g}`;try{let v=await fetch(f,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,Accept:"application/json"}});if(v.ok){let b=await v.json(),m=b.Subject||"",y=b.From||"",S=b.To||"",E=b.Date||"",A=b["Message-Id"]||"";u.info(`subject: ${m}`),u.info(`from_addr: ${y}`),u.info(`to_addr: ${S}`),u.info(`date: ${E}`),u.info(`message_id: ${A}`);let M=b["body-html"]||b["body-plain"]||"";if(M&&M.includes("<")&&(M=eh(M)),u.info(`Body: ${M.substring(0,200)}...`),i.subject&&!m.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!M.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:m,from:y,to:S,date:E,body:M,message_id:A});continue}else u.warn(`Messages API returned ${v.status}`)}catch(v){u.warn(`Failed to parse JSON response: ${v}`)}}try{let f=await fetch(h,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!f.ok){u.warn(`Could not fetch stored message: ${f.status}`);continue}let v=await f.text();u.info(`Fallback: Raw email length: ${v.length}`);let b=v.split(`
|
|
4373
4373
|
`),m=!0,y={},S="";for(let P=0;P<b.length;P++){let V=b[P];if(V.trim()===""&&m){m=!1;continue}if(m){let ee=V.match(/^([^:]+):\s*(.+)$/);ee&&(y[ee[1].toLowerCase()]=ee[2])}else S+=V+`
|
|
4374
|
-
`}let E=y.subject||"",A=y.from||"",M=y.to||"",
|
|
4374
|
+
`}let E=y.subject||"",A=y.from||"",M=y.to||"",L=y.date||"",N=y["message-id"]||"";if(i.subject&&!E.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!S.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:E,from:A,to:M,date:L,body:S.trim(),message_id:N})}catch(f){u.warn(`Error fetching raw message: ${f}`)}}if(o.length>0){try{o.sort((h,p)=>{let g=new Date(h.date).getTime();return new Date(p.date).getTime()-g})}catch{}let d=o[0];return u.info(`Returning most recent email: ${d.subject}`),[d]}return o}catch(r){throw u.error(`Error fetching emails from Mailgun: ${r.message}`),new Error(`Error fetching emails from Mailgun: ${r.message}`)}}function ih(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
|
|
4375
4375
|
|
|
4376
4376
|
Please carefully examine the email content and look for:
|
|
4377
4377
|
1. Numeric codes (usually 4-8 digits)
|
|
@@ -4445,8 +4445,8 @@ To: ${p.to}
|
|
|
4445
4445
|
Date: ${p.date}
|
|
4446
4446
|
|
|
4447
4447
|
Body:
|
|
4448
|
-
${p.body}`,f=await nh(g,a,t.model);u.info(`Extracted content: ${f}`),f&&f!=="NOT_FOUND"&&h.push({content:f,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 f=(new Date().getTime()-o.getTime())/1e3;return u.info(`Successfully extracted content after ${s} attempts in ${f.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(c){u.warn(`Error in polling attempt ${s}: ${c.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(c=>setTimeout(c,n*1e3))}let l=(new Date().getTime()-o.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${s} attempts over ${l.toFixed(1)} seconds`}}catch(a){return u.error(`Error extracting email content: ${a.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${a.message}`}}}R();te();import{z as Ce}from"zod";function Us(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"}}var Bs=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 a=this.getMailgunConfig();if(!a)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN in SDK config.");let o=n.kwargs,r=i.getModel?.()||"gemini-2.5-pro",s=await Ws(a,{model:r,forward_email:o.forward_email,extraction_type:o.extraction_type,prompt:o.prompt,filters:{from_email:o.filter_from_email,to_email:o.filter_to_email,subject:o.filter_subject,body_contains:o.filter_body_contains},timeout:o.timeout});if(s.status==="success"&&s.data){let l=s.result_variable?.replace(/^\$/,"")||Us(o.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)} },`,"});"]}},ah=Ce.object({forward_email:Ce.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:Ce.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:Ce.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:Ce.string().optional().describe("Filter emails by sender address"),filter_to_email:Ce.string().optional().describe("Filter emails by recipient address"),filter_subject:Ce.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:Ce.string().optional().describe("Filter emails by body content (partial match)"),timeout:Ce.number().optional().describe("Timeout in seconds for polling (default: 60)")});function Gs(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:ah,async execute(i,n){let{forward_email:a,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}=i,{page:p,agentServices:g}=n;u.info(`[extract_email_content] Extracting ${o} from ${a}`);try{let f={action_description:`Extract ${o} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:a,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}}};await t.execute(p,f,g);let v=Us(o);return{success:!0,actionEntity:f,message:`Extracted ${o} and saved to $${v}`}}catch(f){return{success:!1,error:f.message,actionEntity:{action_description:`Extract ${o} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:a,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}},feedback:f.message}}}}})}Ct();Pt();Ot();Dt();Nt();Rt();Ft();Ht();Wt();Ut();Bt();jt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();oi();ri();var gn=null;async function ye(){if(gn)return gn;let e=(await Promise.resolve().then(()=>(st(),rt))).default;return gn=new e,gn}async function js(e){let t=await ye(),i=t.getAction("click"),n=t.getAction("hover"),a=t.getAction("right_click"),o=t.getAction("double_click");return Is(e,i),ls(e,n),jr(e,a),ws(e,o),"Click, hover, double-click, right-click, or drag elements"}async function Ks(e){let t=await ye(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),a=t.getAction("reload_page");return rs(e,i),os(e,n),Br(e,a),"Navigate to URLs, go back, or reload the page"}async function zs(e){let t=await ye(),i=t.getAction("clear_input"),n=t.getAction("input_text"),a=t.getAction("press");return $s(e,i),ds(e,n),Wr(e,a),"Type text into inputs, clear input values, or press keyboard keys"}async function Vs(e){let t=await ye(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),a=t.getAction("scroll");return Jr(e,i),Qr(e,n),Vr(e,a),"Scroll the page or scroll to specific text/elements"}async function Xs(e){let t=await ye(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return ms(e,i),$r(e,n),"Switch between browser tabs or close tabs"}async function Ys(e){let t=await ye(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return Pr(e,i),Fr(e,n),"Upload files or wait for downloads to complete"}async function Js(e){let t=await ye(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),a=t.getAction("set_date_for_native_date_picker");return ns(e,i),kr(e,n),Er(e,a),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function qs(e){let t=await ye(),i=t.getAction("wait"),n=t.getAction("save_variable"),a=t.getAction("done");return Lr(e,i),zr(e,n),gs(e,a),Hs(e),"Wait for conditions, save variables, or complete tasks"}async function Zs(e){let t=(await ye()).getAction("generate_2fa_code");xs(e,t);let i=new Bs;return(await Promise.resolve().then(()=>(st(),rt))).default.registerAction("extract_email_content",i),Gs(e,i),"Generate 2FA codes or extract email/activation codes"}async function Qs(e){let t=await ye(),i=t.getAction("verify"),n=t.getAction("ai_extract"),a=t.getAction("ai_wait_until");return ks(e,i),Es(e,n),xr(e,a),"Perform AI-powered assertions, extractions, or wait conditions"}Ae();var oh=[js(H),Ks(H),zs(H),Vs(H),Xs(H),Ys(H),Js(H),qs(H),Qs(H),Zs(H)],Yk=Promise.all(oh);yt();ct();Ie();lt();R();import{chromium as LS,firefox as NS,webkit as RS}from"playwright";ct();var wh=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(wh||{});It();Be();yn();ie();var sl=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}};ct();Ie();R();async function ll(e,t=3e3,i=1e3){try{await Me(e,t,i)}catch{}}async function cl(e,t,i){let n=i*1e3,a=100,o=Date.now();for(;!t.downloadStatus||t.downloadStatus.status==="inProgress";){if(Date.now()-o>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(a)}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 dl(e,t,i,n=60,a){let o=Math.min(n,280),r=Math.max(10,o/10)*1e3,s=Date.now()+o*1e3;for(u.info(`Waiting for condition: "${t}" (timeout: ${o}s)`);;){let l=Date.now();try{if(await i(e,t,a))return u.info(`Condition met: "${t}"`),!0}catch(d){u.warn(`Error evaluating condition: ${d.message}`)}if(Date.now()>s)return u.warn(`Timeout waiting for condition: "${t}"`),!1;let c=r-(Date.now()-l);c>0&&await e.waitForTimeout(c)}}Ie();R();import*as ul from"fs";import*as ui from"path";import{generateSync as xh,createGuardrails as vh}from"otplib";var _h=vh({MIN_SECRET_BYTES:1});function hl(e){return e.url()===":"}var Ia=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 sl(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 Ta(e,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(e){let t=this.context.testDataDir||process.cwd();return ui.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 a=ui.basename(n),o=ui.join(t,a),r=ul.existsSync(o);return r&&u.debug(`[AgentServices] File already exists locally: ${a}`),!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 cl(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+=`
|
|
4449
|
-
${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=xh({secret:e,guardrails:_h});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??!0}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 a=await this.knowledgeRetriever(e,t,i,n);return u.debug(`[AgentServices] Retrieved ${a.length} knowledges for statement`),a}catch(a){return u.warn(`[AgentServices] Failed to retrieve knowledges: ${a.message}`),[]}}};var ml=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(ml||{}),Ca=class extends Error{constructor(e){super(e),this.name="AgentTaskFailedError",this.details=e}};
|
|
4448
|
+
${p.body}`,f=await nh(g,a,t.model);u.info(`Extracted content: ${f}`),f&&f!=="NOT_FOUND"&&h.push({content:f,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 f=(new Date().getTime()-o.getTime())/1e3;return u.info(`Successfully extracted content after ${s} attempts in ${f.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(c){u.warn(`Error in polling attempt ${s}: ${c.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(c=>setTimeout(c,n*1e3))}let l=(new Date().getTime()-o.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${s} attempts over ${l.toFixed(1)} seconds`}}catch(a){return u.error(`Error extracting email content: ${a.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${a.message}`}}}R();te();import{z as Ce}from"zod";function Us(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"}}var Bs=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 a=this.getMailgunConfig();if(!a)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN in SDK config.");let o=n.kwargs,r=i.getModel?.()||"gemini-2.5-pro",s=await Ws(a,{model:r,forward_email:o.forward_email,extraction_type:o.extraction_type,prompt:o.prompt,filters:{from_email:o.filter_from_email,to_email:o.filter_to_email,subject:o.filter_subject,body_contains:o.filter_body_contains},timeout:o.timeout});if(s.status==="success"&&s.data){let l=s.result_variable?.replace(/^\$/,"")||Us(o.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)} },`,"});"]}},ah=Ce.object({forward_email:Ce.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:Ce.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:Ce.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:Ce.string().optional().describe("Filter emails by sender address"),filter_to_email:Ce.string().optional().describe("Filter emails by recipient address"),filter_subject:Ce.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:Ce.string().optional().describe("Filter emails by body content (partial match)"),timeout:Ce.number().optional().describe("Timeout in seconds for polling (default: 60)")});function Gs(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:ah,async execute(i,n){let{forward_email:a,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}=i,{page:p,agentServices:g}=n;u.info(`[extract_email_content] Extracting ${o} from ${a}`);try{let f={action_description:`Extract ${o} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:a,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}}};await t.execute(p,f,g);let v=Us(o);return{success:!0,actionEntity:f,message:`Extracted ${o} and saved to $${v}`}}catch(f){return{success:!1,error:f.message,actionEntity:{action_description:`Extract ${o} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:a,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}},feedback:f.message}}}}})}Ct();Pt();Ot();Lt();Nt();Rt();Ft();Ht();Wt();Ut();Bt();jt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();oi();ri();var gn=null;async function ye(){if(gn)return gn;let e=(await Promise.resolve().then(()=>(st(),rt))).default;return gn=new e,gn}async function js(e){let t=await ye(),i=t.getAction("click"),n=t.getAction("hover"),a=t.getAction("right_click"),o=t.getAction("double_click");return Is(e,i),ls(e,n),jr(e,a),ws(e,o),"Click, hover, double-click, right-click, or drag elements"}async function Ks(e){let t=await ye(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),a=t.getAction("reload_page");return rs(e,i),os(e,n),Br(e,a),"Navigate to URLs, go back, or reload the page"}async function zs(e){let t=await ye(),i=t.getAction("clear_input"),n=t.getAction("input_text"),a=t.getAction("press");return $s(e,i),ds(e,n),Wr(e,a),"Type text into inputs, clear input values, or press keyboard keys"}async function Vs(e){let t=await ye(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),a=t.getAction("scroll");return Jr(e,i),Qr(e,n),Vr(e,a),"Scroll the page or scroll to specific text/elements"}async function Xs(e){let t=await ye(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return ms(e,i),$r(e,n),"Switch between browser tabs or close tabs"}async function Ys(e){let t=await ye(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return Pr(e,i),Fr(e,n),"Upload files or wait for downloads to complete"}async function Js(e){let t=await ye(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),a=t.getAction("set_date_for_native_date_picker");return ns(e,i),kr(e,n),Er(e,a),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function qs(e){let t=await ye(),i=t.getAction("wait"),n=t.getAction("save_variable"),a=t.getAction("done");return Dr(e,i),zr(e,n),gs(e,a),Hs(e),"Wait for conditions, save variables, or complete tasks"}async function Zs(e){let t=(await ye()).getAction("generate_2fa_code");xs(e,t);let i=new Bs;return(await Promise.resolve().then(()=>(st(),rt))).default.registerAction("extract_email_content",i),Gs(e,i),"Generate 2FA codes or extract email/activation codes"}async function Qs(e){let t=await ye(),i=t.getAction("verify"),n=t.getAction("ai_extract"),a=t.getAction("ai_wait_until");return ks(e,i),Es(e,n),xr(e,a),"Perform AI-powered assertions, extractions, or wait conditions"}Ae();var oh=[js(H),Ks(H),zs(H),Vs(H),Xs(H),Ys(H),Js(H),qs(H),Qs(H),Zs(H)],Xk=Promise.all(oh);yt();ct();Ie();lt();R();import{chromium as LS,firefox as DS,webkit as NS}from"playwright";ct();var wh=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(wh||{});It();Be();yn();ie();var sl=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}};ct();Ie();R();async function ll(e,t=3e3,i=1e3){try{await Me(e,t,i)}catch{}}async function cl(e,t,i){let n=i*1e3,a=100,o=Date.now();for(;!t.downloadStatus||t.downloadStatus.status==="inProgress";){if(Date.now()-o>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(a)}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 dl(e,t,i,n=60,a){let o=Math.min(n,280),r=Math.max(10,o/10)*1e3,s=Date.now()+o*1e3;for(u.info(`Waiting for condition: "${t}" (timeout: ${o}s)`);;){let l=Date.now();try{if(await i(e,t,a))return u.info(`Condition met: "${t}"`),!0}catch(d){u.warn(`Error evaluating condition: ${d.message}`)}if(Date.now()>s)return u.warn(`Timeout waiting for condition: "${t}"`),!1;let c=r-(Date.now()-l);c>0&&await e.waitForTimeout(c)}}Ie();R();import*as ul from"fs";import*as ui from"path";import{generateSync as xh,createGuardrails as vh}from"otplib";var _h=vh({MIN_SECRET_BYTES:1});function hl(e){return e.url()===":"}var Ia=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 sl(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 Ta(e,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(e){let t=this.context.testDataDir||process.cwd();return ui.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 a=ui.basename(n),o=ui.join(t,a),r=ul.existsSync(o);return r&&u.debug(`[AgentServices] File already exists locally: ${a}`),!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 cl(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+=`
|
|
4449
|
+
${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=xh({secret:e,guardrails:_h});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??!0}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 a=await this.knowledgeRetriever(e,t,i,n);return u.debug(`[AgentServices] Retrieved ${a.length} knowledges for statement`),a}catch(a){return u.warn(`[AgentServices] Failed to retrieve knowledges: ${a.message}`),[]}}};var ml=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(ml||{}),Ca=class extends Error{constructor(e){super(e),this.name="AgentTaskFailedError",this.details=e}};Dt();R();import*as K from"fs";import*as Q from"path";var kh=1,Sh=3,Eh=40;function hi(e,t){let i={};for(let[n,a]of Object.entries(e))i[n]=t.has(n)?"*****":a;return i}var fl=class{constructor(e){this.context=e,this._newActionEntities=new Map,this.agentServices=new Ia(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(()=>(st(),rt));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.
|
|
4450
4450
|
|
|
4451
4451
|
ONLY dismiss intrusive popups such as:
|
|
4452
4452
|
- Cookie/GDPR consent banners
|
|
@@ -4468,7 +4468,7 @@ If you find an intrusive popup, dismiss it by clicking its close/X button or "No
|
|
|
4468
4468
|
IMPORTANT: Only act with HIGH CONFIDENCE. If unsure whether something is an intrusive popup, do nothing.
|
|
4469
4469
|
It's better to miss a popup than to accidentally interact with normal page elements.
|
|
4470
4470
|
|
|
4471
|
-
If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,Sh),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()}`),hl(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");K.existsSync(n)||K.mkdirSync(n,{recursive:!0});let a=Q.join(n,i);u.info(`[Download Tracking] Downloading file to: ${a}`),await t.saveAs(a),this.context.downloadStatus={filename:i,status:"completed",startTime:this.context.downloadStatus.startTime,filePath:a,timestamp:Date.now()},u.info(`[Download Tracking] Download completed: ${a}`),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 a=i==="beforeunload";try{a?await t.dismiss():await t.accept(),this.context.dialogStatus={type:i,message:n,response:a?"dismiss":"accept",timestamp:Date.now()},u.info(`[Dialog Handling] Dialog ${a?"dismissed":"accepted"} - type: ${i}, message: "${n}"`)}catch(o){u.warn(`[Dialog Handling] Failed to handle dialog (already dismissed?): ${o}`)}})}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,a,o){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),o&&(s.explanation=o)):this.context.aiActionDetails.push({stepId:e,actionType:t,count:n,tokenUsages:[...r],statement:a,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:o,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(),a=await at(t,e,this.agentServices,{executionHistory:n,useCleanScreenshotForAssertion:!0,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(a.debugInfo),this.context.lastActionDebugInfo=a.debugInfo;let o=a.explanation||a.error||"No explanation";if(i&&this.trackAIAction(i,"assert",a.debugInfo,1,t,o),this.context.agentNote=o,i&&this.context.stepTracking&&await this.updateStepResult(i,a.success?"success":"failure",o,void 0,a.debugInfo),!a.success)throw this.addToExecutionHistory(`Assert: "${t}"`,`Failed: ${o}`),new Error(`Assertion failed: ${o}`);return this.addToExecutionHistory(`Assert: "${t}"`,`Passed: ${o}`),!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(),a=await at(t,e,this.agentServices,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(a.debugInfo),this.context.lastActionDebugInfo=a.debugInfo;let o=a.explanation||a.error||"No explanation";return i&&this.trackAIAction(i,"evaluate",a.debugInfo,1,t,o),this.context.agentNote=o,i&&this.context.stepTracking&&await this.updateStepResult(i,"success",o,void 0,a.debugInfo),a.success?(this.addToExecutionHistory(`Evaluate: "${t}"`,`Result: true - ${o}`),!0):(u.warn(`AI evaluation returned false/unknown: ${o}`),this.addToExecutionHistory(`Evaluate: "${t}"`,`Unknown/False: ${o}`),!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 nt(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 a=n.actionEntities[0]?.action_description||t;return this.addToExecutionHistory(t,a),{success:!0,details:n.explanation}}async execute(e,t,i,n,a){if(a!==void 0&&a<=0)throw new Error(`maxSteps must be >= 1, got ${a}`);let o=a!==void 0&&a>1;u.info(`Executing statement: ${t} (${o?`multi, maxSteps: ${a}`:"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(o){let d=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 ot(t,e,this.agentServices,d,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:a??Eh}),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 nt(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 d=s.explanation||s.error||"No explanation";this.trackAIAction(i,"execute",s.debugInfo,1,t,d)}if(s.status!=="success"||s.actionEntities.length===0||!l){let d=s.explanation||s.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",d,void 0,s.debugInfo),new Error(`Action failed: ${d}`)}let c=this.context.agentNote||s.explanation||"Action executed successfully";return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",c,void 0,s.debugInfo),this.addToExecutionHistory(`Execute: "${t}"`,c),{success:!0,details:c,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 a=this.getCompletedExecutionHistory(),o=await Mt(t,e,this.agentServices,{executionHistory:a,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n});if(this.collectTokenUsages(o.debugInfo),o.status!=="success"||o.actionEntities.length===0){let l=o.explanation||o.error||"No explanation";throw i&&this.trackAIAction(i,"generate",o.debugInfo,1,t,l),i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",l,void 0,o.debugInfo),new Error(l)}let r=o.completed,s=o.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",o.debugInfo,1,t,s),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",s,void 0,o.debugInfo),u.info(`[generate] Generated action for "${t}": ${s}, goalAccomplished: ${o.completed}`),{success:r,details:s,actions:o.actionEntities,debugInfo:o.debugInfo}}catch(a){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",a.message),a}}async run(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t);try{let a=this.getCompletedExecutionHistory();this.context.agentNote="";let o=i&&this.context.stepTracking?.artifactsDir,r=n?.onAction||o?d=>{if(d.type==="action"&&d.action_entity&&(n?.onAction?.(d.action_entity),o&&d.debugInfo)){let h=`${i}-step${d.step}`;this.saveDebugInfoToFiles(h,d.debugInfo,this.context.model)}}:void 0,s=await ot(t,e,this.agentServices,r,{executionHistory:a,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:n?.abortSignal,maxSteps:n?.maxSteps});w.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,c=this.context.agentNote?.trim()||s.explanation||s.error||(l?"Step completed":"Step failed");if(i&&s.tokenUsages){let d={tokenUsages:s.tokenUsages};this.trackAIAction(i,"run",d,s.actionEntities?.length||1,t,c)}if(!l)throw new Ca(c);if(n?.stmtUid&&s.actionEntities?.length){let d=s.actionEntities.at(-1);d&&(this._newActionEntities.set(n.stmtUid,d),w.log(`Stored resolved action entity for DRAFT stmtUid: ${n.stmtUid}`))}return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",c,void 0,void 0),this.addToExecutionHistory(`Run: "${t}"`,c),w.log(`Run result: success=${l}, details=${c}`),{success:l,details:c,actions:s.actionEntities}}catch(a){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",a.message),this.addToExecutionHistory(`Run: "${t}"`,`Failed: ${a.message}`),a}}async step(e,t,i,n,a,o=!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(),c=await this.captureDOMSnapshot(e),d=this.context.stepTracking?.captureVariables?hi(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(),f=await this.captureDOMSnapshot(e),v=this.context.stepTracking?.captureVariables?hi(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,y=this.context.stepTracking.results[n]?.screenshot,S=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:c||void 0,variables:d,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:f||void 0,variables:v,screenshotPath:y,timestamp:S})}let b=this.context.agentNote;return(!b||b.trim()==="")&&(b="Execution successful"),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=b),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}catch(p){e=this.agentServices.validatePage(e);let g=o&&!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(),y=await this.captureDOMSnapshot(e),S=this.context.stepTracking.captureVariables?hi(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},E=Date.now()-s,A=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:c||void 0,variables:d,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:p.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:m,domSnapshot:y||void 0,variables:S,timestamp:A})}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 f,v;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){f=`[Auto-dismissed modal: ${m.details}]`,v=m.actions,u.info(`Modal dismissed, retrying original action for step ${n}`);try{let y=await t();return this.context.isSelfHealing=!1,this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=f+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(n,"success",f),this.context.stepTracking.results[n].dismissedModalActions=v,this.context.stepTracking.currentStepId=void 0),this.context.agentNote=f,y}catch(y){u.info(`Retry after modal dismissal failed: ${y.message}, falling back to self-healing`)}}}let b=r??kh;u.info(`Calling execute() to self-heal (maxSteps: ${b})`);try{let m=await this.execute(e,i,n,!1,b);if(this.context.isSelfHealing=!1,!m.success)throw new Error(`Self-healing failed: ${m.details}`);let y=m.actions?.at(-1);a&&y&&(this._newActionEntities.set(a,y),u.info(`Stored new action entity for stmtUid: ${a} (last of ${m.actions?.length} actions)`));let S=e.url(),E=await this.captureDOMSnapshot(e),A=this.context.stepTracking?.captureVariables?hi(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=y,v&&(this.context.stepTracking.results[n].dismissedModalActions=v);let M=f||"";await this.updateStepResult(n,"success",M)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let M=Date.now()-s,D=this.context.stepTracking.results[n]?.screenshot,N=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:c||void 0,variables:d,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{actionEntity:y,playwrightCode:m.actions?.map(P=>P.locator||""),llmPrompt:m.debugInfo?.userPrompt,llmResponse:m.debugInfo?.rawLlmResponse,llmReasoning:m.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(n),durationMs:M,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:S,domSnapshot:E||void 0,variables:A,screenshotPath:D,timestamp:N})}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 y=e.url(),S=await this.captureDOMSnapshot(e),E=this.context.stepTracking.captureVariables?hi(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},A=Date.now()-s,M=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:c||void 0,variables:d,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:A,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:y,domSnapshot:S||void 0,variables:E,timestamp:M})}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 a=`Extract ${t} and save to ${i}`,o=await this.execute(e,a,n);if(!o.success)throw new Error(`AI extraction failed: ${o.details}`);n&&this.context.stepTracking&&await this.updateStepResult(n,"success",`Extracted ${t} to ${i}`)}catch(a){throw n&&this.context.stepTracking&&await this.updateStepResult(n,"failure",a.message),a}}async getDOMText(e){let t=new be(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 be(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains(),a=await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n,highlightElements:!1,viewportExpansion:0});return{elementTreeText:a.elementTree.clickableElementsToString(),elementCount:a.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 ll(e,t,i)}async waitUntilCondition(e,t,i=60,n){return dl(e,t,(a,o,r)=>this.evaluate(a,o,r),i,n)}async uploadFile(e,t,i={},n){return Mr(e,t,i,this.context,(a,o,r)=>this.execute(a,o,r),n)}async loginPage(e,t,i){let{LoginType:n}=await Promise.resolve().then(()=>(gl(),pl));if(u.info("Start login"),w.section("Login Flow"),w.log(`Site URL: ${t.site_url}`),w.log(`Account type: ${t.account.type}`),w.log(`Has cached actions: ${!!i?.cached_actions?.length}`),w.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 a=!!(t.use_ai_verification_for_login_check&&t.verification_hint?.trim()),o=a?`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(a){w.log("Level 1: Checking if already logged in via AI verification hint..."),w.log(`Verification statement: ${o}`);try{if(await this.evaluate(e,o))return w.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};w.log("Level 1 FAILED: AI verification indicates not signed in, trying Level 2")}catch(l){w.log(`Level 1 ERROR: AI verification failed (${l.message}), trying Level 2`)}}else t.use_ai_verification_for_login_check&&!t.verification_hint?.trim()&&w.log("Level 1 SKIPPED: use_ai_verification_for_login_check is enabled but verification_hint is empty, falling back to cached validation expressions");if(!a&&i?.validation_exprs&&i.validation_exprs.length>0){if(w.log("Level 1: Checking if already logged in via storage state..."),w.log(`Validation expressions: ${JSON.stringify(i.validation_exprs)}`),await di(e,i.validation_exprs))return w.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};w.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&&(a||r)){w.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:o})).success){w.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}}w.log("Level 2 FAILED: Cached login failed, trying Level 3")}catch(l){w.log(`Level 2 ERROR: ${l.message}, trying Level 3`)}}else i?.cached_actions&&i.cached_actions.length>0&&w.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.
|
|
4471
|
+
If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,Sh),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()}`),hl(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");K.existsSync(n)||K.mkdirSync(n,{recursive:!0});let a=Q.join(n,i);u.info(`[Download Tracking] Downloading file to: ${a}`),await t.saveAs(a),this.context.downloadStatus={filename:i,status:"completed",startTime:this.context.downloadStatus.startTime,filePath:a,timestamp:Date.now()},u.info(`[Download Tracking] Download completed: ${a}`),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 a=i==="beforeunload";try{a?await t.dismiss():await t.accept(),this.context.dialogStatus={type:i,message:n,response:a?"dismiss":"accept",timestamp:Date.now()},u.info(`[Dialog Handling] Dialog ${a?"dismissed":"accepted"} - type: ${i}, message: "${n}"`)}catch(o){u.warn(`[Dialog Handling] Failed to handle dialog (already dismissed?): ${o}`)}})}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,a,o){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),o&&(s.explanation=o)):this.context.aiActionDetails.push({stepId:e,actionType:t,count:n,tokenUsages:[...r],statement:a,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:o,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(),a=await at(t,e,this.agentServices,{executionHistory:n,useCleanScreenshotForAssertion:!0,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(a.debugInfo),this.context.lastActionDebugInfo=a.debugInfo;let o=a.explanation||a.error||"No explanation";if(i&&this.trackAIAction(i,"assert",a.debugInfo,1,t,o),this.context.agentNote=o,i&&this.context.stepTracking&&await this.updateStepResult(i,a.success?"success":"failure",o,void 0,a.debugInfo),!a.success)throw this.addToExecutionHistory(`Assert: "${t}"`,`Failed: ${o}`),new Error(`Assertion failed: ${o}`);return this.addToExecutionHistory(`Assert: "${t}"`,`Passed: ${o}`),!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(),a=await at(t,e,this.agentServices,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(a.debugInfo),this.context.lastActionDebugInfo=a.debugInfo;let o=a.explanation||a.error||"No explanation";return i&&this.trackAIAction(i,"evaluate",a.debugInfo,1,t,o),this.context.agentNote=o,i&&this.context.stepTracking&&await this.updateStepResult(i,"success",o,void 0,a.debugInfo),a.success?(this.addToExecutionHistory(`Evaluate: "${t}"`,`Result: true - ${o}`),!0):(u.warn(`AI evaluation returned false/unknown: ${o}`),this.addToExecutionHistory(`Evaluate: "${t}"`,`Unknown/False: ${o}`),!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 nt(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 a=n.actionEntities[0]?.action_description||t;return this.addToExecutionHistory(t,a),{success:!0,details:n.explanation}}async execute(e,t,i,n,a){if(a!==void 0&&a<=0)throw new Error(`maxSteps must be >= 1, got ${a}`);let o=a!==void 0&&a>1;u.info(`Executing statement: ${t} (${o?`multi, maxSteps: ${a}`:"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(o){let d=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 ot(t,e,this.agentServices,d,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:a??Eh}),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 nt(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 d=s.explanation||s.error||"No explanation";this.trackAIAction(i,"execute",s.debugInfo,1,t,d)}if(s.status!=="success"||s.actionEntities.length===0||!l){let d=s.explanation||s.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",d,void 0,s.debugInfo),new Error(`Action failed: ${d}`)}let c=this.context.agentNote||s.explanation||"Action executed successfully";return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",c,void 0,s.debugInfo),this.addToExecutionHistory(`Execute: "${t}"`,c),{success:!0,details:c,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 a=this.getCompletedExecutionHistory(),o=await Mt(t,e,this.agentServices,{executionHistory:a,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n});if(this.collectTokenUsages(o.debugInfo),o.status!=="success"||o.actionEntities.length===0){let l=o.explanation||o.error||"No explanation";throw i&&this.trackAIAction(i,"generate",o.debugInfo,1,t,l),i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",l,void 0,o.debugInfo),new Error(l)}let r=o.completed,s=o.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",o.debugInfo,1,t,s),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",s,void 0,o.debugInfo),u.info(`[generate] Generated action for "${t}": ${s}, goalAccomplished: ${o.completed}`),{success:r,details:s,actions:o.actionEntities,debugInfo:o.debugInfo}}catch(a){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",a.message),a}}async run(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t);try{let a=this.getCompletedExecutionHistory();this.context.agentNote="";let o=i&&this.context.stepTracking?.artifactsDir,r=n?.onAction||o?d=>{if(d.type==="action"&&d.action_entity&&(n?.onAction?.(d.action_entity),o&&d.debugInfo)){let h=`${i}-step${d.step}`;this.saveDebugInfoToFiles(h,d.debugInfo,this.context.model)}}:void 0,s=await ot(t,e,this.agentServices,r,{executionHistory:a,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:n?.abortSignal,maxSteps:n?.maxSteps});w.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,c=this.context.agentNote?.trim()||s.explanation||s.error||(l?"Step completed":"Step failed");if(i&&s.tokenUsages){let d={tokenUsages:s.tokenUsages};this.trackAIAction(i,"run",d,s.actionEntities?.length||1,t,c)}if(!l)throw new Ca(c);if(n?.stmtUid&&s.actionEntities?.length){let d=s.actionEntities.at(-1);d&&(this._newActionEntities.set(n.stmtUid,d),w.log(`Stored resolved action entity for DRAFT stmtUid: ${n.stmtUid}`))}return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",c,void 0,void 0),this.addToExecutionHistory(`Run: "${t}"`,c),w.log(`Run result: success=${l}, details=${c}`),{success:l,details:c,actions:s.actionEntities}}catch(a){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",a.message),this.addToExecutionHistory(`Run: "${t}"`,`Failed: ${a.message}`),a}}async step(e,t,i,n,a,o=!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(),c=await this.captureDOMSnapshot(e),d=this.context.stepTracking?.captureVariables?hi(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(),f=await this.captureDOMSnapshot(e),v=this.context.stepTracking?.captureVariables?hi(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,y=this.context.stepTracking.results[n]?.screenshot,S=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:c||void 0,variables:d,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:f||void 0,variables:v,screenshotPath:y,timestamp:S})}let b=this.context.agentNote;return(!b||b.trim()==="")&&(b="Execution successful"),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=b),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}catch(p){e=this.agentServices.validatePage(e);let g=o&&!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(),y=await this.captureDOMSnapshot(e),S=this.context.stepTracking.captureVariables?hi(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},E=Date.now()-s,A=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:c||void 0,variables:d,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:p.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:m,domSnapshot:y||void 0,variables:S,timestamp:A})}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 f,v;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){f=`[Auto-dismissed modal: ${m.details}]`,v=m.actions,u.info(`Modal dismissed, retrying original action for step ${n}`);try{let y=await t();return this.context.isSelfHealing=!1,this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=f+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(n,"success",f),this.context.stepTracking.results[n].dismissedModalActions=v,this.context.stepTracking.currentStepId=void 0),this.context.agentNote=f,y}catch(y){u.info(`Retry after modal dismissal failed: ${y.message}, falling back to self-healing`)}}}let b=r??kh;u.info(`Calling execute() to self-heal (maxSteps: ${b})`);try{let m=await this.execute(e,i,n,!1,b);if(this.context.isSelfHealing=!1,!m.success)throw new Error(`Self-healing failed: ${m.details}`);let y=m.actions?.at(-1);a&&y&&(this._newActionEntities.set(a,y),u.info(`Stored new action entity for stmtUid: ${a} (last of ${m.actions?.length} actions)`));let S=e.url(),E=await this.captureDOMSnapshot(e),A=this.context.stepTracking?.captureVariables?hi(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=y,v&&(this.context.stepTracking.results[n].dismissedModalActions=v);let M=f||"";await this.updateStepResult(n,"success",M)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let M=Date.now()-s,L=this.context.stepTracking.results[n]?.screenshot,N=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:c||void 0,variables:d,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{actionEntity:y,playwrightCode:m.actions?.map(P=>P.locator||""),llmPrompt:m.debugInfo?.userPrompt,llmResponse:m.debugInfo?.rawLlmResponse,llmReasoning:m.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(n),durationMs:M,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:S,domSnapshot:E||void 0,variables:A,screenshotPath:L,timestamp:N})}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 y=e.url(),S=await this.captureDOMSnapshot(e),E=this.context.stepTracking.captureVariables?hi(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},A=Date.now()-s,M=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:c||void 0,variables:d,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:A,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:y,domSnapshot:S||void 0,variables:E,timestamp:M})}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 a=`Extract ${t} and save to ${i}`,o=await this.execute(e,a,n);if(!o.success)throw new Error(`AI extraction failed: ${o.details}`);n&&this.context.stepTracking&&await this.updateStepResult(n,"success",`Extracted ${t} to ${i}`)}catch(a){throw n&&this.context.stepTracking&&await this.updateStepResult(n,"failure",a.message),a}}async getDOMText(e){let t=new be(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 be(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains(),a=await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n,highlightElements:!1,viewportExpansion:0});return{elementTreeText:a.elementTree.clickableElementsToString(),elementCount:a.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 ll(e,t,i)}async waitUntilCondition(e,t,i=60,n){return dl(e,t,(a,o,r)=>this.evaluate(a,o,r),i,n)}async uploadFile(e,t,i={},n){return Mr(e,t,i,this.context,(a,o,r)=>this.execute(a,o,r),n)}async loginPage(e,t,i){let{LoginType:n}=await Promise.resolve().then(()=>(gl(),pl));if(u.info("Start login"),w.section("Login Flow"),w.log(`Site URL: ${t.site_url}`),w.log(`Account type: ${t.account.type}`),w.log(`Has cached actions: ${!!i?.cached_actions?.length}`),w.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 a=!!(t.use_ai_verification_for_login_check&&t.verification_hint?.trim()),o=a?`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(a){w.log("Level 1: Checking if already logged in via AI verification hint..."),w.log(`Verification statement: ${o}`);try{if(await this.evaluate(e,o))return w.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};w.log("Level 1 FAILED: AI verification indicates not signed in, trying Level 2")}catch(l){w.log(`Level 1 ERROR: AI verification failed (${l.message}), trying Level 2`)}}else t.use_ai_verification_for_login_check&&!t.verification_hint?.trim()&&w.log("Level 1 SKIPPED: use_ai_verification_for_login_check is enabled but verification_hint is empty, falling back to cached validation expressions");if(!a&&i?.validation_exprs&&i.validation_exprs.length>0){if(w.log("Level 1: Checking if already logged in via storage state..."),w.log(`Validation expressions: ${JSON.stringify(i.validation_exprs)}`),await di(e,i.validation_exprs))return w.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};w.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&&(a||r)){w.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:o})).success){w.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}}w.log("Level 2 FAILED: Cached login failed, trying Level 3")}catch(l){w.log(`Level 2 ERROR: ${l.message}, trying Level 3`)}}else i?.cached_actions&&i.cached_actions.length>0&&w.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.
|
|
4472
4472
|
Use your best judgement to determine if the page is signed in.
|
|
4473
4473
|
`;if(t.verification_hint&&(s+=`
|
|
4474
4474
|
Signed in verification hint: ${t.verification_hint}
|
|
@@ -4480,4 +4480,4 @@ If the page is not signed in, sign in with the OAuth provider "${l.provider_name
|
|
|
4480
4480
|
`}t.additional_prompt&&(s+=`
|
|
4481
4481
|
Additional instructions: ${t.additional_prompt}
|
|
4482
4482
|
`);try{w.log("Level 3: Attempting agent-based login"),w.log(`Login prompt:
|
|
4483
|
-
${s}`);let l=this.agentServices.knowledgeRetriever,c=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(w.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(v,b,m,y)=>await l(v,b,m,"login")),c=!0,w.log("Login knowledge retriever configured"));let d;try{if(d=await this.run(e,s,"login"),!d.success)return w.log("Level 3 FAILED: Agent login failed"),u.info("Login: Failed"),{success:!1,page:e}}finally{c&&l&&(this.agentServices.setKnowledgeRetriever(l),w.log("Restored original knowledge retriever"))}let h=await e.context().storageState(),p;if(a)w.log("Skipping validation locator generation (AI verification mode enabled)");else if(t.num_verification_exprs!==0)try{w.log("Generating validation locators for future login verification...");let v=await bn(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(b,m)=>this.run(b,m),async b=>this.getDOMText(b));v?(p=v,w.log(`Generated ${p.length} validation locator(s): ${JSON.stringify(p)}`)):w.log("Failed to generate validation locators, login will still succeed")}catch(v){w.log(`Error generating validation locators: ${v.message}`)}else w.log("Skipping validation locator generation (num_verification_exprs=0)");w.log("Level 3 SUCCESS: Agent login succeeded"),u.info("Login: Agent login succeeded");let g=d.actions||[],f=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:h,cached_actions:f,validation_exprs:p}}catch(l){return w.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(()=>(st(),rt))).default,a=new n;for(let o=0;o<t.length;o++){let r=t[o];w.log(`Executing cached action ${o+1}/${t.length}: ${r.action_description||r.action_data?.action_name}`);try{if(!r.action_data){w.log(`Action ${o+1} missing action_data, skipping`);continue}await a.execute(e,r,this.agentServices),await this.waitUntilStable(e,5e3)}catch(s){return w.error(`Cached action ${o+1} failed: ${s.message}`),{success:!1}}}return i?.aiVerificationStatement?(w.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 di(e,i.validationExprs)?{success:!0}:{success:!1}:(w.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 a=Q.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));K.mkdirSync(a,{recursive:!0});let o=Q.join(a,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:o}),n.screenshot=o}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 a={};if(!this.context.stepTracking?.artifactsDir)return u.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),a;let o=Q.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(K.mkdirSync(o,{recursive:!0}),t.systemPrompt){let r=Q.join(o,`system_prompt_${n}.txt`);K.writeFileSync(r,t.systemPrompt),a.system_prompt_path=r,u.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${r}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let r=Q.join(o,`user_prompt_${n}.txt`);K.writeFileSync(r,t.userPrompt),a.user_prompt_path=r,u.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${r}`)}else{let r=t.userPrompt.map(c=>Array.isArray(c.content)?{...c,content:c.content.map(d=>d.type==="image"&&d.file?.startsWith("data:")?{...d,file:"[base64 image data stripped]"}:d)}:c),s=Q.join(o,`messages_${n}.json`),l={system:t.systemPrompt,messages:r};K.writeFileSync(s,JSON.stringify(l,null,2)),a.messages_path=s,u.debug(`[saveDebugInfoToFiles] Saved messages to: ${s}`)}if(t.rawLlmResponse){let r=i?i.replace(/[\/\\:]/g,"-"):"llm",s=Q.join(o,`${r}_response_${n}.txt`);K.writeFileSync(s,t.rawLlmResponse),a.response_path=s,u.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${s}`)}if(t.screenshotWithSom){let r=Q.join(o,`screenshot_${n}.png`);K.writeFileSync(r,Buffer.from(t.screenshotWithSom,"base64")),a.screenshot_path=r,u.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${r}`)}if(t.reasoningContent){let r=Q.join(o,`reasoning_${n}.txt`);K.writeFileSync(r,t.reasoningContent),a.reasoning_path=r,u.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${r}`)}u.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(a).length} artifacts for step ${e}`)}catch(r){u.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,r)}return a}async updateStepResult(e,t,i,n,a){if(!this.context.stepTracking)return;let o=this.context.stepTracking.results[e];if(o){if(t&&(o.status=t,this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(o.message=i),n&&o.artifacts.push(n),a){let r=a.tokenUsages?.[0]?.model,s=o.artifacts.length,l=this.saveDebugInfoToFiles(e,a,r,s);Object.keys(l).length>0&&o.artifacts.push(l)}o.duration=Date.now()-o.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(e,o)}}async writeExecutionResults(e,t){try{if(await K.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 K.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 K.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 K.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}}};It();Hi();Ri();Ze();Ti();$i();Ai();Xe();Ci();Oi();vt();_t();Ae();yt();xt();Ji();Be();kt();St();Qe();Et();Tt();yn();ie();ct();Ie();lt();Te();ft();wt();Ye();Sa();Ui();Bi();Gi();ji();Ki();zi();Vi();Xi();Yi();qi();Zi();Ct();Pt();Ot();
|
|
4483
|
+
${s}`);let l=this.agentServices.knowledgeRetriever,c=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(w.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(v,b,m,y)=>await l(v,b,m,"login")),c=!0,w.log("Login knowledge retriever configured"));let d;try{if(d=await this.run(e,s,"login"),!d.success)return w.log("Level 3 FAILED: Agent login failed"),u.info("Login: Failed"),{success:!1,page:e}}finally{c&&l&&(this.agentServices.setKnowledgeRetriever(l),w.log("Restored original knowledge retriever"))}let h=await e.context().storageState(),p;if(a)w.log("Skipping validation locator generation (AI verification mode enabled)");else if(t.num_verification_exprs!==0)try{w.log("Generating validation locators for future login verification...");let v=await bn(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(b,m)=>this.run(b,m),async b=>this.getDOMText(b));v?(p=v,w.log(`Generated ${p.length} validation locator(s): ${JSON.stringify(p)}`)):w.log("Failed to generate validation locators, login will still succeed")}catch(v){w.log(`Error generating validation locators: ${v.message}`)}else w.log("Skipping validation locator generation (num_verification_exprs=0)");w.log("Level 3 SUCCESS: Agent login succeeded"),u.info("Login: Agent login succeeded");let g=d.actions||[],f=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:h,cached_actions:f,validation_exprs:p}}catch(l){return w.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(()=>(st(),rt))).default,a=new n;for(let o=0;o<t.length;o++){let r=t[o];w.log(`Executing cached action ${o+1}/${t.length}: ${r.action_description||r.action_data?.action_name}`);try{if(!r.action_data){w.log(`Action ${o+1} missing action_data, skipping`);continue}await a.execute(e,r,this.agentServices),await this.waitUntilStable(e,5e3)}catch(s){return w.error(`Cached action ${o+1} failed: ${s.message}`),{success:!1}}}return i?.aiVerificationStatement?(w.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 di(e,i.validationExprs)?{success:!0}:{success:!1}:(w.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 a=Q.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));K.mkdirSync(a,{recursive:!0});let o=Q.join(a,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:o}),n.screenshot=o}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 a={};if(!this.context.stepTracking?.artifactsDir)return u.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),a;let o=Q.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(K.mkdirSync(o,{recursive:!0}),t.systemPrompt){let r=Q.join(o,`system_prompt_${n}.txt`);K.writeFileSync(r,t.systemPrompt),a.system_prompt_path=r,u.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${r}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let r=Q.join(o,`user_prompt_${n}.txt`);K.writeFileSync(r,t.userPrompt),a.user_prompt_path=r,u.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${r}`)}else{let r=t.userPrompt.map(c=>Array.isArray(c.content)?{...c,content:c.content.map(d=>d.type==="image"&&d.file?.startsWith("data:")?{...d,file:"[base64 image data stripped]"}:d)}:c),s=Q.join(o,`messages_${n}.json`),l={system:t.systemPrompt,messages:r};K.writeFileSync(s,JSON.stringify(l,null,2)),a.messages_path=s,u.debug(`[saveDebugInfoToFiles] Saved messages to: ${s}`)}if(t.rawLlmResponse){let r=i?i.replace(/[\/\\:]/g,"-"):"llm",s=Q.join(o,`${r}_response_${n}.txt`);K.writeFileSync(s,t.rawLlmResponse),a.response_path=s,u.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${s}`)}if(t.screenshotWithSom){let r=Q.join(o,`screenshot_${n}.png`);K.writeFileSync(r,Buffer.from(t.screenshotWithSom,"base64")),a.screenshot_path=r,u.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${r}`)}if(t.reasoningContent){let r=Q.join(o,`reasoning_${n}.txt`);K.writeFileSync(r,t.reasoningContent),a.reasoning_path=r,u.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${r}`)}u.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(a).length} artifacts for step ${e}`)}catch(r){u.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,r)}return a}async updateStepResult(e,t,i,n,a){if(!this.context.stepTracking)return;let o=this.context.stepTracking.results[e];if(o){if(t&&(o.status=t,this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(o.message=i),n&&o.artifacts.push(n),a){let r=a.tokenUsages?.[0]?.model,s=o.artifacts.length,l=this.saveDebugInfoToFiles(e,a,r,s);Object.keys(l).length>0&&o.artifacts.push(l)}o.duration=Date.now()-o.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(e,o)}}async writeExecutionResults(e,t){try{if(await K.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 K.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 K.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 K.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}}};It();Hi();Ri();Ze();Ti();$i();Ai();Xe();Ci();Oi();vt();_t();Ae();yt();xt();Ji();Be();kt();St();Qe();Et();Tt();yn();ie();ct();Ie();lt();Te();ft();wt();Ye();Sa();Ui();Bi();Gi();ji();Ki();zi();Vi();Xi();Yi();qi();Zi();Ct();Pt();Ot();Lt();Nt();Rt();Ft();Ht();Wt();Ut();Bt();jt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();oi();ri();on();Dt();j();Ue();R();te();et();cn();F();function Th(){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,a=t.find(m=>m.type==="day").value,o=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"),c=`${i}-${n}-${a}T${o}:${r}:${s}.${l}`,d=e.toISOString().slice(0,-1),h=Date.parse(c+"Z"),p=Date.parse(d+"Z"),g=Math.round((p-h)/(1e3*60)),f=String(Math.floor(Math.abs(g)/60)).padStart(2,"0"),v=String(Math.abs(g)%60).padStart(2,"0"),b=g<=0?"+":"-";return`${i}-${n}-${a}T${o}:${r}:${s}.${l}${b}${f}:${v}`}function wl(e){let t=e.variableStore;return t.has("currentTime")||t.set("currentTime",Th()),{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:[]}}ge();export{al as VariableStore,fl as WebAgent,So as configureSdk,wl as createAgentContext,Oc as defineConfig,Pc as shiplightConfig};
|