shiplightai 0.1.74 → 0.1.76
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-manager.cjs +5 -5
- package/dist/cjs/debugger-pw.cjs +49 -49
- package/dist/cjs/fixture.cjs +97 -97
- package/dist/cjs/index.cjs +4 -4
- package/dist/cjs/reporter.cjs +3 -3
- package/dist/cli.js +75 -75
- package/dist/debugger-manager.d.ts +5 -0
- package/dist/debugger-manager.js +8 -8
- package/dist/debugger-pw.js +48 -48
- package/dist/fixture.d.ts +71 -1
- package/dist/fixture.js +97 -97
- package/dist/index.js +4 -4
- package/dist/reporter.js +3 -3
- package/dist/static-embedded/assets/{index-CoKedfWS.js → index-Dk5ihq1Y.js} +2 -2
- package/dist/static-embedded/assets/{index-BEW7CdFm.js → index-Mg0a6DkO.js} +50 -4
- package/dist/static-embedded/index.html +1 -1
- package/package.json +4 -4
package/dist/cjs/fixture.cjs
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
"use strict";var
|
|
2
|
-
`);o=
|
|
1
|
+
"use strict";var uh=Object.create;var Ji=Object.defineProperty;var hh=Object.getOwnPropertyDescriptor;var mh=Object.getOwnPropertyNames;var ph=Object.getPrototypeOf,gh=Object.prototype.hasOwnProperty;var b=(e,t)=>()=>(e&&(t=e(e=0)),t);var Ve=(e,t)=>{for(var i in t)Ji(e,i,{get:t[i],enumerable:!0})},Vr=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of mh(t))!gh.call(e,o)&&o!==i&&Ji(e,o,{get:()=>t[o],enumerable:!(n=hh(t,o))||n.enumerable});return e};var H=(e,t,i)=>(i=e!=null?uh(ph(e)):{},Vr(t||!e||!e.__esModule?Ji(i,"default",{value:e,enumerable:!0}):i,e)),fh=e=>Vr(Ji({},"__esModule",{value:!0}),e);async function qr(e,t){if(!e.body)throw new Error("Response body is null");let i=e.body.getReader(),n=new TextDecoder,o="";try{for(;;){let{done:a,value:s}=await i.read();if(a)break;o+=n.decode(s,{stream:!0});let r=o.split(`
|
|
2
|
+
`);o=r.pop()||"";for(let l of r){let d=null;if(l.startsWith("data: "))try{let c=l.slice(6);c.trim()&&(d=JSON.parse(c))}catch(c){console.error(`Failed to parse SSE event: ${l}`,c);continue}d&&t(d)}}}finally{i.releaseLock()}}var Zr=b(()=>{"use strict"});function Qr(e){Xo.updateConfig(e)}function V(){return Xo.getConfig()}function es(){switch(process.env.SDK_LOG_LEVEL?.toLowerCase()){case"debug":return 0;case"info":return 1;case"warn":return 2;case"error":return 3;case"silent":return 4;default:return}}var wh,Xo,qi,oe=b(()=>{"use strict";wh=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}},Xo=new wh,qi=Xo});var bh,yh,u,W=b(()=>{"use strict";oe();bh=class{getLevel(){return qi.get("logLevel")}isStderrOnly(){return qi.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){qi.set("logLevel",e)}},yh=new bh,u=yh});async function xh(e,t){let i=await import(e),n=Object.keys(i),o=new at.SyntheticModule(n,function(){for(let a of n)this.setExport(a,i[a])},{context:t});return await o.link(()=>{throw new Error("Nested imports not supported in VM context")}),await o.evaluate(),o}function Yo(e,t,i,n=!1){if(e[t])if(n)u.info(`Overriding existing function: ${t}`),delete e[t];else{u.error(`The name ${t} is already defined in the global scope`);return}try{let o;if(at.isContext(e)?o=new at.Script(i,{importModuleDynamically:async a=>xh(a,e)}).runInContext(e):o=(0,eval)(i),typeof o!="function")throw new Error("The injected code must be a function");e[t]=o}catch(o){u.error(`Error injecting user function ${t}: ${o.message}`)}}async function is(e,t,i=!1){try{let n=await ts.readFile(t,"utf8"),o=JSON.parse(n);u.info(`Loading ${Object.keys(o).length} user functions...`);for(let[a,s]of Object.entries(o))Yo(e,a,s,i)}catch(n){throw u.error("Failed to load user functions:",n),n}}var ts,at,ns=b(()=>{"use strict";W();ts=H(require("fs/promises"),1),at=H(require("vm"),1)});async function os(e){try{let t=await Jo.readFile(e,"utf8"),i=JSON.parse(t);return u.info(`Loaded ${i.length} knowledges from file`),i}catch(t){if(t.code==="ENOENT")return u.debug("No knowledges file found"),[];throw u.error("Failed to load knowledges:",t),t}}async function as(e){try{let t=await Jo.readFile(e,"utf8"),i=JSON.parse(t);return u.info(`Loaded ${i.length} knowledge mappings from file`),i}catch(t){if(t.code==="ENOENT")return u.debug("No knowledge mappings file found"),[];throw u.error("Failed to load knowledge mappings:",t),t}}var Jo,rs=b(()=>{"use strict";W();Jo=H(require("fs/promises"),1)});function Zi(e){let t=(0,qo.zodToJsonSchema)(e,{$refStrategy:"none"});if(t.$schema&&delete t.$schema,t.type!=="object")throw new Error(`Schema must be a Zod object schema, got type: ${t.type}`);return Rt(t),t}function Qi(e){return(0,qo.zodToJsonSchema)(e,{$refStrategy:"none"})}function Rt(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))Rt(i)}e.type==="array"&&e.items&&Rt(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(Rt);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&Rt(i)}}var qo,Ft=b(()=>{"use strict";qo=require("zod-to-json-schema")});var en,tn=b(()=>{"use strict";Ft();en=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:Zi(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:Zi(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:Zi(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});var Zo,vh,w,ae=b(()=>{"use strict";oe();Zo=require("fs"),vh=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=V().agentLogPath;if(e)try{(0,Zo.appendFileSync)(e,`
|
|
3
3
|
=== Agent Execution Log ===
|
|
4
4
|
Started: ${new Date().toISOString()}
|
|
5
5
|
|
|
6
|
-
`),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=
|
|
6
|
+
`),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=V().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();(0,Zo.appendFileSync)(t,`[${i}] ${e}
|
|
7
7
|
`)}catch{}}}section(e){this.log(`
|
|
8
8
|
${"=".repeat(60)}
|
|
9
9
|
${e}
|
|
@@ -12,9 +12,9 @@ ${e}`)}prompt(e,t){this.section("LLM Prompt"),this.log(`System Prompt:
|
|
|
12
12
|
${e}`),this.log(`
|
|
13
13
|
User Prompt:
|
|
14
14
|
${t}`)}response(e){this.log(`LLM Response:
|
|
15
|
-
${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!B().agentLogPath}},b=new ph});var Qi,gh,fh,wh,bh,ns,en,Xo,os,Yo,Jo,pe=y(()=>{"use strict";Qi=Object.defineProperty,gh=Object.getOwnPropertyDescriptor,fh=Object.getOwnPropertyNames,wh=Object.prototype.hasOwnProperty,bh=(e,t,i)=>t in e?Qi(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,ns=(e,t)=>()=>(e&&(t=e(e=0)),t),en=(e,t)=>{for(var i in t)Qi(e,i,{get:t[i],enumerable:!0})},Xo=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of fh(t))!wh.call(e,o)&&o!==i&&Qi(e,o,{get:()=>t[o],enumerable:!(n=gh(t,o))||n.enumerable});return e},os=(e,t,i)=>(Xo(e,t,"default"),i&&Xo(i,t,"default")),Yo=e=>Xo(Qi({},"__esModule",{value:!0}),e),Jo=(e,t,i)=>bh(e,typeof t!="symbol"?t+"":t,i)});function D(e,t){return t??e?.getActionSettings()?.action_timeout_ms??Zo}function yh(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function O(e,t){let i=Oe(t);return i?new Function("page",`return ${i}`)(e):null}async function qo(e,t=[]){let i=e;for(let n of t){let o=await i.locator(n).elementHandle();if(!o)return null;let a=await o.contentFrame();if(await o.dispose(),!a)return null;i=a}return i}function xh(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 vh(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function _h(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 Oe(e){let t=vh(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=_h(e);if(n){let o=JSON.stringify(n);return`${t}.locator(${o}).first()`}return null}var tn,Nt,Zo,ge,C,H=y(()=>{"use strict";pe();tn={};en(tn,{ACTION_TIMEOUT:()=>Zo,GOTO_TIMEOUT:()=>ge,LOCATOR_TIMEOUT:()=>Nt,getActionTimeoutMs:()=>D,getFrameContext:()=>qo,getLocator:()=>O,getMinimalActionEntity:()=>xh,getPageLocatorExpression:()=>Oe,sanitizeForComment:()=>yh});C=ns(()=>{Nt=5e3,Zo=1e4,ge=2e4})});async function Rt(e,t,i=[],n=[]){try{let o=await qo(e,i);if(!o)return h.warn(`Could not find frame context for xpath: ${t}`),null;let a=null;if(n.length>0){let s=n[0];if(!s)return h.warn(`Missing shadow host xpath for element: ${t}`),null;let l=o.locator(`xpath=${as(s)}`),d=kh(t);if(a=await(d?l.locator(`css=${d}`):l.locator(`xpath=${as(t)}`)).elementHandle({timeout:Nt}),!a)return h.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(a=await o.locator(`xpath=${t}`).elementHandle({timeout:Nt}),!a)return h.warn(`Could not find element with xpath: ${t}`),null;let r=await o.evaluate(s=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(s):null,a);return await a.dispose(),r?(h.debug(`Generated locator for ${t}: ${r}`),r):(h.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(o){return h.error(`Error in pickBestLocator: ${o}`),null}}async function nn(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?(h.debug(`Generated locator: ${i}`),i):(h.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return h.error(`Error in pickBestLocator: ${i}`),null}}async function rs(e,t){let i=new Map;return await Promise.all(t.map(async n=>{let o=await Rt(e,n);i.set(n,o)})),i}function as(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function kh(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),n=[];for(let o of i){let a=o.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!a)return null;let r=a[1].toLowerCase(),s=a[2]?`:nth-of-type(${a[2]})`:"";n.push(`${r}${s}`)}return n.join(" > ")}var ze=y(()=>{"use strict";F();H();C()});async function Ft(e,t,i){await e.evaluate(()=>{document.getElementById("playwright-highlight-container")?.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(l=>l()),window._highlightCleanupFunctions=[])});let n=await e.screenshot({type:"png",fullPage:!1}),{default:o}=await import("sharp"),a=o(n),{width:r=0,height:s=0}=await a.metadata();return b.log(`Screenshot actual: ${r}x${s}, viewport: ${t}x${i}`),(r!==t||s!==i?await a.resize(t,i).png().toBuffer():n).toString("base64")}async function Se(e,t,i){let n=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),o=n.asElement();if(!o)throw await n.dispose(),new Error(`No element found at (${t}, ${i})`);let a=await o.boundingBox();if(!a)throw await n.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(a.x+a.width/2),relative_y:i-(a.y+a.height/2),element:o}}async function on(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(o=>{let a=[],r=o;for(;r&&r.nodeType===Node.ELEMENT_NODE;){let s=1,l=r.previousElementSibling;for(;l;)l.tagName===r.tagName&&s++,l=l.previousElementSibling;a.unshift(`${r.tagName.toLowerCase()}[${s}]`),r=r.parentElement}return a.length?`/${a.join("/")}`:null}).catch(()=>null),n=await nn(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function an(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 at=y(()=>{"use strict";ie();ze()});function rn(e,t){let i=t?.trim();return i?Ah(i):e.startsWith(Sh)?Eh:Th}function ss(e,t){return`${rn(e,t)}/llm/v1`}function ls(e,t){return`${rn(e,t)}/llm/v1`}function cs(e,t){return`${rn(e,t)}/llm/v1beta`}function ds(e,t){return`${rn(e,t)}/llm`}function Ah(e){return e.endsWith("/")?e.slice(0,-1):e}var Sh,Eh,Th,Ne=y(()=>{"use strict";Sh="shp_",Eh="https://nova-api.shiplight.ai",Th="https://api.shiplight.ai"});function sn(){let e=(B().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function ms(e){let t=B().env||{};if(sn()){let o=t.GOOGLE_CLOUD_PROJECT;if(!o)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let a=e.startsWith("gemini-3")?"global":t.GOOGLE_CLOUD_LOCATION;if(!a)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return h.debug(`Using Vertex AI provider: model=${e}, location=${a}`),(0,hs.createVertex)({project:o,location:a})(e)}let i=t.GOOGLE_API_KEY;if(i)return h.debug(`Using Google AI provider (API key): model=${e}`),(0,Qo.createGoogleGenerativeAI)({apiKey:i})(e);let n=t.SHIPLIGHT_API_TOKEN;if(n){let o=cs(n,t.SHIPLIGHT_API_URL);return h.debug(`Using Shiplight LLM proxy (Google): model=${e}, baseURL=${o}`),(0,Qo.createGoogleGenerativeAI)({apiKey:n,baseURL:o})(e)}throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.")}function ps(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:us.MEDIA_RESOLUTION_HIGH},o;switch(t){case"gemini-3-flash-preview":o={...n};break;default:o={...i},e===1&&(o.mediaResolution=us.MEDIA_RESOLUTION_HIGH)}return sn()?{vertex:o}:{google:o}}var Qo,hs,us,rt=y(()=>{"use strict";Ne();F();te();Qo=require("@ai-sdk/google"),hs=require("@ai-sdk/google-vertex"),us={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});function fe(e,t){return Math.round(e/1e3*t)}async function Ih(e,t,i,n,o){let a=null,r=null;try{switch(t){case"click_at":{let s=fe(i.x,n),l=fe(i.y,o),d=await Se(e,s,l);a={action_name:"click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"right_click_at":{let s=fe(i.x,n),l=fe(i.y,o),d=await Se(e,s,l);a={action_name:"right_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"double_click_at":{let s=fe(i.x,n),l=fe(i.y,o),d=await Se(e,s,l);a={action_name:"double_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"drag_and_drop":{let s=fe(i.x,n),l=fe(i.y,o),d=fe(i.destination_x,n),c=fe(i.destination_y,o),u=await Se(e,s,l);a={action_name:"drag_drop",kwargs:{relative_x:u.relative_x,relative_y:u.relative_y,delta_x:d-s,delta_y:c-l}},r=u.element;break}default:b.log(`Unsupported Gemini function: ${t}`)}}catch(s){b.error(`Error mapping Gemini action "${t}"`,s)}return{action_data:a,locatorInfo:await on(e,r)}}async function fs(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:o,viewportHeight:a,modelId:r}=e,s=r||Ph,l=B(),d;if(sn()){let f=l.env?.GOOGLE_CLOUD_PROJECT;if(!f)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let S=l.env?.GOOGLE_CLOUD_LOCATION??"global";d={vertexai:!0,project:f,location:S}}else{let f=l.env?.GOOGLE_API_KEY;if(f)h.debug(`Using Google AI provider (API key): model=${s}`),d={apiKey:f};else{let S=l.env?.SHIPLIGHT_API_TOKEN;if(S){let _=ds(S,l.env?.SHIPLIGHT_API_URL);h.debug(`Using Shiplight LLM proxy (Google CUA): model=${s}, baseUrl=${_}`),d={apiKey:S,httpOptions:{baseUrl:_}}}else return{status:"error",error:"Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment."}}}let c=new ln.GoogleGenAI(d);b.log(`Sending request to Gemini CUA (model=${s})...`);let u=await c.models.generateContent({model:s,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:ln.Environment.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:Mh}],temperature:.1}});b.log("Received response from Gemini CUA");let m=u.candidates?.[0];if(!m)return{status:"error",error:"No candidates in Gemini response"};let g=m.content?.parts?.find(f=>f.functionCall);if(!g)return{status:"error",reasoning:m.content?.parts?.filter(f=>f.text).map(f=>f.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:w,args:v}=g.functionCall;b.log(`Generated function call: ${w} with args ${JSON.stringify(v)}`),h.debug(`Generated function call: ${w} with args ${JSON.stringify(v)}`);let{action_data:x,locatorInfo:p}=await Ih(i,w,v,o,a);return x?{status:"success",actionEntity:an(t,x,p),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${w}`}}var ln,gs,Mh,Ph,cn=y(()=>{"use strict";at();ie();rt();Ne();F();te();ln=require("@google/genai");gs={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"]},Mh=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:gs},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:gs}];Ph="gemini-3-flash-preview"});function bs(e){return e!=null&&typeof e=="object"}function st(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function ws(e){return typeof e=="string"?e:void 0}function Ch(e){let t,i;return Array.isArray(e)?(t=st(e[0]),i=st(e[1])):bs(e)&&(t=st(e.x),i=st(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function ys(e){if(!bs(e))return{};let t=Array.isArray(e.path)?e.path.map(Ch).filter(i=>i!==null):void 0;return{type:ws(e.type),x:st(e.x),y:st(e.y),button:ws(e.button),path:t}}var dn=y(()=>{"use strict"});async function $h(e,t){let i=ys(t),n=null,o=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let a=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",r=await Se(e,i.x,i.y);n={action_name:a,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},o=r.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let a=await Se(e,i.x,i.y);n={action_name:"double_click_by_coordinates",kwargs:{relative_x:a.relative_x,relative_y:a.relative_y}},o=a.element;break}case"drag":{if(!i.path||i.path.length<2)break;let a=i.path[0],r=i.path[i.path.length-1],s=await Se(e,a.x,a.y);n={action_name:"drag_drop",kwargs:{relative_x:s.relative_x,relative_y:s.relative_y,delta_x:r.x-a.x,delta_y:r.y-a.y}},o=s.element;break}}return{action_data:n,locatorInfo:await on(e,o)}}async function _s(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:o,modelId:a}=e,r=a||Lh,s=await Ft(i,n,o),l=B(),d=l.env?.OPENAI_API_KEY;if(!d)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let c=l.env?.OPENAI_BASE_URL,u=new vs.default({apiKey:d,...c&&{baseURL:c}}),m=u.responses.create.bind(u.responses);b.log(`Sending request to OpenAI CUA (model=${r})...`);let g=[{role:"user",content:[{type:"input_text",text:t},{type:"input_image",detail:"original",image_url:`data:image/png;base64,${s}`}]}];async function w(S,_){let k={model:r,tools:[Dh],input:S,temperature:.1};return _&&(k.previous_response_id=_),m(k)}let v=await w(g,void 0),x;for(let S=0;S<xs;S++){b.log(`Received response from OpenAI CUA (turn ${S+1})`);let _=v.output.find(I=>I.type==="computer_call");if(!_)return{status:"error",reasoning:v.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let k=_.actions??[];if(k.length>1&&b.log(`[openai CUA] dropping ${k.length-1} batched action(s); only the first is executed`),x=k[0],!x)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(x.type!=="screenshot")break;s=await Ft(i,n,o);let E=[{type:"computer_call_output",call_id:_.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${s}`,detail:"original"}}];v=await w(E,v.id)}if(!x)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(x.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${xs} turns`};b.log(`Generated action: ${JSON.stringify(x)}`);let{action_data:p,locatorInfo:f}=await $h(i,x);return p?{status:"success",actionEntity:an(t,p,f),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(x)}`}}var vs,Lh,Dh,xs,un=y(()=>{"use strict";at();dn();ie();te();vs=R(require("openai"),1);Lh="gpt-5.4",Dh={type:"computer"},xs=4});function Oh(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function Nh(){return Oh(B().env?.ANTHROPIC_MODELS_USE_VERTEXAI)}function Ss(e){let t=B();if(Nh()){let o=t.env?.GOOGLE_CLOUD_PROJECT,a=t.env?.GOOGLE_CLOUD_LOCATION;if(!o)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!a)throw new Error("GOOGLE_CLOUD_LOCATION is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");return h.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${o}, location=${a}`),(0,ks.createVertexAnthropic)({project:o,location:a})(e)}let i=t.env?.ANTHROPIC_API_KEY;if(i)return h.debug(`Using Anthropic provider: model=${e}`),(0,ea.createAnthropic)({apiKey:i})(e);let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let o=ls(n,t.env?.SHIPLIGHT_API_URL);return h.debug(`Using Shiplight LLM proxy (Anthropic): model=${e}, baseURL=${o}`),(0,ea.createAnthropic)({apiKey:n,baseURL:o})(e)}throw new Error("ANTHROPIC_API_KEY not configured in SDK config")}function ta(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var ea,ks,Ht=y(()=>{"use strict";Ne();F();te();ea=require("@ai-sdk/anthropic"),ks=require("@ai-sdk/google-vertex/anthropic")});function Es(e){let t=B(),i=t.env?.OPENAI_API_KEY;if(i){let o=t.env?.OPENAI_BASE_URL;return h.debug(`Using OpenAI provider: model=${e}${o?`, baseURL=${o}`:""}`),(0,ia.createOpenAI)({apiKey:i,baseURL:o})(e)}let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let o=ss(n,t.env?.SHIPLIGHT_API_URL);return h.debug(`Using Shiplight LLM proxy (OpenAI): model=${e}, baseURL=${o}`),(0,ia.createOpenAI)({apiKey:n,baseURL:o})(e)}throw new Error("OPENAI_API_KEY not configured in SDK config")}function Ts(e){return{}}var ia,Wt=y(()=>{"use strict";Ne();F();te();ia=require("@ai-sdk/openai")});function Ms(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(Rh.test(e))return"openai"}function hn(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(Fh.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function we(e){let{provider:t,modelId:i}=hn(e),n=t??Ms(i);if(!n)throw new Error(`Cannot determine provider for model: ${e}. Use a known model prefix (claude-*, gemini-*, gpt-*) or specify a provider (e.g., "openai:${i}", "azure:${i}", "bedrock:${i}").`);if(!i)throw new Error(`Empty model ID in model string: "${e}". Specify a model after the provider prefix (e.g., "${n}:gpt-5.4-mini").`);let o=As[n];if(!o)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(As).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return o(i)}function be(e,t){let{provider:i,modelId:n}=hn(e),o=i??Ms(n);return o==="anthropic"||o==="vertex"?ta(n):o==="openai"||o==="azure"?Ts(n):o==="bedrock"?n.startsWith("anthropic.")?ta(n):{}:ps(t,n)}var Rh,Fh,As,Ee=y(()=>{"use strict";Ht();rt();Wt();Rh=/^(gpt-|o\d|chatgpt-)/;Fh=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);As={anthropic:Ss,google:ms,openai:Es}});function Wh(e){return e.startsWith("gemini-")?"google":"openai"}async function lt(e,t,i={}){let{page:n}=t,o=n.viewportSize();if(!o)return{status:"error",error:"Viewport size not available"};let{width:a,height:r}=o;b.log(`Viewport: ${a}x${r}`);let s=await Ft(n,a,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:d}=hn(l),c=Wh(d),u=Hh[c];b.log(`Using CUA provider: ${c} (model: ${d})`);let m={statement:e,page:n,screenshotB64:s,viewportWidth:a,viewportHeight:r,modelId:d};try{return await u(m)}catch(g){return b.error(`CUA provider "${c}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var Hh,ct=y(()=>{"use strict";cn();un();at();ie();Ee();Hh={google:fs,openai:_s}});function Uh(e,t){let i=new Map;for(let l of t)l.hash&&l.url?i.set(l.hash,l.url):l.uuid&&l.url&&i.set(l.uuid,l.url);let n=/!\[([^\]]*)\]\(image:([a-f0-9]{64}|[a-zA-Z0-9\-]+)\)/g,o=[],a=0,r;for(;(r=n.exec(e))!==null;){let l=e.slice(a,r.index);l&&o.push({type:"text",text:l});let d=r[2];i.has(d)?o.push({type:"image",image:new URL(i.get(d))}):o.push({type:"text",text:r[0]}),a=r.index+r[0].length}let s=e.slice(a);return s&&o.push({type:"text",text:s}),o.length===0&&o.push({type:"text",text:e}),o}function Bh(e){let t=[];for(let i of e){let n=i.content||"",o=i.images||[],a=Uh(n,o);t.length>0&&a.length>0&&t.push({type:"text",text:`
|
|
15
|
+
${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!V().agentLogPath}},w=new vh});var nn,_h,kh,Sh,Eh,ss,on,Qo,ls,ea,ta,ve=b(()=>{"use strict";nn=Object.defineProperty,_h=Object.getOwnPropertyDescriptor,kh=Object.getOwnPropertyNames,Sh=Object.prototype.hasOwnProperty,Eh=(e,t,i)=>t in e?nn(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,ss=(e,t)=>()=>(e&&(t=e(e=0)),t),on=(e,t)=>{for(var i in t)nn(e,i,{get:t[i],enumerable:!0})},Qo=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of kh(t))!Sh.call(e,o)&&o!==i&&nn(e,o,{get:()=>t[o],enumerable:!(n=_h(t,o))||n.enumerable});return e},ls=(e,t,i)=>(Qo(e,t,"default"),i&&Qo(i,t,"default")),ea=e=>Qo(nn({},"__esModule",{value:!0}),e),ta=(e,t,i)=>Eh(e,typeof t!="symbol"?t+"":t,i)});function L(e,t){return t??e?.getActionSettings()?.action_timeout_ms??na}function Th(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function N(e,t){let i=Fe(t);return i?new Function("page",`return ${i}`)(e):null}async function ia(e,t=[]){let i=e;for(let n of t){let o=await i.locator(n).elementHandle();if(!o)return null;let a=await o.contentFrame();if(await o.dispose(),!a)return null;i=a}return i}function Ah(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 Mh(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Ih(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 Fe(e){let t=Mh(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Ih(e);if(n){let o=JSON.stringify(n);return`${t}.locator(${o}).first()`}return null}var an,Ht,na,_e,P,U=b(()=>{"use strict";ve();an={};on(an,{ACTION_TIMEOUT:()=>na,GOTO_TIMEOUT:()=>_e,LOCATOR_TIMEOUT:()=>Ht,getActionTimeoutMs:()=>L,getFrameContext:()=>ia,getLocator:()=>N,getMinimalActionEntity:()=>Ah,getPageLocatorExpression:()=>Fe,sanitizeForComment:()=>Th});P=ss(()=>{Ht=5e3,na=1e4,_e=2e4})});async function Wt(e,t,i=[],n=[]){try{let o=await ia(e,i);if(!o)return u.warn(`Could not find frame context for xpath: ${t}`),null;let a=null;if(n.length>0){let r=n[0];if(!r)return u.warn(`Missing shadow host xpath for element: ${t}`),null;let l=o.locator(`xpath=${cs(r)}`),d=Ph(t);if(a=await(d?l.locator(`css=${d}`):l.locator(`xpath=${cs(t)}`)).elementHandle({timeout:Ht}),!a)return u.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(a=await o.locator(`xpath=${t}`).elementHandle({timeout:Ht}),!a)return u.warn(`Could not find element with xpath: ${t}`),null;let s=await o.evaluate(r=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(r):null,a);return await a.dispose(),s?(u.debug(`Generated locator for ${t}: ${s}`),s):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(o){return u.error(`Error in pickBestLocator: ${o}`),null}}async function rn(e,t){try{let i=await(await t.ownerFrame()??e).evaluate(n=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(n):null,t);return await t.dispose(),i?(u.debug(`Generated locator: ${i}`),i):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return u.error(`Error in pickBestLocator: ${i}`),null}}async function ds(e,t){let i=new Map;return await Promise.all(t.map(async n=>{let o=await Wt(e,n);i.set(n,o)})),i}function cs(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function Ph(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),n=[];for(let o of i){let a=o.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!a)return null;let s=a[1].toLowerCase(),r=a[2]?`:nth-of-type(${a[2]})`:"";n.push(`${s}${r}`)}return n.join(" > ")}var Xe=b(()=>{"use strict";W();U();P()});async function Ut(e,t,i){await e.evaluate(()=>{document.getElementById("playwright-highlight-container")?.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(l=>l()),window._highlightCleanupFunctions=[])});let n=await e.screenshot({type:"png",fullPage:!1}),{default:o}=await import("sharp"),a=o(n),{width:s=0,height:r=0}=await a.metadata();return w.log(`Screenshot actual: ${s}x${r}, viewport: ${t}x${i}`),(s!==t||r!==i?await a.resize(t,i).png().toBuffer():n).toString("base64")}async function Pe(e,t,i){let n=await e.evaluateHandle(s=>document.elementFromPoint(s.x,s.y),{x:t,y:i}),o=n.asElement();if(!o)throw await n.dispose(),new Error(`No element found at (${t}, ${i})`);let a=await o.boundingBox();if(!a)throw await n.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(a.x+a.width/2),relative_y:i-(a.y+a.height/2),element:o}}async function sn(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(o=>{let a=[],s=o;for(;s&&s.nodeType===Node.ELEMENT_NODE;){let r=1,l=s.previousElementSibling;for(;l;)l.tagName===s.tagName&&r++,l=l.previousElementSibling;a.unshift(`${s.tagName.toLowerCase()}[${r}]`),s=s.parentElement}return a.length?`/${a.join("/")}`:null}).catch(()=>null),n=await rn(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function ln(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 rt=b(()=>{"use strict";ae();Xe()});function cn(e,t){let i=t?.trim();return i?Lh(i):e.startsWith(Ch)?$h:Oh}function us(e,t){return`${cn(e,t)}/llm/v1`}function hs(e,t){return`${cn(e,t)}/llm/v1`}function ms(e,t){return`${cn(e,t)}/llm/v1beta`}function ps(e,t){return`${cn(e,t)}/llm`}function Lh(e){return e.endsWith("/")?e.slice(0,-1):e}var Ch,$h,Oh,He=b(()=>{"use strict";Ch="shp_",$h="https://nova-api.shiplight.ai",Oh="https://api.shiplight.ai"});function dn(){let e=(V().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function ws(e){let t=V().env||{};if(dn()){let o=t.GOOGLE_CLOUD_PROJECT;if(!o)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let a=e.startsWith("gemini-3")?"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}`),(0,fs.createVertex)({project:o,location:a})(e)}let i=t.GOOGLE_API_KEY;if(i)return u.debug(`Using Google AI provider (API key): model=${e}`),(0,oa.createGoogleGenerativeAI)({apiKey:i})(e);let n=t.SHIPLIGHT_API_TOKEN;if(n){let o=ms(n,t.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (Google): model=${e}, baseURL=${o}`),(0,oa.createGoogleGenerativeAI)({apiKey:n,baseURL:o})(e)}throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.")}function bs(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:gs.MEDIA_RESOLUTION_HIGH},o;switch(t){case"gemini-3-flash-preview":o={...n};break;default:o={...i},e===1&&(o.mediaResolution=gs.MEDIA_RESOLUTION_HIGH)}return dn()?{vertex:o}:{google:o}}var oa,fs,gs,st=b(()=>{"use strict";He();W();oe();oa=require("@ai-sdk/google"),fs=require("@ai-sdk/google-vertex"),gs={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});function ke(e,t){return Math.round(e/1e3*t)}async function Nh(e,t,i,n,o){let a=null,s=null;try{switch(t){case"click_at":{let r=ke(i.x,n),l=ke(i.y,o),d=await Pe(e,r,l);a={action_name:"click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},s=d.element;break}case"right_click_at":{let r=ke(i.x,n),l=ke(i.y,o),d=await Pe(e,r,l);a={action_name:"right_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},s=d.element;break}case"double_click_at":{let r=ke(i.x,n),l=ke(i.y,o),d=await Pe(e,r,l);a={action_name:"double_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},s=d.element;break}case"drag_and_drop":{let r=ke(i.x,n),l=ke(i.y,o),d=ke(i.destination_x,n),c=ke(i.destination_y,o),h=await Pe(e,r,l);a={action_name:"drag_drop",kwargs:{relative_x:h.relative_x,relative_y:h.relative_y,delta_x:d-r,delta_y:c-l}},s=h.element;break}default:w.log(`Unsupported Gemini function: ${t}`)}}catch(r){w.error(`Error mapping Gemini action "${t}"`,r)}return{action_data:a,locatorInfo:await sn(e,s)}}async function xs(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:o,viewportHeight:a,modelId:s}=e,r=s||Rh,l=V(),d;if(dn()){let f=l.env?.GOOGLE_CLOUD_PROJECT;if(!f)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let S=l.env?.GOOGLE_CLOUD_LOCATION??"global";d={vertexai:!0,project:f,location:S}}else{let f=l.env?.GOOGLE_API_KEY;if(f)u.debug(`Using Google AI provider (API key): model=${r}`),d={apiKey:f};else{let S=l.env?.SHIPLIGHT_API_TOKEN;if(S){let _=ps(S,l.env?.SHIPLIGHT_API_URL);u.debug(`Using Shiplight LLM proxy (Google CUA): model=${r}, baseUrl=${_}`),d={apiKey:S,httpOptions:{baseUrl:_}}}else return{status:"error",error:"Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment."}}}let c=new un.GoogleGenAI(d);w.log(`Sending request to Gemini CUA (model=${r})...`);let h=await c.models.generateContent({model:r,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:un.Environment.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:Dh}],temperature:.1}});w.log("Received response from Gemini CUA");let m=h.candidates?.[0];if(!m)return{status:"error",error:"No candidates in Gemini response"};let g=m.content?.parts?.find(f=>f.functionCall);if(!g)return{status:"error",reasoning:m.content?.parts?.filter(f=>f.text).map(f=>f.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:y,args:v}=g.functionCall;w.log(`Generated function call: ${y} with args ${JSON.stringify(v)}`),u.debug(`Generated function call: ${y} with args ${JSON.stringify(v)}`);let{action_data:x,locatorInfo:p}=await Nh(i,y,v,o,a);return x?{status:"success",actionEntity:ln(t,x,p),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${y}`}}var un,ys,Dh,Rh,hn=b(()=>{"use strict";rt();ae();st();He();W();oe();un=require("@google/genai");ys={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"]},Dh=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:ys},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:ys}];Rh="gemini-3-flash-preview"});function _s(e){return e!=null&&typeof e=="object"}function lt(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function vs(e){return typeof e=="string"?e:void 0}function Fh(e){let t,i;return Array.isArray(e)?(t=lt(e[0]),i=lt(e[1])):_s(e)&&(t=lt(e.x),i=lt(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function ks(e){if(!_s(e))return{};let t=Array.isArray(e.path)?e.path.map(Fh).filter(i=>i!==null):void 0;return{type:vs(e.type),x:lt(e.x),y:lt(e.y),button:vs(e.button),path:t}}var mn=b(()=>{"use strict"});async function Hh(e,t){let i=ks(t),n=null,o=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let a=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",s=await Pe(e,i.x,i.y);n={action_name:a,kwargs:{relative_x:s.relative_x,relative_y:s.relative_y}},o=s.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let a=await Pe(e,i.x,i.y);n={action_name:"double_click_by_coordinates",kwargs:{relative_x:a.relative_x,relative_y:a.relative_y}},o=a.element;break}case"drag":{if(!i.path||i.path.length<2)break;let a=i.path[0],s=i.path[i.path.length-1],r=await Pe(e,a.x,a.y);n={action_name:"drag_drop",kwargs:{relative_x:r.relative_x,relative_y:r.relative_y,delta_x:s.x-a.x,delta_y:s.y-a.y}},o=r.element;break}}return{action_data:n,locatorInfo:await sn(e,o)}}async function Ts(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:o,modelId:a}=e,s=a||Wh,r=await Ut(i,n,o),l=V(),d=l.env?.OPENAI_API_KEY;if(!d)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let c=l.env?.OPENAI_BASE_URL,h=new Es.default({apiKey:d,...c&&{baseURL:c}}),m=h.responses.create.bind(h.responses);w.log(`Sending request to OpenAI CUA (model=${s})...`);let g=[{role:"user",content:[{type:"input_text",text:t},{type:"input_image",detail:"original",image_url:`data:image/png;base64,${r}`}]}];async function y(S,_){let k={model:s,tools:[Uh],input:S,temperature:.1};return _&&(k.previous_response_id=_),m(k)}let v=await y(g,void 0),x;for(let S=0;S<Ss;S++){w.log(`Received response from OpenAI CUA (turn ${S+1})`);let _=v.output.find(I=>I.type==="computer_call");if(!_)return{status:"error",reasoning:v.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let k=_.actions??[];if(k.length>1&&w.log(`[openai CUA] dropping ${k.length-1} batched action(s); only the first is executed`),x=k[0],!x)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(x.type!=="screenshot")break;r=await Ut(i,n,o);let A=[{type:"computer_call_output",call_id:_.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${r}`,detail:"original"}}];v=await y(A,v.id)}if(!x)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(x.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${Ss} turns`};w.log(`Generated action: ${JSON.stringify(x)}`);let{action_data:p,locatorInfo:f}=await Hh(i,x);return p?{status:"success",actionEntity:ln(t,p,f),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(x)}`}}var Es,Wh,Uh,Ss,pn=b(()=>{"use strict";rt();mn();ae();oe();Es=H(require("openai"),1);Wh="gpt-5.4",Uh={type:"computer"},Ss=4});function Bh(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function Gh(){return Bh(V().env?.ANTHROPIC_MODELS_USE_VERTEXAI)}function Ms(e){let t=V();if(Gh()){let o=t.env?.GOOGLE_CLOUD_PROJECT,a=t.env?.GOOGLE_CLOUD_LOCATION;if(!o)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!a)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=${o}, location=${a}`),(0,As.createVertexAnthropic)({project:o,location:a})(e)}let i=t.env?.ANTHROPIC_API_KEY;if(i)return u.debug(`Using Anthropic provider: model=${e}`),(0,aa.createAnthropic)({apiKey:i})(e);let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let o=hs(n,t.env?.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (Anthropic): model=${e}, baseURL=${o}`),(0,aa.createAnthropic)({apiKey:n,baseURL:o})(e)}throw new Error("ANTHROPIC_API_KEY not configured in SDK config")}function ra(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var aa,As,Bt=b(()=>{"use strict";He();W();oe();aa=require("@ai-sdk/anthropic"),As=require("@ai-sdk/google-vertex/anthropic")});function Is(e){let t=V(),i=t.env?.OPENAI_API_KEY;if(i){let o=t.env?.OPENAI_BASE_URL;return u.debug(`Using OpenAI provider: model=${e}${o?`, baseURL=${o}`:""}`),(0,sa.createOpenAI)({apiKey:i,baseURL:o})(e)}let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let o=us(n,t.env?.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (OpenAI): model=${e}, baseURL=${o}`),(0,sa.createOpenAI)({apiKey:n,baseURL:o})(e)}throw new Error("OPENAI_API_KEY not configured in SDK config")}function Ps(e){return{}}var sa,Gt=b(()=>{"use strict";He();W();oe();sa=require("@ai-sdk/openai")});function $s(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(Kh.test(e))return"openai"}function gn(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(jh.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function Se(e){let{provider:t,modelId:i}=gn(e),n=t??$s(i);if(!n)throw new Error(`Cannot determine provider for model: ${e}. Use a known model prefix (claude-*, gemini-*, gpt-*) or specify a provider (e.g., "openai:${i}", "azure:${i}", "bedrock:${i}").`);if(!i)throw new Error(`Empty model ID in model string: "${e}". Specify a model after the provider prefix (e.g., "${n}:gpt-5.4-mini").`);let o=Cs[n];if(!o)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(Cs).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return o(i)}function Ee(e,t){let{provider:i,modelId:n}=gn(e),o=i??$s(n);return o==="anthropic"||o==="vertex"?ra(n):o==="openai"||o==="azure"?Ps(n):o==="bedrock"?n.startsWith("anthropic.")?ra(n):{}:bs(t,n)}var Kh,jh,Cs,Ce=b(()=>{"use strict";Bt();st();Gt();Kh=/^(gpt-|o\d|chatgpt-)/;jh=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);Cs={anthropic:Ms,google:ws,openai:Is}});function Vh(e){return e.startsWith("gemini-")?"google":"openai"}async function ct(e,t,i={}){let{page:n}=t,o=n.viewportSize();if(!o)return{status:"error",error:"Viewport size not available"};let{width:a,height:s}=o;w.log(`Viewport: ${a}x${s}`);let r=await Ut(n,a,s),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:d}=gn(l),c=Vh(d),h=zh[c];w.log(`Using CUA provider: ${c} (model: ${d})`);let m={statement:e,page:n,screenshotB64:r,viewportWidth:a,viewportHeight:s,modelId:d};try{return await h(m)}catch(g){return w.error(`CUA provider "${c}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var zh,dt=b(()=>{"use strict";hn();pn();rt();ae();Ce();zh={google:xs,openai:Ts}});function Xh(e,t){let i=new Map;for(let l of t)l.hash&&l.url?i.set(l.hash,l.url):l.uuid&&l.url&&i.set(l.uuid,l.url);let n=/!\[([^\]]*)\]\(image:([a-f0-9]{64}|[a-zA-Z0-9\-]+)\)/g,o=[],a=0,s;for(;(s=n.exec(e))!==null;){let l=e.slice(a,s.index);l&&o.push({type:"text",text:l});let d=s[2];i.has(d)?o.push({type:"image",image:new URL(i.get(d))}):o.push({type:"text",text:s[0]}),a=s.index+s[0].length}let r=e.slice(a);return r&&o.push({type:"text",text:r}),o.length===0&&o.push({type:"text",text:e}),o}function Yh(e){let t=[];for(let i of e){let n=i.content||"",o=i.images||[],a=Xh(n,o);t.length>0&&a.length>0&&t.push({type:"text",text:`
|
|
16
16
|
|
|
17
|
-
`}),t.push(...a)}return t}function
|
|
17
|
+
`}),t.push(...a)}return t}function fn(e,t=Os){if(t){let i=Yh(e);if(i.length===0)return[];let n={type:"text",text:`
|
|
18
18
|
|
|
19
19
|
<retrieved_knowledge>
|
|
20
20
|
|
|
@@ -34,7 +34,7 @@ Below are expert curated knowledge that are retrieved from the knowledge base; A
|
|
|
34
34
|
|
|
35
35
|
</retrieved_knowledge>
|
|
36
36
|
|
|
37
|
-
`}]:[]}}function
|
|
37
|
+
`}]:[]}}function Ls(e,t=Os){if(!t)return 0;let i=0;for(let n of e)n.images&&(i+=n.images.length);return i}var Os,Kt=b(()=>{"use strict";Os=!1});function Jh(){let e=new Date,t=new Intl.DateTimeFormat("en-US",{timeZone:"America/Los_Angeles",year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1,timeZoneName:"short"}).formatToParts(e),i=t.find(c=>c.type==="year").value,n=t.find(c=>c.type==="month").value,o=t.find(c=>c.type==="day").value,a=t.find(c=>c.type==="hour").value,s=t.find(c=>c.type==="minute").value,r=t.find(c=>c.type==="second").value,l=t.find(c=>c.type==="timeZoneName").value,d=String(e.getMilliseconds()).padStart(3,"0");return`${i}-${n}-${o} ${a}:${s}:${r}.${d} ${l}`}function Ds(e){return`# Your Role
|
|
38
38
|
You are part of a end-to-end testing system that is designed to automate the testing of a website. Given an instruction in natural language, your job is to translate it into an action in the predefined actions. The instruction might not match any action in the predefined actions or might require to interact with an element that is not on the page. It's your job to detect these cases and return an empty action.
|
|
39
39
|
|
|
40
40
|
# Rules
|
|
@@ -94,11 +94,11 @@ Example of empty action when the target element is not on the page, or the instr
|
|
|
94
94
|
"action": {}, // empty action object to indicate the instruction cannot be completed
|
|
95
95
|
"completes_instruction": false
|
|
96
96
|
}
|
|
97
|
-
`}function
|
|
97
|
+
`}function qh(e){if(!e||e.length===0)return"";let t="";return e.forEach(([i,n],o)=>{t+=`(${o+1}) Description: ${i}
|
|
98
98
|
Feedback: ${n}
|
|
99
99
|
`}),`## Additional context
|
|
100
100
|
You just executed following steps in order:
|
|
101
|
-
${t}`}function
|
|
101
|
+
${t}`}function Ns(e,t,i,n,o,a,s=!1,r=Jh(),l=!1,d){let c=[],h=`
|
|
102
102
|
# Instruction
|
|
103
103
|
"${t}"
|
|
104
104
|
|
|
@@ -118,9 +118,9 @@ ${e.tabsText}
|
|
|
118
118
|
|
|
119
119
|
## Interactive elements from current page:
|
|
120
120
|
${e.elementsText}
|
|
121
|
-
`;if(c.push({type:"text",text:
|
|
122
|
-
Current local time is ${
|
|
123
|
-
`,i&&Object.keys(i).length>0){let g=[];for(let
|
|
121
|
+
`;if(c.push({type:"text",text:h}),s&&e.slicedScreenshotsBase64)for(let g of e.slicedScreenshotsBase64)c.push({type:"text",text:"The following images provided are sliced screenshots of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),c.push({type:"image",image:g});else a&&(c.push({type:"text",text:"The following image provided is a screenshot of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),c.push({type:"image",image:a}));if(o&&o.length>0){let g=fn(o,l);c.push(...g)}let m="";if(m+=`
|
|
122
|
+
Current local time is ${r}.
|
|
123
|
+
`,i&&Object.keys(i).length>0){let g=[];for(let y of Object.keys(i))if(d?.has(y))g.push(` - ${y}: [SENSITIVE - value hidden]`);else{let v=i[y],x=typeof v=="string"?v:JSON.stringify(v);g.push(` - ${y}: "${x}"`)}m+=`
|
|
124
124
|
## Available Data Placeholders
|
|
125
125
|
The following placeholders are available for use in your actions:
|
|
126
126
|
${g.join(`
|
|
@@ -131,32 +131,32 @@ To use them, write Jinja-like template syntax: {{ placeholder_name }}
|
|
|
131
131
|
- Do NOT use the actual value directly
|
|
132
132
|
- The values shown are for context only to help you understand what data is available
|
|
133
133
|
- In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")
|
|
134
|
-
`}if(n&&n.length>0){let g=
|
|
134
|
+
`}if(n&&n.length>0){let g=qh(n);m+=`
|
|
135
135
|
`+g}return m+=`
|
|
136
136
|
Based on the above information, please determine the right action to accomplish the task.
|
|
137
|
-
`,c.push({type:"text",text:m}),c}var
|
|
137
|
+
`,c.push({type:"text",text:m}),c}var wn=b(()=>{"use strict";Kt()});async function Zh(e){let t=e.context().pages(),i=null,n=[];for(let a=0;a<t.length;a++){let s=t[a];s===e&&(i=a);let r="(title unavailable)";try{r=await Promise.race([s.title(),new Promise((d,c)=>setTimeout(()=>c(new Error("timeout")),1e3))])}catch{}let l=`Tab ${a}: ${s.url()}`;r&&(l+=` - ${r.slice(0,50)}`),n.push(l)}let o=n.length>0?n.join(`
|
|
138
138
|
`):"";return{currentTabText:i!==null?`Current tab: ${i}
|
|
139
|
-
`:"",tabsText:o}}async function
|
|
140
|
-
`)&&(
|
|
141
|
-
`)[0]),
|
|
142
|
-
Parameters: ${JSON.stringify(
|
|
139
|
+
`:"",tabsText:o}}async function Qh(e,t){let{currentTabText:i,tabsText:n}=await Zh(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function bn(e,t){let{page:i,domService:n,agentServices:o}=e,a=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},s=o.getInteractiveClassNames(),r=o.getIframeFallbackDomains(),{domState:l,screenshotBase64:d,slicedScreenshotsBase64:c}=await n.getClickableElementsWithScreenshot(i,{interactiveClassNames:s,playwrightFrameFallbackDomains:r,useCleanScreenshot:a.useCleanScreenshot,useSlicedScreenshots:a.useSlicedScreenshots,resizeSlicedScreenshots:a.resizeSlicedScreenshots,useAccessibilityTree:a.useAccessibilityTree,actionIntent:a.actionIntent}),h=l.elementTree.clickableElementsToString(),m=await Qh(i,h);return c&&(m.slicedScreenshotsBase64=c),{domTree:h,screenshotBase64:d,slicedScreenshotsBase64:c,domState:l,pageContext:m}}var jt=b(()=>{"use strict"});function yn(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 zt=b(()=>{"use strict"});var ue,ut,G,$e=b(()=>{"use strict";ue=require("zod"),ut=class{constructor(){this.tools=new Map}register(e){if(this.tools.has(e.name))throw new Error(`Tool '${e.name}' is already registered`);let t={name:e.name,description:e.description,schema:e.schema,execute:e.execute,usesElementIndex:e.usesElementIndex??!1,availability:{openai:e.availability?.openai??!0,mcp:e.availability?.mcp??!0}};this.tools.set(e.name,t)}get(e){return this.tools.get(e)}has(e){return this.tools.has(e)}getToolNames(){return Array.from(this.tools.keys())}getTools(){return Array.from(this.tools.values())}async execute(e,t,i){let n=this.tools.get(e);if(!n)throw new Error(`Tool not found: ${e}`);try{let o=t?.description,a={...t};delete a.description;let s=n.schema.parse(a),r={...i,actionDescription:o};return await n.execute(s,r)}catch(o){if(o instanceof ue.z.ZodError){let a=o.issues.map(s=>`${s.path.join(".")}: ${s.message}`).join(", ");return{success:!1,error:`Invalid arguments for tool '${e}': ${a}`,actionEntity:{action_description:t?.description||`${e} (validation failed)`,action_data:{action_name:e,kwargs:t},feedback:`Validation error: ${a}`}}}throw o}}clear(){this.tools.clear()}size(){return this.tools.size}buildActionUnionSchema(){let e=this.getTools().filter(t=>t.availability.openai);return this.buildUnionSchemaFromTools(e)}buildActionUnionSchemaForTools(e,t=!1){let i=new Set(e),n=this.getTools().filter(o=>i.has(o.name));return this.buildUnionSchemaFromTools(n,t)}buildUnionSchemaFromTools(e,t=!1){if(e.length===0)return ue.z.object({done:ue.z.any()});let i=e.map(s=>{let r=s.schema;if(t&&r instanceof ue.z.ZodObject){let l=r._def.shape();r=ue.z.object({...l,description:ue.z.string().describe("Semantic, human-readable description of the action")})}if(r instanceof ue.z.ZodObject){let l=r._def.shape();Object.keys(l).length===0&&(r=ue.z.object({_empty:ue.z.boolean().optional()}))}return ue.z.object({[s.name]:r})});if(i.length===1)return i[0];let[n,o,...a]=i;return ue.z.union([n,o,...a])}},G=new ut});async function K(e,t){if(t<0)return;let{page:i,domService:n}=e;return(e.domState||await n.getClickableElements(i)).selectorMap.get(t)}function em(e){let t=e.split("/").filter(o=>o);if(t.length===0)return"*";let i=t[t.length-1],n=i.match(/^(\w+)(?:\[(\d+)\])?$/);if(n){let[,o,a]=n;return a?`${o}:nth-of-type(${a})`:o}return i}function tm(e,t=!0){try{let i=em(e.xpath);if(e.attributes.class&&t){let o=/^[a-zA-Z_][a-zA-Z0-9_-]*$/,a=e.attributes.class.split(/\s+/);for(let s of a)s.trim()&&o.test(s)&&(i+=`.${s}`)}let n=new Set(["id","name","type","placeholder","aria-label","aria-labelledby","aria-describedby","role","for","autocomplete","required","readonly","alt","title","target"]);t&&["data-id","data-qa","data-cy","data-testid","data-handlepos"].forEach(o=>n.add(o));for(let[o,a]of Object.entries(e.attributes)){if(o==="class"||!o.trim()||!n.has(o))continue;let s=o.replace(/:/g,"\\:");if(a==="")i+=`[${s}]`;else if(/["'<>`\n\r\t]/.test(a)){let r=a;a.includes(`
|
|
140
|
+
`)&&(r=a.split(`
|
|
141
|
+
`)[0]),r=r.replace(/\s+/g," ").trim();let l=r.replace(/"/g,'\\"');i+=`[${s}*="${l}"]`}else i+=`[${s}="${a}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function im(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 tm(e,!1)}function la(e){let t=[],i=e;for(;i&&i.parent!==null;){let a=i.parent;t.push(a),i=a}t.reverse();let n=[],o=t.filter(a=>a.tagName==="iframe");for(let a of o){let s=im(a);u.debug("[frame-path] iframe attrs:",JSON.stringify(a.attributes),"\u2192",s),n.push(s)}return n}async function F(e,t){let i=null,n=la(t);return t.xpath&&(i=await Wt(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var Y=b(()=>{"use strict";Xe();W()});function nm(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 om(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 am(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let n=i.image,o=om(n);if(o)return{type:"image",file:o};let a=typeof n=="string"?n:"";return{type:"image",file:a.startsWith("data:")?a:`data:image/png;base64,${a}`}}return{type:"text",text:i.text}}):t.content}))}async function Rs(e,t,i={}){let{page:n,agentServices:o}=t,a=o.getModel(),s=i.temperature??0,r=o.retrieveKnowledges(e).catch(z=>(w.log(`Failed to retrieve knowledges: ${z.message}`),[])),l=o.isSlicedScreenshotsEnabled(),d=o.isResizeSlicedScreenshotsEnabled(),c=o.isKnowledgeImagesEnabled(),h=o.isAccessibilityTreeEnabled(),m=o.isActionIntentFilteringEnabled(),g=m?nm(e):"all";m&&g!=="all"&&w.log(`Action intent filtering: detected '${g}' intent from statement`);let{screenshotBase64:y,domState:v,pageContext:x}=await bn(t,{useSlicedScreenshots:l,resizeSlicedScreenshots:d,useAccessibilityTree:h,actionIntent:g});t.domState=v;let p=new en(G).getToolDefinitions().map(z=>{let Ie=z.function;return`${Ie.name}: ${Ie.description}
|
|
142
|
+
Parameters: ${JSON.stringify(Ie.parameters,null,2)}`}).join(`
|
|
143
143
|
|
|
144
|
-
`),f=
|
|
144
|
+
`),f=Ds(p),S=await r,_=Ns(x,e,t.variables,t.executionHistory,S.length>0?S:void 0,y,l,void 0,c,t.sensitiveKeys),k=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(z=>{z.role==="user"?k.push({role:"user",content:z.content}):z.role==="assistant"&&k.push({role:"assistant",content:z.content})}),k.push({role:"user",content:_});let A=am(k),I=G.buildActionUnionSchema(),O=Vt.z.object({thought:Vt.z.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:Vt.z.string().describe("Detailed description of the action to be performed").optional().default(""),action:I,completes_instruction:Vt.z.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),C=Array.isArray(_)?_.filter(z=>z.type==="image").length:0,R=Ee(a,C),X=await(0,xn.generateText)({model:Se(a),system:f,messages:k,temperature:s,output:xn.Output.object({schema:O}),providerOptions:R}),ce=X.reasoningText;u.info(`Action Generation Reasoning: ${ce}`);let j=X.output,D=JSON.stringify(j,null,2);u.info(`Generate Action Raw Output: ${D}`);let q=[],ee=yn(X.usage,a);ee&&q.push(ee);let se={systemPrompt:f,userPrompt:A,rawLlmResponse:D,tokenUsages:q},te=j.thought||"",fe=j.description||"",B=j.action||{},Z=j.completes_instruction||!1;if(!B||Object.keys(B).length===0)return{status:"error",reasoning:te||fe||"No action generated",goalAccomplished:Z,error:"Agent did not generate any action",debugInfo:se};let Q=Object.keys(B)[0];if(Q==="done")return{status:"error",reasoning:te||fe||"Task marked as done",goalAccomplished:Z,error:"Agent indicated task is done without generating an action",debugInfo:se};if(Q==="perform_accurate_operation")return await ct(e,t,i);if(!Z){let z="Can't complete the instruction in one action";return{status:"error",reasoning:te||fe||z,goalAccomplished:!1,error:z,debugInfo:se}}let de=B[Q]||{},Ko={};if(typeof de.element_index=="number"){let z=de.element_index;if(z<0)return{status:"error",reasoning:te||fe||"No action generated",goalAccomplished:Z,error:"Agent did not generate any action",debugInfo:se};let Ie=v.selectorMap.get(z);Ie&&(Ko=await F(n,Ie))}let Dt=fe;return Q==="verify"&&(Dt=e,de.statement=e),{status:"success",actionEntity:{...Ko,action_description:Dt||te||`${Q}(${JSON.stringify(de)})`,action_data:{action_name:Q,kwargs:de}},reasoning:te||fe,goalAccomplished:Z,debugInfo:se}}var xn,Vt,vn=b(()=>{"use strict";tn();dt();wn();jt();zt();$e();ae();Ce();Y();W();xn=require("ai"),Vt=require("zod")});function rm(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 ca(e,t,i={}){return i.usePureVision?ct(e,t,i):Rs(e,t,i)}function lm(){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 cm(){return`# Role
|
|
145
145
|
You are an experienced QA person for web applications.
|
|
146
146
|
You are tasked to verify the validity of a given statement based on the screenshot and element tree of a web page.
|
|
147
|
-
`}async function
|
|
147
|
+
`}async function Fs(e,t,i={}){let{page:n,executionHistory:o}=t,a=t.agentServices.getModel();try{let s=t.agentServices.isSlicedScreenshotsEnabled(),r=t.agentServices.isResizeSlicedScreenshotsEnabled(),l=t.agentServices.isKnowledgeImagesEnabled(),d=t.agentServices.isAccessibilityTreeEnabled(),{domTree:c,screenshotBase64:h,slicedScreenshotsBase64:m,domState:g,pageContext:y}=await bn(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:s,resizeSlicedScreenshots:r,useAccessibilityTree:d});t.domState=g;let v="";o&&o.length>0&&(v=`
|
|
148
148
|
# Previous actions in this session:
|
|
149
|
-
${o.map(([
|
|
150
|
-
Result: ${
|
|
149
|
+
${o.map(([B,Z],Q)=>`${Q+1}. Action: ${B}
|
|
150
|
+
Result: ${Z}`).join(`
|
|
151
151
|
`)}
|
|
152
|
-
`);let{dateString:x,timeString:p}=
|
|
152
|
+
`);let{dateString:x,timeString:p}=lm(),f=`
|
|
153
153
|
# User statement
|
|
154
154
|
"${e}"
|
|
155
155
|
|
|
156
156
|
# Current webpage state
|
|
157
157
|
## Tab information:
|
|
158
|
-
${
|
|
159
|
-
${
|
|
158
|
+
${y.currentTabText}Available tabs:
|
|
159
|
+
${y.tabsText}
|
|
160
160
|
|
|
161
161
|
## Element interaction guidelines:
|
|
162
162
|
- Each element has a unique index number (e.g., "[33]<button>")
|
|
@@ -167,23 +167,23 @@ ${w.tabsText}
|
|
|
167
167
|
${c}
|
|
168
168
|
|
|
169
169
|
## Screenshot
|
|
170
|
-
${
|
|
171
|
-
`,S="";if(t.variables&&Object.keys(t.variables).length>0){let
|
|
170
|
+
${s&&m?"The following images are sliced screenshots of the current webpage (left, middle, right sections).":"The image provided is a screenshot of the current webpage."}
|
|
171
|
+
`,S="";if(t.variables&&Object.keys(t.variables).length>0){let B=[];for(let Z of Object.keys(t.variables))if(!t.sensitiveKeys?.has(Z)){let Q=t.variables[Z],de=typeof Q=="string"?Q:JSON.stringify(Q);B.push(` - ${Z}: "${de}"`)}B.length>0&&(S=`
|
|
172
172
|
## Available Variables
|
|
173
173
|
The following non-sensitive variables are available:
|
|
174
|
-
${
|
|
174
|
+
${B.join(`
|
|
175
175
|
`)}`)}let _=`
|
|
176
176
|
${S}
|
|
177
177
|
${v}
|
|
178
178
|
|
|
179
179
|
Today is ${x}. Current local time is ${p}.
|
|
180
180
|
Based on the above information, please determine if the statement is true.
|
|
181
|
-
`,k=await t.agentServices.retrieveKnowledges(e),
|
|
181
|
+
`,k=await t.agentServices.retrieveKnowledges(e),A=[{type:"text",text:f}],I=0;if(s&&m&&m.length>0)for(let B of m)A.push({type:"image",image:B}),I++;else A.push({type:"image",image:h}),I=1;if(k&&k.length>0){let B=fn(k,l);A.push(...B)}A.push({type:"text",text:_});let O=k?Ls(k,l):0,C=I+O,R=Ee(a,C),X=cm(),ce=await(0,_n.generateText)({model:Se(a),system:X,messages:[{role:"user",content:A}],output:_n.Output.object({schema:sm}),temperature:0,providerOptions:R}),{conclusion:j,explanation:D}=ce.output,q=JSON.stringify(ce.output,null,2),ee=[],se=yn(ce.usage,a);se&&ee.push(se);let te=[{role:"user",content:A.map(B=>{if(B.type==="text")return{type:"text",text:B.text};if(B.type==="image"){let Z=B.image,Q=rm(Z);if(Q)return{type:"image",file:Q};let de=typeof Z=="string"?Z:"";return{type:"image",file:de.startsWith("data:")?de:`data:image/png;base64,${de}`}}return{type:"text",text:"[unknown content type]"}})}],fe={systemPrompt:X,userPrompt:te,rawLlmResponse:q,screenshotWithSom:h,tokenUsages:ee,retrievedKnowledges:k&&k.length>0?k:void 0,elementTree:c};return{success:j==="true",explanation:D,debugInfo:fe}}catch(s){return{success:!1,error:s.message}}}var _n,Xt,sm,kn=b(()=>{"use strict";vn();dt();jt();zt();Kt();Ce();_n=require("ai"),Xt=require("zod");sm=Xt.z.object({screenshotDescription:Xt.z.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
|
|
182
182
|
and a description of their location: formatting example: [12] A red button with text "Submit", next to [11]
|
|
183
183
|
[45] A modal dialog titled "Confirmation",
|
|
184
|
-
in the center of the screen`),explanation:
|
|
185
|
-
`).trim()}clickableElementsToString(t){let i=t?.includeAttributes??
|
|
186
|
-
`)}}});function
|
|
184
|
+
in the center of the screen`),explanation:Xt.z.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:Xt.z.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function Ws(){let{default:e}=await import("sharp");return e}async function da(e,t){let i=await Ws(),n=await i(e).metadata(),o=n.width||0,a=n.height||0;if(o===0||a===0)throw new Error("Invalid image dimensions");let s=a,r=0,l=Math.floor((o-s)/2),d=Math.max(0,o-s),c=(y,v)=>{let x=i(e).extract({left:y,top:0,width:v,height:s});return t?.resize&&(x=x.resize(Hs,Hs)),x.png().toBuffer()},[h,m,g]=await Promise.all([c(r,Math.min(s,o)),c(l,Math.min(s,o-l)),c(d,Math.min(s,o-d))]);return[h,m,g]}async function Us(e){let t=(await Ws())(e),i=await t.metadata(),n=i.width||0,o=i.height||0;if(n===0||o===0)throw new Error("Invalid image dimensions");let{data:a}=await t.grayscale().raw().toBuffer({resolveWithObject:!0}),s=[];for(let r=0;r<o;r++){s[r]=[];for(let l=0;l<n;l++)s[r][l]=a[r*n+l]}return{pixels:s,width:n,height:o}}var Hs,Yt=b(()=>{"use strict";Hs=768});function Bs(e){return e?Jt.has(e):!1}function Gs(e){return ht.has(e)}function Ks(e){return e.filter(t=>ht.has(t.type))}var Jt,ht,Sn,En,qt=b(()=>{"use strict";Jt=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),ht=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),Sn=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],En=500});function js(e,t){return e.length>t?e.slice(0,t)+"...":e}var Zt=b(()=>{"use strict"});var zs,Vs,Qt=b(()=>{"use strict";zs=["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"],Vs={"react-flow__(\\S+)":"$1"}});var Xs,ei,Te,mt=b(()=>{"use strict";Zt();Qt();Xs=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},ei=class extends Xs{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}},Te=class Tn extends Xs{constructor(t,i,n,o,a,s=!1,r=!1,l=!1,d=!1,c=!1,h=!1,m=null,g=null,y=null,v=null,x=[],p=null){super(a,p),this.tagName=t,this.xpath=i,this.attributes=n,this.children=o,this.isInteractive=s,this.isScrollable=r,this.markAsClickable=l,this.isTopElement=d,this.isInViewport=c,this.shadowRoot=h,this.highlightIndex=m,this.viewportCoordinates=g,this.pageCoordinates=y,this.viewportInfo=v,this.isNew=null,this.shadowHostXPaths=x}getAllTextTillNextClickableElement(t=-1){let i=[],n=(o,a)=>{if(!(t!==-1&&a>t)&&!(o instanceof Tn&&o!==this&&o.highlightIndex!==null)){if(o instanceof ei)i.push(o.text);else if(o instanceof Tn)for(let s of o.children)n(s,a+1)}};return n(this,0),i.join(`
|
|
185
|
+
`).trim()}clickableElementsToString(t){let i=t?.includeAttributes??zs,n=t?.includeClassesWithRename??Vs,o=[],a=(s,r)=>{let l=r,d=" ".repeat(r);if(s instanceof Tn){if(s.highlightIndex!==null){l+=1;let c=s.isScrollable?"":s.getAllTextTillNextClickableElement(),h=null;if(i.length>0){let p={};for(let _ of Object.keys(s.attributes))if(i.includes(_)){let k=s.attributes[_].trim();k!==""&&(p[_]=k)}let f=i.filter(_=>_ in p);if(f.length>1){let _=new Set,k={};for(let A of f){let I=p[A];I.length>5&&(I in k?_.add(A):k[I]=A)}for(let A of _)delete p[A]}s.tagName===p.role&&delete p.role;let S=["aria-label","placeholder","title"];for(let _ of S)p[_]&&p[_].trim().toLowerCase()===c.trim().toLowerCase()&&delete p[_];Object.keys(p).length>0&&(h=Object.entries(p).map(([_,k])=>`${_}=${js(k,200)}`).join(" "))}let m=s.isNew?`*[${s.highlightIndex}]`:`[${s.highlightIndex}]`,g=[];if(Object.keys(n).length>0&&s.attributes.class){let p=s.attributes.class.split(/\s+/);for(let f of p)for(let[S,_]of Object.entries(n))try{let k=new RegExp(`^${S}$`);if(f.match(k)){let A=f.replace(k,_);A&&g.push(A);break}}catch{continue}}let y=s.isScrollable?" (SCROLLABLE)":"",v=s.markAsClickable?" (CLICKABLE)":"",x=`${d}${m}${y}${v}<${s.tagName}`;if(g.length>0&&(x+=` ${g.join(" ")}`),h&&(x+=` ${h}`),c){let p=c.trim();h||(x+=" "),x+=`>${p}`}else h||(x+=" ");x+=" />",o.push(x)}else{let c=["data-testid","data-test-id"].filter(h=>s.attributes[h]);c.length>0&&(l+=1,o.push(`${d}<${s.tagName} ${c.map(h=>`${h}="${s.attributes[h]}"`).join(" ")} />`))}for(let c of s.children)a(c,l)}else if(s instanceof ei){if(s.hasParentWithHighlightIndex())return;s.parent&&s.parent.isVisible&&s.parent.isTopElement&&o.push(`${d}${s.text}`)}};return a(this,0),o.join(`
|
|
186
|
+
`)}}});function hm(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var dm,um,we,Ye=b(()=>{"use strict";Yt();qt();mt();W();dm=`(
|
|
187
187
|
args = {
|
|
188
188
|
doHighlightElements: true,
|
|
189
189
|
focusHighlightIndex: -1,
|
|
@@ -1951,7 +1951,7 @@ Based on the above information, please determine if the statement is true.
|
|
|
1951
1951
|
|
|
1952
1952
|
return { rootId, map: DOM_HASH_MAP };
|
|
1953
1953
|
}
|
|
1954
|
-
`,
|
|
1954
|
+
`,um=`((args = {
|
|
1955
1955
|
doHighlightElements: true,
|
|
1956
1956
|
focusHighlightIndex: -1,
|
|
1957
1957
|
viewportExpansion: 0,
|
|
@@ -3999,7 +3999,7 @@ Based on the above information, please determine if the statement is true.
|
|
|
3999
3999
|
// Return element data from boxes phase for use in labels phase
|
|
4000
4000
|
elementData: phase === 'boxes' ? collectedElementData : undefined,
|
|
4001
4001
|
};
|
|
4002
|
-
})`;
|
|
4002
|
+
})`;we=class{normalizeDomain(e){let t=e.trim().toLowerCase();if(!t)return"";try{if(t.includes("://"))return new URL(t).hostname.toLowerCase()}catch{return""}return t.split("/")[0].split(":")[0]}isConfiguredIframeFallbackDomain(e,t){let i;try{i=new URL(e).hostname.toLowerCase()}catch{return!1}for(let n of t){let o=this.normalizeDomain(n);if(o&&(i===o||i.endsWith(`.${o}`)))return!0}return!1}shouldProcessWithPlaywrightFrameFallback(e,t){if(!e.inaccessibleFrame)return!1;let i=e.attributes?.src;return i?i.startsWith("chrome-extension://")?!0:this.isConfiguredIframeFallbackDomain(i,t):!1}constructor(e={}){u.debug("\u{1F333} Initializing DomService with options:",e),this.useDomTreeTs=e.useDomTreeTs??!1,this.domTreeRoot=e.domTreeRoot??"body",this.jsCode=this.useDomTreeTs?um:dm}async getClickableElements(e,t={}){let{highlightElements:i=!0,focusElement:n=-1,viewportExpansion:o=0,interactiveClassNames:a=[],playwrightFrameFallbackDomains:s=[],alwaysHighlightFileInput:r=!1,sameRectIoUThreshold:l,actionIntent:d="all"}=t,[c,h]=await this.buildDomTree(e,i,n,o,a,s,r,l,d);return{elementTree:c,selectorMap:h}}async getClickableElementsWithScreenshot(e,t={}){if(t.useAccessibilityTree)return this.getClickableElementsWithAXTree(e,t);let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let n=await this.getClickableElements(e,t);if(await e.waitForTimeout(100),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]),!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let o=i.toString("base64"),a;if(t.useSlicedScreenshots)try{a=(await da(i,{resize:t.resizeSlicedScreenshots})).map(s=>s.toString("base64"))}catch(s){u.warn("Failed to slice screenshot:",s)}return{domState:n,screenshotBase64:o,screenshot:i,slicedScreenshotsBase64:a}}async getClickableElementsWithAXTree(e,t={}){u.debug("\u{1F333} Using CDP Accessibility Tree for element detection");let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let n=await e.context().newCDPSession(e),{nodes:o}=await n.send("Accessibility.getFullAXTree",{depth:-1});u.debug(`\u{1F4CA} Got ${o.length} AXNodes from accessibility tree`);let a=o.filter(p=>{if(p.ignored)return!1;let f=p.role?.value;return!(!f||!Jt.has(f)||p.properties?.find(S=>S.name==="disabled")?.value?.value||!p.backendDOMNodeId)});u.debug(`\u2705 Found ${a.length} interactive elements from AXTree`);let s=o.filter(p=>p.role?.value==="button");u.debug(`\u{1F518} Total buttons in AXTree: ${s.length}`);for(let p of s){let f=[];p.ignored&&f.push("ignored"),p.backendDOMNodeId||f.push("no-backendDOMNodeId"),p.properties?.find(S=>S.name==="disabled")?.value?.value&&f.push("disabled"),u.debug(` - "${p.name?.value||"(no name)"}" ${f.length>0?`[SKIPPED: ${f.join(", ")}]`:"[INCLUDED]"}`)}let r=new Set(a.map(p=>p.backendDOMNodeId)),l=await this.getElementsWithEventListeners(n,t.eventListenerLimit??500),d=0;for(let p of l)r.has(p.backendNodeId)||(a.push({nodeId:`synthetic-${p.backendNodeId}`,ignored:!1,backendDOMNodeId:p.backendNodeId,role:{type:"role",value:"generic"},name:{type:"string",value:""},properties:[{name:"eventListeners",value:{type:"string",value:p.eventTypes.join(",")}}]}),r.add(p.backendNodeId),d++);u.debug(`\u{1F3AF} Added ${d} elements from event listeners (total: ${a.length})`);let c=await this.resolveAXNodesToDOM(n,a),h=c.filter(p=>p.isVisible&&p.isInViewport&&p.isTopElement&&p.boundingRect),m=c.filter(p=>!(p.isVisible&&p.isInViewport&&p.isTopElement&&p.boundingRect));if(m.length>0){u.debug(`\u{1F6AB} Filtered out ${m.length} elements:`);for(let p of m){let f=[];p.isVisible||f.push("not-visible"),p.isInViewport||f.push("not-in-viewport"),p.isTopElement||f.push("not-top-element"),p.boundingRect||f.push("no-bounding-rect"),u.debug(` - <${p.tagName}> "${p.axNode.name?.value||""}" [${f.join(", ")}]`)}}u.debug(`\u{1F441}\uFE0F ${h.length} elements are visible and in viewport`);let{domState:g,highlightIndex:y}=await this.buildDomStateFromAXTree(h);t.highlightElements!==!1&&y>0&&(await this.renderHighlightsForAXElements(e,h.slice(0,y)),await e.waitForTimeout(100)),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]);try{await n.detach()}catch{}if(!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let v=i.toString("base64"),x;if(t.useSlicedScreenshots)try{x=(await da(i,{resize:t.resizeSlicedScreenshots})).map(p=>p.toString("base64"))}catch(p){u.warn("Failed to slice screenshot:",p)}return{domState:g,screenshotBase64:v,screenshot:i,slicedScreenshotsBase64:x}}async resolveAXNodesToDOM(e,t){let i=[],n=t.map(a=>a.backendDOMNodeId).filter(a=>a!==void 0);if(n.length===0)return i;let o=[];for(let a of n)try{let{object:s}=await e.send("DOM.resolveNode",{backendNodeId:a});o.push(s.objectId||null)}catch{o.push(null)}for(let a=0;a<t.length;a++){let s=t[a],r=o[a];if(r)try{let{result:l}=await e.send("Runtime.callFunctionOn",{objectId:r,functionDeclaration:`function() {
|
|
4003
4003
|
const el = this;
|
|
4004
4004
|
const rect = el.getBoundingClientRect();
|
|
4005
4005
|
const rects = el.getClientRects();
|
|
@@ -4083,36 +4083,36 @@ Based on the above information, please determine if the statement is true.
|
|
|
4083
4083
|
} : null,
|
|
4084
4084
|
clientRects: clientRectsArray
|
|
4085
4085
|
};
|
|
4086
|
-
}`,returnByValue:!0});l.value&&i.push({axNode:r,...l.value})}catch(l){h.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=_n){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),o=vn.join(","),{nodeIds:a}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:o});h.debug(`\u{1F50D} Checking ${Math.min(a.length,t)} elements for event listeners`);for(let r of a.slice(0,t))try{let{object:s}=await e.send("DOM.resolveNode",{nodeId:r});if(!s.objectId)continue;let{listeners:l}=await e.send("DOMDebugger.getEventListeners",{objectId:s.objectId}),d=l.filter(c=>ut.has(c.type));if(d.length>0){let{node:c}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:c.backendNodeId,eventTypes:d.map(u=>u.type)})}await e.send("Runtime.releaseObject",{objectId:s.objectId})}catch{}h.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){h.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new ye("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),n=0;for(let o of e){let a=o.axNode.role?.value||"",r=o.axNode.name?.value||"",s=["button","link","menuitem","tab","switch"].includes(a),l=new ye(o.tagName,o.xpath,o.attributes,[],o.isVisible,!0,a==="scrollbar",s,o.isTopElement,o.isInViewport,!1,n,o.boundingRect?{topLeft:{x:o.boundingRect.x,y:o.boundingRect.y},topRight:{x:o.boundingRect.x+o.boundingRect.width,y:o.boundingRect.y},bottomLeft:{x:o.boundingRect.x,y:o.boundingRect.y+o.boundingRect.height},bottomRight:{x:o.boundingRect.x+o.boundingRect.width,y:o.boundingRect.y+o.boundingRect.height},center:{x:o.boundingRect.x+o.boundingRect.width/2,y:o.boundingRect.y+o.boundingRect.height/2},width:o.boundingRect.width,height:o.boundingRect.height}:null,null,null,[],i);if(r){let d=new qt(r,!0,l);l.children.push(d)}i.children.push(l),t.set(n,l),n++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:n}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:n,colors:o})=>{let a="playwright-highlight-container",r=document.getElementById(a);r||(r=document.createElement("div"),r.id=a,r.style.position="fixed",r.style.pointerEvents="none",r.style.top="0",r.style.left="0",r.style.width="100%",r.style.height="100%",r.style.zIndex="2147483647",r.style.backgroundColor="transparent",document.body.appendChild(r)),n.forEach((s,l)=>{if(!s.boundingRect)return;let d=o[l%o.length],c=s.boundingRect,u=document.createElement("div");u.style.position="fixed",u.style.border=`1px solid ${d}`,u.style.backgroundColor="transparent",u.style.pointerEvents="none",u.style.boxSizing="border-box",u.style.top=`${c.y}px`,u.style.left=`${c.x}px`,u.style.width=`${c.width}px`,u.style.height=`${c.height}px`,r.appendChild(u);let m=document.createElement("div");m.style.position="fixed",m.style.background=d,m.style.color="white",m.style.padding="1px 4px",m.style.borderRadius="4px",m.style.fontSize=l>=100?"8px":"12px",m.textContent=String(l);let g=Math.max(0,c.y-16),w=Math.max(0,Math.min(c.x+c.width-20,window.innerWidth-25));m.style.top=`${g}px`,m.style.left=`${w}px`,r.appendChild(m)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let n=document.getElementById("playwright-highlight-container");n&&n.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(o=>o()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),h.debug("\u2705 Highlights removed from page")}catch(n){h.warn("Failed to remove highlights:",n.message)}for(let n of e.frames()){let o=n.url();if(!(!o.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(o,t)))try{await n.evaluate(i)}catch{}}}async getCrossOriginIframes(e){let t=await e.locator("iframe").filter({hasNot:e.locator(":visible")}).evaluateAll(s=>s.map(l=>l.src)),i=s=>{try{let l=new URL(s);return["doubleclick.net","adroll.com","googletagmanager.com"].some(d=>l.hostname.includes(d))}catch{return!1}},n=e.url(),o=new URL(n).hostname,a=e.frames(),r=[];for(let s of a){let l=s.url();try{let d=new URL(l).hostname;d&&d!==o&&!t.includes(l)&&!i(l)&&r.push(l)}catch{continue}}return r}async buildDomTree(e,t,i,n,o,a,r,s,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(am(e.url()))return[new ye("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let d={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:o,alwaysHighlightFileInput:r,sameRectIoUThreshold:s,actionIntent:l,domTreeRoot:this.domTreeRoot};h.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let c,u=null;if(this.useDomTreeTs&&t)try{let x={...d,phase:"boxes",grayscaleImage:null},p=await e.evaluate(({code:I,argsObj:P})=>new Function("return "+I)()(P),{code:this.jsCode,argsObj:x});h.debug(`\u{1F4E6} Phase 1: Drew ${p.elementData?.length||0} bounding boxes`);let f=await e.screenshot({type:"png",fullPage:!1});h.debug("\u{1F4F8} Captured screenshot with bounding boxes");let S=performance.now(),_=await Rs(f);u=_.pixels;let k=Math.round(performance.now()-S);h.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${_.width}x${_.height}) in ${k}ms`);let E={...d,phase:"labels",grayscaleImage:u,elementData:p.elementData};c=await e.evaluate(({code:I,argsObj:P})=>new Function("return "+I)()(P),{code:this.jsCode,argsObj:E}),c.map=p.map,c.rootId=p.rootId,c.highlightCount=p.highlightCount,c.perfMetrics=p.perfMetrics,h.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(x){h.warn("Two-phase rendering failed, falling back to legacy mode:",x.message),u=null;let p={...d,grayscaleImage:null};c=await e.evaluate(({code:f,argsObj:S})=>new Function("return "+f)()(S),{code:this.jsCode,argsObj:p}),h.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{c=await e.evaluate(({code:x,argsObj:p})=>new Function("return "+x)()(p),{code:this.jsCode,argsObj:d}),h.debug("\u2705 JavaScript DOM analysis completed")}catch(x){throw h.error("Error evaluating JavaScript:",x.message),x}if(!c||typeof c!="object")throw h.error("JavaScript returned invalid result:",c),new Error("JavaScript DOM analysis returned invalid result");if(!c.map||!c.rootId)throw h.error("JavaScript result missing map or rootId:",JSON.stringify(c,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(l!=="all"&&c.highlightCount===0){h.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let x={...d,actionIntent:"all"};c=await e.evaluate(({code:p,argsObj:f})=>new Function("return "+p)()(f),{code:this.jsCode,argsObj:x})}let m=Object.entries(c.map).filter(([,x])=>x.tagName==="iframe");h.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${m.length}`);for(let[x,p]of m){let f=p;h.debug(`\u{1F50D} [ext-iframe] iframe node id=${x} src=${f.attributes?.src} inaccessibleFrame=${f.inaccessibleFrame}`)}let g=e.frames();h.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let x of g)h.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${x.url()}`);let w=[];for(let[x,p]of Object.entries(c.map)){let f=p;this.shouldProcessWithPlaywrightFrameFallback(f,a)&&w.push({nodeId:x,src:f.attributes.src})}if(h.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${w.length}`),w.length>0){h.debug(`\u{1F50C} Found ${w.length} inaccessible iframe(s) for Playwright fallback, processing`);let x=-1;for(let p of Object.values(c.map)){let f=p;f.highlightIndex!=null&&(x=Math.max(x,f.highlightIndex))}h.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${x}`);for(let p=0;p<w.length;p++){let{nodeId:f,src:S}=w[p];h.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${p}]: ${S}`);let _=P=>{try{let L=new URL(P);if(L.protocol==="chrome-extension:"&&L.hostname)return`chrome-extension://${L.hostname}`;let K=L.origin;return K==="null"?null:K}catch{return null}},k=_(S);h.debug(`\u{1F50D} [ext-iframe] iframe src origin=${k??"null"}`);let E=null,I=e.frames().find(P=>{let L=P.url();if(L===S)return E="exact",h.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${L}`),!0;let K=_(L);return h.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${L} origin=${K??"null"} vs srcOrigin=${k??"null"}`),k&&K===k?(E="origin",h.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${L}`),!0):!1});if(!I){h.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${S}`),h.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(P=>P.url()).join(", ")}`);continue}h.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${S} (frame url: ${I.url()})`);try{let P={...d,initialHighlightIndex:x+1,domTreeRoot:"body"};h.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${P.initialHighlightIndex}`);let L=await I.evaluate(({code:V,argsObj:J})=>new Function("return "+V)()(J),{code:this.jsCode,argsObj:P});if(h.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(L?.map??{}).length} rootId=${L?.rootId}`),!L?.map||!L.rootId){h.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let K=Object.values(L.map).filter(V=>V.highlightIndex!=null);h.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${K.length}`);for(let V of K){let J=V;h.debug(`\u{1F50D} [ext-iframe] - <${J.tagName}> highlightIndex=${J.highlightIndex} text="${J.children?.length?"...":""}"`)}for(let V of Object.values(L.map)){let J=V;J.highlightIndex!=null&&(x=Math.max(x,J.highlightIndex))}let X=`ext_${p}_`;for(let[V,J]of Object.entries(L.map)){let ke={...J};ke.children&&(ke.children=ke.children.map(Ke=>`${X}${Ke}`)),c.map[`${X}${V}`]=ke}let _e=c.map[f];_e?(_e.children=[..._e.children||[],`${X}${L.rootId}`],h.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${f}`)):h.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${f} not found in map`),h.debug(`\u2705 Merged fallback iframe content from: ${S}`)}catch(P){h.warn(`Failed to process fallback iframe ${S}:`,P)}}}if(c&&c.perfMetrics){let x=c.perfMetrics.nodeMetrics?.totalNodes??0,p=0;if(c.map)for(let S of Object.values(c.map))typeof S=="object"&&S!==null&&S.isInteractive&&p++;let f=e.url().length>50?e.url().slice(0,50)+"...":e.url();h.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${f} interactive=${p}/${x}`)}h.debug("\u{1F504} Starting TypeScript DOM tree construction...");let v=await this.constructDomTree(c);return h.debug("\u2705 TypeScript DOM tree construction completed"),v}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,o=new Map,a=new Map;for(let[s,l]of Object.entries(t)){let[d,c]=this.parseNode(l);d!==null&&(o.set(s,d),a.set(s,c),d instanceof ye&&d.highlightIndex!==null&&n.set(d.highlightIndex,d))}for(let[s,l]of a){let d=o.get(s);if(d instanceof ye)for(let c of l){let u=o.get(c);u&&(u.parent=d,d.children.push(u))}}let r=o.get(i);if(!r||!(r instanceof ye))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 qt(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 ye(e.tagName,e.xpath,e.attributes||{},[],e.isVisible??!1,e.isInteractive??!1,e.isScrollable??!1,e.markAsClickable??!1,e.isTopElement??!1,e.isInViewport??!1,e.shadowRoot??!1,e.highlightIndex??null,e.viewportCoordinates??null,e.pageCoordinates??null,t,i,null),o=e.children||[];return[n,o]}}});var js,zs,_w,Sn=y(()=>{"use strict";js=require("zod"),zs=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},_w=js.z.object({})});var Vs,En=y(()=>{"use strict";H();C();Vs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.keys;if(!o||typeof o!="string")throw new Error("Missing or invalid keys for send keys on element action");let a=O(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.press(o,{timeout:r}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=Oe(e);if(!t){let o=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(o)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",n=D();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});var rm,Xs,mt,Zt=y(()=>{"use strict";pe();rm=R(require("playwright/test"),1),Xs=R(require("playwright/test"),1),mt={};en(mt,{default:()=>Xs.default});os(mt,rm)});var ra,Ys,Cw,Tn=y(()=>{"use strict";Zt();ra=require("zod"),Ys=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.code;if(!o)throw new Error("Missing code for js_code action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 js_code requires an agent reference");await new Function("page","expect","agent",`
|
|
4086
|
+
}`,returnByValue:!0});l.value&&i.push({axNode:s,...l.value})}catch(l){u.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=En){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),o=Sn.join(","),{nodeIds:a}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:o});u.debug(`\u{1F50D} Checking ${Math.min(a.length,t)} elements for event listeners`);for(let s of a.slice(0,t))try{let{object:r}=await e.send("DOM.resolveNode",{nodeId:s});if(!r.objectId)continue;let{listeners:l}=await e.send("DOMDebugger.getEventListeners",{objectId:r.objectId}),d=l.filter(c=>ht.has(c.type));if(d.length>0){let{node:c}=await e.send("DOM.describeNode",{nodeId:s});i.push({backendNodeId:c.backendNodeId,eventTypes:d.map(h=>h.type)})}await e.send("Runtime.releaseObject",{objectId:r.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 Te("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),n=0;for(let o of e){let a=o.axNode.role?.value||"",s=o.axNode.name?.value||"",r=["button","link","menuitem","tab","switch"].includes(a),l=new Te(o.tagName,o.xpath,o.attributes,[],o.isVisible,!0,a==="scrollbar",r,o.isTopElement,o.isInViewport,!1,n,o.boundingRect?{topLeft:{x:o.boundingRect.x,y:o.boundingRect.y},topRight:{x:o.boundingRect.x+o.boundingRect.width,y:o.boundingRect.y},bottomLeft:{x:o.boundingRect.x,y:o.boundingRect.y+o.boundingRect.height},bottomRight:{x:o.boundingRect.x+o.boundingRect.width,y:o.boundingRect.y+o.boundingRect.height},center:{x:o.boundingRect.x+o.boundingRect.width/2,y:o.boundingRect.y+o.boundingRect.height/2},width:o.boundingRect.width,height:o.boundingRect.height}:null,null,null,[],i);if(s){let d=new ei(s,!0,l);l.children.push(d)}i.children.push(l),t.set(n,l),n++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:n}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:n,colors:o})=>{let a="playwright-highlight-container",s=document.getElementById(a);s||(s=document.createElement("div"),s.id=a,s.style.position="fixed",s.style.pointerEvents="none",s.style.top="0",s.style.left="0",s.style.width="100%",s.style.height="100%",s.style.zIndex="2147483647",s.style.backgroundColor="transparent",document.body.appendChild(s)),n.forEach((r,l)=>{if(!r.boundingRect)return;let d=o[l%o.length],c=r.boundingRect,h=document.createElement("div");h.style.position="fixed",h.style.border=`1px solid ${d}`,h.style.backgroundColor="transparent",h.style.pointerEvents="none",h.style.boxSizing="border-box",h.style.top=`${c.y}px`,h.style.left=`${c.x}px`,h.style.width=`${c.width}px`,h.style.height=`${c.height}px`,s.appendChild(h);let m=document.createElement("div");m.style.position="fixed",m.style.background=d,m.style.color="white",m.style.padding="1px 4px",m.style.borderRadius="4px",m.style.fontSize=l>=100?"8px":"12px",m.textContent=String(l);let g=Math.max(0,c.y-16),y=Math.max(0,Math.min(c.x+c.width-20,window.innerWidth-25));m.style.top=`${g}px`,m.style.left=`${y}px`,s.appendChild(m)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let n=document.getElementById("playwright-highlight-container");n&&n.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(o=>o()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),u.debug("\u2705 Highlights removed from page")}catch(n){u.warn("Failed to remove highlights:",n.message)}for(let n of e.frames()){let o=n.url();if(!(!o.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(o,t)))try{await n.evaluate(i)}catch{}}}async getCrossOriginIframes(e){let t=await e.locator("iframe").filter({hasNot:e.locator(":visible")}).evaluateAll(r=>r.map(l=>l.src)),i=r=>{try{let l=new URL(r);return["doubleclick.net","adroll.com","googletagmanager.com"].some(d=>l.hostname.includes(d))}catch{return!1}},n=e.url(),o=new URL(n).hostname,a=e.frames(),s=[];for(let r of a){let l=r.url();try{let d=new URL(l).hostname;d&&d!==o&&!t.includes(l)&&!i(l)&&s.push(l)}catch{continue}}return s}async buildDomTree(e,t,i,n,o,a,s,r,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(hm(e.url()))return[new Te("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let d={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:o,alwaysHighlightFileInput:s,sameRectIoUThreshold:r,actionIntent:l,domTreeRoot:this.domTreeRoot};u.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let c,h=null;if(this.useDomTreeTs&&t)try{let x={...d,phase:"boxes",grayscaleImage:null},p=await e.evaluate(({code:I,argsObj:O})=>new Function("return "+I)()(O),{code:this.jsCode,argsObj:x});u.debug(`\u{1F4E6} Phase 1: Drew ${p.elementData?.length||0} bounding boxes`);let f=await e.screenshot({type:"png",fullPage:!1});u.debug("\u{1F4F8} Captured screenshot with bounding boxes");let S=performance.now(),_=await Us(f);h=_.pixels;let k=Math.round(performance.now()-S);u.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${_.width}x${_.height}) in ${k}ms`);let A={...d,phase:"labels",grayscaleImage:h,elementData:p.elementData};c=await e.evaluate(({code:I,argsObj:O})=>new Function("return "+I)()(O),{code:this.jsCode,argsObj:A}),c.map=p.map,c.rootId=p.rootId,c.highlightCount=p.highlightCount,c.perfMetrics=p.perfMetrics,u.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(x){u.warn("Two-phase rendering failed, falling back to legacy mode:",x.message),h=null;let p={...d,grayscaleImage:null};c=await e.evaluate(({code:f,argsObj:S})=>new Function("return "+f)()(S),{code:this.jsCode,argsObj:p}),u.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{c=await e.evaluate(({code:x,argsObj:p})=>new Function("return "+x)()(p),{code:this.jsCode,argsObj:d}),u.debug("\u2705 JavaScript DOM analysis completed")}catch(x){throw u.error("Error evaluating JavaScript:",x.message),x}if(!c||typeof c!="object")throw u.error("JavaScript returned invalid result:",c),new Error("JavaScript DOM analysis returned invalid result");if(!c.map||!c.rootId)throw u.error("JavaScript result missing map or rootId:",JSON.stringify(c,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(l!=="all"&&c.highlightCount===0){u.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let x={...d,actionIntent:"all"};c=await e.evaluate(({code:p,argsObj:f})=>new Function("return "+p)()(f),{code:this.jsCode,argsObj:x})}let m=Object.entries(c.map).filter(([,x])=>x.tagName==="iframe");u.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${m.length}`);for(let[x,p]of m){let f=p;u.debug(`\u{1F50D} [ext-iframe] iframe node id=${x} src=${f.attributes?.src} inaccessibleFrame=${f.inaccessibleFrame}`)}let g=e.frames();u.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let x of g)u.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${x.url()}`);let y=[];for(let[x,p]of Object.entries(c.map)){let f=p;this.shouldProcessWithPlaywrightFrameFallback(f,a)&&y.push({nodeId:x,src:f.attributes.src})}if(u.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${y.length}`),y.length>0){u.debug(`\u{1F50C} Found ${y.length} inaccessible iframe(s) for Playwright fallback, processing`);let x=-1;for(let p of Object.values(c.map)){let f=p;f.highlightIndex!=null&&(x=Math.max(x,f.highlightIndex))}u.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${x}`);for(let p=0;p<y.length;p++){let{nodeId:f,src:S}=y[p];u.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${p}]: ${S}`);let _=O=>{try{let C=new URL(O);if(C.protocol==="chrome-extension:"&&C.hostname)return`chrome-extension://${C.hostname}`;let R=C.origin;return R==="null"?null:R}catch{return null}},k=_(S);u.debug(`\u{1F50D} [ext-iframe] iframe src origin=${k??"null"}`);let A=null,I=e.frames().find(O=>{let C=O.url();if(C===S)return A="exact",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${C}`),!0;let R=_(C);return u.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${C} origin=${R??"null"} vs srcOrigin=${k??"null"}`),k&&R===k?(A="origin",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${C}`),!0):!1});if(!I){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(O=>O.url()).join(", ")}`);continue}u.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${S} (frame url: ${I.url()})`);try{let O={...d,initialHighlightIndex:x+1,domTreeRoot:"body"};u.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${O.initialHighlightIndex}`);let C=await I.evaluate(({code:j,argsObj:D})=>new Function("return "+j)()(D),{code:this.jsCode,argsObj:O});if(u.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(C?.map??{}).length} rootId=${C?.rootId}`),!C?.map||!C.rootId){u.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let R=Object.values(C.map).filter(j=>j.highlightIndex!=null);u.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${R.length}`);for(let j of R){let D=j;u.debug(`\u{1F50D} [ext-iframe] - <${D.tagName}> highlightIndex=${D.highlightIndex} text="${D.children?.length?"...":""}"`)}for(let j of Object.values(C.map)){let D=j;D.highlightIndex!=null&&(x=Math.max(x,D.highlightIndex))}let X=`ext_${p}_`;for(let[j,D]of Object.entries(C.map)){let q={...D};q.children&&(q.children=q.children.map(ee=>`${X}${ee}`)),c.map[`${X}${j}`]=q}let ce=c.map[f];ce?(ce.children=[...ce.children||[],`${X}${C.rootId}`],u.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${f}`)):u.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${f} not found in map`),u.debug(`\u2705 Merged fallback iframe content from: ${S}`)}catch(O){u.warn(`Failed to process fallback iframe ${S}:`,O)}}}if(c&&c.perfMetrics){let x=c.perfMetrics.nodeMetrics?.totalNodes??0,p=0;if(c.map)for(let S of Object.values(c.map))typeof S=="object"&&S!==null&&S.isInteractive&&p++;let f=e.url().length>50?e.url().slice(0,50)+"...":e.url();u.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${f} interactive=${p}/${x}`)}u.debug("\u{1F504} Starting TypeScript DOM tree construction...");let v=await this.constructDomTree(c);return u.debug("\u2705 TypeScript DOM tree construction completed"),v}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,o=new Map,a=new Map;for(let[r,l]of Object.entries(t)){let[d,c]=this.parseNode(l);d!==null&&(o.set(r,d),a.set(r,c),d instanceof Te&&d.highlightIndex!==null&&n.set(d.highlightIndex,d))}for(let[r,l]of a){let d=o.get(r);if(d instanceof Te)for(let c of l){let h=o.get(c);h&&(h.parent=d,d.children.push(h))}}let s=o.get(i);if(!s||!(s instanceof Te))throw new Error("Failed to parse HTML to dictionary");return[s,n]}parseNode(e){if(!e)return[null,[]];if(e.type==="TEXT_NODE")return[new ei(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 Te(e.tagName,e.xpath,e.attributes||{},[],e.isVisible??!1,e.isInteractive??!1,e.isScrollable??!1,e.markAsClickable??!1,e.isTopElement??!1,e.isInViewport??!1,e.shadowRoot??!1,e.highlightIndex??null,e.viewportCoordinates??null,e.pageCoordinates??null,t,i,null),o=e.children||[];return[n,o]}}});var Ys,Js,Pw,An=b(()=>{"use strict";Ys=require("zod"),Js=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},Pw=Ys.z.object({})});var qs,Mn=b(()=>{"use strict";U();P();qs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.keys;if(!o||typeof o!="string")throw new Error("Missing or invalid keys for send keys on element action");let a=N(e,t),s=L(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.press(o,{timeout:s}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=Fe(e);if(!t){let o=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(o)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",n=L();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});var mm,Zs,pt,ti=b(()=>{"use strict";ve();mm=H(require("playwright/test"),1),Zs=H(require("playwright/test"),1),pt={};on(pt,{default:()=>Zs.default});ls(pt,mm)});var ua,Qs,Hw,In=b(()=>{"use strict";ti();ua=require("zod"),Qs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.code;if(!o)throw new Error("Missing code for js_code action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 js_code requires an agent reference");await new Function("page","expect","agent",`
|
|
4087
4087
|
return (async () => {
|
|
4088
4088
|
${o}
|
|
4089
4089
|
})();
|
|
4090
|
-
`)(e,
|
|
4091
|
-
`);for(let o of n)i.push(` ${o}`);return i.push("}"),i}},
|
|
4090
|
+
`)(e,pt.expect,a)}transpile(e){let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
|
|
4091
|
+
`);for(let o of n)i.push(` ${o}`);return i.push("}"),i}},Hw=ua.z.object({code:ua.z.string().describe("JavaScript code to execute in the browser context")})});var el,Pn=b(()=>{"use strict";U();P();el=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=N(e,t);if(o){await o.waitFor({state:"attached",timeout:L(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let s=a.x+n.kwargs.relative_x+a.width/2,r=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.move(s,r),await e.waitForTimeout(200),await e.mouse.click(s,r,{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 tl,Cn=b(()=>{"use strict";tl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=this.generateFunctionCallCode(n.kwargs);if(!o)throw new Error("Missing function name for function action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 FunctionAction requires an agent reference");await new Function("page","agent",`
|
|
4092
4092
|
return (async () => {
|
|
4093
4093
|
${o}
|
|
4094
4094
|
})();
|
|
4095
|
-
`)(e,a)}transpile(e){let t=this.generateFunctionCallCode(e.action_data?.kwargs||{});return t?[t.endsWith(";")?t:`${t};`]:["// Skipping function: missing functionName"]}generateFunctionCallCode(e){let t=e.functionName;if(!t)return null;let i;if(Array.isArray(e.args))i=e.args.map(String);else if(Array.isArray(e.parameterNames)){let
|
|
4095
|
+
`)(e,a)}transpile(e){let t=this.generateFunctionCallCode(e.action_data?.kwargs||{});return t?[t.endsWith(";")?t:`${t};`]:["// Skipping function: missing functionName"]}generateFunctionCallCode(e){let t=e.functionName;if(!t)return null;let i;if(Array.isArray(e.args))i=e.args.map(String);else if(Array.isArray(e.parameterNames)){let s=e.parameterValues||[];i=e.parameterNames.map((r,l)=>l<s.length?String(s[l]):"undefined")}else return`await ${t}()`;if(i.length===0)return`await ${t}()`;let n=["page","testContext","request","agent"],o=["undefined","null","true","false"],a=i.map(s=>n.includes(s)||o.includes(s)||/^-?\d+(\.\d+)?$/.test(s)?s:s.startsWith("$")?`agent.agentServices.readVariable('${s.substring(1)}')`:`"${s}"`);return`await ${t}(${a.join(", ")})`}}});var il,$n=b(()=>{"use strict";il=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.code;if(!o)throw new Error("Missing code for js_action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 js_action requires an agent reference");await new Function("page","agent",`
|
|
4096
4096
|
return (async () => {
|
|
4097
4097
|
${o}
|
|
4098
4098
|
})();
|
|
4099
4099
|
`)(e,a)}transpile(e){let t=e.action_data?.kwargs?.code;return t?t.split(`
|
|
4100
|
-
`):["// Skipping js_action: missing code"]}}});var Qs,Pn=y(()=>{"use strict";H();C();Qs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=O(e,t);if(o){await o.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let r=a.x+n.kwargs.relative_x+a.width/2,s=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s),await e.waitForTimeout(500)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(500);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var el,Cn=y(()=>{"use strict";H();C();el=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=O(e,t);if(o){await o.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let r=a.x+n.kwargs.relative_x+a.width/2,s=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.dblclick(r,s,{delay:50}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.dblclick(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("double_click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var tl,$n=y(()=>{"use strict";H();C();tl=class{async execute(e,t,i){let n=i.getActionSettings().drag_drop_steps??10,o=t.action_data;if(!o)throw new Error("Action data not found");let a=o.kwargs,r=[a.coord_source_x,a.coord_source_y],s=[a.coord_target_x,a.coord_target_y];if(typeof a.relative_x=="number"&&typeof a.relative_y=="number"&&typeof a.delta_x=="number"&&typeof a.delta_y=="number"){let l=O(e,t);if(!l)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await l.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let d=await(await l).boundingBox();if(!d)throw new Error("Could not get bounding box for drag_drop element");let c=d.x+a.relative_x+d.width/2,u=d.y+a.relative_y+d.height/2,m=c+a.delta_x,g=u+a.delta_y;await e.mouse.move(c,u),await e.mouse.down(),n>0?await e.mouse.move(m,g,{steps:n}):await e.mouse.move(m,g),await e.mouse.up()}else if(r.every(l=>typeof l=="number")&&s.every(l=>typeof l=="number")){let[l,d]=r,[c,u]=s;await e.mouse.move(l,d),await e.mouse.down(),n>0?await e.mouse.move(c,u,{steps:n}):await e.mouse.move(c,u),await e.mouse.up()}else throw new Error("Missing coordinates for drag_drop action: requires either element-anchored coordinates with delta, or full absolute coordinates");await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return typeof t.relative_x=="number"&&(n.relative_x=t.relative_x),typeof t.relative_y=="number"&&(n.relative_y=t.relative_y),typeof t.delta_x=="number"&&(n.delta_x=t.delta_x),typeof t.delta_y=="number"&&(n.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(n.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(n.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(n.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(n.coord_target_y=t.coord_target_y),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("drag_drop", page, {',...i.map(o=>` ${o},`),"});"]}}});var Ln,il,Dn=y(()=>{"use strict";ht();Ln=require("crypto"),il=class{static convertDomElementToHistoryElement(e){let t=this.getParentBranchPath(e),i=this.generateCssSelector(e);return{tagName:e.tagName,xpath:e.xpath,highlightIndex:e.highlightIndex,entireParentBranchPath:t,attributes:e.attributes,shadowRoot:e.shadowRoot,cssSelector:i,pageCoordinates:e.pageCoordinates,viewportCoordinates:e.viewportCoordinates,viewportInfo:e.viewportInfo}}static findHistoryElementInTree(e,t){let i=this.hashDomHistoryElement(e),n=o=>{if(o.highlightIndex!==null){let a=this.hashDomElement(o);if(this.compareHashes(a,i))return o}for(let a of o.children)if(a instanceof ye){let r=n(a);if(r!==null)return r}return null};return n(t)}static compareHistoryElementAndDomElement(e,t){let i=this.hashDomHistoryElement(e),n=this.hashDomElement(t);return this.compareHashes(i,n)}static hashDomHistoryElement(e){let t=this.parentBranchPathHash(e.entireParentBranchPath),i=this.attributesHash(e.attributes),n=this.xpathHash(e.xpath);return{branchPathHash:t,attributesHash:i,xpathHash:n}}static hashDomElement(e){let t=this.getParentBranchPath(e),i=this.parentBranchPathHash(t),n=this.attributesHash(e.attributes),o=this.xpathHash(e.xpath);return{branchPathHash:i,attributesHash:n,xpathHash:o}}static getParentBranchPath(e){let t=[],i=e;for(;i!==null&&i.parent!==null;)t.push(i),i=i.parent;return t.reverse(),t.map(n=>n.tagName)}static parentBranchPathHash(e){let t=e.join("/");return(0,Ln.createHash)("sha256").update(t).digest("hex")}static attributesHash(e){let t=Object.entries(e).map(([i,n])=>`${i}=${n}`).join("");return(0,Ln.createHash)("sha256").update(t).digest("hex")}static xpathHash(e){return(0,Ln.createHash)("sha256").update(e).digest("hex")}static compareHashes(e,t){return e.branchPathHash===t.branchPathHash&&e.attributesHash===t.attributesHash&&e.xpathHash===t.xpathHash}static generateCssSelector(e){let t=e.attributes.id;if(t)return`#${t}`;let i=e.attributes.class;if(i){let n=i.split(/\s+/).filter(o=>o.trim());if(n.length>0)return`${e.tagName}.${n.join(".")}`}return e.tagName}}});var sa,pt=y(()=>{"use strict";sa=(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))(sa||{})});var gt={};je(gt,{evaluateStatement:()=>Ye,executeAction:()=>Qt,executeStep:()=>Xe,generateActionStep:()=>wt,runTask:()=>Je});var ft=y(()=>{"use strict";ei();xn();bn();Zi();ct();cn();un();at();dn();pn();Bt();Gt();Te();Ot();Ut();Dn();Ve();zt();Xt();ht();Yt();Jt();ie();Ee();Ht();rt();Wt();Ne();j();ze();F();te();pt();H();pe()});var la,nl,Ob,On=y(()=>{"use strict";la=require("zod"),nl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.statement;if(!o)throw new Error("Missing statement for ai_action");let a=n.kwargs.use_pure_vision,{executeStep:r}=await Promise.resolve().then(()=>(ft(),gt)),s=await r(o,e,i,{usePureVision:a});if(s.status!=="success")throw new Error(s.error||"Action execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let n=JSON.stringify(i),o=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${n}, '${t||""}', ${o});`]}},Ob=la.z.object({statement:la.z.string().describe('The action to perform (e.g., "click the submit button")')})});var ca,ol,Fb,Nn=y(()=>{"use strict";ca=require("zod"),ol=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.statement;if(!o)throw new Error("Missing statement for ai_step");let{runTask:a}=await Promise.resolve().then(()=>(ft(),gt)),r=await a(o,e,i);if(r.status!=="success")throw new Error(r.error||"Task execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;return i?[`await agent.run(page, ${JSON.stringify(i)}, '${t||""}');`]:["// Skipping ai_step: missing statement"]}},Fb=ca.z.object({statement:ca.z.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});function rl(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:sm,async execute(i,n){let{timeout_seconds:o=10}=i,{page:a,agentServices:r}=n;try{let s={action_description:`Wait for download to complete (timeout: ${o}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:o}}};return await t.execute(a,s,r),{success:!0,actionEntity:s,message:"Download completed"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:o}},feedback:s.message}}}}})}var da,al,sm,ti=y(()=>{"use strict";da=require("zod"),al=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,o)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},sm=da.z.object({timeout_seconds:da.z.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});function ll(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:lm,async execute(i,n){let{condition:o,timeout_seconds:a=60}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Wait until: ${o}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:o,timeout_seconds:a}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Condition met: ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Wait until: ${o} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:o,timeout_seconds:a}},feedback:l.message}}}}})}var Rn,sl,lm,ii=y(()=>{"use strict";Rn=require("zod"),sl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.condition;if(!o)throw new Error("Missing condition for ai_wait_until");let a=(n.kwargs.timeout_seconds||60)*1e3,r=5e3,s=Date.now(),{evaluateStatement:l}=await Promise.resolve().then(()=>(ft(),gt));for(;Date.now()-s<a;){if((await l(o,e,i,{})).success)return;await e.waitForTimeout(r)}throw new Error(`Timeout waiting for condition: ${o}`)}transpile(e,t){let i=e.action_data?.kwargs?.condition,n=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${n}, '${t}');`]:["// Skipping ai_wait_until: missing condition"]}},lm=Rn.z.object({condition:Rn.z.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:Rn.z.number().positive().optional().describe("Timeout in seconds (default: 60)")})});async function cm(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function cl(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function ul(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:dm,usesElementIndex:!0,async execute(i,n){let{element_index:o,delta_x:a,delta_y:r}=i,{page:s,agentServices:l}=n;try{let d=await U(n,o);if(!d)return{success:!1,error:`Element with index ${o} not found`,actionEntity:cl(`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:r})};let c=await cm("scroll_on_element",`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,d,s,{delta_x:a,delta_y:r});return await t.execute(s,c,l),{success:!0,actionEntity:c,message:`Scrolled on element ${o} horizontally: ${a}px, vertically: ${r}px`}}catch(d){return{success:!1,error:d.message,actionEntity:cl(`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:r})}}}})}var bt,dl,dm,ni=y(()=>{"use strict";j();H();bt=require("zod");C();dl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.delta_x||0,a=n.kwargs.delta_y||0,r=O(e,t),s=D(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:s}),await e.mouse.wheel(o,a);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Oe(e);if(!t){let o=e.action_data?.kwargs?.delta_x||0,a=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${o}, delta_y: ${a} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,n=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${D()} });`,`await page.mouse.wheel(${i}, ${n});`]}};dm=bt.z.object({element_index:bt.z.number().int().describe("Index of the scrollable element"),delta_x:bt.z.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:bt.z.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:bt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function ml(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:um,async execute(i,n){let{text:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Scroll to text "${o}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Scrolled to text "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Scroll to text "${o}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:o}},feedback:l.message}}}}})}var ua,hl,um,oi=y(()=>{"use strict";ua=require("zod"),hl=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();`]}},um=ua.z.object({text:ua.z.string().describe("Text to scroll to on the page")})});async function hm(e,t,i,n){return{...await N(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function pl(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 fl(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:mm,usesElementIndex:!0,async execute(i,n){let{element_index:o,option:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await U(n,o);if(!d)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:pl(l||`Select option in dropdown ${o}`,{index:o,option:a})};let c=await hm(d,r,a,l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Selected option "${a}" in dropdown ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:pl(`Select option in dropdown ${o}`,{index:o,option:a})}}}})}var ai,gl,mm,ri=y(()=>{"use strict";j();H();ai=require("zod");C();gl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.text||n.kwargs.option,a=O(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(a&&o)await a.selectOption(o,{timeout:r});else throw new Error("Missing locator or option label for select_dropdown_option action")}transpile(e){let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("select_dropdown_option", page, {',...i.map(n=>` ${n},`),"});"]}};mm=ai.z.object({element_index:ai.z.number().int().describe("Index of the dropdown/select element"),option:ai.z.string().describe("Option value, label, or index to select"),timeout_ms:ai.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function pm(e,t,i,n){return{...await N(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function ha(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 bl(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">).
|
|
4100
|
+
`):["// Skipping js_action: missing code"]}}});var nl,On=b(()=>{"use strict";U();P();nl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=N(e,t);if(o){await o.waitFor({state:"attached",timeout:L(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let s=a.x+n.kwargs.relative_x+a.width/2,r=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.move(s,r),await e.waitForTimeout(200),await e.mouse.click(s,r),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 ol,Ln=b(()=>{"use strict";U();P();ol=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=N(e,t);if(o){await o.waitFor({state:"attached",timeout:L(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let s=a.x+n.kwargs.relative_x+a.width/2,r=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.dblclick(s,r,{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 al,Dn=b(()=>{"use strict";U();P();al=class{async execute(e,t,i){let n=i.getActionSettings().drag_drop_steps??10,o=t.action_data;if(!o)throw new Error("Action data not found");let a=o.kwargs,s=[a.coord_source_x,a.coord_source_y],r=[a.coord_target_x,a.coord_target_y];if(typeof a.relative_x=="number"&&typeof a.relative_y=="number"&&typeof a.delta_x=="number"&&typeof a.delta_y=="number"){let l=N(e,t);if(!l)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await l.waitFor({state:"attached",timeout:L(i,t.action_data?.kwargs?.timeout_ms)});let d=await(await l).boundingBox();if(!d)throw new Error("Could not get bounding box for drag_drop element");let c=d.x+a.relative_x+d.width/2,h=d.y+a.relative_y+d.height/2,m=c+a.delta_x,g=h+a.delta_y;await e.mouse.move(c,h),await e.mouse.down(),n>0?await e.mouse.move(m,g,{steps:n}):await e.mouse.move(m,g),await e.mouse.up()}else if(s.every(l=>typeof l=="number")&&r.every(l=>typeof l=="number")){let[l,d]=s,[c,h]=r;await e.mouse.move(l,d),await e.mouse.down(),n>0?await e.mouse.move(c,h,{steps:n}):await e.mouse.move(c,h),await e.mouse.up()}else throw new Error("Missing coordinates for drag_drop action: requires either element-anchored coordinates with delta, or full absolute coordinates");await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return typeof t.relative_x=="number"&&(n.relative_x=t.relative_x),typeof t.relative_y=="number"&&(n.relative_y=t.relative_y),typeof t.delta_x=="number"&&(n.delta_x=t.delta_x),typeof t.delta_y=="number"&&(n.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(n.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(n.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(n.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(n.coord_target_y=t.coord_target_y),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("drag_drop", page, {',...i.map(o=>` ${o},`),"});"]}}});var Nn,rl,Rn=b(()=>{"use strict";mt();Nn=require("crypto"),rl=class{static convertDomElementToHistoryElement(e){let t=this.getParentBranchPath(e),i=this.generateCssSelector(e);return{tagName:e.tagName,xpath:e.xpath,highlightIndex:e.highlightIndex,entireParentBranchPath:t,attributes:e.attributes,shadowRoot:e.shadowRoot,cssSelector:i,pageCoordinates:e.pageCoordinates,viewportCoordinates:e.viewportCoordinates,viewportInfo:e.viewportInfo}}static findHistoryElementInTree(e,t){let i=this.hashDomHistoryElement(e),n=o=>{if(o.highlightIndex!==null){let a=this.hashDomElement(o);if(this.compareHashes(a,i))return o}for(let a of o.children)if(a instanceof Te){let s=n(a);if(s!==null)return s}return null};return n(t)}static compareHistoryElementAndDomElement(e,t){let i=this.hashDomHistoryElement(e),n=this.hashDomElement(t);return this.compareHashes(i,n)}static hashDomHistoryElement(e){let t=this.parentBranchPathHash(e.entireParentBranchPath),i=this.attributesHash(e.attributes),n=this.xpathHash(e.xpath);return{branchPathHash:t,attributesHash:i,xpathHash:n}}static hashDomElement(e){let t=this.getParentBranchPath(e),i=this.parentBranchPathHash(t),n=this.attributesHash(e.attributes),o=this.xpathHash(e.xpath);return{branchPathHash:i,attributesHash:n,xpathHash:o}}static getParentBranchPath(e){let t=[],i=e;for(;i!==null&&i.parent!==null;)t.push(i),i=i.parent;return t.reverse(),t.map(n=>n.tagName)}static parentBranchPathHash(e){let t=e.join("/");return(0,Nn.createHash)("sha256").update(t).digest("hex")}static attributesHash(e){let t=Object.entries(e).map(([i,n])=>`${i}=${n}`).join("");return(0,Nn.createHash)("sha256").update(t).digest("hex")}static xpathHash(e){return(0,Nn.createHash)("sha256").update(e).digest("hex")}static compareHashes(e,t){return e.branchPathHash===t.branchPathHash&&e.attributesHash===t.attributesHash&&e.xpathHash===t.xpathHash}static generateCssSelector(e){let t=e.attributes.id;if(t)return`#${t}`;let i=e.attributes.class;if(i){let n=i.split(/\s+/).filter(o=>o.trim());if(n.length>0)return`${e.tagName}.${n.join(".")}`}return e.tagName}}});var ha,gt=b(()=>{"use strict";ha=(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))(ha||{})});var ft={};Ve(ft,{evaluateStatement:()=>qe,executeAction:()=>ii,executeStep:()=>Je,generateActionStep:()=>bt,runTask:()=>Ze});var wt=b(()=>{"use strict";ni();kn();vn();tn();dt();hn();pn();rt();mn();wn();jt();zt();$e();Ft();Kt();Rn();Ye();Yt();qt();mt();Zt();Qt();ae();Ce();Bt();st();Gt();He();Y();Xe();W();oe();gt();U();ve()});var ma,sl,Gb,Fn=b(()=>{"use strict";ma=require("zod"),sl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.statement;if(!o)throw new Error("Missing statement for ai_action");let a=n.kwargs.use_pure_vision,{executeStep:s}=await Promise.resolve().then(()=>(wt(),ft)),r=await s(o,e,i,{usePureVision:a});if(r.status!=="success")throw new Error(r.error||"Action execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let n=JSON.stringify(i),o=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${n}, '${t||""}', ${o});`]}},Gb=ma.z.object({statement:ma.z.string().describe('The action to perform (e.g., "click the submit button")')})});var pa,ll,zb,Hn=b(()=>{"use strict";pa=require("zod"),ll=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.statement;if(!o)throw new Error("Missing statement for ai_step");let{runTask:a}=await Promise.resolve().then(()=>(wt(),ft)),s=await a(o,e,i);if(s.status!=="success")throw new Error(s.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"]}},zb=pa.z.object({statement:pa.z.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});function dl(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:pm,async execute(i,n){let{timeout_seconds:o=10}=i,{page:a,agentServices:s}=n;try{let r={action_description:`Wait for download to complete (timeout: ${o}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:o}}};return await t.execute(a,r,s),{success:!0,actionEntity:r,message:"Download completed"}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:o}},feedback:r.message}}}}})}var ga,cl,pm,oi=b(()=>{"use strict";ga=require("zod"),cl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,o)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},pm=ga.z.object({timeout_seconds:ga.z.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});function hl(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:gm,async execute(i,n){let{condition:o,timeout_seconds:a=60}=i,{page:s,agentServices:r}=n;try{let l={action_description:`Wait until: ${o}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:o,timeout_seconds:a}}};return await t.execute(s,l,r),{success:!0,actionEntity:l,message:`Condition met: ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Wait until: ${o} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:o,timeout_seconds:a}},feedback:l.message}}}}})}var Wn,ul,gm,ai=b(()=>{"use strict";Wn=require("zod"),ul=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.condition;if(!o)throw new Error("Missing condition for ai_wait_until");let a=(n.kwargs.timeout_seconds||60)*1e3,s=5e3,r=Date.now(),{evaluateStatement:l}=await Promise.resolve().then(()=>(wt(),ft));for(;Date.now()-r<a;){if((await l(o,e,i,{})).success)return;await e.waitForTimeout(s)}throw new Error(`Timeout waiting for condition: ${o}`)}transpile(e,t){let i=e.action_data?.kwargs?.condition,n=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${n}, '${t}');`]:["// Skipping ai_wait_until: missing condition"]}},gm=Wn.z.object({condition:Wn.z.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:Wn.z.number().positive().optional().describe("Timeout in seconds (default: 60)")})});async function fm(e,t,i,n,o={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function ml(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function gl(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:wm,usesElementIndex:!0,async execute(i,n){let{element_index:o,delta_x:a,delta_y:s}=i,{page:r,agentServices:l}=n;try{let d=await K(n,o);if(!d)return{success:!1,error:`Element with index ${o} not found`,actionEntity:ml(`Scroll on element ${o} horizontally: ${a}px, vertically: ${s}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:s})};let c=await fm("scroll_on_element",`Scroll on element ${o} horizontally: ${a}px, vertically: ${s}px`,d,r,{delta_x:a,delta_y:s});return await t.execute(r,c,l),{success:!0,actionEntity:c,message:`Scrolled on element ${o} horizontally: ${a}px, vertically: ${s}px`}}catch(d){return{success:!1,error:d.message,actionEntity:ml(`Scroll on element ${o} horizontally: ${a}px, vertically: ${s}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:s})}}}})}var yt,pl,wm,ri=b(()=>{"use strict";Y();U();yt=require("zod");P();pl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.delta_x||0,a=n.kwargs.delta_y||0,s=N(e,t),r=L(i,t.action_data?.kwargs?.timeout_ms);if(s)await s.hover({timeout:r}),await e.mouse.wheel(o,a);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Fe(e);if(!t){let o=e.action_data?.kwargs?.delta_x||0,a=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${o}, delta_y: ${a} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,n=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${L()} });`,`await page.mouse.wheel(${i}, ${n});`]}};wm=yt.z.object({element_index:yt.z.number().int().describe("Index of the scrollable element"),delta_x:yt.z.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:yt.z.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:yt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function wl(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:bm,async execute(i,n){let{text:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l={action_description:r||`Scroll to text "${o}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:o}}};return await t.execute(a,l,s),{success:!0,actionEntity:l,message:`Scrolled to text "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||`Scroll to text "${o}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:o}},feedback:l.message}}}}})}var fa,fl,bm,si=b(()=>{"use strict";fa=require("zod"),fl=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();`]}},bm=fa.z.object({text:fa.z.string().describe("Text to scroll to on the page")})});async function ym(e,t,i,n){return{...await F(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function bl(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 xl(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:xm,usesElementIndex:!0,async execute(i,n){let{element_index:o,option:a}=i,{page:s,agentServices:r,actionDescription:l}=n;try{let d=await K(n,o);if(!d)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:bl(l||`Select option in dropdown ${o}`,{index:o,option:a})};let c=await ym(d,s,a,l);return await t.execute(s,c,r),{success:!0,actionEntity:c,message:`Selected option "${a}" in dropdown ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:bl(`Select option in dropdown ${o}`,{index:o,option:a})}}}})}var li,yl,xm,ci=b(()=>{"use strict";Y();U();li=require("zod");P();yl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.text||n.kwargs.option,a=N(e,t),s=L(i,t.action_data?.kwargs?.timeout_ms);if(a&&o)await a.selectOption(o,{timeout:s});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},`),"});"]}};xm=li.z.object({element_index:li.z.number().int().describe("Index of the dropdown/select element"),option:li.z.string().describe("Option value, label, or index to select"),timeout_ms:li.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function vm(e,t,i,n){return{...await F(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function wa(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 _l(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">).
|
|
4101
4101
|
|
|
4102
4102
|
IMPORTANT: ONLY use this action for input elements that have type="date" attribute (native HTML date picker).
|
|
4103
4103
|
Do NOT use it for custom/non-native date pickers
|
|
4104
4104
|
|
|
4105
|
-
The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:gm,usesElementIndex:!0,async execute(i,n){let{element_index:o,date:a}=i,{page:r,agentServices:s}=n;try{let l=await U(n,o);if(!l)return{success:!1,error:`Date picker element with index ${o} not found`,actionEntity:ha(`Set date to ${a} on element ${o}`,{index:o,date:a})};let d=l.attributes.type;if(d!=="date")return{success:!1,error:`Element ${o} is not a native date picker (type="${d}"). This action only works with <input type="date">.`,actionEntity:ha(`Set date to ${a} on element ${o}`,{index:o,date:a})};let c=await pm(`Set date to ${a} on element ${o}`,l,r,a);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Set date to ${a} on element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:ha(`Set date to ${a} on element ${o}`,{index:o,date:a})}}}})}var si,wl,gm,li=y(()=>{"use strict";j();H();si=require("zod");C();wl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.date;if(!o)throw new Error("Date value is required");if(!/^\d{4}-\d{2}-\d{2}$/.test(o))throw new Error(`Invalid date format: ${o}. Expected format: YYYY-MM-DD (e.g., 2024-03-15)`);let a=i.replaceVariables(String(o)),r=O(e,t);if(r){let s=await r.getAttribute("type").catch(()=>null);if(s&&s!=="date")throw new Error(`Element is not a native date picker (type="${s}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await r.fill(a,{timeout:D(i,t.action_data?.kwargs?.timeout_ms)})}else throw new Error("No locator found for set_date_for_native_date_picker action")}transpile(e){let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(n=>` ${n},`),"});"]}};gm=si.z.object({element_index:si.z.number().int().describe("Index of the native date picker input element"),date:si.z.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:si.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function xl(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:fm,async execute(i,n){let o=i.tab_index,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Switch to tab ${o}`,action_data:{action_name:"switch_tab",kwargs:{page_id:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Switched to tab ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Switch to tab ${o}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:o}},feedback:l.message}}}}})}var ma,yl,fm,ci=y(()=>{"use strict";ma=require("zod"),yl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.page_id??n.kwargs.tab_index??0;if(typeof o=="number"){let a=e.context().pages(),r=o===-1?a.length-1:o;if(i){let s=await i.switchTab(r);await s.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await s.waitForTimeout(500)}}else throw new Error("Missing page_id for switch_tab action")}transpile(e){return['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]}},fm=ma.z.object({tab_index:ma.z.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});async function kl(e,t,i,n,o,a){let r=Array.isArray(t)?t:[t];if(r.length===0)throw new Error("No file paths provided for upload");let s=r.map(c=>{if(c.startsWith("/")||c.match(/^[A-Za-z]:\\/))return c;let u=n.testDataDir||process.cwd();return _l.default.join(u,c)});h.info(`Uploading files: ${s.join(", ")}`);let l=i.timeout||2e4,d={useFileInput:i.useFileInput||!1,timeout:l};if(i.selector&&typeof i.selector!="string"){let c=i.selector;await Fn(e,c,s,d);return}if(i.selector&&typeof i.selector=="string"){let c=i.selector,u=(c.startsWith("xpath="),e.locator(c));await Fn(e,u,s,d);return}if(o){let c=r.map(m=>`"${m}"`).join(", "),u="";i.targetDescription?u=`Upload ${c} to ${i.targetDescription}`:u=`Upload ${c}`,h.info(`Using AI to handle file upload: ${u}`),await o(e,u,a)}else throw new Error("No selector provided and AI action execution is not available")}async function Fn(e,t,i,n){let{useFileInput:o,timeout:a,mockShowOpenFilePicker:r}=n;if(r){h.info("Using mockShowOpenFilePicker approach");let s=i.map(l=>({path:l,buffer:new Uint8Array(vl.default.readFileSync(l))}));await e.evaluate(l=>{window.__pw_showOpenFilePicker_mock_files=l},s),await t.click({timeout:a}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(o)h.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:a}),await e.waitForTimeout(3e3);else{h.info("Using file chooser approach");let s=e.waitForEvent("filechooser",{timeout:a});s.catch(()=>{}),await t.click({timeout:a}),await(await s).setFiles(i),await e.waitForTimeout(3e3)}h.info(`Successfully uploaded ${i.length} file(s)`)}var vl,_l,di=y(()=>{"use strict";F();vl=R(require("fs"),1),_l=R(require("path"),1)});async function wm(e,t,i={},n){return{...await N(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function Sl(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 Tl(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:bm,usesElementIndex:!0,async execute(i,n){let{element_index:o,paths:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await U(n,o);if(!d)return{success:!1,error:`File input element with index ${o} not found`,actionEntity:Sl(l||`Upload file to element ${o}`,{index:o,paths:a})};let c=await wm(d,r,{paths:a},l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Uploaded file to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:Sl(l||`Upload file to element ${o}`,{index:o,paths:a})}}}})}var Ae,El,bm,hy,ui=y(()=>{"use strict";di();j();H();Ae=require("zod");C();El=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=[];if(n.kwargs.paths?o=Array.isArray(n.kwargs.paths)?n.kwargs.paths:[n.kwargs.paths]:n.kwargs.path&&(o=Array.isArray(n.kwargs.path)?n.kwargs.path:[n.kwargs.path]),o.length===0)throw new Error("No file paths provided for upload_file action");await i.downloadTestDataFiles(o);let a=o.map(d=>i.getTestDataFilePath(d)),r=O(e,t);if(!r)throw new Error("Missing locator for upload_file action");let s=n.kwargs.use_file_input||!1,l=i.getActionSettings().mock_show_open_file_picker??!1;await Fn(e,r,a,{useFileInput:s,timeout:D(i,t.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:l})}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return t.paths?n.paths=t.paths:t.path&&(n.path=t.path),t.use_file_input&&(n.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...i.map(o=>` ${o},`),"});"]}};bm=Ae.z.object({element_index:Ae.z.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:Ae.z.string().describe("Paths to the files to upload"),timeout_ms:Ae.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});hy=Ae.z.object({element_index:Ae.z.number().int().describe("Index of the file input element"),paths:Ae.z.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:Ae.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Ml(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:ym,async execute(i,n){let{seconds:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Wait ${o} seconds`,action_data:{action_name:"wait",kwargs:{seconds:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Waited ${o} seconds`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Wait ${o} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:o}},feedback:l.message}}}}})}var pa,Al,ym,hi=y(()=>{"use strict";pa=require("zod"),Al=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});`]}},ym=pa.z.object({seconds:pa.z.number().positive().describe("Number of seconds to wait")})});function Il(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:xm,async execute(i,n){let{keys:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Press keys "${o}"`,action_data:{action_name:"press",kwargs:{keys:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Pressed keys "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Press keys "${o}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:o}},feedback:l.message}}}}})}var ga,fa,xm,mi=y(()=>{"use strict";ga=require("zod"),fa=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)});`]}},xm=ga.z.object({keys:ga.z.string().describe("A single key or key combination to press (e.g. Escape, Backspace, Insert, PageDown, Delete, Tab, Enter). Key combinations like `Control+o`, `Control+Shift+T`, `ControlOrMeta+a` are supported. Note: This does NOT support sequences - to press multiple keys in sequence (e.g., Control+A then Backspace), call this action multiple times.")})});function $l(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:vm,async execute(i,n){let{page:o,agentServices:a}=n;try{let r={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await t.execute(o,r,a),{success:!0,actionEntity:r,message:`Reloaded ${o.url()}`}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Reload page (failed)",action_data:{action_name:"reload_page",kwargs:{}},feedback:r.message}}}}})}var Pl,Cl,vm,pi=y(()=>{"use strict";H();Pl=require("zod");C();Cl=class{async execute(e,t){await e.reload({timeout:ge}),await e.waitForLoadState("load",{timeout:ge}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},vm=Pl.z.object({})});async function _m(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Ll(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Dl(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:km,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await U(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:Ll(`Right-click element ${o}`,"right_click",{index:o})};let d=s||`Right-click element ${o}`,c=await _m("right_click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Right-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Ll(`Right-click element ${o}`,"right_click",{index:o})}}}})}var Hn,wa,km,gi=y(()=>{"use strict";j();H();Hn=require("zod");C();wa=class{async execute(e,t,i){let n=O(e,t),o=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({button:"right",timeout:o});else throw new Error("No locator found for right_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("right_click", page, {});']:['await agent.execAction("right_click", page, {',...t.map(i=>` ${i},`),"});"]}};km=Hn.z.object({element_index:Hn.z.number().int().describe("Index of the element to right-click"),timeout_ms:Hn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Nl(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:Sm,async execute(i,n){let{name:o,value:a}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Save variable "${o}" = "${a}"`,action_data:{action_name:"save_variable",kwargs:{name:o,value:a}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Saved variable "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Save variable "${o}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:o,value:a}},feedback:l.message}}}}})}var Wn,Ol,Sm,fi=y(()=>{"use strict";Wn=require("zod"),Ol=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.name,a=n.kwargs.value;if(!o||a===void 0)throw new Error("Missing variable name or value for save_variable");o.startsWith("$")&&(o=o.slice(1)),i.saveVariable(o,a)}transpile(e){let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]}},Sm=Wn.z.object({name:Wn.z.string().describe("Variable name to save"),value:Wn.z.string().describe("Value to save in the variable")})});async function Em(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function Tm(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function Rl(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:Am,async execute(i,n){let{down:o,num_pages:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=l||`Scroll ${o?"down":"up"} ${a} page(s)`,c=await Em("scroll",d,{down:o,num_pages:a});return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Scrolled ${o?"down":"up"} ${a} page(s)`}}catch(d){return{success:!1,error:d.message,actionEntity:Tm(l||`Scroll ${o?"down":"up"} ${a} page(s)`,"scroll",{down:o,num_pages:a})}}}})}var Un,wi,Am,bi=y(()=>{"use strict";Un=require("zod"),wi=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.down??!0,o=i.kwargs.num_pages??1,a=n?1:-1;await e.evaluate(`window.scrollBy(0, window.innerHeight * ${o} * ${a})`)}transpile(e){let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]}};Am=Un.z.object({down:Un.z.boolean().describe("True to scroll down, False to scroll up"),num_pages:Un.z.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});function Hl(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:Mm,async execute(i,n){let{otp_secret_key:o}=i,{page:a,agentServices:r}=n;try{let s={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:o}}};return await t.execute(a,s,r),{success:!0,actionEntity:s,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:o}},feedback:s.message}}}}})}var ba,Fl,Mm,yi=y(()=>{"use strict";ba=require("zod"),Fl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.otp_secret_key;if(!o)throw new Error("Missing otp_secret_key for generate_2fa_code");let a=i.replaceVariables(String(o)),r=await i.generate2faCode(a);i.saveVariable("otp_code",r)}transpile(e){let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]}},Mm=ba.z.object({otp_secret_key:ba.z.string().describe("The OTP secret key to generate the 2FA code from")})});async function Im(e,t,i){return{...await N(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function Wl(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 Bl(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:Pm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await U(n,o);if(!l)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:Wl(s||`Get options from dropdown ${o}`,{index:o})};let d=await Im(l,a,s);return await t.execute(a,d,r),{success:!0,actionEntity:d,message:d.feedback||"No options found"}}catch(l){return{success:!1,error:l.message,actionEntity:Wl(s||`Get options from dropdown ${o}`,{index:o})}}}})}var ya,Ul,Pm,xi=y(()=>{"use strict";j();ya=require("zod"),Ul=class{async execute(e,t,i){if(!t.xpath)throw new Error("XPath not found in action entity");let n=[];for(let o of e.frames())try{let a=await o.evaluate(r=>{let s=document.evaluate(r,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return s?{options:Array.from(s.options).map(l=>({text:l.text,value:l.value,index:l.index})),id:s.id,name:s.name}:null},t.xpath);if(a){let r=[];for(let s of a.options){let l=JSON.stringify(s.text);r.push(`${s.index}: text=${l}`)}n.push(...r)}}catch{}if(n.length>0){let o=n.join(`
|
|
4105
|
+
The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:_m,usesElementIndex:!0,async execute(i,n){let{element_index:o,date:a}=i,{page:s,agentServices:r}=n;try{let l=await K(n,o);if(!l)return{success:!1,error:`Date picker element with index ${o} not found`,actionEntity:wa(`Set date to ${a} on element ${o}`,{index:o,date:a})};let d=l.attributes.type;if(d!=="date")return{success:!1,error:`Element ${o} is not a native date picker (type="${d}"). This action only works with <input type="date">.`,actionEntity:wa(`Set date to ${a} on element ${o}`,{index:o,date:a})};let c=await vm(`Set date to ${a} on element ${o}`,l,s,a);return await t.execute(s,c,r),{success:!0,actionEntity:c,message:`Set date to ${a} on element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:wa(`Set date to ${a} on element ${o}`,{index:o,date:a})}}}})}var di,vl,_m,ui=b(()=>{"use strict";Y();U();di=require("zod");P();vl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.date;if(!o)throw new Error("Date value is required");if(!/^\d{4}-\d{2}-\d{2}$/.test(o))throw new Error(`Invalid date format: ${o}. Expected format: YYYY-MM-DD (e.g., 2024-03-15)`);let a=i.replaceVariables(String(o)),s=N(e,t);if(s){let r=await s.getAttribute("type").catch(()=>null);if(r&&r!=="date")throw new Error(`Element is not a native date picker (type="${r}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await s.fill(a,{timeout:L(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},`),"});"]}};_m=di.z.object({element_index:di.z.number().int().describe("Index of the native date picker input element"),date:di.z.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:di.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Sl(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:km,async execute(i,n){let o=i.tab_index,{page:a,agentServices:s,actionDescription:r}=n;try{let l={action_description:r||`Switch to tab ${o}`,action_data:{action_name:"switch_tab",kwargs:{page_id:o}}};return await t.execute(a,l,s),{success:!0,actionEntity:l,message:`Switched to tab ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||`Switch to tab ${o}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:o}},feedback:l.message}}}}})}var ba,kl,km,hi=b(()=>{"use strict";ba=require("zod"),kl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.page_id??n.kwargs.tab_index??0;if(typeof o=="number"){let a=e.context().pages(),s=o===-1?a.length-1:o;if(i){let r=await i.switchTab(s);await r.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await r.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} } },`,"});"]}},km=ba.z.object({tab_index:ba.z.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});async function Al(e,t,i,n,o,a){let s=Array.isArray(t)?t:[t];if(s.length===0)throw new Error("No file paths provided for upload");let r=s.map(c=>{if(c.startsWith("/")||c.match(/^[A-Za-z]:\\/))return c;let h=n.testDataDir||process.cwd();return Tl.default.join(h,c)});u.info(`Uploading files: ${r.join(", ")}`);let l=i.timeout||2e4,d={useFileInput:i.useFileInput||!1,timeout:l};if(i.selector&&typeof i.selector!="string"){let c=i.selector;await Un(e,c,r,d);return}if(i.selector&&typeof i.selector=="string"){let c=i.selector,h=(c.startsWith("xpath="),e.locator(c));await Un(e,h,r,d);return}if(o){let c=s.map(m=>`"${m}"`).join(", "),h="";i.targetDescription?h=`Upload ${c} to ${i.targetDescription}`:h=`Upload ${c}`,u.info(`Using AI to handle file upload: ${h}`),await o(e,h,a)}else throw new Error("No selector provided and AI action execution is not available")}async function Un(e,t,i,n){let{useFileInput:o,timeout:a,mockShowOpenFilePicker:s}=n;if(s){u.info("Using mockShowOpenFilePicker approach");let r=i.map(l=>({path:l,buffer:new Uint8Array(El.default.readFileSync(l))}));await e.evaluate(l=>{window.__pw_showOpenFilePicker_mock_files=l},r),await t.click({timeout:a}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(o)u.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:a}),await e.waitForTimeout(3e3);else{u.info("Using file chooser approach");let r=e.waitForEvent("filechooser",{timeout:a});r.catch(()=>{}),await t.click({timeout:a}),await(await r).setFiles(i),await e.waitForTimeout(3e3)}u.info(`Successfully uploaded ${i.length} file(s)`)}var El,Tl,mi=b(()=>{"use strict";W();El=H(require("fs"),1),Tl=H(require("path"),1)});async function Sm(e,t,i={},n){return{...await F(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function Ml(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 Pl(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:Em,usesElementIndex:!0,async execute(i,n){let{element_index:o,paths:a}=i,{page:s,agentServices:r,actionDescription:l}=n;try{let d=await K(n,o);if(!d)return{success:!1,error:`File input element with index ${o} not found`,actionEntity:Ml(l||`Upload file to element ${o}`,{index:o,paths:a})};let c=await Sm(d,s,{paths:a},l);return await t.execute(s,c,r),{success:!0,actionEntity:c,message:`Uploaded file to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:Ml(l||`Upload file to element ${o}`,{index:o,paths:a})}}}})}var Oe,Il,Em,xy,pi=b(()=>{"use strict";mi();Y();U();Oe=require("zod");P();Il=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=[];if(n.kwargs.paths?o=Array.isArray(n.kwargs.paths)?n.kwargs.paths:[n.kwargs.paths]:n.kwargs.path&&(o=Array.isArray(n.kwargs.path)?n.kwargs.path:[n.kwargs.path]),o.length===0)throw new Error("No file paths provided for upload_file action");await i.downloadTestDataFiles(o);let a=o.map(d=>i.getTestDataFilePath(d)),s=N(e,t);if(!s)throw new Error("Missing locator for upload_file action");let r=n.kwargs.use_file_input||!1,l=i.getActionSettings().mock_show_open_file_picker??!1;await Un(e,s,a,{useFileInput:r,timeout:L(i,t.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:l})}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return t.paths?n.paths=t.paths:t.path&&(n.path=t.path),t.use_file_input&&(n.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...i.map(o=>` ${o},`),"});"]}};Em=Oe.z.object({element_index:Oe.z.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:Oe.z.string().describe("Paths to the files to upload"),timeout_ms:Oe.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});xy=Oe.z.object({element_index:Oe.z.number().int().describe("Index of the file input element"),paths:Oe.z.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:Oe.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function $l(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:Tm,async execute(i,n){let{seconds:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l={action_description:r||`Wait ${o} seconds`,action_data:{action_name:"wait",kwargs:{seconds:o}}};return await t.execute(a,l,s),{success:!0,actionEntity:l,message:`Waited ${o} seconds`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||`Wait ${o} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:o}},feedback:l.message}}}}})}var ya,Cl,Tm,gi=b(()=>{"use strict";ya=require("zod"),Cl=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.seconds||1;await e.waitForTimeout(n*1e3)}transpile(e){return[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]}},Tm=ya.z.object({seconds:ya.z.number().positive().describe("Number of seconds to wait")})});function Ol(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:Am,async execute(i,n){let{keys:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l={action_description:r||`Press keys "${o}"`,action_data:{action_name:"press",kwargs:{keys:o}}};return await t.execute(a,l,s),{success:!0,actionEntity:l,message:`Pressed keys "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||`Press keys "${o}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:o}},feedback:l.message}}}}})}var xa,va,Am,fi=b(()=>{"use strict";xa=require("zod"),va=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)});`]}},Am=xa.z.object({keys:xa.z.string().describe("A single key or key combination to press (e.g. Escape, Backspace, Insert, PageDown, Delete, Tab, Enter). Key combinations like `Control+o`, `Control+Shift+T`, `ControlOrMeta+a` are supported. Note: This does NOT support sequences - to press multiple keys in sequence (e.g., Control+A then Backspace), call this action multiple times.")})});function Nl(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:Mm,async execute(i,n){let{page:o,agentServices:a}=n;try{let s={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await t.execute(o,s,a),{success:!0,actionEntity:s,message:`Reloaded ${o.url()}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Reload page (failed)",action_data:{action_name:"reload_page",kwargs:{}},feedback:s.message}}}}})}var Ll,Dl,Mm,wi=b(()=>{"use strict";U();Ll=require("zod");P();Dl=class{async execute(e,t){await e.reload({timeout:_e}),await e.waitForLoadState("load",{timeout:_e}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},Mm=Ll.z.object({})});async function Im(e,t,i,n,o={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Rl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Fl(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:Pm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await K(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:Rl(`Right-click element ${o}`,"right_click",{index:o})};let d=r||`Right-click element ${o}`,c=await Im("right_click",d,l,a);return await t.execute(a,c,s),{success:!0,actionEntity:c,message:`Right-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Rl(`Right-click element ${o}`,"right_click",{index:o})}}}})}var Bn,_a,Pm,bi=b(()=>{"use strict";Y();U();Bn=require("zod");P();_a=class{async execute(e,t,i){let n=N(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({button:"right",timeout:o});else throw new Error("No locator found for right_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("right_click", page, {});']:['await agent.execAction("right_click", page, {',...t.map(i=>` ${i},`),"});"]}};Pm=Bn.z.object({element_index:Bn.z.number().int().describe("Index of the element to right-click"),timeout_ms:Bn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Wl(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:Cm,async execute(i,n){let{name:o,value:a}=i,{page:s,agentServices:r}=n;try{let l={action_description:`Save variable "${o}" = "${a}"`,action_data:{action_name:"save_variable",kwargs:{name:o,value:a}}};return await t.execute(s,l,r),{success:!0,actionEntity:l,message:`Saved variable "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Save variable "${o}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:o,value:a}},feedback:l.message}}}}})}var Gn,Hl,Cm,yi=b(()=>{"use strict";Gn=require("zod"),Hl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.name,a=n.kwargs.value;if(!o||a===void 0)throw new Error("Missing variable name or value for save_variable");o.startsWith("$")&&(o=o.slice(1)),i.saveVariable(o,a)}transpile(e){let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]}},Cm=Gn.z.object({name:Gn.z.string().describe("Variable name to save"),value:Gn.z.string().describe("Value to save in the variable")})});async function $m(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function Om(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function Ul(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:Lm,async execute(i,n){let{down:o,num_pages:a}=i,{page:s,agentServices:r,actionDescription:l}=n;try{let d=l||`Scroll ${o?"down":"up"} ${a} page(s)`,c=await $m("scroll",d,{down:o,num_pages:a});return await t.execute(s,c,r),{success:!0,actionEntity:c,message:`Scrolled ${o?"down":"up"} ${a} page(s)`}}catch(d){return{success:!1,error:d.message,actionEntity:Om(l||`Scroll ${o?"down":"up"} ${a} page(s)`,"scroll",{down:o,num_pages:a})}}}})}var Kn,xi,Lm,vi=b(()=>{"use strict";Kn=require("zod"),xi=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.down??!0,o=i.kwargs.num_pages??1,a=n?1:-1;await e.evaluate(`window.scrollBy(0, window.innerHeight * ${o} * ${a})`)}transpile(e){let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]}};Lm=Kn.z.object({down:Kn.z.boolean().describe("True to scroll down, False to scroll up"),num_pages:Kn.z.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});function Gl(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:Dm,async execute(i,n){let{otp_secret_key:o}=i,{page:a,agentServices:s}=n;try{let r={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:o}}};return await t.execute(a,r,s),{success:!0,actionEntity:r,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:o}},feedback:r.message}}}}})}var ka,Bl,Dm,_i=b(()=>{"use strict";ka=require("zod"),Bl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.otp_secret_key;if(!o)throw new Error("Missing otp_secret_key for generate_2fa_code");let a=i.replaceVariables(String(o)),s=await i.generate2faCode(a);i.saveVariable("otp_code",s)}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)} } },`,"});"]}},Dm=ka.z.object({otp_secret_key:ka.z.string().describe("The OTP secret key to generate the 2FA code from")})});async function Nm(e,t,i){return{...await F(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function Kl(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 zl(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:Rm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await K(n,o);if(!l)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:Kl(r||`Get options from dropdown ${o}`,{index:o})};let d=await Nm(l,a,r);return await t.execute(a,d,s),{success:!0,actionEntity:d,message:d.feedback||"No options found"}}catch(l){return{success:!1,error:l.message,actionEntity:Kl(r||`Get options from dropdown ${o}`,{index:o})}}}})}var Sa,jl,Rm,ki=b(()=>{"use strict";Y();Sa=require("zod"),jl=class{async execute(e,t,i){if(!t.xpath)throw new Error("XPath not found in action entity");let n=[];for(let o of e.frames())try{let a=await o.evaluate(s=>{let r=document.evaluate(s,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return r?{options:Array.from(r.options).map(l=>({text:l.text,value:l.value,index:l.index})),id:r.id,name:r.name}:null},t.xpath);if(a){let s=[];for(let r of a.options){let l=JSON.stringify(r.text);s.push(`${r.index}: text=${l}`)}n.push(...s)}}catch{}if(n.length>0){let o=n.join(`
|
|
4106
4106
|
`);o+=`
|
|
4107
|
-
Use the exact text string in select_dropdown_option`,i.addNote(o)}else i.addNote("No options found in any frame for dropdown")}transpile(e){let t=[];return e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("get_dropdown_options", page, {});']:['await agent.execAction("get_dropdown_options", page, {',...t.map(i=>` ${i},`),"});"]}};Pm=ya.z.object({element_index:ya.z.number().int().describe("Index of the dropdown/select element")})});function jl(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:Cm,async execute(i,n){let{page:o,agentServices:a,actionDescription:r}=n;try{let s={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(o,s,a),{success:!0,actionEntity:s,message:"Navigated back"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(r||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:s.message}}}}})}var Gl,Kl,Cm,vi=y(()=>{"use strict";H();Gl=require("zod");C();Kl=class{async execute(e,t){await e.goBack({timeout:ge}),await e.waitForLoadState("load",{timeout:ge}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},Cm=Gl.z.object({})});function zl(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:$m,async execute(i,n){let{url:o,new_tab:a,timeout_seconds:r}=i,{page:s,agentServices:l,actionDescription:d}=n,c={url:o,new_tab:a??!1};r!==void 0&&(c.timeout_seconds=r);let u=r?` (timeout: ${r}s)`:"";try{let m=a?`Open ${o} in new tab`:`Navigate to ${o}`,g={action_description:d||m,action_data:{action_name:"go_to_url",kwargs:c}};return await t.execute(s,g,l),{success:!0,actionEntity:g,message:(a?`Opened ${o} in new tab`:`Navigated to ${o}`)+u}}catch(m){let g=a?`Open ${o} in new tab`:`Navigate to ${o}`;return{success:!1,error:m.message,actionEntity:{action_description:(d||g)+" (failed)",action_data:{action_name:"go_to_url",kwargs:c},feedback:m.message}}}}})}var _i,xa,$m,ki=y(()=>{"use strict";H();_i=require("zod");C();xa=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.url;if(!o)throw new Error("Missing URL for go_to_url action");let a=n.kwargs.new_tab===!0,r=i.replaceVariables(String(o));if(r.startsWith("/")){let d=e.url(),c=null;try{let u=new URL(d);u.origin&&u.origin!=="null"&&(c=u.origin)}catch{}c&&(r=c+r)}let s=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:ge,l=e;a&&(l=await e.context().newPage(),i.setPage(l)),await l.goto(r,{timeout:s})}transpile(e){let t=e.action_data?.kwargs?.url||"",i=e.action_data?.kwargs?.new_tab===!0,n=e.action_data?.kwargs?.timeout_seconds,o=[`url: ${JSON.stringify(t)}`];return i&&o.push("new_tab: true"),n&&o.push(`timeout_seconds: ${n}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${o.join(", ")} } },`,"});"]}},$m=_i.z.object({url:_i.z.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:_i.z.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:_i.z.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});async function Lm(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Vl(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 Xl(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:Dm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await U(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:Vl(`Hover element ${o}`,"hover",{index:o})};let d=s||`Hover over element ${o}`,c=await Lm("hover",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Hovered over element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Vl(`Hover element ${o}`,"hover",{index:o})}}}})}var Bn,va,Dm,Si=y(()=>{"use strict";j();H();Bn=require("zod");C();va=class{async execute(e,t,i){let n=O(e,t),o=D(i,t.action_data?.kwargs?.timeout_ms);if(n){await n.waitFor({state:"attached",timeout:o});let a=await n.elementHandle();if(!a)throw new Error("Unable to obtain element handle for hover action");let r=await a.boundingBox();if(!r)throw new Error("Unable to determine bounding box for hover action");let s=r.x+r.width/2,l=r.y+r.height/2;await e.mouse.move(s,l)}else throw new Error("No locator found for hover action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("hover", page, {});']:['await agent.execAction("hover", page, {',...t.map(i=>` ${i},`),"});"]}};Dm=Bn.z.object({element_index:Bn.z.number().int().describe("Index of the element to hover over"),timeout_ms:Bn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Om(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Yl(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 Jl(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:Nm,usesElementIndex:!0,async execute(i,n){let{element_index:o,text:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await U(n,o);if(!d)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:Yl(l||`Input text to element ${o}`,"input_text",{index:o,text:a})};let c=l||`Input text to element ${o}`,u=await Om("input_text",c,d,r,{text:a});return await t.execute(r,u,s),{success:!0,actionEntity:u,message:`Input text to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:Yl(`Input text to element ${o}`,"input_text",{index:o,text:a})}}}})}var Ei,_a,Nm,Ti=y(()=>{"use strict";j();H();Ei=require("zod");C();_a=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.text??n.kwargs.value??"",a=i.replaceVariables(String(o)),r=O(e,t),s=D(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(d=>{d.value&&(d.value="")},null,{timeout:s}),await r.click({timeout:s}),await e.waitForTimeout(200);let l=i.getActionSettings().type_delay;l!==void 0?await e.keyboard.type(a,{delay:l}):await e.keyboard.type(a)}else throw new Error("No locator found for input_text action")}transpile(e){let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("input_text", page, {',...i.map(n=>` ${n},`),"});"]}};Nm=Ei.z.object({element_index:Ei.z.number().int().describe("Index of the input element"),text:Ei.z.string().describe("Text to type into the input. To use a placeholder, write {{ placeholder_name }} using exact placeholder name. Use clear_input first if you want to replace existing content."),timeout_ms:Ei.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Rm(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function ql(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 Ql(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:Fm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await U(n,o);if(!l)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:ql(s||`Clear element ${o}`,"clear_input",{index:o})};let d=s||`Clear element ${o}`,c=await Rm("clear_input",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Cleared element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:ql(`Clear element ${o}`,"clear_input",{index:o})}}}})}var Gn,Zl,Fm,Ai=y(()=>{"use strict";j();H();Gn=require("zod");C();Zl=class{async execute(e,t,i){let n=O(e,t),o=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:o}),await e.keyboard.press("ControlOrMeta+a"),await e.waitForTimeout(200),await e.keyboard.press("Backspace"),await e.waitForTimeout(200);else throw new Error("No locator found for clear_input action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("clear_input", page, {});']:['await agent.execAction("clear_input", page, {',...t.map(i=>` ${i},`),"});"]}};Fm=Gn.z.object({element_index:Gn.z.number().int().describe("Index of the input element to clear"),timeout_ms:Gn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Hm(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function ec(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 tc(e,t){e.register({name:"click",description:"Click an interactive element.",schema:Wm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await U(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:ec(`Click element ${o}`,"click",{index:o})};let d=s||`Click element ${o}`,c=await Hm("click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:ec(`Click element ${o}`,"click",{index:o})}}}})}var Kn,jn,Wm,Mi=y(()=>{"use strict";j();H();Kn=require("zod");C();jn=class{async execute(e,t,i){let n=O(e,t),o=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:o});else throw new Error("No locator found for click action")}transpile(e){let t=Oe(e);if(!t)return['await agent.execAction("click", page, {});'];let i=D();return[`await ${t}.click({ timeout: ${i} });`]}};Wm=Kn.z.object({element_index:Kn.z.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:Kn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function nc(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:Um,async execute(i,n){let{index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Close tab ${o}`,action_data:{action_name:"close_tab",kwargs:{page_id:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Closed tab ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:l.message}}}}})}var ka,ic,Um,Ii=y(()=>{"use strict";ka=require("zod"),ic=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.page_id??n.kwargs.index;if(o===void 0&&(o=e.context().pages().indexOf(e)),typeof o=="number"){if(o===0)throw new Error("Cannot close the first tab (page_id 0). Skipping close_tab action.");i&&await i.closeTab(o)}else throw new Error("Missing page_id for close_tab action")}transpile(e){let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]}},Um=ka.z.object({index:ka.z.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});function ac(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:Bm,async execute(i,n){let{page:o,agentServices:a}=n;try{let r={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await t.execute(o,r,a),{success:!0,actionEntity:r,message:"Task marked as complete"}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Task completed (failed)",action_data:{action_name:"done",kwargs:{}},feedback:r.message}}}}})}var zn,oc,Bm,Pi=y(()=>{"use strict";zn=require("zod"),oc=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},Bm=zn.z.object({success:zn.z.boolean().describe("Whether the task was completed successfully"),summary:zn.z.string().describe("Summary of what was accomplished or why it failed")})});async function Gm(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function rc(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 sc(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:Km,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await U(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:rc(`Double-click element ${o}`,"double_click",{index:o})};let d=s||`Double-click element ${o}`,c=await Gm("double_click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Double-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:rc(`Double-click element ${o}`,"double_click",{index:o})}}}})}var Vn,Sa,Km,Ci=y(()=>{"use strict";j();H();Vn=require("zod");C();Sa=class{async execute(e,t,i){let n=O(e,t),o=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.dblclick({timeout:o});else throw new Error("No locator found for double_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("double_click", page, {});']:['await agent.execAction("double_click", page, {',...t.map(i=>` ${i},`),"});"]}};Km=Vn.z.object({element_index:Vn.z.number().int().describe("Index of the element to double-click"),timeout_ms:Vn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function cc(e){if(!e.trim())return!1;try{return(0,lc.parse)(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var lc,Xn=y(()=>{"use strict";lc=require("@babel/parser")});function dc(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:jm,async execute(i,n){let{statement:o}=i,{page:a,agentServices:r}=n;try{let s={action_description:`${o}`,action_data:{action_name:"verify",kwargs:{statement:o}}};return await t.execute(a,s,r),{success:!0,actionEntity:s,message:`Assertion verified: ${o}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Verify: ${o} (failed)`,action_data:{action_name:"verify",kwargs:{statement:o}},feedback:s.message}}}},availability:{openai:!0,mcp:!0}})}var Ea,Yn,jm,$i=y(()=>{"use strict";Zt();Xn();F();Ea=require("zod"),Yn=class{async execute(e,t,i){let n=t.action_data?.kwargs,o=typeof n?.code=="string",a=o?n?.statement||t.action_description:t.action_description||n?.statement;if(o&&a){let c=Date.now();try{await this.executeJSAssertion(e,n.code,i),h.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${a}`),i.addNote(`Assertion passed: ${a}`);return}catch(u){let m=((Date.now()-c)/1e3).toFixed(1);h.info(`[VERIFY:JS\u2192AI] JS failed ${m}s (${u instanceof Error?u.message:String(u)}), falling back to AI: ${a}`)}}else if(o){let c=Date.now();await this.executeJSAssertion(e,n.code,i),h.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${a||"js-only"}`),i.addNote(`Assertion passed: ${a||"js-only"}`);return}if(!a)throw new Error("Missing statement or code for verify action");let r=Date.now();h.info(`[VERIFY:AI] Evaluating: ${a}`);let{evaluateStatement:s}=await Promise.resolve().then(()=>(ft(),gt)),l=await s(a,e,i,{useCleanScreenshotForAssertion:!0}),d=l.explanation||l.error||(l.success?`Assertion passed: ${a}`:"Assertion failed");if(i.addNote(d),!l.success)throw h.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${a}`),new Error(l.error||l.explanation||"Assertion failed");h.info(`[VERIFY:AI] \u2713 ${((Date.now()-r)/1e3).toFixed(1)}s: ${a}`)}async executeJSAssertion(e,t,i){let n=i.agent;if(!n)throw new Error("Agent not initialized on AgentServices \u2014 ai_assert requires an agent reference");try{await new Function("page","expect","agent",`
|
|
4107
|
+
Use the exact text string in select_dropdown_option`,i.addNote(o)}else i.addNote("No options found in any frame for dropdown")}transpile(e){let t=[];return e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("get_dropdown_options", page, {});']:['await agent.execAction("get_dropdown_options", page, {',...t.map(i=>` ${i},`),"});"]}};Rm=Sa.z.object({element_index:Sa.z.number().int().describe("Index of the dropdown/select element")})});function Yl(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:Fm,async execute(i,n){let{page:o,agentServices:a,actionDescription:s}=n;try{let r={action_description:s||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(o,r,a),{success:!0,actionEntity:r,message:"Navigated back"}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:(s||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:r.message}}}}})}var Vl,Xl,Fm,Si=b(()=>{"use strict";U();Vl=require("zod");P();Xl=class{async execute(e,t){await e.goBack({timeout:_e}),await e.waitForLoadState("load",{timeout:_e}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},Fm=Vl.z.object({})});function Jl(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:Hm,async execute(i,n){let{url:o,new_tab:a,timeout_seconds:s}=i,{page:r,agentServices:l,actionDescription:d}=n,c={url:o,new_tab:a??!1};s!==void 0&&(c.timeout_seconds=s);let h=s?` (timeout: ${s}s)`:"";try{let m=a?`Open ${o} in new tab`:`Navigate to ${o}`,g={action_description:d||m,action_data:{action_name:"go_to_url",kwargs:c}};return await t.execute(r,g,l),{success:!0,actionEntity:g,message:(a?`Opened ${o} in new tab`:`Navigated to ${o}`)+h}}catch(m){let g=a?`Open ${o} in new tab`:`Navigate to ${o}`;return{success:!1,error:m.message,actionEntity:{action_description:(d||g)+" (failed)",action_data:{action_name:"go_to_url",kwargs:c},feedback:m.message}}}}})}var Ei,Ea,Hm,Ti=b(()=>{"use strict";U();Ei=require("zod");P();Ea=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.url;if(!o)throw new Error("Missing URL for go_to_url action");let a=n.kwargs.new_tab===!0,s=i.replaceVariables(String(o));if(s.startsWith("/")){let d=e.url(),c=null;try{let h=new URL(d);h.origin&&h.origin!=="null"&&(c=h.origin)}catch{}c&&(s=c+s)}let r=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:_e,l=e;a&&(l=await e.context().newPage(),i.setPage(l)),await l.goto(s,{timeout:r})}transpile(e){let t=e.action_data?.kwargs?.url||"",i=e.action_data?.kwargs?.new_tab===!0,n=e.action_data?.kwargs?.timeout_seconds,o=[`url: ${JSON.stringify(t)}`];return i&&o.push("new_tab: true"),n&&o.push(`timeout_seconds: ${n}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${o.join(", ")} } },`,"});"]}},Hm=Ei.z.object({url:Ei.z.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:Ei.z.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:Ei.z.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});async function Wm(e,t,i,n,o={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function ql(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 Zl(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:Um,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await K(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:ql(`Hover element ${o}`,"hover",{index:o})};let d=r||`Hover over element ${o}`,c=await Wm("hover",d,l,a);return await t.execute(a,c,s),{success:!0,actionEntity:c,message:`Hovered over element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:ql(`Hover element ${o}`,"hover",{index:o})}}}})}var jn,Ta,Um,Ai=b(()=>{"use strict";Y();U();jn=require("zod");P();Ta=class{async execute(e,t,i){let n=N(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n){await n.waitFor({state:"attached",timeout:o});let a=await n.elementHandle();if(!a)throw new Error("Unable to obtain element handle for hover action");let s=await a.boundingBox();if(!s)throw new Error("Unable to determine bounding box for hover action");let r=s.x+s.width/2,l=s.y+s.height/2;await e.mouse.move(r,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},`),"});"]}};Um=jn.z.object({element_index:jn.z.number().int().describe("Index of the element to hover over"),timeout_ms:jn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Bm(e,t,i,n,o={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Ql(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 ec(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:Gm,usesElementIndex:!0,async execute(i,n){let{element_index:o,text:a}=i,{page:s,agentServices:r,actionDescription:l}=n;try{let d=await K(n,o);if(!d)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:Ql(l||`Input text to element ${o}`,"input_text",{index:o,text:a})};let c=l||`Input text to element ${o}`,h=await Bm("input_text",c,d,s,{text:a});return await t.execute(s,h,r),{success:!0,actionEntity:h,message:`Input text to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:Ql(`Input text to element ${o}`,"input_text",{index:o,text:a})}}}})}var Mi,Aa,Gm,Ii=b(()=>{"use strict";Y();U();Mi=require("zod");P();Aa=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.text??n.kwargs.value??"",a=i.replaceVariables(String(o)),s=N(e,t),r=L(i,t.action_data?.kwargs?.timeout_ms);if(s){await s.evaluate(d=>{d.value&&(d.value="")},null,{timeout:r}),await s.click({timeout:r}),await e.waitForTimeout(200);let l=i.getActionSettings().type_delay;l!==void 0?await e.keyboard.type(a,{delay:l}):await e.keyboard.type(a)}else throw new Error("No locator found for input_text action")}transpile(e){let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("input_text", page, {',...i.map(n=>` ${n},`),"});"]}};Gm=Mi.z.object({element_index:Mi.z.number().int().describe("Index of the input element"),text:Mi.z.string().describe("Text to type into the input. To use a placeholder, write {{ placeholder_name }} using exact placeholder name. Use clear_input first if you want to replace existing content."),timeout_ms:Mi.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Km(e,t,i,n,o={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function tc(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 nc(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:jm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await K(n,o);if(!l)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:tc(r||`Clear element ${o}`,"clear_input",{index:o})};let d=r||`Clear element ${o}`,c=await Km("clear_input",d,l,a);return await t.execute(a,c,s),{success:!0,actionEntity:c,message:`Cleared element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:tc(`Clear element ${o}`,"clear_input",{index:o})}}}})}var zn,ic,jm,Pi=b(()=>{"use strict";Y();U();zn=require("zod");P();ic=class{async execute(e,t,i){let n=N(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:o}),await e.keyboard.press("ControlOrMeta+a"),await e.waitForTimeout(200),await e.keyboard.press("Backspace"),await e.waitForTimeout(200);else throw new Error("No locator found for clear_input action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("clear_input", page, {});']:['await agent.execAction("clear_input", page, {',...t.map(i=>` ${i},`),"});"]}};jm=zn.z.object({element_index:zn.z.number().int().describe("Index of the input element to clear"),timeout_ms:zn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function zm(e,t,i,n,o={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function oc(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 ac(e,t){e.register({name:"click",description:"Click an interactive element.",schema:Vm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await K(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:oc(`Click element ${o}`,"click",{index:o})};let d=r||`Click element ${o}`,c=await zm("click",d,l,a);return await t.execute(a,c,s),{success:!0,actionEntity:c,message:`Clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:oc(`Click element ${o}`,"click",{index:o})}}}})}var Vn,Xn,Vm,Ci=b(()=>{"use strict";Y();U();Vn=require("zod");P();Xn=class{async execute(e,t,i){let n=N(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:o});else throw new Error("No locator found for click action")}transpile(e){let t=Fe(e);if(!t)return['await agent.execAction("click", page, {});'];let i=L();return[`await ${t}.click({ timeout: ${i} });`]}};Vm=Vn.z.object({element_index:Vn.z.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:Vn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function sc(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:Xm,async execute(i,n){let{index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l={action_description:r||`Close tab ${o}`,action_data:{action_name:"close_tab",kwargs:{page_id:o}}};return await t.execute(a,l,s),{success:!0,actionEntity:l,message:`Closed tab ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:l.message}}}}})}var Ma,rc,Xm,$i=b(()=>{"use strict";Ma=require("zod"),rc=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.page_id??n.kwargs.index;if(o===void 0&&(o=e.context().pages().indexOf(e)),typeof o=="number"){if(o===0)throw new Error("Cannot close the first tab (page_id 0). Skipping close_tab action.");i&&await i.closeTab(o)}else throw new Error("Missing page_id for close_tab action")}transpile(e){let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]}},Xm=Ma.z.object({index:Ma.z.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});function cc(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:Ym,async execute(i,n){let{page:o,agentServices:a}=n;try{let s={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await t.execute(o,s,a),{success:!0,actionEntity:s,message:"Task marked as complete"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Task completed (failed)",action_data:{action_name:"done",kwargs:{}},feedback:s.message}}}}})}var Yn,lc,Ym,Oi=b(()=>{"use strict";Yn=require("zod"),lc=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},Ym=Yn.z.object({success:Yn.z.boolean().describe("Whether the task was completed successfully"),summary:Yn.z.string().describe("Summary of what was accomplished or why it failed")})});async function Jm(e,t,i,n,o={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function dc(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 uc(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:qm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await K(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:dc(`Double-click element ${o}`,"double_click",{index:o})};let d=r||`Double-click element ${o}`,c=await Jm("double_click",d,l,a);return await t.execute(a,c,s),{success:!0,actionEntity:c,message:`Double-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:dc(`Double-click element ${o}`,"double_click",{index:o})}}}})}var Jn,Ia,qm,Li=b(()=>{"use strict";Y();U();Jn=require("zod");P();Ia=class{async execute(e,t,i){let n=N(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.dblclick({timeout:o});else throw new Error("No locator found for double_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("double_click", page, {});']:['await agent.execAction("double_click", page, {',...t.map(i=>` ${i},`),"});"]}};qm=Jn.z.object({element_index:Jn.z.number().int().describe("Index of the element to double-click"),timeout_ms:Jn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function mc(e){if(!e.trim())return!1;try{return(0,hc.parse)(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var hc,qn=b(()=>{"use strict";hc=require("@babel/parser")});function pc(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:Zm,async execute(i,n){let{statement:o}=i,{page:a,agentServices:s}=n;try{let r={action_description:`${o}`,action_data:{action_name:"verify",kwargs:{statement:o}}};return await t.execute(a,r,s),{success:!0,actionEntity:r,message:`Assertion verified: ${o}`}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:`Verify: ${o} (failed)`,action_data:{action_name:"verify",kwargs:{statement:o}},feedback:r.message}}}},availability:{openai:!0,mcp:!0}})}var Pa,Zn,Zm,Di=b(()=>{"use strict";ti();qn();W();Pa=require("zod"),Zn=class{async execute(e,t,i){let n=t.action_data?.kwargs,o=typeof n?.code=="string",a=o?n?.statement||t.action_description:t.action_description||n?.statement;if(o&&a){let c=Date.now();try{await this.executeJSAssertion(e,n.code,i),u.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${a}`),i.addNote(`Assertion passed: ${a}`);return}catch(h){let m=((Date.now()-c)/1e3).toFixed(1);u.info(`[VERIFY:JS\u2192AI] JS failed ${m}s (${h instanceof Error?h.message:String(h)}), falling back to AI: ${a}`)}}else if(o){let c=Date.now();await this.executeJSAssertion(e,n.code,i),u.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${a||"js-only"}`),i.addNote(`Assertion passed: ${a||"js-only"}`);return}if(!a)throw new Error("Missing statement or code for verify action");let s=Date.now();u.info(`[VERIFY:AI] Evaluating: ${a}`);let{evaluateStatement:r}=await Promise.resolve().then(()=>(wt(),ft)),l=await r(a,e,i,{useCleanScreenshotForAssertion:!0}),d=l.explanation||l.error||(l.success?`Assertion passed: ${a}`:"Assertion failed");if(i.addNote(d),!l.success)throw u.info(`[VERIFY:AI] \u2717 ${((Date.now()-s)/1e3).toFixed(1)}s: ${a}`),new Error(l.error||l.explanation||"Assertion failed");u.info(`[VERIFY:AI] \u2713 ${((Date.now()-s)/1e3).toFixed(1)}s: ${a}`)}async executeJSAssertion(e,t,i){let n=i.agent;if(!n)throw new Error("Agent not initialized on AgentServices \u2014 ai_assert requires an agent reference");try{await new Function("page","expect","agent",`
|
|
4108
4108
|
return (async () => {
|
|
4109
4109
|
${t}
|
|
4110
4110
|
})();
|
|
4111
|
-
`)(e,
|
|
4112
|
-
`),l=JSON.stringify(o);return["{ const _t = Date.now(); try {",...
|
|
4113
|
-
`)}return o?[`await agent.assert(page, ${JSON.stringify(o)}, ${a});`]:["// Skipping verify: missing statement or code"]}},
|
|
4114
|
-
${e.stepHistory.slice(-3).map(l=>{let d=`${l.outcome.success?"\u2713":"\u2717"} Step ${l.stepNumber}: ${l.goal}`;if(l.actions.length>1)l.actions.forEach((c,
|
|
4115
|
-
\u2192 Action ${
|
|
4111
|
+
`)(e,pt.expect,n)}catch(o){throw new Error(`Assertion failed: ${o instanceof Error?o.message:String(o)}`)}}transpile(e,t){let i=e.action_data?.kwargs,n=typeof i?.code=="string",o=n?i?.statement||e.action_description:e.action_description||i?.statement,a=JSON.stringify(t||"");if(n){let s=i.code;if(!mc(s))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(s)});`];if(o){let r=s.split(`
|
|
4112
|
+
`),l=JSON.stringify(o);return["{ const _t = Date.now(); try {",...r.map(d=>` ${d}`),` console.log(\`[VERIFY:JS] \u2713 \${((Date.now()-_t)/1000).toFixed(1)}s: ${l}\`);`,"} catch (_e) {",` console.log(\`[VERIFY:JS\u2192AI] JS failed \${((Date.now()-_t)/1000).toFixed(1)}s: (\${_e instanceof Error ? _e.message : String(_e)}), falling back to AI: ${l}\`);`,` await agent.assert(page, ${l}, ${a});`,"} }"]}return s.split(`
|
|
4113
|
+
`)}return o?[`await agent.assert(page, ${JSON.stringify(o)}, ${a});`]:["// Skipping verify: missing statement or code"]}},Zm=Pa.z.object({statement:Pa.z.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});function fc(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:Qm,async execute(i,n){let{element_description:o,variable_name:a}=i,{page:s,agentServices:r}=n;try{let l={action_description:`Extract ${o} to ${a}`,action_data:{action_name:"ai_extract",kwargs:{element_description:o,variable_name:a}}};return await t.execute(s,l,r),{success:!0,actionEntity:l,message:`Extracted ${o} to ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Extract ${o} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:o,variable_name:a}},feedback:l.message}}}},availability:{openai:!1,mcp:!0}})}var Qn,gc,Qm,Ni=b(()=>{"use strict";Qn=require("zod"),gc=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.element_description,a=n.kwargs.variable_name;if(!o||!a)throw new Error("Missing element_description or variable_name for ai_extract");let s=`Extract ${o} and save to ${a}`,{executeStep:r}=await Promise.resolve().then(()=>(wt(),ft)),l=await r(s,e,i);if(l.status!=="success")throw new Error(l.error||"Extraction failed")}transpile(e,t){let i=e.action_data?.kwargs?.element_description,n=e.action_data?.kwargs?.variable_name;if(!i||!n)return["// Skipping ai_extract: missing element_description or variable_name"];let o=JSON.stringify(i),a=JSON.stringify(n);return[`await agent.extract(page, ${o}, ${a}, '${t||""}');`]}},Qm=Qn.z.object({element_description:Qn.z.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:Qn.z.string().describe("Name of the variable to store the extracted value")})});var ep,tp,Ri,eo=b(()=>{"use strict";ep=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],tp=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],Ri=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:ep.includes(t)}static getAiStatement(e){let t=e.action_data?.action_name;if(!t)return null;let i=e.action_data?.kwargs||{};switch(t){case"ai_action":case"ai_step":return i.statement||null;case"verify":case"ai_assert":case"assert":return i.statement||e.action_description||null;case"ai_extract":let n=i.element_description,o=i.variable_name;return n&&o?`Extract ${n} and save to ${o}`:null;case"ai_wait_until":return i.condition||null;default:return null}}static canSelfHeal(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!tp.includes(t)}}});var Ca,$a,to,Oa=b(()=>{"use strict";An();Mn();In();Pn();Cn();$n();On();Ln();Dn();Fn();Hn();oi();ai();ri();si();ci();ui();hi();pi();gi();fi();wi();bi();yi();vi();_i();ki();Si();Ti();Ai();Ii();Pi();Ci();$i();Oi();Li();Di();Ni();eo();U();ve();Ca=class M{static registerAction(t,i){M.actions.set(t,i)}constructor(){M.initialized||(this.registerBuiltinActions(),M.initialized=!0)}registerBuiltinActions(){M.registerAction("go_to_url",new Ea),M.registerAction("go_back",new Xl),M.registerAction("reload_page",new Dl),M.registerAction("close_tab",new rc),M.registerAction("switch_tab",new kl),M.registerAction("click",new Xn),M.registerAction("hover",new Ta),M.registerAction("right_click",new _a),M.registerAction("double_click",new Ia),M.registerAction("click_by_coordinates",new nl),M.registerAction("right_click_by_coordinates",new el),M.registerAction("double_click_by_coordinates",new ol),M.registerAction("drag_drop",new al),M.registerAction("input_text",new Aa),M.registerAction("clear_input",new ic),M.registerAction("press",new va),M.registerAction("send_keys_on_element",new qs),M.registerAction("scroll_on_element",new pl),M.registerAction("scroll_to_text",new fl),M.registerAction("scroll",new xi),M.registerAction("upload_file",new Il),M.registerAction("wait_for_download_complete",new cl),M.registerAction("get_dropdown_options",new jl),M.registerAction("select_dropdown_option",new yl),M.registerAction("set_date_for_native_date_picker",new vl),M.registerAction("verify",new Zn),M.registerAction("ai_action",new sl),M.registerAction("ai_extract",new gc),M.registerAction("ai_step",new ll),M.registerAction("ai_wait_until",new ul),M.registerAction("generate_2fa_code",new Bl),M.registerAction("wait",new Cl),M.registerAction("wait_for_page_ready",new Js),M.registerAction("save_variable",new Hl),M.registerAction("js_code",new Qs),M.registerAction("js_action",new il),M.registerAction("function",new tl),M.registerAction("done",new lc),M.registerAction("click_element",new Xn),M.registerAction("click_element_by_index",new Xn),M.registerAction("hover_element_by_index",new Ta),M.registerAction("right_click_on_element",new _a),M.registerAction("double_click_on_element",new Ia),M.registerAction("scroll_down",new xi),M.registerAction("scroll_up",new xi),M.registerAction("scroll_element",new xi),M.registerAction("send_keys",new va),M.registerAction("open_tab",new Ea),M.registerAction("fill",new Aa),M.registerAction("ai_assert",new Zn),M.registerAction("assert",new Zn)}getAction(t){return M.actions.get(t)}hasAction(t){return M.actions.has(t)}getActionNames(){return Array.from(M.actions.keys())}async execute(t,i,n){if(!n)throw new Error("AgentServices not found");let o=i.action_data?.action_name;if(!o)throw new Error("Action name not found in action_data");let a=this.getAction(o);if(!a)throw new Error(`Unknown action: ${o}`);await a.execute(t,i,n)}transpile(t,i,n){let{sanitizeForComment:o}=(P(),ea(an)),a=t.action_description||"",s=t.action_data?.action_name||"",r=this.getAction(s);if(!r)return[`// ${i}: Unknown action: ${s}`];let l=r.transpile(t,i);if(Ri.isAiAction(t))return[`// ${i}: ${o(a)}`,"page = agent.agentServices.validatePage(page);",...l];let d=JSON.stringify(a),c=l.map(g=>` ${g}`),h=Ri.canSelfHeal(t),m=n?JSON.stringify(n):"undefined";return[`// ${i}: ${o(a)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...c,`}, ${d}, '${i}', ${m}, ${h});`]}transpileUncachedAction(t,i,n=!1,o=!1,a){let{sanitizeForComment:s}=(P(),ea(an));if(!t)return[`// ${i}: Skipping - no description`];let r=JSON.stringify(t);if(o){let l=a?`, { stmtUid: ${JSON.stringify(a)} }`:"";return[`// ${i}: ${s(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${r}, '${i}'${l});`]}return[`// ${i}: ${s(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${r}, '${i}', ${n});`]}};Ca.actions=new Map,Ca.initialized=!1;$a=Ca,to=$a});var xt={};Ve(xt,{ActionHandler:()=>$a,default:()=>to});var vt=b(()=>{"use strict";Oa();An();Mn();In();Pn();Cn();$n();On();Ln();Dn();Fn();Hn();oi();ai();ri();si();ci();ui();hi();pi();gi();fi();wi();bi();yi();vi();_i();ki();Si();Ti();Ai();Ii();Pi();Ci();$i();Oi();Li();Di();ti();Ni();qn();mi();Y();Xe();W();oe();gt();eo();U();ve()});function io(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
|
|
4114
|
+
${e.stepHistory.slice(-3).map(l=>{let d=`${l.outcome.success?"\u2713":"\u2717"} Step ${l.stepNumber}: ${l.goal}`;if(l.actions.length>1)l.actions.forEach((c,h)=>{let m=c.action_description||"Unknown action";d+=`
|
|
4115
|
+
\u2192 Action ${h+1}: ${m}`});else if(l.actions.length===1){let c=l.actions[0]?.action_description||"Unknown action";d+=`
|
|
4116
4116
|
\u2192 ${c}`}if(!l.outcome.success&&l.outcome.error){let c=l.outcome.error.substring(0,100);d+=`
|
|
4117
4117
|
Error: ${c}${l.outcome.error.length>100?"...":""}`}return l.evaluation&&(d+=`
|
|
4118
4118
|
Eval: ${l.evaluation}`),d}).join(`
|
|
@@ -4121,8 +4121,8 @@ ${e.stepHistory.slice(-3).map(l=>{let d=`${l.outcome.success?"\u2713":"\u2717"}
|
|
|
4121
4121
|
${e.memory.map((l,d)=>`${d+1}. ${l}`).join(`
|
|
4122
4122
|
`)}
|
|
4123
4123
|
`,a=()=>e.lastEvaluation?`**Previous Step Evaluation**: ${e.lastEvaluation}
|
|
4124
|
-
`:"",
|
|
4125
|
-
`:"",
|
|
4124
|
+
`:"",s=()=>e.lastGoal?`**Previous Goal**: ${e.lastGoal}
|
|
4125
|
+
`:"",r=()=>{if(e.consecutiveFailures===0)return"";let l=e.maxFailures-e.consecutiveFailures;return`\u26A0\uFE0F **Warning**: ${e.consecutiveFailures} consecutive failure(s). ${l} attempts remaining before task fails.
|
|
4126
4126
|
`};return`## TASK CONTEXT
|
|
4127
4127
|
|
|
4128
4128
|
>>> YOUR INSTRUCTION: ${t} <<<
|
|
@@ -4130,7 +4130,7 @@ ${e.memory.map((l,d)=>`${d+1}. ${l}`).join(`
|
|
|
4130
4130
|
**Current URL**: ${i}
|
|
4131
4131
|
**Step**: ${e.currentStep+1}/${e.maxSteps}
|
|
4132
4132
|
|
|
4133
|
-
${a()}${
|
|
4133
|
+
${a()}${s()}${o()}${n()}${r()}`.trim()}function wc(){return`
|
|
4134
4134
|
\u26A0\uFE0F **FINAL STEP WARNING** \u26A0\uFE0F
|
|
4135
4135
|
|
|
4136
4136
|
This is your last step. You MUST use the "done" action now.
|
|
@@ -4139,14 +4139,14 @@ This is your last step. You MUST use the "done" action now.
|
|
|
4139
4139
|
- If the task is incomplete or partially complete, set success=false
|
|
4140
4140
|
- Include everything you've accomplished in the done action's text field
|
|
4141
4141
|
- No other actions are allowed on this step
|
|
4142
|
-
`.trim()}function
|
|
4143
|
-
`)}function
|
|
4142
|
+
`.trim()}function ip(){let e=G.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 _t.z.ZodObject){let o=i.schema.shape,a=[];Object.keys(o).forEach(s=>{let r=o[s],l="any";r instanceof _t.z.ZodNumber?l="number":r instanceof _t.z.ZodString?l="string":r instanceof _t.z.ZodBoolean?l="boolean":r instanceof _t.z.ZodEnum&&(l=r._def.values.map(d=>`"${d}"`).join(" | ")),a.push(`${s}: ${l}`)}),n=`{${a.join(", ")}}`}return{name:i.name,description:i.description,params:n}}).sort((i,n)=>i.name.localeCompare(n.name)),t=[];return t.push("## AVAILABLE ACTIONS"),t.push(""),t.push("Use these exact action names in your JSON response:"),t.push(""),e.forEach(i=>{t.push(`- \`${i.name}\` - ${i.description} (kwargs: ${i.params})`)}),t.push(""),t.join(`
|
|
4143
|
+
`)}function no(e,t={}){if(e)return e;let{useThinking:i=!0,useMemory:n=!0,useEvaluation:o=!0,useMultiAction:a=!0}=t,s=o?`
|
|
4144
4144
|
1. **Evaluate Previous Step**: After each action, evaluate whether the previous goal was accomplished:
|
|
4145
4145
|
- "success: <reason>" if the goal was fully achieved
|
|
4146
4146
|
- "partial: <reason>" if the goal was partially achieved but needs more work
|
|
4147
4147
|
- "failure: <reason>" if the goal was not achieved
|
|
4148
4148
|
- Leave empty on the first step
|
|
4149
|
-
`:"",
|
|
4149
|
+
`:"",r=n?`
|
|
4150
4150
|
2. **Track Important Facts**: Maintain a memory of important information discovered during task execution:
|
|
4151
4151
|
- User credentials or sensitive data
|
|
4152
4152
|
- Important URLs or resource identifiers
|
|
@@ -4161,7 +4161,7 @@ This is your last step. You MUST use the "done" action now.
|
|
|
4161
4161
|
- Plan the immediate next step
|
|
4162
4162
|
`:"",d=i?` "thinking": "<your internal reasoning about current state and next action>", // Optional
|
|
4163
4163
|
`:"",c=o?` "evaluation_previous_goal": "success: <reason>" | "partial: <reason>" | "failure: <reason>" | "", // Empty on first step
|
|
4164
|
-
`:"",
|
|
4164
|
+
`:"",h=n?` "memory": "<important facts to remember>", // Update only when learning something new
|
|
4165
4165
|
`:"",m=a?` "actions": [ // Can be single action or multiple actions in sequence
|
|
4166
4166
|
{
|
|
4167
4167
|
"description": "<human readable description WITHOUT element index, e.g. 'Click the Submit button'>",
|
|
@@ -4247,7 +4247,7 @@ CRITICAL: Detect when you are stuck and stop immediately:
|
|
|
4247
4247
|
|
|
4248
4248
|
When stuck, call \`done\` with success=false and explain what happened.
|
|
4249
4249
|
|
|
4250
|
-
${
|
|
4250
|
+
${ip()}
|
|
4251
4251
|
## Reasoning Rules
|
|
4252
4252
|
|
|
4253
4253
|
Use the \`thinking\` field to reason about each step:
|
|
@@ -4257,14 +4257,14 @@ Use the \`thinking\` field to reason about each step:
|
|
|
4257
4257
|
- Determine the next action needed to fulfill the instruction.
|
|
4258
4258
|
- Stay focused on the literal instruction - do not expand or interpret beyond it.
|
|
4259
4259
|
- If the page is still loading, wait before acting.
|
|
4260
|
-
${
|
|
4260
|
+
${s}${r}${l}
|
|
4261
4261
|
## Output Format
|
|
4262
4262
|
|
|
4263
4263
|
You must ALWAYS respond with a valid JSON in this exact format:
|
|
4264
4264
|
|
|
4265
4265
|
\`\`\`json
|
|
4266
4266
|
{
|
|
4267
|
-
${d}${c}${
|
|
4267
|
+
${d}${c}${h} "current_goal": "State the current goal. Include only what to achieve, not how to achieve it.",
|
|
4268
4268
|
${m}
|
|
4269
4269
|
"completes_instruction": true | false // Is the entire task complete?
|
|
4270
4270
|
}
|
|
@@ -4283,13 +4283,13 @@ ${m}
|
|
|
4283
4283
|
**Current Goal Examples:**
|
|
4284
4284
|
- "Add the product to the cart"
|
|
4285
4285
|
- "Find more product listings and extract details from the next 5 items on the page"
|
|
4286
|
-
${g}`.trim()}var
|
|
4286
|
+
${g}`.trim()}var _t,oo=b(()=>{"use strict";$e();_t=require("zod")});var ao,La=b(()=>{"use strict";oo();ae();ao=class{constructor(e){this.messages=[],this.systemPrompt=e}getMessages(){return{system:this.systemPrompt,messages:[...this.messages]}}addStateMessage(e,t,i,n,o,a={}){let{executionHistory:s,placeholderData:r,sensitiveKeys:l,isFinalStep:d,finalStepWarning:c}=a,h=[],m=io(o,e,t);if(h.push({type:"text",text:m}),h.push({type:"text",text:`## CURRENT PAGE STATE
|
|
4287
4287
|
|
|
4288
4288
|
**Interactive Elements**:
|
|
4289
|
-
${i}`}),
|
|
4289
|
+
${i}`}),s&&Array.isArray(s)&&s.length>0){let g=s.map(([y,v],x)=>`${x+1}. ${y} \u2192 ${v}`);h.push({type:"text",text:`## EXECUTION HISTORY (from test)
|
|
4290
4290
|
|
|
4291
4291
|
${g.join(`
|
|
4292
|
-
`)}`})}if(
|
|
4292
|
+
`)}`})}if(r&&Object.keys(r).length>0){w.log("Adding placeholder data description");let g=this.getPlaceholderDataDescription(r,l);w.log(`Placeholder data description: ${g}`),g&&h.push({type:"text",text:g})}d&&c&&h.push({type:"text",text:c}),h.push({type:"image",image:n}),w.log(`Adding state message: ${h.length} parts`),this.messages.push({role:"user",content:h})}addAssistantMessage(e){this.messages.push({role:"assistant",content:e})}addTextMessage(e,t){this.messages.push({role:e,content:t})}getMessageCount(){return this.messages.length}clear(){this.messages=[]}getRecentMessages(e){return this.messages.slice(-e)}updateSystemPrompt(e){this.systemPrompt=e}addAssistantMessageWithToolCalls(e){this.messages.push({role:"assistant",content:e.map(t=>({type:"tool-call",toolCallId:t.toolCallId,toolName:t.toolName,input:t.input}))})}addToolResponseMessage(e,t,i){this.messages.push({role:"tool",content:[{type:"tool-result",toolCallId:t,toolName:i,output:typeof e=="string"?{type:"text",value:e}:{type:"json",value:e}}]})}getPlaceholderDataDescription(e,t){let i=[];for(let o of Object.keys(e))if(e[o])if(t?.has(o))i.push(` - ${o}: [SENSITIVE - value hidden]`);else{let a=e[o],s=typeof a=="string"?a:JSON.stringify(a);i.push(` - ${o}: "${s}"`)}if(i.length===0)return"";let n=`## DATA PLACEHOLDERS
|
|
4293
4293
|
|
|
4294
4294
|
`;return n+=`The following placeholders are available for use in your actions:
|
|
4295
4295
|
`,n+=`${i.join(`
|
|
@@ -4299,7 +4299,7 @@ ${g.join(`
|
|
|
4299
4299
|
`,n+=`- Use the EXACT placeholder name as shown above
|
|
4300
4300
|
`,n+=`- Do NOT use the actual value directly in the action
|
|
4301
4301
|
`,n+=`- The values shown are for context only to help you understand what data is available
|
|
4302
|
-
`,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
|
|
4302
|
+
`,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 We,kt=b(()=>{"use strict";We=`
|
|
4303
4303
|
// check to make sure we're not inside the PDF viewer
|
|
4304
4304
|
window.isPdfViewer = !!document?.body?.querySelector('body > embed[type="application/pdf"][width="100%"]')
|
|
4305
4305
|
if (!window.isPdfViewer) {
|
|
@@ -4354,9 +4354,9 @@ if (!window.isPdfViewer) {
|
|
|
4354
4354
|
};
|
|
4355
4355
|
})();
|
|
4356
4356
|
}
|
|
4357
|
-
`});function pc(e,t=!0,i=!1){return[...e!==void 0?[`--remote-debugging-port=${e}`,"--remote-allow-origins=*"]:[],"--no-sandbox","--disable-blink-features=AutomationControlled","--timezone=America/Los_Angeles",...i?["--headless"]:[],...t?["--disable-web-security","--disable-site-isolation-trials","--disable-features=IsolateOrigins,site-per-process","--allow-running-insecure-content","--ignore-certificate-errors","--ignore-ssl-errors","--ignore-certificate-errors-spki-list"]:[]]}async function gc(e,t){let i=await e.newContext(t);return i.addInitScript(Re),i}async function no(e){return(await(await fetch(`http://127.0.0.1:${e}/json/version`)).json()).webSocketDebuggerUrl.replace("localhost","127.0.0.1")}async function fc(e,t){let i=await(await fetch(`http://localhost:${e}/json/list`)).json();for(let n of i)if(n.type==="page"&&n.id===t)return n.webSocketDebuggerUrl;throw new Error(`No page found for id: ${t}`)}async function wc(e){let t=await e.context().newCDPSession(e),i=await t.send("Target.getTargetInfo");return await t.detach(),i.targetInfo}async function ep(e,t){let i=new Set,n=Date.now(),o=new Set(["document","stylesheet","image","font","script","iframe"]),a=new Set(["text/html","text/css","application/javascript","image/","font/","application/json"]),r=["analytics","tracking","telemetry","beacon","metrics","doubleclick","adsystem","adserver","advertising","facebook.com/plugins","platform.twitter","linkedin.com/embed","livechat","zendesk","intercom","crisp.chat","hotjar","push-notifications","onesignal","pushwoosh","heartbeat","ping","alive","webrtc","rtmp://","wss://","cloudfront.net","fastly.net"],s=u=>{let m=u.toLowerCase();return m.startsWith("data:")||m.startsWith("blob:")?!0:r.some(g=>m.includes(g))},l=u=>{let m=u.resourceType(),g=u.url();if(!o.has(m)||s(g))return;let w=u.headers();w.purpose==="prefetch"||["video","audio"].includes(w["sec-fetch-dest"])||(i.add(u),n=Date.now())},d=async u=>{let m=u.request();if(!i.has(m))return;let g=(u.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(v=>g.includes(v))){i.delete(m);return}if(![...a].some(v=>g.startsWith(v))){i.delete(m);return}let w=u.headers()["content-length"];if(w)try{if(parseInt(w,10)>5*1024*1024){i.delete(m);return}}catch{}i.delete(m),n=Date.now()},c=Date.now()-Qm;for(let u of await e.requests()){let m=u.resourceType(),g=u.url(),w=u.timing();o.has(m)&&!s(g)&&w.responseEnd===-1&&w.startTime>=c&&(i.add(u),n=Date.now())}h.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",d);try{let u=Date.now(),m=Zm;for(;;){await new Promise(w=>setTimeout(w,100));let g=Date.now();if(i.size===0&&g-n>=m){h.debug(`[waitForStableNetwork] Network idle after ${g-u}ms`);break}if(g-u>t){h.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",l),e.removeListener("response",d)}}async function Me(e,t=qm,i=Jm){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),ep(e,t)])}catch(r){throw r instanceof Error?new Error(`Failed during network stabilization: ${r.message}`):new Error("An unknown error occurred during network stabilization.")}let o=Date.now()-n,a=Math.max(i-o,0);a>0&&await new Promise(r=>setTimeout(r,a))}var oo,Jm,qm,Zm,Qm,Ie=y(()=>{"use strict";_t();F();oo=async(e,t,i)=>{let n=await e.context().newCDPSession(e),o=await n.send("Browser.getWindowForTarget");await n.send("Browser.setWindowBounds",{windowId:o.windowId,bounds:{width:t,height:i,windowState:"normal"}});try{await Promise.race([n.detach(),new Promise((a,r)=>setTimeout(()=>r(new Error("CDP detach timeout")),1e3))])}catch{}},Jm=.5*1e3,qm=30*1e3,Zm=1*1e3,Qm=3*1e3});function tp(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 xc(e,t,i={}){let n=Date.now();if(i.maxSteps!==void 0&&i.maxSteps<=0)throw new Error(`maxSteps must be >= 1, got ${i.maxSteps}`);let o=i.maxSteps??15,a=3,r=t.agentServices.getModel(),s=t.domService||new ue(t.agentServices.getDomServiceOptions()),l={...t,domService:s};b.init(),b.section("Task Execution Started"),b.log(`Task: ${e}`),b.log(`Max steps: ${o}`),b.log(`Model: ${r}`);let d={currentStep:0,maxSteps:o,consecutiveFailures:0,maxFailures:a,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},c=[],u=eo(i.customPrompt),m=new io(u);b.log(`System prompt length: ${u.length} chars`);let g=!1,w="",v=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:o});d.currentStep<o;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");d.currentStep++;let x=Date.now();b.section(`Step ${d.currentStep}/${o}`),b.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:d.currentStep});try{b.log("Waiting for page to stabilize..."),await Me(l.page),b.log("Page stabilized")}catch{b.log("Page stabilization timed out, continuing anyway")}let p;try{b.log("Preparing context (DOM + screenshot)...");let I=l.agentServices.getInteractiveClassNames(),P=l.agentServices.getIframeFallbackDomains();p=await bc(l.page,l.domService,I,P),b.log("Context prepared")}catch(I){if(I.message.includes("Execution context was destroyed")){b.log("Page navigating, waiting for load..."),await Me(l.page);let P=l.agentServices.getInteractiveClassNames(),L=l.agentServices.getIframeFallbackDomains();p=await bc(l.page,l.domService,P,L)}else throw b.error("Error preparing context",I),I}m.addStateMessage(e,p.currentUrl,p.domTree,p.screenshotBase64,d,{isFinalStep:d.currentStep===o-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let f=await np(m,r,i,p.screenshotBase64);if(f.tokenUsages&&f.tokenUsages.length>0&&c.push(...f.tokenUsages),!f.stepOutput){if(b.error("Failed to get valid LLM response"),d.consecutiveFailures++,d.consecutiveFailures>=a){w="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let S=f.stepOutput;sp(d.currentStep,o,S);let _=await ap(S,l,p.domState,d.currentStep,i.onEvent,p.screenshotBase64,f.debugInfo);v.push(..._.actionEntities);let k=rp(d.currentStep,S,_,d,x,f.debugInfo,f.tokenUsages),E=Date.now()-x;if(i.onEvent?.({type:"step_complete",step:d.currentStep,duration:E}),d.consecutiveFailures>=a){b.error(`Too many consecutive failures (${d.consecutiveFailures}), stopping`),w=`Reached the maximum allowed consecutive failures. Most recent error: ${d.lastFailReason}`;break}if(_.doneResult){g=_.doneResult.success,w=_.doneResult.summary;break}if(_.completesInstruction){g=!0,w="Instruction completed";break}}return d.currentStep>=o&&!g&&(w="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:d.currentStep,duration:Date.now()-n}),b.log(`Build success result: summary=${w}, completed=${g}, actions=${v.length}, tokens=${c.length}`),lp(d,v,g,w,n,c,r)}catch(x){let p=x.message;return b.error(`Task execution failed: ${p}`,x),i.onEvent?.({type:"error",error:p,recoverable:!1}),cp(d,p,n,c,r)}}async function bc(e,t,i,n){let{domState:o,screenshotBase64:a}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n}),r=o.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:r,screenshotBase64:a,domState:o}}function ip(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let n=i.image,o=typeof n=="string"?n:"";return{type:"image",file:o.startsWith("data:")?o:`data:image/png;base64,${o}`}}return{type:"text",text:i.text}}):t.content}))}async function np(e,t,i,n){let o=i.temperature??0,{system:a,messages:r}=e.getMessages(),s=0;for(let u of r)Array.isArray(u.content)&&(s+=u.content.filter(m=>m.type==="image").length);let l=be(t,s),d={model:we(t),system:a,messages:r,temperature:o,providerOptions:l},c=3;for(let u=0;u<c;u++)try{let m=Date.now();b.log(`Calling LLM (${t})...`);let g=await(0,yc.generateText)(d),w=Date.now()-m,v=g,x=v.usage;b.llmCall(t,w,x);let p=v.reasoningText;p&&(b.thinking(p),i.onEvent?.({type:"thinking",text:p})),e.addAssistantMessage(g.text);let f={systemPrompt:a,userPrompt:ip(r),rawLlmResponse:g.text,reasoningContent:p,screenshotWithSom:n},S=[],_=tp(x,t);_&&S.push(_);let k=op(g.text);if(!k)if(u<c-1){b.log(`Attempt ${u+1}/${c}: Failed to parse response, retrying...`),e.addTextMessage("user","Your response was not valid JSON. Please respond with a properly formatted JSON object according to the expected format."),await new Promise(E=>setTimeout(E,i.retryDelay||1e3));continue}else return b.error("All parsing attempts failed"),{stepOutput:null,debugInfo:f,tokenUsages:S};return{stepOutput:k,debugInfo:f,tokenUsages:S}}catch(m){if(u<c-1){b.log(`Attempt ${u+1}/${c}: LLM call failed (${m.message}), retrying...`),await new Promise(g=>setTimeout(g,i.retryDelay||1e3));continue}else throw b.error("All LLM call attempts failed",m),m}return{stepOutput:null}}function op(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 b.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return b.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return b.error("Action missing required field: action_name"),null;if(!n.description)return b.error("Action missing required field: description"),null}return i}catch(i){return b.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),b.error(`Parse error: ${i.message}`),null}}async function ap(e,t,i,n,o,a,r){let s=[],l=!0,d=null;b.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let c=null,u={...t,domState:i},m=a;for(let g of e.actions){if(g.action_name==="done"){c={success:g.kwargs.success??!0,summary:g.kwargs.summary||g.kwargs.text||"Task completed"};break}let w={},v=g.kwargs?.element_index??g.kwargs?.index;if(typeof v=="number"){let p=i.selectorMap.get(v);p&&(w=await N(t.page,p))}let x={...w,action_description:g.description,action_data:{action_name:g.action_name,kwargs:g.kwargs}};try{let p=await W.execute(g.action_name,g.kwargs,u);g.action_name==="perform_accurate_operation"&&(x=p.actionEntity);let f=await u.agentServices.getCurrentPage();if(f&&(u.page=f,t.page=u.page),p?.success===!1){l=!1,b.log("Action failed, stopping execution of remaining actions in this step"),d=p.error||"Action execution failed";break}s.push(x),o?.({type:"action",action_entity:x,step:n,debugInfo:r})}catch(p){l=!1,d=p.message,b.error(`Action execution failed: ${p.message}`);break}}return{allSuccess:l,failReason:d,actionEntities:s,doneResult:c,completesInstruction:e.completes_instruction??!1}}function rp(e,t,i,n,o,a,r){let s={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:o,duration:Date.now()-o,outcome:{success:i.allSuccess},debugInfo:a,tokenUsages:r};if(n.lastGoal=t.current_goal,t.evaluation_previous_goal&&(n.lastEvaluation=t.evaluation_previous_goal),t.memory&&t.memory.trim()){let l=t.memory.trim();n.memory.includes(l)||(n.memory.push(l),n.memory.length>10&&(n.memory=n.memory.slice(-10)))}return i.allSuccess?(n.consecutiveFailures=0,n.lastFailReason=null):(n.consecutiveFailures++,n.lastFailReason=i.failReason),n.stepHistory.push(s),s}function sp(e,t,i){if(b.log(`Step ${e}/${t}`),i.thinking&&b.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&b.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&b.log(`Memory: ${i.memory}`),b.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];b.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else b.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,o)=>{b.log(` ${o+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function lp(e,t,i,n,o,a,r){let s=a.reduce((c,u)=>c+u.prompt_tokens,0),l=a.reduce((c,u)=>c+u.completion_tokens,0),d=a.reduce((c,u)=>c+u.total_tokens,0);return{success:!0,completed:i,summary:n,trajectory:{steps:e.currentStep,actions:t,stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-o,model:r,successfulSteps:e.stepHistory.filter(c=>c.outcome.success).length,failedSteps:e.stepHistory.filter(c=>!c.outcome.success).length,promptTokens:s,completionTokens:l,totalTokens:d,tokenUsages:a}}}function cp(e,t,i,n,o){let a=n.reduce((l,d)=>l+d.prompt_tokens,0),r=n.reduce((l,d)=>l+d.completion_tokens,0),s=n.reduce((l,d)=>l+d.total_tokens,0);return{success:!1,completed:!1,error:t,trajectory:{steps:e.currentStep,actions:[],stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-i,model:o,successfulSteps:e.stepHistory.filter(l=>l.outcome.success).length,failedSteps:e.stepHistory.filter(l=>!l.outcome.success).length,promptTokens:a,completionTokens:r,totalTokens:s,tokenUsages:n}}}var yc,vc=y(()=>{"use strict";Ia();to();Te();Ve();ie();Ie();Ee();j();yc=require("ai")});var _c={};je(_c,{TaskMessageManager:()=>io,formatFinalStepWarning:()=>mc,formatTaskContext:()=>Qn,getBrowserTaskJSONPrompt:()=>eo,runTaskLoop:()=>xc});var kc=y(()=>{"use strict";vc();Ia();to();Te();Dn();Ve();zt();Xt();ht();Yt();Jt();ie();Ie();_t();Ee();Ht();rt();Wt();Ne();j();ze();F();te();pt();H();pe()});async function Qt(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(W.has(i)){let o=await W.execute(i,n,t),a=o?.success!==!1,r=o?.error||o?.message;return{success:a,error:a?void 0:r}}else{let{page:o,agentServices:a}=t;return await(await dp()).execute(o,e,a),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function dp(){if(ao)return ao;let e=await Promise.resolve().then(()=>(xt(),yt));return ao=new e.default,ao}async function wt(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new ue(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await oa(r,a,n);return s.status==="error"?{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error,debugInfo:s.debugInfo}:{status:"success",completed:s.goalAccomplished||!1,actionEntities:s.actionEntity?[s.actionEntity]:[],explanation:s.reasoning,debugInfo:s.debugInfo}}async function Xe(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new ue(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await oa(r,a,n);if(s.status==="error"||!s.actionEntity)return{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error||"No action generated",debugInfo:s.debugInfo};let{actionEntity:l,reasoning:d,goalAccomplished:c,debugInfo:u}=s,m=await Qt(l,a);return m.success?(d&&i.addNote(d),{status:"success",completed:c||!1,actionEntities:[l],explanation:d,debugInfo:u}):{status:"error",completed:!1,actionEntities:[l],error:m.error||"Action execution failed",debugInfo:u}}async function Ye(e,t,i,n={}){let o={page:t,agentServices:i,domService:new ue(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},a=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),Ds(a,o,n)}async function Je(e,t,i,n,o={}){let{runTaskLoop:a}=await Promise.resolve().then(()=>(kc(),_c)),r=n?l=>{n(l)}:void 0,s=await a(e,{page:t,agentServices:i,domService:void 0,executionHistory:o.executionHistory,variables:o.variables,sensitiveKeys:o.sensitiveKeys},{maxSteps:o.maxSteps,onEvent:r,abortSignal:o.abortSignal});return{status:s.success?"success":"error",completed:s.completed,actionEntities:s.trajectory.actions,explanation:s.summary,error:s.error,tokenUsages:s.metadata.tokenUsages}}var ao,ei=y(()=>{"use strict";xn();Te();Ve();ao=null});function Sc(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:up,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,o={page:i.page,agentServices:i.agentServices,domService:i.domService},a=await lt(n,o,{});if(a.status==="error"||!a.actionEntity)return{success:!1,actionEntity:{action_description:n,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:n}}},error:a.error||"Failed to generate action"};let{actionEntity:r}=a,s=await Qt(r,o);return{success:s.success,actionEntity:r,message:s.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:s.error}}})}var Pa,up,Ca=y(()=>{"use strict";ei();ct();Pa=require("zod"),up=Pa.z.object({instruction:Pa.z.string().describe('The instruction of the operation to perform. Can only include one operation. Do not inlcude element indexes just describe the element, e.g. "select the text "Hello, world!" in "Hello, world!""')})});async function hp(e,t,i){let{apiKey:n,domain:o}=e;if(!n||!o)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let a=[];try{let r=`https://api.mailgun.net/v3/${o}/events`,s={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(s.from=i.from_email),i.since)s.begin=Math.floor(i.since/1e3).toString();else{let c=new Date(Date.now()-6e5);s.begin=Math.floor(c.getTime()/1e3).toString()}h.info(`Mailgun params: ${JSON.stringify(s)}`);let l=await fetch(r+"?"+new URLSearchParams(s),{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!l.ok){let c=await l.text();throw new Error(`Mailgun events API error: ${c}`)}let d=(await l.json()).items||[];for(let c of d.slice(0,10)){if(c.event!=="accepted")continue;let u=(c.storage||{}).url;if(h.info(`message_url: ${u}`),!u){let w=(c.message||{}).headers||{},v=w.subject||"",x=w.from||"",p=w.to||"";if(i.from_email&&!x.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!p.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!v.toLowerCase().includes(i.subject.toLowerCase()))continue;a.push({subject:v,from:x,to:p,date:new Date(c.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:w["message-id"]||""});continue}let m=u.split("/"),g=m[m.length-1];if(h.info(`Storage key: ${g}`),g){let w=`https://api.mailgun.net/v3/domains/${o}/messages/${g}`;try{let v=await fetch(w,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,Accept:"application/json"}});if(v.ok){let x=await v.json(),p=x.Subject||"",f=x.From||"",S=x.To||"",_=x.Date||"",k=x["Message-Id"]||"";h.info(`subject: ${p}`),h.info(`from_addr: ${f}`),h.info(`to_addr: ${S}`),h.info(`date: ${_}`),h.info(`message_id: ${k}`);let E=x["body-html"]||x["body-plain"]||"";if(E&&E.includes("<")&&(E=(0,Tc.convert)(E)),h.info(`Body: ${E.substring(0,200)}...`),i.subject&&!p.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!E.toLowerCase().includes(i.body_contains.toLowerCase()))continue;a.push({subject:p,from:f,to:S,date:_,body:E,message_id:k});continue}else h.warn(`Messages API returned ${v.status}`)}catch(v){h.warn(`Failed to parse JSON response: ${v}`)}}try{let w=await fetch(u,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!w.ok){h.warn(`Could not fetch stored message: ${w.status}`);continue}let v=await w.text();h.info(`Fallback: Raw email length: ${v.length}`);let x=v.split(`
|
|
4358
|
-
`),p=!0,f={},S="";for(let
|
|
4359
|
-
`}let _=f.subject||"",k=f.from||"",
|
|
4357
|
+
`});function bc(e,t=!0,i=!1){return[...e!==void 0?[`--remote-debugging-port=${e}`,"--remote-allow-origins=*"]:[],"--no-sandbox","--disable-blink-features=AutomationControlled","--timezone=America/Los_Angeles",...i?["--headless"]:[],...t?["--disable-web-security","--disable-site-isolation-trials","--disable-features=IsolateOrigins,site-per-process","--allow-running-insecure-content","--ignore-certificate-errors","--ignore-ssl-errors","--ignore-certificate-errors-spki-list"]:[]]}async function yc(e,t){let i=await e.newContext(t);return i.addInitScript(We),i}async function ro(e){return(await(await fetch(`http://127.0.0.1:${e}/json/version`)).json()).webSocketDebuggerUrl.replace("localhost","127.0.0.1")}async function xc(e,t){let i=await(await fetch(`http://localhost:${e}/json/list`)).json();for(let n of i)if(n.type==="page"&&n.id===t)return n.webSocketDebuggerUrl;throw new Error(`No page found for id: ${t}`)}async function vc(e){let t=await e.context().newCDPSession(e),i=await t.send("Target.getTargetInfo");return await t.detach(),i.targetInfo}async function sp(e,t){let i=new Set,n=Date.now(),o=new Set(["document","stylesheet","image","font","script","iframe"]),a=new Set(["text/html","text/css","application/javascript","image/","font/","application/json"]),s=["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"],r=h=>{let m=h.toLowerCase();return m.startsWith("data:")||m.startsWith("blob:")?!0:s.some(g=>m.includes(g))},l=h=>{let m=h.resourceType(),g=h.url();if(!o.has(m)||r(g))return;let y=h.headers();y.purpose==="prefetch"||["video","audio"].includes(y["sec-fetch-dest"])||(i.add(h),n=Date.now())},d=async h=>{let m=h.request();if(!i.has(m))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(m);return}if(![...a].some(v=>g.startsWith(v))){i.delete(m);return}let y=h.headers()["content-length"];if(y)try{if(parseInt(y,10)>5*1024*1024){i.delete(m);return}}catch{}i.delete(m),n=Date.now()},c=Date.now()-rp;for(let h of await e.requests()){let m=h.resourceType(),g=h.url(),y=h.timing();o.has(m)&&!r(g)&&y.responseEnd===-1&&y.startTime>=c&&(i.add(h),n=Date.now())}u.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",d);try{let h=Date.now(),m=ap;for(;;){await new Promise(y=>setTimeout(y,100));let g=Date.now();if(i.size===0&&g-n>=m){u.debug(`[waitForStableNetwork] Network idle after ${g-h}ms`);break}if(g-h>t){u.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",l),e.removeListener("response",d)}}async function Le(e,t=op,i=np){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),sp(e,t)])}catch(s){throw s instanceof Error?new Error(`Failed during network stabilization: ${s.message}`):new Error("An unknown error occurred during network stabilization.")}let o=Date.now()-n,a=Math.max(i-o,0);a>0&&await new Promise(s=>setTimeout(s,a))}var so,np,op,ap,rp,De=b(()=>{"use strict";kt();W();so=async(e,t,i)=>{let n=await e.context().newCDPSession(e),o=await n.send("Browser.getWindowForTarget");await n.send("Browser.setWindowBounds",{windowId:o.windowId,bounds:{width:t,height:i,windowState:"normal"}});try{await Promise.race([n.detach(),new Promise((a,s)=>setTimeout(()=>s(new Error("CDP detach timeout")),1e3))])}catch{}},np=.5*1e3,op=30*1e3,ap=1*1e3,rp=3*1e3});function lp(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 Sc(e,t,i={}){let n=Date.now();if(i.maxSteps!==void 0&&i.maxSteps<=0)throw new Error(`maxSteps must be >= 1, got ${i.maxSteps}`);let o=i.maxSteps??15,a=3,s=t.agentServices.getModel(),r=t.domService||new we(t.agentServices.getDomServiceOptions()),l={...t,domService:r};w.init(),w.section("Task Execution Started"),w.log(`Task: ${e}`),w.log(`Max steps: ${o}`),w.log(`Model: ${s}`);let d={currentStep:0,maxSteps:o,consecutiveFailures:0,maxFailures:a,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},c=[],h=no(i.customPrompt),m=new ao(h);w.log(`System prompt length: ${h.length} chars`);let g=!1,y="",v=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:o});d.currentStep<o;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");d.currentStep++;let x=Date.now();w.section(`Step ${d.currentStep}/${o}`),w.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:d.currentStep});try{w.log("Waiting for page to stabilize..."),await Le(l.page),w.log("Page stabilized")}catch{w.log("Page stabilization timed out, continuing anyway")}let p;try{w.log("Preparing context (DOM + screenshot)...");let I=l.agentServices.getInteractiveClassNames(),O=l.agentServices.getIframeFallbackDomains();p=await _c(l.page,l.domService,I,O),w.log("Context prepared")}catch(I){if(I.message.includes("Execution context was destroyed")){w.log("Page navigating, waiting for load..."),await Le(l.page);let O=l.agentServices.getInteractiveClassNames(),C=l.agentServices.getIframeFallbackDomains();p=await _c(l.page,l.domService,O,C)}else throw w.error("Error preparing context",I),I}m.addStateMessage(e,p.currentUrl,p.domTree,p.screenshotBase64,d,{isFinalStep:d.currentStep===o-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let f=await dp(m,s,i,p.screenshotBase64);if(f.tokenUsages&&f.tokenUsages.length>0&&c.push(...f.tokenUsages),!f.stepOutput){if(w.error("Failed to get valid LLM response"),d.consecutiveFailures++,d.consecutiveFailures>=a){y="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let S=f.stepOutput;pp(d.currentStep,o,S);let _=await hp(S,l,p.domState,d.currentStep,i.onEvent,p.screenshotBase64,f.debugInfo);v.push(..._.actionEntities);let k=mp(d.currentStep,S,_,d,x,f.debugInfo,f.tokenUsages),A=Date.now()-x;if(i.onEvent?.({type:"step_complete",step:d.currentStep,duration:A}),d.consecutiveFailures>=a){w.error(`Too many consecutive failures (${d.consecutiveFailures}), stopping`),y=`Reached the maximum allowed consecutive failures. Most recent error: ${d.lastFailReason}`;break}if(_.doneResult){g=_.doneResult.success,y=_.doneResult.summary;break}if(_.completesInstruction){g=!0,y="Instruction completed";break}}return d.currentStep>=o&&!g&&(y="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:d.currentStep,duration:Date.now()-n}),w.log(`Build success result: summary=${y}, completed=${g}, actions=${v.length}, tokens=${c.length}`),gp(d,v,g,y,n,c,s)}catch(x){let p=x.message;return w.error(`Task execution failed: ${p}`,x),i.onEvent?.({type:"error",error:p,recoverable:!1}),fp(d,p,n,c,s)}}async function _c(e,t,i,n){let{domState:o,screenshotBase64:a}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n}),s=o.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:s,screenshotBase64:a,domState:o}}function cp(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let n=i.image,o=typeof n=="string"?n:"";return{type:"image",file:o.startsWith("data:")?o:`data:image/png;base64,${o}`}}return{type:"text",text:i.text}}):t.content}))}async function dp(e,t,i,n){let o=i.temperature??0,{system:a,messages:s}=e.getMessages(),r=0;for(let h of s)Array.isArray(h.content)&&(r+=h.content.filter(m=>m.type==="image").length);let l=Ee(t,r),d={model:Se(t),system:a,messages:s,temperature:o,providerOptions:l},c=3;for(let h=0;h<c;h++)try{let m=Date.now();w.log(`Calling LLM (${t})...`);let g=await(0,kc.generateText)(d),y=Date.now()-m,v=g,x=v.usage;w.llmCall(t,y,x);let p=v.reasoningText;p&&(w.thinking(p),i.onEvent?.({type:"thinking",text:p})),e.addAssistantMessage(g.text);let f={systemPrompt:a,userPrompt:cp(s),rawLlmResponse:g.text,reasoningContent:p,screenshotWithSom:n},S=[],_=lp(x,t);_&&S.push(_);let k=up(g.text);if(!k)if(h<c-1){w.log(`Attempt ${h+1}/${c}: Failed to parse response, retrying...`),e.addTextMessage("user","Your response was not valid JSON. Please respond with a properly formatted JSON object according to the expected format."),await new Promise(A=>setTimeout(A,i.retryDelay||1e3));continue}else return w.error("All parsing attempts failed"),{stepOutput:null,debugInfo:f,tokenUsages:S};return{stepOutput:k,debugInfo:f,tokenUsages:S}}catch(m){if(h<c-1){w.log(`Attempt ${h+1}/${c}: LLM call failed (${m.message}), retrying...`),await new Promise(g=>setTimeout(g,i.retryDelay||1e3));continue}else throw w.error("All LLM call attempts failed",m),m}return{stepOutput:null}}function up(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 hp(e,t,i,n,o,a,s){let r=[],l=!0,d=null;w.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let c=null,h={...t,domState:i},m=a;for(let g of e.actions){if(g.action_name==="done"){c={success:g.kwargs.success??!0,summary:g.kwargs.summary||g.kwargs.text||"Task completed"};break}let y={},v=g.kwargs?.element_index??g.kwargs?.index;if(typeof v=="number"){let p=i.selectorMap.get(v);p&&(y=await F(t.page,p))}let x={...y,action_description:g.description,action_data:{action_name:g.action_name,kwargs:g.kwargs}};try{let p=await G.execute(g.action_name,g.kwargs,h);g.action_name==="perform_accurate_operation"&&(x=p.actionEntity);let f=await h.agentServices.getCurrentPage();if(f&&(h.page=f,t.page=h.page),p?.success===!1){l=!1,w.log("Action failed, stopping execution of remaining actions in this step"),d=p.error||"Action execution failed";break}r.push(x),o?.({type:"action",action_entity:x,step:n,debugInfo:s})}catch(p){l=!1,d=p.message,w.error(`Action execution failed: ${p.message}`);break}}return{allSuccess:l,failReason:d,actionEntities:r,doneResult:c,completesInstruction:e.completes_instruction??!1}}function mp(e,t,i,n,o,a,s){let r={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:o,duration:Date.now()-o,outcome:{success:i.allSuccess},debugInfo:a,tokenUsages:s};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(r),r}function pp(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,o)=>{w.log(` ${o+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function gp(e,t,i,n,o,a,s){let r=a.reduce((c,h)=>c+h.prompt_tokens,0),l=a.reduce((c,h)=>c+h.completion_tokens,0),d=a.reduce((c,h)=>c+h.total_tokens,0);return{success:!0,completed:i,summary:n,trajectory:{steps:e.currentStep,actions:t,stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-o,model:s,successfulSteps:e.stepHistory.filter(c=>c.outcome.success).length,failedSteps:e.stepHistory.filter(c=>!c.outcome.success).length,promptTokens:r,completionTokens:l,totalTokens:d,tokenUsages:a}}}function fp(e,t,i,n,o){let a=n.reduce((l,d)=>l+d.prompt_tokens,0),s=n.reduce((l,d)=>l+d.completion_tokens,0),r=n.reduce((l,d)=>l+d.total_tokens,0);return{success:!1,completed:!1,error:t,trajectory:{steps:e.currentStep,actions:[],stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-i,model:o,successfulSteps:e.stepHistory.filter(l=>l.outcome.success).length,failedSteps:e.stepHistory.filter(l=>!l.outcome.success).length,promptTokens:a,completionTokens:s,totalTokens:r,tokenUsages:n}}}var kc,Ec=b(()=>{"use strict";La();oo();$e();Ye();ae();De();Ce();Y();kc=require("ai")});var Tc={};Ve(Tc,{TaskMessageManager:()=>ao,formatFinalStepWarning:()=>wc,formatTaskContext:()=>io,getBrowserTaskJSONPrompt:()=>no,runTaskLoop:()=>Sc});var Ac=b(()=>{"use strict";Ec();La();oo();$e();Rn();Ye();Yt();qt();mt();Zt();Qt();ae();De();kt();Ce();Bt();st();Gt();He();Y();Xe();W();oe();gt();U();ve()});async function ii(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(G.has(i)){let o=await G.execute(i,n,t),a=o?.success!==!1,s=o?.error||o?.message;return{success:a,error:a?void 0:s}}else{let{page:o,agentServices:a}=t;return await(await wp()).execute(o,e,a),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function wp(){if(lo)return lo;let e=await Promise.resolve().then(()=>(vt(),xt));return lo=new e.default,lo}async function bt(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new we(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},s=i.replaceVariables(e),r=await ca(s,a,n);return r.status==="error"?{status:"error",completed:r.goalAccomplished||!1,actionEntities:[],explanation:r.reasoning,error:r.error,debugInfo:r.debugInfo}:{status:"success",completed:r.goalAccomplished||!1,actionEntities:r.actionEntity?[r.actionEntity]:[],explanation:r.reasoning,debugInfo:r.debugInfo}}async function Je(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new we(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},s=i.replaceVariables(e),r=await ca(s,a,n);if(r.status==="error"||!r.actionEntity)return{status:"error",completed:r.goalAccomplished||!1,actionEntities:[],explanation:r.reasoning,error:r.error||"No action generated",debugInfo:r.debugInfo};let{actionEntity:l,reasoning:d,goalAccomplished:c,debugInfo:h}=r,m=await ii(l,a);return m.success?(d&&i.addNote(d),{status:"success",completed:c||!1,actionEntities:[l],explanation:d,debugInfo:h}):{status:"error",completed:!1,actionEntities:[l],error:m.error||"Action execution failed",debugInfo:h}}async function qe(e,t,i,n={}){let o={page:t,agentServices:i,domService:new we(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},a=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),Fs(a,o,n)}async function Ze(e,t,i,n,o={}){let{runTaskLoop:a}=await Promise.resolve().then(()=>(Ac(),Tc)),s=n?l=>{n(l)}:void 0,r=await a(e,{page:t,agentServices:i,domService:void 0,executionHistory:o.executionHistory,variables:o.variables,sensitiveKeys:o.sensitiveKeys},{maxSteps:o.maxSteps,onEvent:s,abortSignal:o.abortSignal});return{status:r.success?"success":"error",completed:r.completed,actionEntities:r.trajectory.actions,explanation:r.summary,error:r.error,tokenUsages:r.metadata.tokenUsages}}var lo,ni=b(()=>{"use strict";kn();$e();Ye();lo=null});function Mc(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:bp,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,o={page:i.page,agentServices:i.agentServices,domService:i.domService},a=await ct(n,o,{});if(a.status==="error"||!a.actionEntity)return{success:!1,actionEntity:{action_description:n,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:n}}},error:a.error||"Failed to generate action"};let{actionEntity:s}=a,r=await ii(s,o);return{success:r.success,actionEntity:s,message:r.success?`Successfully executed action: ${s.action_data?.action_name}`:void 0,error:r.error}}})}var Da,bp,Na=b(()=>{"use strict";ni();dt();Da=require("zod"),bp=Da.z.object({instruction:Da.z.string().describe('The instruction of the operation to perform. Can only include one operation. Do not inlcude element indexes just describe the element, e.g. "select the text "Hello, world!" in "Hello, world!""')})});async function yp(e,t,i){let{apiKey:n,domain:o}=e;if(!n||!o)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let a=[];try{let s=`https://api.mailgun.net/v3/${o}/events`,r={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(r.from=i.from_email),i.since)r.begin=Math.floor(i.since/1e3).toString();else{let c=new Date(Date.now()-6e5);r.begin=Math.floor(c.getTime()/1e3).toString()}u.info(`Mailgun params: ${JSON.stringify(r)}`);let l=await fetch(s+"?"+new URLSearchParams(r),{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!l.ok){let c=await l.text();throw new Error(`Mailgun events API error: ${c}`)}let d=(await l.json()).items||[];for(let c of d.slice(0,10)){if(c.event!=="accepted")continue;let h=(c.storage||{}).url;if(u.info(`message_url: ${h}`),!h){let y=(c.message||{}).headers||{},v=y.subject||"",x=y.from||"",p=y.to||"";if(i.from_email&&!x.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!p.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!v.toLowerCase().includes(i.subject.toLowerCase()))continue;a.push({subject:v,from:x,to:p,date:new Date(c.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:y["message-id"]||""});continue}let m=h.split("/"),g=m[m.length-1];if(u.info(`Storage key: ${g}`),g){let y=`https://api.mailgun.net/v3/domains/${o}/messages/${g}`;try{let v=await fetch(y,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,Accept:"application/json"}});if(v.ok){let x=await v.json(),p=x.Subject||"",f=x.From||"",S=x.To||"",_=x.Date||"",k=x["Message-Id"]||"";u.info(`subject: ${p}`),u.info(`from_addr: ${f}`),u.info(`to_addr: ${S}`),u.info(`date: ${_}`),u.info(`message_id: ${k}`);let A=x["body-html"]||x["body-plain"]||"";if(A&&A.includes("<")&&(A=(0,Pc.convert)(A)),u.info(`Body: ${A.substring(0,200)}...`),i.subject&&!p.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!A.toLowerCase().includes(i.body_contains.toLowerCase()))continue;a.push({subject:p,from:f,to:S,date:_,body:A,message_id:k});continue}else u.warn(`Messages API returned ${v.status}`)}catch(v){u.warn(`Failed to parse JSON response: ${v}`)}}try{let y=await fetch(h,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!y.ok){u.warn(`Could not fetch stored message: ${y.status}`);continue}let v=await y.text();u.info(`Fallback: Raw email length: ${v.length}`);let x=v.split(`
|
|
4358
|
+
`),p=!0,f={},S="";for(let C=0;C<x.length;C++){let R=x[C];if(R.trim()===""&&p){p=!1;continue}if(p){let X=R.match(/^([^:]+):\s*(.+)$/);X&&(f[X[1].toLowerCase()]=X[2])}else S+=R+`
|
|
4359
|
+
`}let _=f.subject||"",k=f.from||"",A=f.to||"",I=f.date||"",O=f["message-id"]||"";if(i.subject&&!_.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!S.toLowerCase().includes(i.body_contains.toLowerCase()))continue;a.push({subject:_,from:k,to:A,date:I,body:S.trim(),message_id:O})}catch(y){u.warn(`Error fetching raw message: ${y}`)}}if(a.length>0){try{a.sort((h,m)=>{let g=new Date(h.date).getTime();return new Date(m.date).getTime()-g})}catch{}let c=a[0];return u.info(`Returning most recent email: ${c.subject}`),[c]}return a}catch(s){throw u.error(`Error fetching emails from Mailgun: ${s.message}`),new Error(`Error fetching emails from Mailgun: ${s.message}`)}}function xp(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
|
|
4360
4360
|
|
|
4361
4361
|
Please carefully examine the email content and look for:
|
|
4362
4362
|
1. Numeric codes (usually 4-8 digits)
|
|
@@ -4413,39 +4413,39 @@ Examples of what to extract:
|
|
|
4413
4413
|
Extract: https://service.com/v/longtoken123456789abcdefghijklmnopqrstuvwxyz?param1=value1¶m2=value2
|
|
4414
4414
|
|
|
4415
4415
|
Return ONLY the complete extracted URL or "NOT_FOUND".`;if(e==="custom"){if(!t)throw new Error("Custom prompt is required when extraction_type is custom");return t+`
|
|
4416
|
-
Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function
|
|
4416
|
+
Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function vp(e,t,i){try{let n=`${t}
|
|
4417
4417
|
---
|
|
4418
4418
|
Email Content:
|
|
4419
4419
|
---
|
|
4420
4420
|
${e}
|
|
4421
4421
|
---
|
|
4422
|
-
`,o=
|
|
4422
|
+
`,o=Se(i);return(await(0,Ic.generateText)({model:o,messages:[{role:"user",content:n}],temperature:0,providerOptions:Ee(i,0)})).text.trim()||"NOT_FOUND"}catch(n){throw u.error(`Error in LLM extraction: ${n.message}`),new Error(`Error in LLM extraction: ${n.message}`)}}async function Cc(e,t){u.info(`extract_email_content:
|
|
4423
4423
|
forward_email: ${t.forward_email}
|
|
4424
4424
|
extraction_type: ${t.extraction_type}
|
|
4425
4425
|
filters: ${JSON.stringify(t.filters||{})}
|
|
4426
4426
|
timeout: ${t.timeout||60}
|
|
4427
|
-
polling_interval: 10`);let i=t.timeout||60,n=10;try{if(t.extraction_type==="custom"&&!t.prompt)return{data:void 0,status:"error",message:"Custom prompt is required when extraction_type is custom"};let o=
|
|
4427
|
+
polling_interval: 10`);let i=t.timeout||60,n=10;try{if(t.extraction_type==="custom"&&!t.prompt)return{data:void 0,status:"error",message:"Custom prompt is required when extraction_type is custom"};let o=xp(t.extraction_type,t.prompt),a=new Date,s=new Date(a.getTime()+i*1e3),r=0;for(u.info(`Starting email polling for ${i} seconds with ${n}s intervals`);new Date<s;){r++,u.info(`Polling attempt ${r}`);try{let d=t.filters||{},c=await yp(e,t.forward_email,d);if(c.length>0){u.info(`Found ${c.length} emails matching criteria`);let h=[];for(let m of c){let g=`Subject: ${m.subject}
|
|
4428
4428
|
From: ${m.from}
|
|
4429
4429
|
To: ${m.to}
|
|
4430
4430
|
Date: ${m.date}
|
|
4431
4431
|
|
|
4432
4432
|
Body:
|
|
4433
|
-
${m.body}`,
|
|
4434
|
-
`)}var
|
|
4435
|
-
`)}var fp,wp,Fc=y(()=>{"use strict";Da();Te();fp=[so(W),lo(W),co(W),uo(W),ho(W),mo(W),po(W),go(W),wo(W),fo(W)],wp=Promise.all(fp)});function Wc(e){return e.getTools().map(t=>({name:t.name,description:t.description,inputSchema:Ji(t.schema)}))}var Hc,Uc=y(()=>{"use strict";Ot();Hc=class{constructor(e,t){this.registry=e,this.getContext=t}getToolDefinitions(){return this.registry.getTools().filter(e=>e.availability.mcp).map(e=>({name:e.name,description:e.description,inputSchema:Ji(e.schema)}))}getToolDefinitionsFiltered(e){let t=new Set(e);return this.registry.getTools().filter(i=>t.has(i.name)&&i.availability.mcp).map(i=>({name:i.name,description:i.description,inputSchema:Ji(i.schema)}))}async createServer(e="web-sdk-tools"){throw new Error("MCP server creation not yet implemented. Install and configure an MCP SDK like @modelcontextprotocol/sdk")}async executeTool(e,t){let i=await this.getContext(),n=await this.registry.execute(e,t,i);return{content:[{type:"text",text:n.success?n.message||"Tool executed successfully":n.error||"Tool execution failed"}]}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});var Bc=y(()=>{"use strict"});function Gc(){let e=process.env.SHIPLIGHT_REGISTRY_URL;return e?e.replace(/\/$/,""):null}async function kt(e){let t=Gc();if(!t)return null;try{let i=await fetch(`${t}/browsers`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify(e)});return i.ok?(await i.json()).id??null:null}catch{return null}}async function St(e){if(!e)return;let t=Gc();if(t)try{await fetch(`${t}/browsers/${encodeURIComponent(e)}`,{method:"DELETE"})}catch{}}var Oa=y(()=>{"use strict"});function yo(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let r=a.startsWith("$")?a.slice(1):a,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o}var Z_,T,tk,ck,hk,bp,xo,yp,xp,vp,_p,kp,Sp,Ep,Tp,qe,Et,jc,Ap,bo,Ni,J_,q_,vo,zc,Vc,Xc,Yc,Ri,Na,Ra,Mp,Kc,Ip,Oi,Pp,Cp,$p,re,Lp,Dp,ek,uk,Tt=y(()=>{"use strict";pe();Z_=require("uuid"),T=require("zod"),tk=require("yaml"),ck=require("uuid"),hk=require("yaml");bp="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",xo=112,yp=1920,xp=1080,vp=1920,_p=1080-xo,kp=1280,Sp=720,Ep=500,Tp=500,qe="Desktop Chrome",Et=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Et||{}),jc={"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"}},Ap={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"]},bo=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Ap[e].map(n=>jc[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Ni=e=>jc[e],J_={desktop:{label:"Desktop",type:"desktop",devices:bo("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:bo("mobile")}},q_={desktop:{label:"Desktop",type:"desktop",devices:bo("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:bo("mobile",!0)}},vo=(e,t=!1)=>{let i={userAgent:bp,viewport:{width:vp,height:_p},isMobile:!1,hasTouch:!1};if(!e||e===qe)return i;let n=Ni(e);if(!n)return i;let{width:o,height:a}=n.viewport,r=Math.max(Ep/o,1),s=Math.max(Tp/a,1),l=Math.max(r,s),d={width:Math.round(o*l),height:Math.round(a*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},zc=e=>{let t={width:yp,height:xp};if(!e||e===qe)return t;let i=vo(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+xo}:t},Vc=e=>{let t={width:kp,height:Sp};if(!e||e===qe)return t;let i=vo(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Xc=e=>!e||e===qe?void 0:Ni(e)?.channel,Yc=e=>!e||e===qe?"chromium":Ni(e)?.defaultBrowserType??"chromium",Ri=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Ri||{}),Na=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Na||{}),Ra=class Jc{constructor(){Jo(this,"data",{}),Jo(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 Jc;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[o,a]of Object.entries(t.data))i.set(o,a,n.has(o))}return i}},Mp=T.z.enum(["JS_CODE","AI_MODE"]),Kc=T.z.object({type:Mp,expression:T.z.string()}),Ip=T.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Oi=T.z.object({uid:T.z.string(),type:Ip,comment:T.z.string().optional()}),Pp=T.z.object({action_data:T.z.object({action_name:T.z.string(),kwargs:T.z.record(T.z.any()).optional(),args:T.z.array(T.z.any()).optional()}),action_description:T.z.string().optional(),url:T.z.string().optional(),xpath:T.z.string().nullable().optional(),locator:T.z.string().nullable().optional(),css_selector:T.z.string().nullable().optional(),unique_selector:T.z.string().nullable().optional(),element_index:T.z.number().nullable().optional(),frame_path:T.z.array(T.z.any()).optional(),artifacts:T.z.record(T.z.any()).optional(),feedback:T.z.string().optional(),original_browser_use_action:T.z.any().optional()}).passthrough(),Cp=Oi.extend({type:T.z.literal("DRAFT"),description:T.z.string()}),$p=Oi.extend({type:T.z.literal("ACTION"),description:T.z.string(),action_entity:Pp.optional(),locator:T.z.string().optional(),use_pure_vision:T.z.boolean().optional()}),re=T.z.lazy(()=>T.z.union([Cp,$p,Oi.extend({type:T.z.literal("STEP"),description:T.z.string().optional().default(""),statements:T.z.array(re),reference_id:T.z.number().optional(),template_path:T.z.string().optional(),template_params:T.z.record(T.z.string()).optional()}),Oi.extend({type:T.z.literal("IF_ELSE"),description:T.z.string().optional(),condition:Kc,then:T.z.array(re),else:T.z.array(re).optional()}),Oi.extend({type:T.z.literal("WHILE_LOOP"),description:T.z.string().optional(),condition:Kc,body:T.z.array(re),timeout_ms:T.z.number().optional()})])),Lp=T.z.object({name:T.z.string(),statements:T.z.array(re),teardown:T.z.array(re).optional(),skip:T.z.union([T.z.boolean(),T.z.string()]).optional(),timeout:T.z.number().optional(),fail:T.z.union([T.z.boolean(),T.z.string()]).optional(),only:T.z.boolean().optional(),slow:T.z.boolean().optional()}),Dp=T.z.object({tests:T.z.array(Lp).min(1),beforeAll:T.z.array(re).optional(),afterAll:T.z.array(re).optional(),beforeEach:T.z.array(re).optional(),afterEach:T.z.array(re).optional()}),ek=T.z.object({comment:T.z.string().optional(),version:T.z.string().optional(),goal:T.z.string().optional(),url:T.z.string().optional(),baseURL:T.z.string().optional(),final_feedback:T.z.string().optional(),completed:T.z.boolean().optional(),success:T.z.boolean().optional(),statements:T.z.array(re).optional(),teardown:T.z.array(re).optional(),last_modified_at:T.z.string().optional(),testGroup:Dp.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"}),uk=1024*1024});async function Op(e,t){let i=JSON.parse(Fe.default.readFileSync(t,"utf-8"));i.cookies?.length&&await e.addCookies(i.cookies)}var Fe,qc,At,Ze,Zc,Qc=y(()=>{"use strict";Oa();Tt();Ie();_t();F();Fe=R(require("fs"),1),qc=R(require("os"),1),At=R(require("path"),1),Ze=require("playwright");Zc=class{constructor(e={}){e.testDir&&(this.testDir=e.testDir,this.videoBasePath=At.default.join(e.testDir,"videos"),this.statesBasePath=At.default.join(e.testDir,"states"),this.downloadsBasePath=At.default.join(e.testDir,"downloads"),Fe.default.mkdirSync(this.videoBasePath,{recursive:!0}),Fe.default.mkdirSync(this.statesBasePath,{recursive:!0}),Fe.default.mkdirSync(this.downloadsBasePath,{recursive:!0})),this.terminationTimeout=e.terminationTimeout??null,this.defaultHeadless=e.headless??!1,this.additionalArgs=e.additionalArgs??[]}async launchBrowser(e={}){let t=e.debugPort,i=e.headless??this.defaultHeadless,n=Yc(e.deviceName),o=Xc(e.deviceName),a=n===Et.Chromium,r=!!e.extensionPath;h.info(`[BrowserManager] Launching ${n} browser for device: ${e.deviceName||"default"}${t?` on port ${t}`:""}`);let s={headless:i};if(a){r&&i&&(h.warn("[BrowserManager] Extension requested in headless mode; forcing headed mode to load extension."),i=!1,s.headless=!1);let k=[];(e.enableCamera||e.enableMicrophone)&&(k.push("--use-fake-device-for-media-stream","--use-fake-ui-for-media-stream"),e.enableMicrophone&&e.fakeAudioCapturePath&&(k.push(`--use-file-for-fake-audio-capture=${e.fakeAudioCapturePath}`),h.info(`[BrowserManager] Using fake audio capture file: ${e.fakeAudioCapturePath}`)));let E=r&&e.extensionPath?[`--disable-extensions-except=${e.extensionPath}`,`--load-extension=${e.extensionPath}`]:[];s.args=[...pc(t,e.disableSecurity??!0,i),...k,...E,...this.additionalArgs],o&&(s.channel=o,h.debug(`[BrowserManager] Launching browser with channel: ${o}`))}let l=vo(e.deviceName),d=Vc(e.deviceName),c={acceptDownloads:!0,...l,timezoneId:e.timezoneId||"America/Los_Angeles",locale:e.locale||"en-US"};e.viewport&&(c.viewport=e.viewport,c.screen=e.viewport),e.isMobile!==void 0&&(c.isMobile=e.isMobile),e.hasTouch!==void 0&&(c.hasTouch=e.hasTouch),e.userAgent&&(c.userAgent=e.userAgent),e.colorScheme&&(c.colorScheme=e.colorScheme),e.geolocation&&(c.geolocation=e.geolocation,c.permissions=[...c.permissions||[],"geolocation"]);let u=r&&a?e.localStorageStatePath:void 0;e.localStorageStatePath&&!u&&(c.storageState=e.localStorageStatePath),e.recordVideo&&this.videoBasePath&&(c.recordVideo={dir:this.videoBasePath,size:{width:d.width,height:d.height}}),e.proxy&&(c.proxy=e.proxy),e.extraHTTPHeaders&&Object.keys(e.extraHTTPHeaders).length>0&&(c.extraHTTPHeaders=e.extraHTTPHeaders);let m,g,w,v=!1;if(a&&(r||e.userDataDir)){if(e.userDataDir)w=e.userDataDir;else{let E=this.testDir||Fe.default.mkdtempSync(At.default.join(qc.default.tmpdir(),"shiplight-"));w=At.default.join(E,`ext-profile-${Date.now()}`),Fe.default.mkdirSync(w,{recursive:!0}),v=!0}let k={...s,...c};g=await Ze.chromium.launchPersistentContext(w,k),u&&(await Op(g,u),h.info(`[BrowserManager] Loaded storage state into persistent context from ${u}`)),m=g.browser(),h.info(`[BrowserManager] Launched persistent context${e.extensionPath?` for extension at ${e.extensionPath}`:` with profile at ${w}`}`)}else{switch(n){case Et.Firefox:m=await Ze.firefox.launch(s);break;case Et.Webkit:m=await Ze.webkit.launch(s);break;case Et.Chromium:default:m=await Ze.chromium.launch(s);break}g=await m.newContext(c)}if(g.addInitScript(Re),a){let k=["clipboard-read","clipboard-write"];e.enableCamera&&k.push("camera"),e.enableMicrophone&&k.push("microphone");try{await g.grantPermissions(k),h.info(`[BrowserManager] Granted permissions: ${k.join(", ")}`)}catch(E){h.warn("[BrowserManager] Failed to grant permissions:",E)}}else(e.enableCamera||e.enableMicrophone)&&h.warn("[BrowserManager] Camera/microphone enabled but browser is not Chromium; ignoring.");if(e.cookies&&e.cookies.length>0){let k=(Date.now()+31536e6)/1e3,E=e.cookies.map(I=>({...I,expires:k}));await g.addCookies(E),h.info(`[BrowserManager] Added ${e.cookies.length} cookies to browser context with expires=${k}`)}let x=e.viewport,p=x?{width:x.width,height:x.height+xo}:zc(e.deviceName);if(h.info(`[BrowserManager] windowSize=${JSON.stringify(p)}`),a){let k=async E=>{try{await oo(E,p.width,p.height),x&&await E.setViewportSize(x)}catch(I){h.warn("[BrowserManager] Failed to set window bounds via CDP:",I)}};for(let E of g.pages())await k(E);g.on("page",k)}let f="";if(a&&t!==void 0)try{f=await no(t)}catch(k){h.warn("[BrowserManager] Failed to get CDP WebSocket URL:",k)}let S=null;f&&(S=await kt({cdpUrl:f,label:`agent ${e.deviceName??n}`,pid:process.pid}),S&&h.info(`[BrowserManager] Registered browser with dev-box registry id=${S}`));let _={debugPort:t,browser:m,context:g,startTime:new Date,timeout:null,browserWsUrl:f,downloadsBasePath:this.downloadsBasePath,browserType:n,userDataDir:w,isTempUserDataDir:v,registryId:S};if(this.terminationTimeout!==null){let k=setTimeout(()=>{h.info(`[BrowserManager] Browser auto-terminated after ${this.terminationTimeout}ms`),this.terminateBrowser(_).catch(E=>h.error("[BrowserManager] Error terminating browser:",E))},this.terminationTimeout);_.timeout=k}return _}async terminateBrowser(e){if(e.timeout&&clearTimeout(e.timeout),await St(e.registryId??null),await e.context.close(),await e.browser.close(),e.isTempUserDataDir&&e.userDataDir)try{Fe.default.rmSync(e.userDataDir,{recursive:!0,force:!0})}catch(t){h.warn("[BrowserManager] Failed to clean up temp user data dir:",e.userDataDir,t)}}getVideoBasePath(){return this.videoBasePath}getStatesBasePath(){return this.statesBasePath}getDownloadsBasePath(){return this.downloadsBasePath}}});function Np(e){let t=(0,ed.execFileSync)("ps",["-axo","pid=,ppid=,args="],{encoding:"utf-8"}),i=[];for(let a of t.split(`
|
|
4436
|
-
`)){let
|
|
4437
|
-
`),
|
|
4433
|
+
${m.body}`,y=await vp(g,o,t.model);u.info(`Extracted content: ${y}`),y&&y!=="NOT_FOUND"&&h.push({content:y,email_subject:m.subject,email_from:m.from,email_date:m.date})}if(h.length>0){let m=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 y=(new Date().getTime()-a.getTime())/1e3;return u.info(`Successfully extracted content after ${r} attempts in ${y.toFixed(1)} seconds`),{data:m.content,result_variable:g,status:"success",message:`Successfully extracted content from email: ${m.email_subject.substring(0,50)}... (attempts: ${r})`}}else u.info(`Found emails but no extractable content in attempt ${r}`)}else u.info(`No emails found in attempt ${r}`)}catch(d){u.warn(`Error in polling attempt ${r}: ${d.message}`)}if(new Date(Date.now()+n*1e3)>=s){u.info("Not enough time for another polling attempt");break}u.info(`Waiting ${n} seconds before next attempt...`),await new Promise(d=>setTimeout(d,n*1e3))}let l=(new Date().getTime()-a.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${r} attempts over ${l.toFixed(1)} seconds`}}catch(o){return u.error(`Error extracting email content: ${o.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${o.message}`}}}var Ic,Pc,Ra=b(()=>{"use strict";Ce();W();Ic=require("ai"),Pc=require("html-to-text")});function $c(e){switch(e){case"verification_code":return"email_otp_code";case"activation_link":return"email_magic_link";case"custom":return"email_extracted_content";default:return"email_content"}}function Lc(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:_p,async execute(i,n){let{forward_email:o,extraction_type:a,prompt:s,filter_from_email:r,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:h}=i,{page:m,agentServices:g}=n;u.info(`[extract_email_content] Extracting ${a} from ${o}`);try{let y={action_description:`Extract ${a} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:o,extraction_type:a,prompt:s,filter_from_email:r,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:h}}};await t.execute(m,y,g);let v=$c(a);return{success:!0,actionEntity:y,message:`Extracted ${a} and saved to $${v}`}}catch(y){return{success:!1,error:y.message,actionEntity:{action_description:`Extract ${a} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:o,extraction_type:a,prompt:s,filter_from_email:r,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:h}},feedback:y.message}}}}})}var Ae,Oc,_p,Fa=b(()=>{"use strict";Ra();W();oe();Ae=require("zod");Oc=class{getMailgunConfig(){let e=V().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""}}async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=this.getMailgunConfig();if(!o)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN in SDK config.");let a=n.kwargs,s=i.getModel?.()||"gemini-2.5-pro",r=await Cc(o,{model:s,forward_email:a.forward_email,extraction_type:a.extraction_type,prompt:a.prompt,filters:{from_email:a.filter_from_email,to_email:a.filter_to_email,subject:a.filter_subject,body_contains:a.filter_body_contains},timeout:a.timeout});if(r.status==="success"&&r.data){let l=r.result_variable?.replace(/^\$/,"")||$c(a.extraction_type);i.variableStore.set(l,r.data),u.info(`[extract_email_content] Extracted and saved to ${l}`)}else throw new Error(r.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)} },`,"});"]}},_p=Ae.z.object({forward_email:Ae.z.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:Ae.z.enum(["verification_code","activation_link","custom"]).describe("Type of content to extract: verification_code for OTP codes, activation_link for magic links, custom for custom prompts"),prompt:Ae.z.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:Ae.z.string().optional().describe("Filter emails by sender address"),filter_to_email:Ae.z.string().optional().describe("Filter emails by recipient address"),filter_subject:Ae.z.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:Ae.z.string().optional().describe("Filter emails by body content (partial match)"),timeout:Ae.z.number().optional().describe("Timeout in seconds for polling (default: 60)")})});async function Me(){if(co)return co;let e=(await Promise.resolve().then(()=>(vt(),xt))).default;return co=new e,co}async function uo(e){let t=await Me(),i=t.getAction("click"),n=t.getAction("hover"),o=t.getAction("right_click"),a=t.getAction("double_click");return ac(e,i),Zl(e,n),Fl(e,o),uc(e,a),"Click, hover, double-click, right-click, or drag elements"}async function ho(e){let t=await Me(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),o=t.getAction("reload_page");return Jl(e,i),Yl(e,n),Nl(e,o),"Navigate to URLs, go back, or reload the page"}async function mo(e){let t=await Me(),i=t.getAction("clear_input"),n=t.getAction("input_text"),o=t.getAction("press");return nc(e,i),ec(e,n),Ol(e,o),"Type text into inputs, clear input values, or press keyboard keys"}async function po(e){let t=await Me(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),o=t.getAction("scroll");return gl(e,i),wl(e,n),Ul(e,o),"Scroll the page or scroll to specific text/elements"}async function go(e){let t=await Me(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return sc(e,i),Sl(e,n),"Switch between browser tabs or close tabs"}async function fo(e){let t=await Me(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return Pl(e,i),dl(e,n),"Upload files or wait for downloads to complete"}async function wo(e){let t=await Me(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),o=t.getAction("set_date_for_native_date_picker");return zl(e,i),xl(e,n),_l(e,o),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function bo(e){let t=await Me(),i=t.getAction("wait"),n=t.getAction("save_variable"),o=t.getAction("done");return $l(e,i),Wl(e,n),cc(e,o),Mc(e),"Wait for conditions, save variables, or complete tasks"}async function yo(e){let t=(await Me()).getAction("generate_2fa_code");Gl(e,t);let i=new Oc;return(await Promise.resolve().then(()=>(vt(),xt))).default.registerAction("extract_email_content",i),Lc(e,i),"Generate 2FA codes or extract email/activation codes"}async function xo(e){let t=await Me(),i=t.getAction("verify"),n=t.getAction("ai_extract"),o=t.getAction("ai_wait_until");return pc(e,i),fc(e,n),hl(e,o),"Perform AI-powered assertions, extractions, or wait conditions"}async function Dc(e){let[t,i,n,o,a,s,r,l,d,c]=await Promise.all([uo(e),ho(e),mo(e),po(e),go(e),fo(e),wo(e),bo(e),yo(e),xo(e)]);return{mouse:t,navigation:i,input:n,scroll:o,tabs:a,files:s,forms:r,utility:l,auth:d,ai:c}}function Nc(e){return[`- Mouse: ${e.mouse}`,`- Navigation: ${e.navigation}`,`- Input: ${e.input}`,`- Scroll: ${e.scroll}`,`- Tabs: ${e.tabs}`,`- Files: ${e.files}`,`- Forms: ${e.forms}`,`- Utility: ${e.utility}`,`- Auth: ${e.auth}`,`- AI: ${e.ai}`].join(`
|
|
4434
|
+
`)}var co,Ha=b(()=>{"use strict";Na();Fa();oi();ai();ri();si();ci();ui();hi();pi();gi();fi();wi();bi();yi();vi();_i();ki();Si();Ti();Ai();Ii();Pi();Ci();$i();Oi();Li();Di();Ni();co=null});async function Rc(){await Sp}function Fc(){return G}function Hc(e=!0){let t=new ut;return e&&(uo(t),ho(t),mo(t),po(t),go(t),fo(t),wo(t),yo(t),bo(t),xo(t)),t}async function Wc(){let e=new ut,t=await Dc(e),i=Nc(t);return{registry:e,capabilities:t,summary:i}}function Uc(){return["- Mouse: Click, hover, double-click, right-click or drag on elements","- Navigation: Navigate to URLs, go back, or reload the page","- Input: Type text into inputs, clear input fields, or press keyboard keys","- Scroll: Scroll the page or scroll to specific text/elements","- Tabs: Switch between browser tabs or close tabs","- Files: Upload files or wait for downloads to complete","- Forms: Get dropdown options or select dropdown values","- Utility: Wait for conditions, save variables, or complete tasks","- Auth: Generate 2FA codes or extract email/activation codes","- AI: Perform AI-powered verifications, extractions, or wait conditions"].join(`
|
|
4435
|
+
`)}var kp,Sp,Bc=b(()=>{"use strict";Ha();$e();kp=[uo(G),ho(G),mo(G),po(G),go(G),fo(G),wo(G),bo(G),xo(G),yo(G)],Sp=Promise.all(kp)});function Kc(e){return e.getTools().map(t=>({name:t.name,description:t.description,inputSchema:Qi(t.schema)}))}var Gc,jc=b(()=>{"use strict";Ft();Gc=class{constructor(e,t){this.registry=e,this.getContext=t}getToolDefinitions(){return this.registry.getTools().filter(e=>e.availability.mcp).map(e=>({name:e.name,description:e.description,inputSchema:Qi(e.schema)}))}getToolDefinitionsFiltered(e){let t=new Set(e);return this.registry.getTools().filter(i=>t.has(i.name)&&i.availability.mcp).map(i=>({name:i.name,description:i.description,inputSchema:Qi(i.schema)}))}async createServer(e="web-sdk-tools"){throw new Error("MCP server creation not yet implemented. Install and configure an MCP SDK like @modelcontextprotocol/sdk")}async executeTool(e,t){let i=await this.getContext(),n=await this.registry.execute(e,t,i);return{content:[{type:"text",text:n.success?n.message||"Tool executed successfully":n.error||"Tool execution failed"}]}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});var zc=b(()=>{"use strict"});function Vc(){let e=process.env.SHIPLIGHT_REGISTRY_URL;return e?e.replace(/\/$/,""):null}async function St(e){let t=Vc();if(!t)return null;try{let i=await fetch(`${t}/browsers`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify(e)});return i.ok?(await i.json()).id??null:null}catch{return null}}async function Et(e){if(!e)return;let t=Vc();if(t)try{await fetch(`${t}/browsers/${encodeURIComponent(e)}`,{method:"DELETE"})}catch{}}var Wa=b(()=>{"use strict"});function _o(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let s=a.startsWith("$")?a.slice(1):a,r=i[s]??i[`$${s}`];return r!=null?String(r):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,s)=>{let r=n(s.trim());return r!==void 0?r:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,s)=>{let r=n(s);return r!==void 0?r:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,s)=>{let r=n(s.trim());return r!==void 0?r:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,s)=>{let r=n(s);return r!==void 0?r:a}),o}var rk,E,ck,wk,xk,Hi,Ua,Ep,ko,Tp,Ap,Mp,Ip,Pp,Cp,$p,Op,Qe,Tt,Yc,Lp,vo,Wi,ok,ak,So,Jc,qc,Zc,Qc,Ba,Dp,Xc,Np,Fi,Rp,Fp,Hp,he,Wp,Up,lk,yk,At=b(()=>{"use strict";ve();rk=require("uuid"),E=require("zod"),ck=require("yaml"),wk=require("uuid"),xk=require("yaml"),Hi=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Hi||{}),Ua=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Ua||{});Ep="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",ko=112,Tp=1920,Ap=1080,Mp=1920,Ip=1080-ko,Pp=1280,Cp=720,$p=500,Op=500,Qe="Desktop Chrome",Tt=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Tt||{}),Yc={"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"}},Lp={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"]},vo=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Lp[e].map(n=>Yc[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Wi=e=>Yc[e],ok={desktop:{label:"Desktop",type:"desktop",devices:vo("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:vo("mobile")}},ak={desktop:{label:"Desktop",type:"desktop",devices:vo("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:vo("mobile",!0)}},So=(e,t=!1)=>{let i={userAgent:Ep,viewport:{width:Mp,height:Ip},isMobile:!1,hasTouch:!1};if(!e||e===Qe)return i;let n=Wi(e);if(!n)return i;let{width:o,height:a}=n.viewport,s=Math.max($p/o,1),r=Math.max(Op/a,1),l=Math.max(s,r),d={width:Math.round(o*l),height:Math.round(a*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},Jc=e=>{let t={width:Tp,height:Ap};if(!e||e===Qe)return t;let i=So(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+ko}:t},qc=e=>{let t={width:Pp,height:Cp};if(!e||e===Qe)return t;let i=So(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Zc=e=>!e||e===Qe?void 0:Wi(e)?.channel,Qc=e=>!e||e===Qe?"chromium":Wi(e)?.defaultBrowserType??"chromium",Ba=class ed{constructor(){ta(this,"data",{}),ta(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 ed;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[o,a]of Object.entries(t.data))i.set(o,a,n.has(o))}return i}},Dp=E.z.enum(["JS_CODE","AI_MODE"]),Xc=E.z.object({type:Dp,expression:E.z.string()}),Np=E.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Fi=E.z.object({uid:E.z.string(),type:Np,comment:E.z.string().optional()}),Rp=E.z.object({action_data:E.z.object({action_name:E.z.string(),kwargs:E.z.record(E.z.any()).optional(),args:E.z.array(E.z.any()).optional()}),action_description:E.z.string().optional(),url:E.z.string().optional(),xpath:E.z.string().nullable().optional(),locator:E.z.string().nullable().optional(),css_selector:E.z.string().nullable().optional(),unique_selector:E.z.string().nullable().optional(),element_index:E.z.number().nullable().optional(),frame_path:E.z.array(E.z.any()).optional(),artifacts:E.z.record(E.z.any()).optional(),feedback:E.z.string().optional(),original_browser_use_action:E.z.any().optional()}).passthrough(),Fp=Fi.extend({type:E.z.literal("DRAFT"),description:E.z.string()}),Hp=Fi.extend({type:E.z.literal("ACTION"),description:E.z.string(),action_entity:Rp.optional(),locator:E.z.string().optional(),use_pure_vision:E.z.boolean().optional()}),he=E.z.lazy(()=>E.z.union([Fp,Hp,Fi.extend({type:E.z.literal("STEP"),description:E.z.string().optional().default(""),statements:E.z.array(he),reference_id:E.z.number().optional(),template_path:E.z.string().optional(),template_params:E.z.record(E.z.string()).optional()}),Fi.extend({type:E.z.literal("IF_ELSE"),description:E.z.string().optional(),condition:Xc,then:E.z.array(he),else:E.z.array(he).optional()}),Fi.extend({type:E.z.literal("WHILE_LOOP"),description:E.z.string().optional(),condition:Xc,body:E.z.array(he),timeout_ms:E.z.number().optional()})])),Wp=E.z.object({name:E.z.string(),statements:E.z.array(he),teardown:E.z.array(he).optional(),skip:E.z.union([E.z.boolean(),E.z.string()]).optional(),timeout:E.z.number().optional(),fail:E.z.union([E.z.boolean(),E.z.string()]).optional(),only:E.z.boolean().optional(),slow:E.z.boolean().optional()}),Up=E.z.object({tests:E.z.array(Wp).min(1),beforeAll:E.z.array(he).optional(),afterAll:E.z.array(he).optional(),beforeEach:E.z.array(he).optional(),afterEach:E.z.array(he).optional()}),lk=E.z.object({comment:E.z.string().optional(),version:E.z.string().optional(),goal:E.z.string().optional(),url:E.z.string().optional(),baseURL:E.z.string().optional(),final_feedback:E.z.string().optional(),completed:E.z.boolean().optional(),success:E.z.boolean().optional(),statements:E.z.array(he).optional(),teardown:E.z.array(he).optional(),last_modified_at:E.z.string().optional(),testGroup:Up.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"}),yk=1024*1024});async function Bp(e,t){let i=JSON.parse(Ue.default.readFileSync(t,"utf-8"));i.cookies?.length&&await e.addCookies(i.cookies)}var Ue,td,Mt,et,id,nd=b(()=>{"use strict";Wa();At();De();kt();W();Ue=H(require("fs"),1),td=H(require("os"),1),Mt=H(require("path"),1),et=require("playwright");id=class{constructor(e={}){e.testDir&&(this.testDir=e.testDir,this.videoBasePath=Mt.default.join(e.testDir,"videos"),this.statesBasePath=Mt.default.join(e.testDir,"states"),this.downloadsBasePath=Mt.default.join(e.testDir,"downloads"),Ue.default.mkdirSync(this.videoBasePath,{recursive:!0}),Ue.default.mkdirSync(this.statesBasePath,{recursive:!0}),Ue.default.mkdirSync(this.downloadsBasePath,{recursive:!0})),this.terminationTimeout=e.terminationTimeout??null,this.defaultHeadless=e.headless??!1,this.additionalArgs=e.additionalArgs??[]}async launchBrowser(e={}){let t=e.debugPort,i=e.headless??this.defaultHeadless,n=Qc(e.deviceName),o=Zc(e.deviceName),a=n===Tt.Chromium,s=!!e.extensionPath;u.info(`[BrowserManager] Launching ${n} browser for device: ${e.deviceName||"default"}${t?` on port ${t}`:""}`);let r={headless:i};if(a){s&&i&&(u.warn("[BrowserManager] Extension requested in headless mode; forcing headed mode to load extension."),i=!1,r.headless=!1);let k=[];(e.enableCamera||e.enableMicrophone)&&(k.push("--use-fake-device-for-media-stream","--use-fake-ui-for-media-stream"),e.enableMicrophone&&e.fakeAudioCapturePath&&(k.push(`--use-file-for-fake-audio-capture=${e.fakeAudioCapturePath}`),u.info(`[BrowserManager] Using fake audio capture file: ${e.fakeAudioCapturePath}`)));let A=s&&e.extensionPath?[`--disable-extensions-except=${e.extensionPath}`,`--load-extension=${e.extensionPath}`]:[];r.args=[...bc(t,e.disableSecurity??!0,i),...k,...A,...this.additionalArgs],o&&(r.channel=o,u.debug(`[BrowserManager] Launching browser with channel: ${o}`))}let l=So(e.deviceName),d=qc(e.deviceName),c={acceptDownloads:!0,...l,timezoneId:e.timezoneId||"America/Los_Angeles",locale:e.locale||"en-US"};e.viewport&&(c.viewport=e.viewport,c.screen=e.viewport),e.isMobile!==void 0&&(c.isMobile=e.isMobile),e.hasTouch!==void 0&&(c.hasTouch=e.hasTouch),e.userAgent&&(c.userAgent=e.userAgent),e.colorScheme&&(c.colorScheme=e.colorScheme),e.geolocation&&(c.geolocation=e.geolocation,c.permissions=[...c.permissions||[],"geolocation"]);let h=s&&a?e.localStorageStatePath:void 0;e.localStorageStatePath&&!h&&(c.storageState=e.localStorageStatePath),e.recordVideo&&this.videoBasePath&&(c.recordVideo={dir:this.videoBasePath,size:{width:d.width,height:d.height}}),e.proxy&&(c.proxy=e.proxy),e.extraHTTPHeaders&&Object.keys(e.extraHTTPHeaders).length>0&&(c.extraHTTPHeaders=e.extraHTTPHeaders);let m,g,y,v=!1;if(a&&(s||e.userDataDir)){if(e.userDataDir)y=e.userDataDir;else{let A=this.testDir||Ue.default.mkdtempSync(Mt.default.join(td.default.tmpdir(),"shiplight-"));y=Mt.default.join(A,`ext-profile-${Date.now()}`),Ue.default.mkdirSync(y,{recursive:!0}),v=!0}let k={...r,...c};g=await et.chromium.launchPersistentContext(y,k),h&&(await Bp(g,h),u.info(`[BrowserManager] Loaded storage state into persistent context from ${h}`)),m=g.browser(),u.info(`[BrowserManager] Launched persistent context${e.extensionPath?` for extension at ${e.extensionPath}`:` with profile at ${y}`}`)}else{switch(n){case Tt.Firefox:m=await et.firefox.launch(r);break;case Tt.Webkit:m=await et.webkit.launch(r);break;case Tt.Chromium:default:m=await et.chromium.launch(r);break}g=await m.newContext(c)}if(g.addInitScript(We),a){let k=["clipboard-read","clipboard-write"];e.enableCamera&&k.push("camera"),e.enableMicrophone&&k.push("microphone");try{await g.grantPermissions(k),u.info(`[BrowserManager] Granted permissions: ${k.join(", ")}`)}catch(A){u.warn("[BrowserManager] Failed to grant permissions:",A)}}else(e.enableCamera||e.enableMicrophone)&&u.warn("[BrowserManager] Camera/microphone enabled but browser is not Chromium; ignoring.");if(e.cookies&&e.cookies.length>0){let k=(Date.now()+31536e6)/1e3,A=e.cookies.map(I=>({...I,expires:k}));await g.addCookies(A),u.info(`[BrowserManager] Added ${e.cookies.length} cookies to browser context with expires=${k}`)}let x=e.viewport,p=x?{width:x.width,height:x.height+ko}:Jc(e.deviceName);if(u.info(`[BrowserManager] windowSize=${JSON.stringify(p)}`),a){let k=async A=>{try{await so(A,p.width,p.height),x&&await A.setViewportSize(x)}catch(I){u.warn("[BrowserManager] Failed to set window bounds via CDP:",I)}};for(let A of g.pages())await k(A);g.on("page",k)}let f="";if(a&&t!==void 0)try{f=await ro(t)}catch(k){u.warn("[BrowserManager] Failed to get CDP WebSocket URL:",k)}let S=null;f&&(S=await St({cdpUrl:f,label:`agent ${e.deviceName??n}`,pid:process.pid}),S&&u.info(`[BrowserManager] Registered browser with dev-box registry id=${S}`));let _={debugPort:t,browser:m,context:g,startTime:new Date,timeout:null,browserWsUrl:f,downloadsBasePath:this.downloadsBasePath,browserType:n,userDataDir:y,isTempUserDataDir:v,registryId:S};if(this.terminationTimeout!==null){let k=setTimeout(()=>{u.info(`[BrowserManager] Browser auto-terminated after ${this.terminationTimeout}ms`),this.terminateBrowser(_).catch(A=>u.error("[BrowserManager] Error terminating browser:",A))},this.terminationTimeout);_.timeout=k}return _}async terminateBrowser(e){if(e.timeout&&clearTimeout(e.timeout),await Et(e.registryId??null),await e.context.close(),await e.browser.close(),e.isTempUserDataDir&&e.userDataDir)try{Ue.default.rmSync(e.userDataDir,{recursive:!0,force:!0})}catch(t){u.warn("[BrowserManager] Failed to clean up temp user data dir:",e.userDataDir,t)}}getVideoBasePath(){return this.videoBasePath}getStatesBasePath(){return this.statesBasePath}getDownloadsBasePath(){return this.downloadsBasePath}}});function Gp(e){let t=(0,od.execFileSync)("ps",["-axo","pid=,ppid=,args="],{encoding:"utf-8"}),i=[];for(let a of t.split(`
|
|
4436
|
+
`)){let s=a.trimStart().match(/^(\d+)\s+(\d+)\s+(.*)$/);s&&i.push({pid:parseInt(s[1],10),ppid:parseInt(s[2],10),args:s[3]})}let n=new Set([e]),o=!0;for(;o;){o=!1;for(let a of i)!n.has(a.pid)&&n.has(a.ppid)&&(n.add(a.pid),o=!0)}for(let a of i){if(a.pid===e||!n.has(a.pid)||!/chrome|chromium/i.test(a.args))continue;let s=a.args.match(/--user-data-dir=([^\s]+)/);if(s)return s[1]}return null}async function Kp(e,t){let i=rd.join(e,"DevToolsActivePort"),n=Date.now()+t;for(;Date.now()<n;){try{let o=ad.readFileSync(i,"utf-8").trim(),[a,s]=o.split(`
|
|
4437
|
+
`),r=parseInt(a,10);if(Number.isFinite(r)&&r>0&&typeof s=="string"&&s.startsWith("/"))return{port:r,wsPath:s}}catch{}await new Promise(o=>setTimeout(o,100))}throw new Error(`Timed out waiting for ${i} \u2014 Chromium never exposed DevTools`)}async function Eo(e,t=3e4){let i=Gp(e);if(!i)throw new Error(`No Chromium descendant of pid ${e} with --user-data-dir found. Did you launch with --remote-debugging-port=0 and is the browser still running?`);let{port:n,wsPath:o}=await Kp(i,t);return`ws://127.0.0.1:${n}${o}`}var od,ad,rd,sd=b(()=>{"use strict";od=require("child_process"),ad=H(require("fs"),1),rd=H(require("path"),1)});var ld,cd=b(()=>{"use strict";At();ld=e=>{if(!e||e===Qe)return"desktop";let t=Wi(e);return t&&t.isMobile?"mobile":"desktop"}});var jp,dd=b(()=>{"use strict";jp=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(jp||{})});async function ud(e,t){let i=Object.getPrototypeOf(async()=>{}).constructor,n=`
|
|
4438
4438
|
return await (${t});
|
|
4439
|
-
`;return await new i("page",n)(e)}async function
|
|
4439
|
+
`;return await new i("page",n)(e)}async function Ui(e,t,i){let n=[],o=[];for(let a of t){let s=!1;try{let r=`page.${a}`;w.log(`Checking element existence: ${r}`),n.push(`Checking element existence: ${r}`);try{await ud(e,`${r}.waitFor({ state: 'attached', timeout: ${zp} })`),w.log(`Element is attached: ${r}`),n.push(`Element is attached: ${r}`),s=!0}catch{await ud(e,`${r}.count()`)>0?(w.log(`Element found (snapshot): ${r}`),n.push(`Element found (snapshot): ${r}`),s=!0):(w.log(`Element not found: ${r}`),n.push(`Element not found: ${r}`),s=!1)}}catch(r){w.log(`Error checking element: ${r.message}`),n.push(`Error checking element: ${r.message}`),s=!1}if(o.push(s),!s&&i)break}return{successResults:o,logs:n}}async function Ga(e,t,i=!0){let{successResults:n,logs:o}=await Ui(e,t,i);return{success:n.length===t.length&&n.every(a=>a),logs:o}}async function Bi(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 Ga(e,t,!0);return i?w.log("All validation expressions passed"):w.log(`Validation failed: ${n.join(", ")}`),i}async function Ka(e,t){let i=e.context().browser();if(!i)throw new Error("Cannot create unsigned-in context: browser not available");let n=await i.newContext(),o=await n.newPage();return await o.goto(t),await Le(o,Vp),{context:n,page:o,close:async()=>{await o.close(),await n.close()}}}async function ja(e,t,i,n,o,a){let s=`
|
|
4440
4440
|
Based on the current page status, generate ${o} Playwright locators in JavaScript code that can
|
|
4441
4441
|
be used by a program to verify the page is signed in.
|
|
4442
4442
|
Each expression should yield a locator object that can be used for waiting and checking visibility.
|
|
4443
|
-
`;t&&(
|
|
4443
|
+
`;t&&(s+=`
|
|
4444
4444
|
For your comparison, the DOM elements of the UNSIGNED IN page are:
|
|
4445
4445
|
"""
|
|
4446
4446
|
${t}
|
|
4447
4447
|
"""
|
|
4448
|
-
`),
|
|
4448
|
+
`),s+=`
|
|
4449
4449
|
Output the code in a code block with \`\`\`javascript\`\`\` at the beginning and \`\`\` at the end.
|
|
4450
4450
|
|
|
4451
4451
|
Here is an example of the right format:
|
|
@@ -4469,33 +4469,33 @@ Don't use locators that may change with page content, such as:
|
|
|
4469
4469
|
|
|
4470
4470
|
It is a good idea to add 'first()' to the locator to make it more stable for locators
|
|
4471
4471
|
that can result in multiple results.
|
|
4472
|
-
`,i&&(
|
|
4472
|
+
`,i&&(s+=`
|
|
4473
4473
|
Previously generated expressions and their results:
|
|
4474
4474
|
"""
|
|
4475
4475
|
${i}
|
|
4476
4476
|
"""
|
|
4477
|
-
Avoid regenerating these failed ones, but can reuse the successful ones.`),n&&(
|
|
4477
|
+
Avoid regenerating these failed ones, but can reuse the successful ones.`),n&&(s+=`
|
|
4478
4478
|
${n}
|
|
4479
|
-
`),
|
|
4479
|
+
`),s+=`
|
|
4480
4480
|
Remember, you must have the javascript code block in your final response.
|
|
4481
|
-
`,
|
|
4482
|
-
${
|
|
4483
|
-
`).map(d=>d.trim()).filter(d=>d.length>0).map(d=>(d.startsWith("page.")&&(d=d.slice(5)),d))}async function
|
|
4481
|
+
`,w.log("Agent generating validation locators"),w.log(`Prompt:
|
|
4482
|
+
${s}`);let r=await a(e,s);if(!r.success)throw new Error(r.details||"Agent failed to generate verification code");let l=(r.details||"").match(/```javascript\n(.*)\n```/s);if(!l)throw new Error("Agent failed to generate verification code: no javascript code block found");return l[1].split(`
|
|
4483
|
+
`).map(d=>d.trim()).filter(d=>d.length>0).map(d=>(d.startsWith("page.")&&(d=d.slice(5)),d))}async function To(e,t,i,n,o){let a=null;try{a=await Ka(e,t);let s=await o(a.page),r=3,l="";for(let d=0;d<r;d++)try{let c=await ja(e,s,l||null,i.verification_hint??null,i.num_verification_exprs??1,n);w.log(`Generated validation locators: ${JSON.stringify(c)}`);{let{successResults:h,logs:m}=await Ui(e,c,!1);if(l+=`Test results on a SIGNED IN page. EXPECT ALL PASS:
|
|
4484
4484
|
${m.join(`
|
|
4485
4485
|
`)}
|
|
4486
4486
|
|
|
4487
|
-
`,!
|
|
4487
|
+
`,!h.every(g=>g)){w.log(`Locator validation on signed-in page failed. Results: ${JSON.stringify(h)}`),w.log(`Validation logs:
|
|
4488
4488
|
${m.join(`
|
|
4489
|
-
`)}`);continue}}{
|
|
4489
|
+
`)}`);continue}}{w.log("Validating locators in unsigned-in context, EXPECT ALL TO FAIL");let{successResults:h,logs:m}=await Ui(a.page,c,!1);if(l+=`Test results on an UNSIGNED IN page. EXPECT ALL FAIL:
|
|
4490
4490
|
${m.join(`
|
|
4491
4491
|
`)}
|
|
4492
4492
|
|
|
4493
|
-
`,
|
|
4493
|
+
`,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:
|
|
4494
4494
|
${m.join(`
|
|
4495
|
-
`)}`);continue}}return
|
|
4496
|
-
${e.trim()}`:this.context.agentNote=e.trim())}readVariable(e){let t=e.startsWith("$")?e.slice(1):e,i=this.context.variableStore.get(t);return
|
|
4497
|
-
`),a=o.filter(
|
|
4498
|
-
`).trim()}catch{return}}function
|
|
4495
|
+
`)}`);continue}}return w.log("Generated validation locators passed dual validation"),c}catch(c){w.log(`Failed to generate validation expressions (attempt ${d+1}/${r}): ${c.message}`)}return w.log("Failed to generate valid locators after max retries"),null}finally{a&&await a.close()}}var zp,Vp,Ao=b(()=>{"use strict";ae();De();zp=5e3,Vp=1e4});var hd,za=b(()=>{"use strict";hd=class{constructor(e){this.currentPage=null,this.currentIndex=-1,this.context=e,this.initialize()}initialize(){this.context.on("page",async t=>{await this.handleNewPage(t)});let e=this.context.pages();e.length>0&&(this.currentPage=e[0],this.currentIndex=0);for(let t of e)this.setupPageListeners(t)}async handleNewPage(e){try{this.setupPageListeners(e);let t=this.context.pages().indexOf(e);await this.setCurrentPage(e,t)}catch{}}setupPageListeners(e){e.on("close",async()=>{await this.handlePageClose(e)})}async handlePageClose(e){try{if(this.currentPage===e){let t=this.context.pages(),i=t.slice().reverse().find(n=>!n.isClosed());i&&await this.setCurrentPage(i,t.indexOf(i))}}catch{}}async setCurrentPage(e,t){let i=this.currentPage!==e;this.currentPage=e,this.currentIndex=t,i&&await e.bringToFront()}async switchToPage(e){let t=this.context.pages();if(e<0||e>=t.length)throw new Error(`Invalid page index: ${e}. Available pages: 0-${t.length-1}`);let i=t[e];if(i.isClosed())throw new Error(`Page at index ${e} is closed`);return await this.setCurrentPage(i,e),i}async closePage(e){let t=this.context.pages();if(e<0||e>=t.length)throw new Error(`Invalid page index: ${e}. Available pages: 0-${t.length-1}`);let i=t[e];if(i.isClosed())throw new Error(`Page at index ${e} is already closed`);await i.close()}getCurrentPage(){return this.currentPage}getCurrentIndex(){return this.currentIndex}getAllPages(){return this.context.pages()}getPageCount(){return this.context.pages().length}}});async function md(e,t=3e3,i=1e3){try{await Le(e,t,i)}catch{}}async function pd(e,t,i){let n=i*1e3,o=100,a=Date.now();for(;!t.downloadStatus||t.downloadStatus.status==="inProgress";){if(Date.now()-a>n){let s;throw t.downloadStatus?s=`Timed out after ${n}ms waiting for download to complete`:s="No download in progress or completed",u.error(s),new Error(s)}await e.waitForTimeout(o)}if(t.downloadStatus.status==="failed"){let s=`Download failed: ${t.downloadStatus.error||"Unknown error"}`;throw u.error(s),new Error(s)}t.agentNote=`Download completed: ${t.downloadStatus.filename}`}async function gd(e,t,i,n=60,o){let a=Math.min(n,300),s=Math.max(10,a/10)*1e3,r=Date.now()+a*1e3;for(u.info(`Waiting for condition: "${t}" (timeout: ${a}s)`);;){let l=Date.now();try{if(await i(e,t,o))return u.info(`Condition met: "${t}"`),!0}catch(c){u.warn(`Error evaluating condition: ${c.message}`)}if(Date.now()>r)return u.warn(`Timeout waiting for condition: "${t}"`),!1;let d=s-(Date.now()-l);d>0&&await e.waitForTimeout(d)}}var Mo=b(()=>{"use strict";De();W()});function wd(e){return e.url()===":"}var fd,Gi,Io,Xp,Po,Va=b(()=>{"use strict";za();At();Mo();De();W();fd=H(require("fs"),1),Gi=H(require("path"),1),Io=require("otplib"),Xp=(0,Io.createGuardrails)({MIN_SECRET_BYTES:1});Po=class{constructor(e){this.context=e,this.testDataFileNames=[],this.extensionEnabled=!1}setTestDataDownloader(e,t){this.testDataDownloader=e,this.testDataFileNames=t??[]}setupPageTracking(e){this.tabManager=new hd(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 _o(e,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(e){let t=this.context.testDataDir||process.cwd();return Gi.join(t,e)}async downloadTestDataFiles(e){if(e.length===0){u.debug("[AgentServices] No file paths provided for download");return}let t=this.context.testDataDir||process.cwd(),i=e.filter(n=>{let o=Gi.basename(n),a=Gi.join(t,o),s=fd.existsSync(a);return s&&u.debug(`[AgentServices] File already exists locally: ${o}`),!s});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 pd(e,this.context,t)}getRecentDownloadedFilePath(){return this.context.downloadStatus?this.context.downloadStatus.status!=="completed"?(u.debug(`Download is ${this.context.downloadStatus.status}, not completed`),null):this.context.downloadStatus.filePath?(u.info(`Retrieved recent download path: ${this.context.downloadStatus.filePath}`),this.context.downloadStatus.filePath):(u.warn("Download completed but file path is missing"),null):(u.debug("No download found"),null)}addSensitive(e,t){this.context.variableStore.set(e,t,!0)}saveVariable(e,t){let i=e.startsWith("$")?e.slice(1):e;this.context.variableStore.set(i,t),u.debug(`Saved variable: ${i} = ${JSON.stringify(t)}`),this.context.agentNote=`A new value is saved to the variable "${i}".`}addNote(e){!e||e.trim()===""||(this.context.agentNote?this.context.agentNote+=`
|
|
4496
|
+
${e.trim()}`:this.context.agentNote=e.trim())}readVariable(e){let t=e.startsWith("$")?e.slice(1):e,i=this.context.variableStore.get(t);return u.debug(`Read variable: ${t} = ${JSON.stringify(i)}`),i}async generate2faCode(e){try{let t=(0,Io.generateSync)({secret:e,guardrails:Xp});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 Le(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 o=await this.knowledgeRetriever(e,t,i,n);return u.debug(`[AgentServices] Retrieved ${o.length} knowledges for statement`),o}catch(o){return u.warn(`[AgentServices] Failed to retrieve knowledges: ${o.message}`),[]}}}});var Xa,Co,Ya=b(()=>{"use strict";Xa=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(Xa||{}),Co=class extends Error{constructor(e){super(e),this.name="AgentTaskFailedError",this.details=e}}});var bd={};Ve(bd,{LoginType:()=>Hi,checkLocators:()=>Ui,createUnsignedInContext:()=>Ka,generateAndValidateLoginLocators:()=>To,generateValidationLocators:()=>ja,validateLogin:()=>Bi,validateLoginLocators:()=>Ga});var yd=b(()=>{"use strict";Ao();ae();At();De();kt();W();oe();gt();ve()});function Jp(e){try{let t=e.toString(),i,n=t.indexOf("=>");if(n!==-1){let r=t.slice(n+2).trim();if(r.startsWith("{")){let l=r.lastIndexOf("}");i=r.slice(1,l)}else return r.trim()}else{let r=t.indexOf("{"),l=t.lastIndexOf("}");r!==-1&&l>r&&(i=t.slice(r+1,l))}if(!i)return;let o=i.split(`
|
|
4497
|
+
`),a=o.filter(r=>r.trim().length>0);if(a.length===0)return;let s=Math.min(...a.map(r=>r.match(/^(\s*)/)?.[1].length??0));return o.map(r=>r.slice(s)).join(`
|
|
4498
|
+
`).trim()}catch{return}}function It(e,t){let i={};for(let[n,o]of Object.entries(e))i[n]=t.has(n)?"*****":o;return i}var J,ie,Yp,qp,Zp,Ja,xd=b(()=>{"use strict";ni();Ye();Ao();ae();Va();Mo();Ya();mi();W();J=H(require("fs"),1),ie=H(require("path"),1),Yp=1;qp=3,Zp=40;Ja=class{constructor(e){this.context=e,this._newActionEntities=new Map,this.agentServices=new Po(e),this.agentServices.agent=this,this.context.tokenUsages||(this.context.tokenUsages=[])}getNewActionEntities(){return this._newActionEntities}getAgentNote(){return this.context.agentNote||void 0}async getActionHandler(){if(!this._actionHandler){let{default:e}=await Promise.resolve().then(()=>(vt(),xt));this._actionHandler=new e}return this._actionHandler}async execAction(e,t,i){let n=(await this.getActionHandler()).getAction(e);if(!n)throw new Error(`Unknown action: ${e}`);await n.execute(t,i,this.agentServices)}async dismissModalIfPresent(e,t){try{let i=await this.execute(e,`TASK: Check if there is an INTRUSIVE POPUP blocking the page, and dismiss it if present.
|
|
4499
4499
|
|
|
4500
4500
|
ONLY dismiss intrusive popups such as:
|
|
4501
4501
|
- Cookie/GDPR consent banners
|
|
@@ -4517,19 +4517,19 @@ If you find an intrusive popup, dismiss it by clicking its close/X button or "No
|
|
|
4517
4517
|
IMPORTANT: Only act with HIGH CONFIDENCE. If unsure whether something is an intrusive popup, do nothing.
|
|
4518
4518
|
It's better to miss a popup than to accidentally interact with normal page elements.
|
|
4519
4519
|
|
|
4520
|
-
If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,Kp),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(h.info(`[Download Tracking] Setting up download tracking for page: ${e.url()}`),md(e)){h.info(`[Download Tracking] Skipping download tracking for blank tab: ${e.url()}`),e.close();return}e.on("download",async t=>{let i=t.suggestedFilename();h.info(`[Download Tracking] Download event detected! File: ${i}`),this.context.downloadStatus={filename:i,status:"inProgress",startTime:Date.now()},h.info(`[Download Tracking] Download status set to inProgress: ${JSON.stringify(this.context.downloadStatus)}`);try{let n=this.context.downloadDir||Q.join(process.cwd(),"downloads");z.existsSync(n)||z.mkdirSync(n,{recursive:!0});let o=Q.join(n,i);h.info(`[Download Tracking] Downloading file to: ${o}`),await t.saveAs(o),this.context.downloadStatus={filename:i,status:"completed",startTime:this.context.downloadStatus.startTime,filePath:o,timestamp:Date.now()},h.info(`[Download Tracking] Download completed: ${o}`),h.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()},h.error(`[Download Tracking] Download failed for ${i}: ${n.message}`)}})}setupDialogHandling(e){if(h.debug(`[Dialog Handling] setupDialogHandling called, isClosed=${e.isClosed()}, url=${e.url()}`),e.isClosed()){h.debug("[Dialog Handling] Skipping - page is closed");return}h.info(`[Dialog Handling] Setting up dialog handling for page: ${e.url()}`),e.on("dialog",async t=>{let i=t.type(),n=t.message();h.info(`[Dialog Handling] Dialog detected - type: ${i}, message: "${n}"`);let o=i==="beforeunload";try{o?await t.dismiss():await t.accept(),this.context.dialogStatus={type:i,message:n,response:o?"dismiss":"accept",timestamp:Date.now()},h.info(`[Dialog Handling] Dialog ${o?"dismissed":"accepted"} - type: ${i}, message: "${n}"`)}catch(a){h.warn(`[Dialog Handling] Failed to handle dialog (already dismissed?): ${a}`)}})}getRecentDownloadedFilePath(){return this.agentServices.getRecentDownloadedFilePath()}addNote(e){this.agentServices.addNote(e)}collectTokenUsages(e){let t;Array.isArray(e)?t=e:e?.tokenUsages&&(t=e.tokenUsages),t&&t.length>0?(this.context.tokenUsages||(this.context.tokenUsages=[]),this.context.tokenUsages.push(...t),h.debug(`[collectTokenUsages] Added ${t.length} token usage(s), total: ${this.context.tokenUsages.length}`)):h.debug("[collectTokenUsages] No token usages to collect (undefined or empty)")}trackAIAction(e,t,i,n=1,o,a){if(!e)return;let r=i?.tokenUsages||[];this.context.aiActionDetails||(this.context.aiActionDetails=[]);let s=this.context.aiActionDetails.find(l=>l.stepId===e&&l.actionType===t);s?(s.count+=n,r.length>0&&s.tokenUsages.push(...r),i?.userPrompt&&(s.userPrompt=i.userPrompt),i?.rawLlmResponse&&(s.rawLlmResponse=i.rawLlmResponse),i?.reasoningContent&&(s.reasoningContent=i.reasoningContent),i?.elementTree&&(s.elementTree=i.elementTree),i?.screenshotWithSom&&(s.screenshotWithSom=i.screenshotWithSom),a&&(s.explanation=a)):this.context.aiActionDetails.push({stepId:e,actionType:t,count:n,tokenUsages:[...r],statement:o,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:a,elementTree:i?.elementTree,screenshotWithSom:i?.screenshotWithSom}),h.debug(`[trackAIAction] Tracked ${t} for step ${e}, count: ${n}`)}async assert(e,t,i){h.info(`Asserting statement: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"assert"),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),o=await Ye(t,e,this.agentServices,{executionHistory:n,useCleanScreenshotForAssertion:!0,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(o.debugInfo),this.context.lastActionDebugInfo=o.debugInfo;let a=o.explanation||o.error||"No explanation";if(i&&this.trackAIAction(i,"assert",o.debugInfo,1,t,a),this.context.agentNote=a,i&&this.context.stepTracking&&await this.updateStepResult(i,o.success?"success":"failure",a,void 0,o.debugInfo),!o.success)throw this.addToExecutionHistory(`Assert: "${t}"`,`Failed: ${a}`),new Error(`Assertion failed: ${a}`);return this.addToExecutionHistory(`Assert: "${t}"`,`Passed: ${a}`),!0}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async evaluate(e,t,i){h.info(`Evaluating condition: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"evaluate"),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),o=await Ye(t,e,this.agentServices,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(o.debugInfo),this.context.lastActionDebugInfo=o.debugInfo;let a=o.explanation||o.error||"No explanation";return i&&this.trackAIAction(i,"evaluate",o.debugInfo,1,t,a),this.context.agentNote=a,i&&this.context.stepTracking&&await this.updateStepResult(i,"success",a,void 0,o.debugInfo),o.success?(this.addToExecutionHistory(`Evaluate: "${t}"`,`Result: true - ${a}`),!0):(h.warn(`AI evaluation returned false/unknown: ${a}`),this.addToExecutionHistory(`Evaluate: "${t}"`,`Unknown/False: ${a}`),!1)}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async performAction(e,t){h.info(`Act: ${t}`);let i=this.getCompletedExecutionHistory(),n=await Xe(t,e,this.agentServices,{executionHistory:i,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});if(this.collectTokenUsages(n.debugInfo),n.status!=="success"||n.actionEntities.length===0)return{success:!1,details:n.explanation||n.error||"Action failed"};let o=n.actionEntities[0]?.action_description||t;return this.addToExecutionHistory(t,o),{success:!0,details:n.explanation}}async execute(e,t,i,n,o){if(o!==void 0&&o<=0)throw new Error(`maxSteps must be >= 1, got ${o}`);let a=o!==void 0&&o>1;h.info(`Executing statement: ${t} (${a?`multi, maxSteps: ${o}`:"single"})`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"execute"),e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e);try{let r=this.getCompletedExecutionHistory();this.context.agentNote="";let s,l;if(a){let c=i&&this.context.stepTracking?.artifactsDir?u=>{if(u.type==="action"&&u.debugInfo){let m=`${i}-step${u.step}`;this.saveDebugInfoToFiles(m,u.debugInfo,this.context.model)}}:void 0;if(s=await Je(t,e,this.agentServices,c,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:o??jp}),l=s.completed,this.collectTokenUsages(s.tokenUsages),i&&s.tokenUsages){let u={tokenUsages:s.tokenUsages};this.trackAIAction(i,"execute",u,s.actionEntities?.length||1,t,s.explanation||"Multi-step execution completed")}}else if(e=this.agentServices.validatePage(e),s=await Xe(t,e,this.agentServices,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n}),l=s.completed,this.collectTokenUsages(s.debugInfo),this.context.lastActionDebugInfo=s.debugInfo,i){let c=s.explanation||s.error||"No explanation";this.trackAIAction(i,"execute",s.debugInfo,1,t,c)}if(s.status!=="success"||s.actionEntities.length===0||!l){let c=s.explanation||s.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",c,void 0,s.debugInfo),new Error(`Action failed: ${c}`)}let d=this.context.agentNote||s.explanation||"Action executed successfully";return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,s.debugInfo),this.addToExecutionHistory(`Execute: "${t}"`,d),{success:!0,details:d,actions:s.actionEntities,debugInfo:s.debugInfo}}catch(r){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",r.message),this.addToExecutionHistory(`Execute: "${t}"`,`Failed: ${r.message}`),r}}async generate(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"generate");try{let o=this.getCompletedExecutionHistory(),a=await wt(t,e,this.agentServices,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n});if(this.collectTokenUsages(a.debugInfo),a.status!=="success"||a.actionEntities.length===0){let l=a.explanation||a.error||"No explanation";throw i&&this.trackAIAction(i,"generate",a.debugInfo,1,t,l),i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",l,void 0,a.debugInfo),new Error(l)}let r=a.completed,s=a.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",a.debugInfo,1,t,s),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",s,void 0,a.debugInfo),h.info(`[generate] Generated action for "${t}": ${s}, goalAccomplished: ${a.completed}`),{success:r,details:s,actions:a.actionEntities,debugInfo:a.debugInfo}}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),o}}async run(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"run");try{let o=this.getCompletedExecutionHistory();this.context.agentNote="";let a=i&&this.context.stepTracking?.artifactsDir,r=n?.onAction||a?c=>{if(c.type==="action"&&c.action_entity&&(n?.onAction?.(c.action_entity),a&&c.debugInfo)){let u=`${i}-step${c.step}`;this.saveDebugInfoToFiles(u,c.debugInfo,this.context.model)}}:void 0,s=await Je(t,e,this.agentServices,r,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:n?.abortSignal,maxSteps:n?.maxSteps});b.log(`Run task result: status=${s.status}, completed=${s.completed}, actions=${s.actionEntities?.length||0}`),this.collectTokenUsages(s.tokenUsages);let l=s.status==="success"&&s.completed,d=this.context.agentNote?.trim()||s.explanation||s.error||(l?"Step completed":"Step failed");if(i&&s.tokenUsages){let c={tokenUsages:s.tokenUsages};this.trackAIAction(i,"run",c,s.actionEntities?.length||1,t,d)}if(!l)throw new Mo(d);if(n?.stmtUid&&s.actionEntities?.length){let c=s.actionEntities.at(-1);c&&(this._newActionEntities.set(n.stmtUid,c),b.log(`Stored resolved action entity for DRAFT stmtUid: ${n.stmtUid}`))}return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,void 0),this.addToExecutionHistory(`Run: "${t}"`,d),b.log(`Run result: success=${l}, details=${d}`),{success:l,details:d,actions:s.actionEntities}}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),this.addToExecutionHistory(`Run: "${t}"`,`Failed: ${o.message}`),o}}async step(e,t,i,n,o,a=!0,r){let s=Date.now();if(this.context.stepTracking){await this.createStepResult(e,n,i,"step");let m=Gp(t);m&&this.context.stepTracking.results[n]&&(this.context.stepTracking.results[n].code=m)}e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e),this.context.stepTracking&&(this.context.stepTracking.currentStepId=n),e=this.agentServices.validatePage(e);let l=e.url(),d=await this.captureDOMSnapshot(e),c=this.context.stepTracking?.captureVariables?Mt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},u=this.context.stepTracking?.results[n]?.screenshot;try{h.info(`Executing step ${n}: ${i}`),this.addToExecutionHistory(i,""),this.context.agentNote="",e=this.agentServices.validatePage(e);let m=await t();e=this.agentServices.validatePage(e);let g=e.url(),w=await this.captureDOMSnapshot(e),v=this.context.stepTracking?.captureVariables?Mt(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 p=Date.now()-s,f=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:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:p,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:g,domSnapshot:w||void 0,variables:v,screenshotPath:f,timestamp:S})}let x=this.context.agentNote;return(!x||x.trim()==="")&&(x="Execution successful"),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=x),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}catch(m){e=this.agentServices.validatePage(e);let g=a&&!this.context.isSelfHealing;if(g&&(this.context.stepTracking&&await this.updateStepResult(n,"failure",m.message),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=m.message)),!i||i.trim()==="")throw h.error("No description provided for self-healing"),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m;if(!g){if(h.info(`Failed to heal at step ${n}. ${i}`),this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let p=e.url(),f=await this.captureDOMSnapshot(e),S=this.context.stepTracking.captureVariables?Mt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},_=Date.now()-s,k=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:_,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:p,domSnapshot:f||void 0,variables:S,timestamp:k})}throw this.context.stepTracking&&(await this.updateStepResult(n,void 0,void 0),this.context.stepTracking.currentStepId=void 0),m}this.context.isSelfHealing=!0,h.info(`Action failed at step ${n}. ${i}`),h.info(`with error: ${m.message}`);let w,v;if(this.context.autoDismissModal){h.info("Attempting modal dismissal before self-healing...");let p=await this.dismissModalIfPresent(e,i);if(h.info(`Modal dismissal result: ${p.details}`),p.modalDismissed){w=`[Auto-dismissed modal: ${p.details}]`,v=p.actions,h.info(`Modal dismissed, retrying original action for step ${n}`);try{let f=await t();return this.context.isSelfHealing=!1,this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=w+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(n,"success",w),this.context.stepTracking.results[n].dismissedModalActions=v,this.context.stepTracking.currentStepId=void 0),this.context.agentNote=w,f}catch(f){h.info(`Retry after modal dismissal failed: ${f.message}, falling back to self-healing`)}}}let x=r??Bp;h.info(`Calling execute() to self-heal (maxSteps: ${x})`);try{let p=await this.execute(e,i,n,!1,x);if(this.context.isSelfHealing=!1,!p.success)throw new Error(`Self-healing failed: ${p.details}`);let f=p.actions?.at(-1);o&&f&&(this._newActionEntities.set(o,f),h.info(`Stored new action entity for stmtUid: ${o} (last of ${p.actions?.length} actions)`));let S=e.url(),_=await this.captureDOMSnapshot(e),k=this.context.stepTracking?.captureVariables?Mt(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=f,v&&(this.context.stepTracking.results[n].dismissedModalActions=v);let E=w||"";await this.updateStepResult(n,"success",E)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let E=Date.now()-s,I=this.context.stepTracking.results[n]?.screenshot,P=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{actionEntity:f,playwrightCode:p.actions?.map(L=>L.locator||""),llmPrompt:p.debugInfo?.userPrompt,llmResponse:p.debugInfo?.rawLlmResponse,llmReasoning:p.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(n),durationMs:E,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:S,domSnapshot:_||void 0,variables:k,screenshotPath:I,timestamp:P})}return this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}catch(p){if(this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let f=e.url(),S=await this.captureDOMSnapshot(e),_=this.context.stepTracking.captureVariables?Mt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},k=Date.now()-s,E=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:k,status:"failure",errorMessage:p.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:f,domSnapshot:S||void 0,variables:_,timestamp:E})}throw this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}}}async extract(e,t,i,n){n&&this.context.stepTracking&&await this.createStepResult(e,n,`Extract ${t} into ${i}`,"extract");try{let o=`Extract ${t} and save to ${i}`,a=await this.execute(e,o,n);if(!a.success)throw new Error(`AI extraction failed: ${a.details}`);n&&this.context.stepTracking&&await this.updateStepResult(n,"success",`Extracted ${t} to ${i}`)}catch(o){throw n&&this.context.stepTracking&&await this.updateStepResult(n,"failure",o.message),o}}async getDOMText(e){let t=new ue(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains();return(await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n})).elementTree.clickableElementsToString()}async captureDOMSnapshot(e){if(!this.context.stepTracking?.captureStateTransitions||!this.context.stepTracking?.captureDom)return null;try{let t=new ue(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains(),o=await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n,highlightElements:!1,viewportExpansion:0});return{elementTreeText:o.elementTree.clickableElementsToString(),elementCount:o.selectorMap.size,timestamp:Date.now()}}catch(t){return h.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 cd(e,t,i)}async waitUntilCondition(e,t,i=60,n){return ud(e,t,(o,a,r)=>this.evaluate(o,a,r),i,n)}async uploadFile(e,t,i={},n){return kl(e,t,i,this.context,(o,a,r)=>this.execute(o,a,r),n)}async loginPage(e,t,i){let{LoginType:n}=await Promise.resolve().then(()=>(gd(),pd));if(h.info("Start login"),b.section("Login Flow"),b.log(`Site URL: ${t.site_url}`),b.log(`Account type: ${t.account.type}`),b.log(`Has cached actions: ${!!i?.cached_actions?.length}`),b.log(`Has validation exprs: ${!!i?.validation_exprs?.length}`),t.skip_verification)return h.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),h.info(`Navigating to: ${t.site_url}`),await e.goto(t.site_url),await this.waitUntilStable(e,1e4,3e3);let o=!!(t.use_ai_verification_for_login_check&&t.verification_hint?.trim()),a=o?`Check if the page is already signed in. Consider it signed in only when this verification statement is satisfied: ${t.verification_hint.trim()}`:void 0;if(o){b.log("Level 1: Checking if already logged in via AI verification hint..."),b.log(`Verification statement: ${a}`);try{if(await this.evaluate(e,a))return b.log("Level 1 SUCCESS: Already logged in via AI verification"),h.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};b.log("Level 1 FAILED: AI verification indicates not signed in, trying Level 2")}catch(l){b.log(`Level 1 ERROR: AI verification failed (${l.message}), trying Level 2`)}}else t.use_ai_verification_for_login_check&&!t.verification_hint?.trim()&&b.log("Level 1 SKIPPED: use_ai_verification_for_login_check is enabled but verification_hint is empty, falling back to cached validation expressions");if(!o&&i?.validation_exprs&&i.validation_exprs.length>0){if(b.log("Level 1: Checking if already logged in via storage state..."),b.log(`Validation expressions: ${JSON.stringify(i.validation_exprs)}`),await Hi(e,i.validation_exprs))return b.log("Level 1 SUCCESS: Already logged in via storage state"),h.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};b.log("Level 1 FAILED: Storage state validation failed, trying Level 2")}let r=!!(i?.validation_exprs&&i.validation_exprs.length>0);if(i?.cached_actions&&i.cached_actions.length>0&&(o||r)){b.log(`Level 2: Attempting cached login with ${i.cached_actions.length} actions`);try{if((await this.executeCachedLogin(e,i.cached_actions,{validationExprs:i.validation_exprs,aiVerificationStatement:a})).success){b.log("Level 2 SUCCESS: Cached login succeeded"),h.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}}b.log("Level 2 FAILED: Cached login failed, trying Level 3")}catch(l){b.log(`Level 2 ERROR: ${l.message}, trying Level 3`)}}else i?.cached_actions&&i.cached_actions.length>0&&b.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.
|
|
4520
|
+
If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,qp),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()}`),wd(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||ie.join(process.cwd(),"downloads");J.existsSync(n)||J.mkdirSync(n,{recursive:!0});let o=ie.join(n,i);u.info(`[Download Tracking] Downloading file to: ${o}`),await t.saveAs(o),this.context.downloadStatus={filename:i,status:"completed",startTime:this.context.downloadStatus.startTime,filePath:o,timestamp:Date.now()},u.info(`[Download Tracking] Download completed: ${o}`),u.info(`[Download Tracking] Download status set to completed: ${JSON.stringify(this.context.downloadStatus)}`)}catch(n){this.context.downloadStatus={filename:i,status:"failed",startTime:this.context.downloadStatus.startTime,error:n.message,timestamp:Date.now()},u.error(`[Download Tracking] Download failed for ${i}: ${n.message}`)}})}setupDialogHandling(e){if(u.debug(`[Dialog Handling] setupDialogHandling called, isClosed=${e.isClosed()}, url=${e.url()}`),e.isClosed()){u.debug("[Dialog Handling] Skipping - page is closed");return}u.info(`[Dialog Handling] Setting up dialog handling for page: ${e.url()}`),e.on("dialog",async t=>{let i=t.type(),n=t.message();u.info(`[Dialog Handling] Dialog detected - type: ${i}, message: "${n}"`);let o=i==="beforeunload";try{o?await t.dismiss():await t.accept(),this.context.dialogStatus={type:i,message:n,response:o?"dismiss":"accept",timestamp:Date.now()},u.info(`[Dialog Handling] Dialog ${o?"dismissed":"accepted"} - type: ${i}, message: "${n}"`)}catch(a){u.warn(`[Dialog Handling] Failed to handle dialog (already dismissed?): ${a}`)}})}getRecentDownloadedFilePath(){return this.agentServices.getRecentDownloadedFilePath()}addNote(e){this.agentServices.addNote(e)}collectTokenUsages(e){let t;Array.isArray(e)?t=e:e?.tokenUsages&&(t=e.tokenUsages),t&&t.length>0?(this.context.tokenUsages||(this.context.tokenUsages=[]),this.context.tokenUsages.push(...t),u.debug(`[collectTokenUsages] Added ${t.length} token usage(s), total: ${this.context.tokenUsages.length}`)):u.debug("[collectTokenUsages] No token usages to collect (undefined or empty)")}trackAIAction(e,t,i,n=1,o,a){if(!e)return;let s=i?.tokenUsages||[];this.context.aiActionDetails||(this.context.aiActionDetails=[]);let r=this.context.aiActionDetails.find(l=>l.stepId===e&&l.actionType===t);r?(r.count+=n,s.length>0&&r.tokenUsages.push(...s),i?.userPrompt&&(r.userPrompt=i.userPrompt),i?.rawLlmResponse&&(r.rawLlmResponse=i.rawLlmResponse),i?.reasoningContent&&(r.reasoningContent=i.reasoningContent),i?.elementTree&&(r.elementTree=i.elementTree),i?.screenshotWithSom&&(r.screenshotWithSom=i.screenshotWithSom),a&&(r.explanation=a)):this.context.aiActionDetails.push({stepId:e,actionType:t,count:n,tokenUsages:[...s],statement:o,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:a,elementTree:i?.elementTree,screenshotWithSom:i?.screenshotWithSom}),u.debug(`[trackAIAction] Tracked ${t} for step ${e}, count: ${n}`)}async assert(e,t,i){u.info(`Asserting statement: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"assert"),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),o=await qe(t,e,this.agentServices,{executionHistory:n,useCleanScreenshotForAssertion:!0,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(o.debugInfo),this.context.lastActionDebugInfo=o.debugInfo;let a=o.explanation||o.error||"No explanation";if(i&&this.trackAIAction(i,"assert",o.debugInfo,1,t,a),this.context.agentNote=a,i&&this.context.stepTracking&&await this.updateStepResult(i,o.success?"success":"failure",a,void 0,o.debugInfo),!o.success)throw this.addToExecutionHistory(`Assert: "${t}"`,`Failed: ${a}`),new Error(`Assertion failed: ${a}`);return this.addToExecutionHistory(`Assert: "${t}"`,`Passed: ${a}`),!0}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async evaluate(e,t,i){u.info(`Evaluating condition: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"evaluate"),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),o=await qe(t,e,this.agentServices,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(o.debugInfo),this.context.lastActionDebugInfo=o.debugInfo;let a=o.explanation||o.error||"No explanation";return i&&this.trackAIAction(i,"evaluate",o.debugInfo,1,t,a),this.context.agentNote=a,i&&this.context.stepTracking&&await this.updateStepResult(i,"success",a,void 0,o.debugInfo),o.success?(this.addToExecutionHistory(`Evaluate: "${t}"`,`Result: true - ${a}`),!0):(u.warn(`AI evaluation returned false/unknown: ${a}`),this.addToExecutionHistory(`Evaluate: "${t}"`,`Unknown/False: ${a}`),!1)}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async performAction(e,t){u.info(`Act: ${t}`);let i=this.getCompletedExecutionHistory(),n=await Je(t,e,this.agentServices,{executionHistory:i,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});if(this.collectTokenUsages(n.debugInfo),n.status!=="success"||n.actionEntities.length===0)return{success:!1,details:n.explanation||n.error||"Action failed"};let o=n.actionEntities[0]?.action_description||t;return this.addToExecutionHistory(t,o),{success:!0,details:n.explanation}}async execute(e,t,i,n,o){if(o!==void 0&&o<=0)throw new Error(`maxSteps must be >= 1, got ${o}`);let a=o!==void 0&&o>1;u.info(`Executing statement: ${t} (${a?`multi, maxSteps: ${o}`:"single"})`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"execute"),e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e);try{let s=this.getCompletedExecutionHistory();this.context.agentNote="";let r,l;if(a){let c=i&&this.context.stepTracking?.artifactsDir?h=>{if(h.type==="action"&&h.debugInfo){let m=`${i}-step${h.step}`;this.saveDebugInfoToFiles(m,h.debugInfo,this.context.model)}}:void 0;if(r=await Ze(t,e,this.agentServices,c,{executionHistory:s,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:o??Zp}),l=r.completed,this.collectTokenUsages(r.tokenUsages),i&&r.tokenUsages){let h={tokenUsages:r.tokenUsages};this.trackAIAction(i,"execute",h,r.actionEntities?.length||1,t,r.explanation||"Multi-step execution completed")}}else if(e=this.agentServices.validatePage(e),r=await Je(t,e,this.agentServices,{executionHistory:s,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n}),l=r.completed,this.collectTokenUsages(r.debugInfo),this.context.lastActionDebugInfo=r.debugInfo,i){let c=r.explanation||r.error||"No explanation";this.trackAIAction(i,"execute",r.debugInfo,1,t,c)}if(r.status!=="success"||r.actionEntities.length===0||!l){let c=r.explanation||r.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",c,void 0,r.debugInfo),new Error(`Action failed: ${c}`)}let d=this.context.agentNote||r.explanation||"Action executed successfully";return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,r.debugInfo),this.addToExecutionHistory(`Execute: "${t}"`,d),{success:!0,details:d,actions:r.actionEntities,debugInfo:r.debugInfo}}catch(s){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",s.message),this.addToExecutionHistory(`Execute: "${t}"`,`Failed: ${s.message}`),s}}async generate(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"generate");try{let o=this.getCompletedExecutionHistory(),a=await bt(t,e,this.agentServices,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n});if(this.collectTokenUsages(a.debugInfo),a.status!=="success"||a.actionEntities.length===0){let l=a.explanation||a.error||"No explanation";throw i&&this.trackAIAction(i,"generate",a.debugInfo,1,t,l),i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",l,void 0,a.debugInfo),new Error(l)}let s=a.completed,r=a.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",a.debugInfo,1,t,r),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",r,void 0,a.debugInfo),u.info(`[generate] Generated action for "${t}": ${r}, goalAccomplished: ${a.completed}`),{success:s,details:r,actions:a.actionEntities,debugInfo:a.debugInfo}}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),o}}async run(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"run");try{let o=this.getCompletedExecutionHistory();this.context.agentNote="";let a=i&&this.context.stepTracking?.artifactsDir,s=n?.onAction||a?c=>{if(c.type==="action"&&c.action_entity&&(n?.onAction?.(c.action_entity),a&&c.debugInfo)){let h=`${i}-step${c.step}`;this.saveDebugInfoToFiles(h,c.debugInfo,this.context.model)}}:void 0,r=await Ze(t,e,this.agentServices,s,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:n?.abortSignal,maxSteps:n?.maxSteps});w.log(`Run task result: status=${r.status}, completed=${r.completed}, actions=${r.actionEntities?.length||0}`),this.collectTokenUsages(r.tokenUsages);let l=r.status==="success"&&r.completed,d=this.context.agentNote?.trim()||r.explanation||r.error||(l?"Step completed":"Step failed");if(i&&r.tokenUsages){let c={tokenUsages:r.tokenUsages};this.trackAIAction(i,"run",c,r.actionEntities?.length||1,t,d)}if(!l)throw new Co(d);if(n?.stmtUid&&r.actionEntities?.length){let c=r.actionEntities.at(-1);c&&(this._newActionEntities.set(n.stmtUid,c),w.log(`Stored resolved action entity for DRAFT stmtUid: ${n.stmtUid}`))}return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,void 0),this.addToExecutionHistory(`Run: "${t}"`,d),w.log(`Run result: success=${l}, details=${d}`),{success:l,details:d,actions:r.actionEntities}}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),this.addToExecutionHistory(`Run: "${t}"`,`Failed: ${o.message}`),o}}async step(e,t,i,n,o,a=!0,s){let r=Date.now();if(this.context.stepTracking){await this.createStepResult(e,n,i,"step");let m=Jp(t);m&&this.context.stepTracking.results[n]&&(this.context.stepTracking.results[n].code=m)}e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e),this.context.stepTracking&&(this.context.stepTracking.currentStepId=n),e=this.agentServices.validatePage(e);let l=e.url(),d=await this.captureDOMSnapshot(e),c=this.context.stepTracking?.captureVariables?It(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 m=await t();e=this.agentServices.validatePage(e);let g=e.url(),y=await this.captureDOMSnapshot(e),v=this.context.stepTracking?.captureVariables?It(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 p=Date.now()-r,f=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:d||void 0,variables:c,screenshotPath:h,timestamp:r}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:p,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:g,domSnapshot:y||void 0,variables:v,screenshotPath:f,timestamp:S})}let x=this.context.agentNote;return(!x||x.trim()==="")&&(x="Execution successful"),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=x),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}catch(m){e=this.agentServices.validatePage(e);let g=a&&!this.context.isSelfHealing;if(g&&(this.context.stepTracking&&await this.updateStepResult(n,"failure",m.message),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=m.message)),!i||i.trim()==="")throw u.error("No description provided for self-healing"),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m;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 p=e.url(),f=await this.captureDOMSnapshot(e),S=this.context.stepTracking.captureVariables?It(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},_=Date.now()-r,k=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:h,timestamp:r}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:_,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:p,domSnapshot:f||void 0,variables:S,timestamp:k})}throw this.context.stepTracking&&(await this.updateStepResult(n,void 0,void 0),this.context.stepTracking.currentStepId=void 0),m}this.context.isSelfHealing=!0,u.info(`Action failed at step ${n}. ${i}`),u.info(`with error: ${m.message}`);let y,v;if(this.context.autoDismissModal){u.info("Attempting modal dismissal before self-healing...");let p=await this.dismissModalIfPresent(e,i);if(u.info(`Modal dismissal result: ${p.details}`),p.modalDismissed){y=`[Auto-dismissed modal: ${p.details}]`,v=p.actions,u.info(`Modal dismissed, retrying original action for step ${n}`);try{let f=await t();return this.context.isSelfHealing=!1,this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=y+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(n,"success",y),this.context.stepTracking.results[n].dismissedModalActions=v,this.context.stepTracking.currentStepId=void 0),this.context.agentNote=y,f}catch(f){u.info(`Retry after modal dismissal failed: ${f.message}, falling back to self-healing`)}}}let x=s??Yp;u.info(`Calling execute() to self-heal (maxSteps: ${x})`);try{let p=await this.execute(e,i,n,!1,x);if(this.context.isSelfHealing=!1,!p.success)throw new Error(`Self-healing failed: ${p.details}`);let f=p.actions?.at(-1);o&&f&&(this._newActionEntities.set(o,f),u.info(`Stored new action entity for stmtUid: ${o} (last of ${p.actions?.length} actions)`));let S=e.url(),_=await this.captureDOMSnapshot(e),k=this.context.stepTracking?.captureVariables?It(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=f,v&&(this.context.stepTracking.results[n].dismissedModalActions=v);let A=y||"";await this.updateStepResult(n,"success",A)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let A=Date.now()-r,I=this.context.stepTracking.results[n]?.screenshot,O=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:h,timestamp:r}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{actionEntity:f,playwrightCode:p.actions?.map(C=>C.locator||""),llmPrompt:p.debugInfo?.userPrompt,llmResponse:p.debugInfo?.rawLlmResponse,llmReasoning:p.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(n),durationMs:A,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:S,domSnapshot:_||void 0,variables:k,screenshotPath:I,timestamp:O})}return this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}catch(p){if(this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let f=e.url(),S=await this.captureDOMSnapshot(e),_=this.context.stepTracking.captureVariables?It(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},k=Date.now()-r,A=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:h,timestamp:r}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:k,status:"failure",errorMessage:p.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:f,domSnapshot:S||void 0,variables:_,timestamp:A})}throw this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}}}async extract(e,t,i,n){n&&this.context.stepTracking&&await this.createStepResult(e,n,`Extract ${t} into ${i}`,"extract");try{let o=`Extract ${t} and save to ${i}`,a=await this.execute(e,o,n);if(!a.success)throw new Error(`AI extraction failed: ${a.details}`);n&&this.context.stepTracking&&await this.updateStepResult(n,"success",`Extracted ${t} to ${i}`)}catch(o){throw n&&this.context.stepTracking&&await this.updateStepResult(n,"failure",o.message),o}}async getDOMText(e){let t=new we(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 we(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains(),o=await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n,highlightElements:!1,viewportExpansion:0});return{elementTreeText:o.elementTree.clickableElementsToString(),elementCount:o.selectorMap.size,timestamp:Date.now()}}catch(t){return u.warn("Failed to capture DOM snapshot:",t),null}}getConsoleLogsForStep(e){return this.context.stepTracking?.consoleLogs?this.context.stepTracking.consoleLogs.filter(t=>t.stepId===e).map(t=>({type:t.type,message:t.message,timestamp:t.timestamp})):[]}async waitUntilStable(e,t=3e3,i=1e3){return md(e,t,i)}async waitUntilCondition(e,t,i=60,n){return gd(e,t,(o,a,s)=>this.evaluate(o,a,s),i,n)}async uploadFile(e,t,i={},n){return Al(e,t,i,this.context,(o,a,s)=>this.execute(o,a,s),n)}async loginPage(e,t,i){let{LoginType:n}=await Promise.resolve().then(()=>(yd(),bd));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 o=!!(t.use_ai_verification_for_login_check&&t.verification_hint?.trim()),a=o?`Check if the page is already signed in. Consider it signed in only when this verification statement is satisfied: ${t.verification_hint.trim()}`:void 0;if(o){w.log("Level 1: Checking if already logged in via AI verification hint..."),w.log(`Verification statement: ${a}`);try{if(await this.evaluate(e,a))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(!o&&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 Bi(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 s=!!(i?.validation_exprs&&i.validation_exprs.length>0);if(i?.cached_actions&&i.cached_actions.length>0&&(o||s)){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:a})).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 r=`First check if the page is already signed in. If it is, do nothing.
|
|
4521
4521
|
Use your best judgement to determine if the page is signed in.
|
|
4522
|
-
`;if(t.verification_hint&&(
|
|
4522
|
+
`;if(t.verification_hint&&(r+=`
|
|
4523
4523
|
Signed in verification hint: ${t.verification_hint}
|
|
4524
|
-
`),t.account.type===n.PASSWORD)
|
|
4524
|
+
`),t.account.type===n.PASSWORD)r+=`
|
|
4525
4525
|
If the page is not signed in, sign in using provided credentials ($username, $password, etc).
|
|
4526
|
-
`;else{let l=t.account;
|
|
4526
|
+
`;else{let l=t.account;r+=`
|
|
4527
4527
|
If the page is not signed in, sign in with the OAuth provider "${l.provider_name}" using provided credentials
|
|
4528
4528
|
($username, $password), and use $otp_secret_key to generate $otp_code for two-factor authentication. If you can't login with the provided credentials, just stop and report the failure.
|
|
4529
|
-
`}t.additional_prompt&&(
|
|
4529
|
+
`}t.additional_prompt&&(r+=`
|
|
4530
4530
|
Additional instructions: ${t.additional_prompt}
|
|
4531
|
-
`);try{
|
|
4532
|
-
${s}`);let l=this.agentServices.knowledgeRetriever,d=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(b.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(v,x,p,f)=>await l(v,x,p,"login")),d=!0,b.log("Login knowledge retriever configured"));let c;try{if(c=await this.run(e,s,"login"),!c.success)return b.log("Level 3 FAILED: Agent login failed"),h.info("Login: Failed"),{success:!1,page:e}}finally{d&&l&&(this.agentServices.setKnowledgeRetriever(l),b.log("Restored original knowledge retriever"))}let u=await e.context().storageState(),m;if(o)b.log("Skipping validation locator generation (AI verification mode enabled)");else if(t.num_verification_exprs!==0)try{b.log("Generating validation locators for future login verification...");let v=await ko(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(x,p)=>this.run(x,p),async x=>this.getDOMText(x));v?(m=v,b.log(`Generated ${m.length} validation locator(s): ${JSON.stringify(m)}`)):b.log("Failed to generate validation locators, login will still succeed")}catch(v){b.log(`Error generating validation locators: ${v.message}`)}else b.log("Skipping validation locator generation (num_verification_exprs=0)");b.log("Level 3 SUCCESS: Agent login succeeded"),h.info("Login: Agent login succeeded");let g=c.actions||[],w=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:u,cached_actions:w,validation_exprs:m}}catch(l){return b.error(`Agent login failed: ${l.message}`),h.info("Login: Failed"),{success:!1,page:e}}}async executeCachedLogin(e,t,i){let n=(await Promise.resolve().then(()=>(xt(),yt))).default,o=new n;for(let a=0;a<t.length;a++){let r=t[a];b.log(`Executing cached action ${a+1}/${t.length}: ${r.action_description||r.action_data?.action_name}`);try{if(!r.action_data){b.log(`Action ${a+1} missing action_data, skipping`);continue}await o.execute(e,r,this.agentServices),await this.waitUntilStable(e,5e3)}catch(s){return b.error(`Cached action ${a+1} failed: ${s.message}`),{success:!1}}}return i?.aiVerificationStatement?(b.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 Hi(e,i.validationExprs)?{success:!0}:{success:!1}:(b.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,n){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 o={description:i,startTime:Date.now(),artifacts:[],type:n,code:i};if(this.context.stepTracking.artifactsDir){let a=Q.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));z.mkdirSync(a,{recursive:!0});let r=Q.join(a,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:r}),o.screenshot=r}o.contextBefore=this.snapshotVariables(),this.context.stepTracking.results[t]=o}catch(o){h.warn(`createStepResult failed for step ${t}: ${o}`),this.context.stepTracking.results[t]={description:i,startTime:Date.now(),artifacts:[],contextBefore:this.snapshotVariables()}}}}snapshotVariables(){return Mt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys())}saveDebugInfoToFiles(e,t,i,n=0){let o={};if(!this.context.stepTracking?.artifactsDir)return h.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),o;let a=Q.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(z.mkdirSync(a,{recursive:!0}),t.systemPrompt){let r=Q.join(a,`system_prompt_${n}.txt`);z.writeFileSync(r,t.systemPrompt),o.system_prompt_path=r,h.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${r}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let r=Q.join(a,`user_prompt_${n}.txt`);z.writeFileSync(r,t.userPrompt),o.user_prompt_path=r,h.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${r}`)}else{let r=t.userPrompt.map(d=>Array.isArray(d.content)?{...d,content:d.content.map(c=>c.type==="image"&&c.file?.startsWith("data:")?{...c,file:"[base64 image data stripped]"}:c)}:d),s=Q.join(a,`messages_${n}.json`),l={system:t.systemPrompt,messages:r};z.writeFileSync(s,JSON.stringify(l,null,2)),o.messages_path=s,h.debug(`[saveDebugInfoToFiles] Saved messages to: ${s}`)}if(t.rawLlmResponse){let r=i?i.replace(/[\/\\:]/g,"-"):"llm",s=Q.join(a,`${r}_response_${n}.txt`);z.writeFileSync(s,t.rawLlmResponse),o.response_path=s,h.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${s}`)}if(t.screenshotWithSom){let r=Q.join(a,`screenshot_${n}.png`);z.writeFileSync(r,Buffer.from(t.screenshotWithSom,"base64")),o.screenshot_path=r,h.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${r}`)}if(t.reasoningContent){let r=Q.join(a,`reasoning_${n}.txt`);z.writeFileSync(r,t.reasoningContent),o.reasoning_path=r,h.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${r}`)}h.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(o).length} artifacts for step ${e}`)}catch(r){h.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,r)}return o}async updateStepResult(e,t,i,n,o){if(!this.context.stepTracking)return;let a=this.context.stepTracking.results[e];if(a){if(t&&(a.status=t,a.contextAfter=this.snapshotVariables(),this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(a.message=i),n&&a.artifacts.push(n),o){let r=o.tokenUsages?.[0]?.model,s=a.artifacts.length,l=this.saveDebugInfoToFiles(e,o,r,s);Object.keys(l).length>0&&a.artifacts.push(l)}a.duration=Date.now()-a.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(e,a)}}async writeExecutionResults(e,t){try{if(await z.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 z.promises.writeFile(i,JSON.stringify(this.context.stepTracking.results,null,2)),h.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 z.promises.writeFile(i,JSON.stringify(this.context.tokenUsages,null,2)),h.debug(`Token usages written to: ${i}`)}if(this.context.aiActionDetails&&this.context.aiActionDetails.length>0){let i=Q.join(e,"ai-actions.json");await z.promises.writeFile(i,JSON.stringify(this.context.aiActionDetails,null,2)),h.debug(`AI action details written to: ${i}`)}}catch(i){throw h.error("Failed to write execution results:",i),i}}}});function zp(){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(p=>p.type==="year").value,n=t.find(p=>p.type==="month").value,o=t.find(p=>p.type==="day").value,a=t.find(p=>p.type==="hour").value,r=t.find(p=>p.type==="minute").value,s=t.find(p=>p.type==="second").value,l=String(e.getMilliseconds()).padStart(3,"0"),d=`${i}-${n}-${o}T${a}:${r}:${s}.${l}`,c=e.toISOString().slice(0,-1),u=Date.parse(d+"Z"),m=Date.parse(c+"Z"),g=Math.round((m-u)/(1e3*60)),w=String(Math.floor(Math.abs(g)/60)).padStart(2,"0"),v=String(Math.abs(g)%60).padStart(2,"0"),x=g<=0?"+":"-";return`${i}-${n}-${o}T${a}:${r}:${s}.${l}${x}${w}:${v}`}function za(e){let t=e.variableStore;return t.has("currentTime")||t.set("currentTime",zp()),{model:e.model,computer_use_model:e.computer_use_model,variableStore:t,organizationId:e.organizationId,organizationSettings:e.organizationSettings,executionHistory:e.executionHistory||[],testDataDir:e.testDataDir,downloadDir:e.downloadDir,useNativeGenerator:e.useNativeGenerator,autoDismissModal:e.autoDismissModal,tokenUsages:[],aiActionDetails:[]}}var wd=y(()=>{"use strict"});var bd={};je(bd,{ActionHandler:()=>Zn,ActionHelper:()=>Di,Agent:()=>ja,AgentServices:()=>Ao,AgentStepEventTypes:()=>Ga,AgentTaskFailedError:()=>Mo,BrowserManager:()=>Zc,DEFAULT_EVENT_LISTENER_LIMIT:()=>_n,DomService:()=>ue,EVENT_LISTENER_CANDIDATE_SELECTORS:()=>vn,HistoryTreeProcessor:()=>il,INIT_SCRIPT:()=>Re,INTERACTION_EVENT_TYPES:()=>ut,INTERACTIVE_ROLES:()=>Vt,LogLevel:()=>sa,LoginType:()=>Ri,MCPToolProvider:()=>Hc,OpenAIToolProvider:()=>qi,SDK_VERSION:()=>Xp,ToolRegistry:()=>dt,TwoFactorAuthType:()=>Na,VariableStore:()=>Ra,WebAgent:()=>ja,configureSdk:()=>Yr,createAgent:()=>Vp,createAgentContext:()=>za,createToolRegistry:()=>Oc,createToolRegistryWithCapabilities:()=>Nc,discoverChromiumCdpUrl:()=>_o,ensureToolsRegistered:()=>Lc,evaluateStatement:()=>Ye,executeStep:()=>Xe,exportMCPTools:()=>Wc,filterInteractionListeners:()=>Ws,generateActionStep:()=>wt,getActionEntityLocatorInfo:()=>N,getBrowserCdpUrl:()=>no,getCapabilitySummary:()=>Rc,getFramePath:()=>na,getModel:()=>we,getPageInfo:()=>wc,getPageWsUrl:()=>fc,getPlatformFromDeviceName:()=>od,getProviderOptions:()=>be,getSdkConfig:()=>B,getToolRegistry:()=>Dc,injectUserFunction:()=>Ko,isInteractionEventType:()=>Hs,isInteractiveRole:()=>Fs,loadKnowledgeMappings:()=>ts,loadKnowledges:()=>es,loadUserFunctions:()=>Zr,logger:()=>h,newBrowserContext:()=>gc,parseSSEStream:()=>Vr,parseSdkLogLevelFromEnv:()=>Jr,pickBestLocator:()=>Rt,pickBestLocatorForElement:()=>nn,pickBestLocators:()=>rs,registerBrowser:()=>kt,replaceVariables:()=>yo,runTask:()=>Je,setWindowBounds:()=>oo,toolRegistry:()=>W,unregisterBrowser:()=>St});function Vp(e){let t=new Ra,i=new Set(e.sensitiveKeys||[]);if(e.variables)for(let[o,a]of Object.entries(e.variables))t.set(o,a,i.has(o));let n=za({model:e.model,variableStore:t,testDataDir:e.testDataDir,downloadDir:e.downloadDir});return new ja(n)}var Xp,Va=y(()=>{"use strict";Xr();Qr();is();Fc();Uc();Bc();Da();Ca();La();$a();Qc();nd();ad();rd();Oa();fd();ei();xn();bn();Zi();ct();cn();un();at();dn();pn();Bt();Gt();Te();Ot();Ut();Dn();Ve();zt();Xt();ht();Yt();Jt();So();ie();Ba();Ua();Tt();Eo();Ie();_t();Ee();Ht();rt();Wt();Ne();Ka();Ma();Sn();En();Tn();An();Mn();In();Pn();Cn();$n();On();Nn();ti();ii();ni();oi();ri();li();ci();ui();hi();mi();pi();gi();fi();bi();yi();xi();vi();ki();Si();Ti();Ai();Mi();Ii();Pi();Ci();$i();Zt();Li();Xn();di();j();ze();F();te();pt();qn();H();wd();pe();Xp="1.0.0"});var yd,xd=y(()=>{"use strict";yd=class{version;goal;url;constructor(e,t){this.version=e,this.goal=t.goal,this.url=t.url}generatePrelude(){let e=`// version ${this.version}
|
|
4531
|
+
`);try{w.log("Level 3: Attempting agent-based login"),w.log(`Login prompt:
|
|
4532
|
+
${r}`);let l=this.agentServices.knowledgeRetriever,d=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(w.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(v,x,p,f)=>await l(v,x,p,"login")),d=!0,w.log("Login knowledge retriever configured"));let c;try{if(c=await this.run(e,r,"login"),!c.success)return w.log("Level 3 FAILED: Agent login failed"),u.info("Login: Failed"),{success:!1,page:e}}finally{d&&l&&(this.agentServices.setKnowledgeRetriever(l),w.log("Restored original knowledge retriever"))}let h=await e.context().storageState(),m;if(o)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 To(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(x,p)=>this.run(x,p),async x=>this.getDOMText(x));v?(m=v,w.log(`Generated ${m.length} validation locator(s): ${JSON.stringify(m)}`)):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=c.actions||[],y=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:h,cached_actions:y,validation_exprs:m}}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(()=>(vt(),xt))).default,o=new n;for(let a=0;a<t.length;a++){let s=t[a];w.log(`Executing cached action ${a+1}/${t.length}: ${s.action_description||s.action_data?.action_name}`);try{if(!s.action_data){w.log(`Action ${a+1} missing action_data, skipping`);continue}await o.execute(e,s,this.agentServices),await this.waitUntilStable(e,5e3)}catch(r){return w.error(`Cached action ${a+1} failed: ${r.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 Bi(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,n){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 o={description:i,startTime:Date.now(),artifacts:[],type:n,code:i};if(this.context.stepTracking.artifactsDir){let a=ie.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));J.mkdirSync(a,{recursive:!0});let s=ie.join(a,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:s}),o.screenshot=s}o.contextBefore=this.snapshotVariables(),this.context.stepTracking.results[t]=o}catch(o){u.warn(`createStepResult failed for step ${t}: ${o}`),this.context.stepTracking.results[t]={description:i,startTime:Date.now(),artifacts:[],contextBefore:this.snapshotVariables()}}}}snapshotVariables(){return It(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys())}saveDebugInfoToFiles(e,t,i,n=0){let o={};if(!this.context.stepTracking?.artifactsDir)return u.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),o;let a=ie.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(J.mkdirSync(a,{recursive:!0}),t.systemPrompt){let s=ie.join(a,`system_prompt_${n}.txt`);J.writeFileSync(s,t.systemPrompt),o.system_prompt_path=s,u.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${s}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let s=ie.join(a,`user_prompt_${n}.txt`);J.writeFileSync(s,t.userPrompt),o.user_prompt_path=s,u.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${s}`)}else{let s=t.userPrompt.map(d=>Array.isArray(d.content)?{...d,content:d.content.map(c=>c.type==="image"&&c.file?.startsWith("data:")?{...c,file:"[base64 image data stripped]"}:c)}:d),r=ie.join(a,`messages_${n}.json`),l={system:t.systemPrompt,messages:s};J.writeFileSync(r,JSON.stringify(l,null,2)),o.messages_path=r,u.debug(`[saveDebugInfoToFiles] Saved messages to: ${r}`)}if(t.rawLlmResponse){let s=i?i.replace(/[\/\\:]/g,"-"):"llm",r=ie.join(a,`${s}_response_${n}.txt`);J.writeFileSync(r,t.rawLlmResponse),o.response_path=r,u.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${r}`)}if(t.screenshotWithSom){let s=ie.join(a,`screenshot_${n}.png`);J.writeFileSync(s,Buffer.from(t.screenshotWithSom,"base64")),o.screenshot_path=s,u.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${s}`)}if(t.reasoningContent){let s=ie.join(a,`reasoning_${n}.txt`);J.writeFileSync(s,t.reasoningContent),o.reasoning_path=s,u.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${s}`)}u.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(o).length} artifacts for step ${e}`)}catch(s){u.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,s)}return o}async updateStepResult(e,t,i,n,o){if(!this.context.stepTracking)return;let a=this.context.stepTracking.results[e];if(a){if(t&&(a.status=t,a.contextAfter=this.snapshotVariables(),this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(a.message=i),n&&a.artifacts.push(n),o){let s=o.tokenUsages?.[0]?.model,r=a.artifacts.length,l=this.saveDebugInfoToFiles(e,o,s,r);Object.keys(l).length>0&&a.artifacts.push(l)}a.duration=Date.now()-a.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(e,a)}}async writeExecutionResults(e,t){try{if(await J.promises.mkdir(e,{recursive:!0}),this.context.stepTracking?.results&&Object.keys(this.context.stepTracking.results).length>0){let i=ie.join(e,"test-results.json");await J.promises.writeFile(i,JSON.stringify(this.context.stepTracking.results,null,2)),u.debug(`Test results written to: ${i}`)}if(t?.tokenUsages&&this.context.tokenUsages&&this.context.tokenUsages.length>0){let i=ie.join(e,"token-usages.json");await J.promises.writeFile(i,JSON.stringify(this.context.tokenUsages,null,2)),u.debug(`Token usages written to: ${i}`)}if(this.context.aiActionDetails&&this.context.aiActionDetails.length>0){let i=ie.join(e,"ai-actions.json");await J.promises.writeFile(i,JSON.stringify(this.context.aiActionDetails,null,2)),u.debug(`AI action details written to: ${i}`)}}catch(i){throw u.error("Failed to write execution results:",i),i}}}});function Qp(){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(p=>p.type==="year").value,n=t.find(p=>p.type==="month").value,o=t.find(p=>p.type==="day").value,a=t.find(p=>p.type==="hour").value,s=t.find(p=>p.type==="minute").value,r=t.find(p=>p.type==="second").value,l=String(e.getMilliseconds()).padStart(3,"0"),d=`${i}-${n}-${o}T${a}:${s}:${r}.${l}`,c=e.toISOString().slice(0,-1),h=Date.parse(d+"Z"),m=Date.parse(c+"Z"),g=Math.round((m-h)/(1e3*60)),y=String(Math.floor(Math.abs(g)/60)).padStart(2,"0"),v=String(Math.abs(g)%60).padStart(2,"0"),x=g<=0?"+":"-";return`${i}-${n}-${o}T${a}:${s}:${r}.${l}${x}${y}:${v}`}function qa(e){let t=e.variableStore;return t.has("currentTime")||t.set("currentTime",Qp()),{model:e.model,computer_use_model:e.computer_use_model,variableStore:t,organizationId:e.organizationId,organizationSettings:e.organizationSettings,executionHistory:e.executionHistory||[],testDataDir:e.testDataDir,downloadDir:e.downloadDir,useNativeGenerator:e.useNativeGenerator,autoDismissModal:e.autoDismissModal,tokenUsages:[],aiActionDetails:[]}}var vd=b(()=>{"use strict"});var _d={};Ve(_d,{ActionHandler:()=>to,ActionHelper:()=>Ri,Agent:()=>Ja,AgentServices:()=>Po,AgentStepEventTypes:()=>Xa,AgentTaskFailedError:()=>Co,BrowserManager:()=>id,DEFAULT_EVENT_LISTENER_LIMIT:()=>En,DomService:()=>we,EVENT_LISTENER_CANDIDATE_SELECTORS:()=>Sn,HistoryTreeProcessor:()=>rl,INIT_SCRIPT:()=>We,INTERACTION_EVENT_TYPES:()=>ht,INTERACTIVE_ROLES:()=>Jt,LogLevel:()=>ha,LoginType:()=>Hi,MCPToolProvider:()=>Gc,OpenAIToolProvider:()=>en,SDK_VERSION:()=>tg,ToolRegistry:()=>ut,TwoFactorAuthType:()=>Ua,VariableStore:()=>Ba,WebAgent:()=>Ja,configureSdk:()=>Qr,createAgent:()=>eg,createAgentContext:()=>qa,createToolRegistry:()=>Hc,createToolRegistryWithCapabilities:()=>Wc,discoverChromiumCdpUrl:()=>Eo,ensureToolsRegistered:()=>Rc,evaluateStatement:()=>qe,executeStep:()=>Je,exportMCPTools:()=>Kc,filterInteractionListeners:()=>Ks,generateActionStep:()=>bt,getActionEntityLocatorInfo:()=>F,getBrowserCdpUrl:()=>ro,getCapabilitySummary:()=>Uc,getFramePath:()=>la,getModel:()=>Se,getPageInfo:()=>vc,getPageWsUrl:()=>xc,getPlatformFromDeviceName:()=>ld,getProviderOptions:()=>Ee,getSdkConfig:()=>V,getToolRegistry:()=>Fc,injectUserFunction:()=>Yo,isInteractionEventType:()=>Gs,isInteractiveRole:()=>Bs,loadKnowledgeMappings:()=>as,loadKnowledges:()=>os,loadUserFunctions:()=>is,logger:()=>u,newBrowserContext:()=>yc,parseSSEStream:()=>qr,parseSdkLogLevelFromEnv:()=>es,pickBestLocator:()=>Wt,pickBestLocatorForElement:()=>rn,pickBestLocators:()=>ds,registerBrowser:()=>St,replaceVariables:()=>_o,runTask:()=>Ze,setWindowBounds:()=>so,toolRegistry:()=>G,unregisterBrowser:()=>Et});function eg(e){let t=new Ba,i=new Set(e.sensitiveKeys||[]);if(e.variables)for(let[o,a]of Object.entries(e.variables))t.set(o,a,i.has(o));let n=qa({model:e.model,variableStore:t,testDataDir:e.testDataDir,downloadDir:e.downloadDir});return new Ja(n)}var tg,Za=b(()=>{"use strict";Zr();ns();rs();Bc();Ha();jc();zc();Na();Fa();Ra();nd();sd();cd();dd();Wa();xd();ni();kn();vn();tn();dt();hn();pn();rt();mn();wn();jt();zt();$e();Ft();Kt();Rn();Ye();Yt();qt();mt();Zt();Qt();Ao();ae();Va();za();At();Mo();De();kt();Ce();Bt();st();Gt();He();Ya();Oa();An();Mn();In();Pn();Cn();$n();On();Ln();Dn();Fn();Hn();oi();ai();ri();si();ci();ui();hi();pi();gi();fi();wi();bi();yi();vi();_i();ki();Si();Ti();Ai();Ii();Pi();Ci();$i();Oi();Li();Di();ti();Ni();qn();mi();Y();Xe();W();oe();gt();eo();U();vd();ve();tg="1.0.0"});var er,tr,kd=b(()=>{"use strict";er=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(er||{}),tr=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(tr||{})});var Sd,Ed=b(()=>{"use strict";Sd=class{version;goal;url;constructor(e,t){this.version=e,this.goal=t.goal,this.url=t.url}generatePrelude(){let e=`// version ${this.version}
|
|
4533
4533
|
`,t=this.goal,i=this.url;e+=`// Navigate to the specified URL
|
|
4534
4534
|
const targetUrl = process.env.PLAYWRIGHT_STARTING_URL || '${i}';
|
|
4535
4535
|
if (targetUrl !== null) {
|
|
@@ -4543,7 +4543,7 @@ await page.waitForTimeout(2000);
|
|
|
4543
4543
|
`,e+=` // Goal:
|
|
4544
4544
|
`;let n=t.trim().split(`
|
|
4545
4545
|
`);for(let o of n)e+=` // ${o}
|
|
4546
|
-
`;return e}generatePostlude(){return""}}});function vd(e){if(!e)return"desktop";for(let t of Zp)if(t.test(e))return"mobile";return"desktop"}var Zp,_d=y(()=>{"use strict";Zp=[/iphone/i,/ipad/i,/android/i,/pixel/i,/galaxy/i,/mobile/i,/nexus/i,/blackberry/i,/kindle/i]});function kd(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let r=a.startsWith("$")?a.slice(1):a,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o}var Sd=y(()=>{"use strict"});function Ja(e){let t=e.match(/\.getByRole\(['"]([^'"]+)['"]/);if(t&&t[1]){let p=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(p&&p[1]){let S=p[1].replace(/\\(.)/g,"$1");return`${t[1]} element with text "${S}"`}let f=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(f&&f[1]){let S=f[1].replace(/^\/|\/$/g,""),_=S.length>30?`${S.substring(0,27)}...`:S;return`${t[1]} element with text matching "${_}"`}return`${t[1]} element`}let i=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(i&&i[1]){let p=It(e),f=i[1].replace(/\\(.)/g,"$1");return`${p} with text "${f}"`}let n=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(n&&n[1])return`${It(e)} with text matching ${n[1]}`;let o=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(o&&o[1]){let p=It(e),f=o[1].replace(/\\(.)/g,"$1");return`${p} containing "${f}"`}let a=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(a&&a[1]){let p=It(e),f=a[1].replace(/\\(.)/g,"$1");return`${p} containing "${f}"`}let r=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(r&&r[1]){let p=It(e),f=r[1].replace(/\\(.)/g,"$1");return`${p} not containing "${f}"`}let s=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(s&&s[1]){let p=It(e),f=s[1].replace(/\\(.)/g,"$1");return`${p} not containing "${f}"`}let l=e.match(/name:\s*'((?:[^'\\]|\\.)*)'/);if(l&&l[1])return`"${l[1].replace(/\\(.)/g,"$1")}"`;let d=e.match(/name:\s*"((?:[^"\\]|\\.)*)"/);if(d&&d[1])return`"${d[1].replace(/\\(.)/g,"$1")}"`;let c=e.match(/getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(c&&c[1])return`"${c[1].replace(/\\(.)/g,"$1")}"`;let u=e.match(/getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(u&&u[1])return`"${u[1].replace(/\\(.)/g,"$1")}"`;let m=e.match(/getByPlaceholder\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(m&&m[1])return`input with placeholder "${m[1].replace(/\\(.)/g,"$1")}"`;let g=e.match(/getByPlaceholder\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(g&&g[1])return`input with placeholder "${g[1].replace(/\\(.)/g,"$1")}"`;let w=e.match(/getByLabel\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(w&&w[1])return`"${w[1].replace(/\\(.)/g,"$1")}"`;let v=e.match(/getByLabel\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(v&&v[1])return`"${v[1].replace(/\\(.)/g,"$1")}"`;let x=e.match(/getByRole\(['"]([^'"]+)['"]/);return x&&x[1]?`${x[1]} element`:e.length>50?`${e.substring(0,47)}...`:e}function qa(e,t){if(!e||!t)return null;let i=t.replace(/^ref=/,""),n=e.split(`
|
|
4547
|
-
`);for(let o of n){if(!o.includes(`[ref=${i}]`))continue;let
|
|
4548
|
-
`)}function le(e){switch(e.type){case"DRAFT":return tg(e);case"ACTION":return Dd(e);case"STEP":return ng(e);case"IF_ELSE":return og(e);case"WHILE_LOOP":return ag(e)}}function tg(e){return{intent:e.description}}function Dd(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"&&l.trim()?{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"&&s.trim()&&e.description)return{description:e.description,js:s}}if(t==="ai_wait_until"){let s=i?.condition;if(typeof s=="string"){let l={WAIT_UNTIL:s};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="wait"){let s=i?.seconds,d={WAIT:e.description||`Wait ${s}s`};return typeof s=="number"&&(d.seconds=s),d}if(t==="js_code"){let s=i?.code;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{description:e.description||"Code block",js:s}}if(!e.action_entity)return{intent:e.description};let n=e.action_entity.action_data??e.action_entity.action;if(!n)return{intent:e.description};let o={intent:e.description,action:n.action_name},a=e.locator??e.action_entity.locator;a&&(o.locator=a);let r=e.action_entity.xpath;if(r&&(o.xpath=r),e.use_pure_vision&&(o.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[s,l]of Object.entries(n.kwargs))s!=="uid"&&(s==="statement"&&(t==="ai_action"||t==="ai_step")||(o[s]=l));return n.args&&n.args.length>0&&(o.args=n.args),o}function Od(e,t,i){let n={uid:"",type:"ACTION",description:t||e.action_description||"",action_entity:e,locator:i},o=Dd(n);if(typeof o=="object"&&o!==null){let a={...o};return delete a.intent,delete a.description,delete a.VERIFY,delete a.WAIT_UNTIL,delete a.WAIT,delete a.statement,Object.keys(a).length>0?(0,$.stringify)(a,Ct).trim():""}return(0,$.stringify)(o,Ct).trim()}function Nd(e){let t=(0,$.parse)(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object");if("VERIFY"in t){let c=String(t.VERIFY),u=typeof t.js=="string"?t.js:void 0;return{description:c,actionEntity:{action_description:c,action_data:{action_name:"verify",kwargs:{statement:c,...u?{code:u}:{}}}}}}if("URL"in t){let c=String(t.URL),u={url:c};return t.new_tab===!0&&(u.new_tab=!0),typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Navigate to ${c}`,actionEntity:{action_description:`Navigate to ${c}`,action_data:{action_name:"go_to_url",kwargs:u}}}}if("CODE"in t){let c=String(t.CODE);return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:c}}}}}if("js"in t&&typeof t.js=="string"&&!("VERIFY"in t)&&!("action"in t)){let c=typeof t.description=="string"?t.description:typeof t.intent=="string"?t.intent:"";return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:t.js}}}}}if("WAIT_UNTIL"in t){let c=String(t.WAIT_UNTIL),u={condition:c};return typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Wait until ${c}`,actionEntity:{action_description:`Wait until ${c}`,action_data:{action_name:"ai_wait_until",kwargs:u}}}}if("WAIT"in t){let c=String(t.WAIT),u={};return typeof t.seconds=="number"&&(u.seconds=t.seconds),{description:c,actionEntity:{action_description:c,action_data:{action_name:"wait",kwargs:u}}}}let i=typeof t.intent=="string"?t.intent:void 0,n=typeof t.action=="string"?t.action:void 0,o=typeof t.locator=="string"?t.locator:void 0,a=typeof t.xpath=="string"?t.xpath:void 0,r=Array.isArray(t.frame_path)?t.frame_path:void 0,s=Array.isArray(t.args)?t.args:void 0,l={};for(let[c,u]of Object.entries(t))ig.has(c)||(l[c]=u);return n?{actionEntity:{action_description:i||"",action_data:{action_name:n,kwargs:l,...s&&s.length>0?{args:s}:{}},...o?{locator:o}:{},...a?{xpath:a}:{},...r?{frame_path:r}:{}},description:i,locator:o}:{description:i,actionEntity:{action_description:i||""}}}function ng(e){if(e.template_path){let i={template:e.template_path};return e.template_params&&Object.keys(e.template_params).length>0&&(i.params=e.template_params),i}let t={STEP:e.description,statements:e.statements.map(le)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function og(e){let t={IF:Rd(e.condition),THEN:e.then.map(le)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(le)),t}function ag(e){let t={WHILE:Rd(e.condition),DO:e.body.map(le)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function Rd(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function Fd(e){let t=(0,$.parseAllDocuments)(e),i;if(t.length>1||t.length===1&&!Array.isArray(t[0]?.toJSON()))i=t.map((n,o)=>n.errors.length>0?{__parseError:`Document ${o+1}: ${n.errors[0].message}`}:n.toJSON());else{let n;try{n=(0,$.parse)(e)}catch(o){throw new Error(`Invalid YAML: ${o instanceof Error?o.message:String(o)}`)}if(!Array.isArray(n))throw new Error("Expected a YAML array or multi-document YAML (separated by ---)");i=n}return i.map((n,o)=>{try{if(n&&typeof n=="object"&&"__parseError"in n)return{error:n.__parseError};if(!n||typeof n!="object")return{error:`Item ${o+1}: expected an object`};let a=n,r=typeof a.name=="string"&&a.name.trim()||void 0,s=typeof a.goal=="string"?a.goal.trim():"";if(!s)return{error:`Item ${o+1}: missing "goal" field`};if(Array.isArray(a.statements))try{let l=(0,$.stringify)(a,Ct),d=et(l);return{name:r,goal:d.goal??s,testFlow:d}}catch{}return{name:r,goal:s}}catch(a){return{error:`Item ${o+1}: ${a instanceof Error?a.message:String(a)}`}}})}function Hd(e){try{let t=(0,$.parse)(e);if(!t||typeof t!="object")return{};let i={};return typeof t.test_case_id=="number"&&Number.isFinite(t.test_case_id)&&(i.test_case_id=t.test_case_id),typeof t.template_id=="number"&&Number.isFinite(t.template_id)&&(i.template_id=t.template_id),typeof t.name=="string"&&t.name.trim()&&(i.name=t.name.trim()),typeof t.timeout=="number"&&Number.isFinite(t.timeout)&&(i.timeout=t.timeout),t.settings&&typeof t.settings=="object"&&!Array.isArray(t.settings)&&(i.settings=t.settings),t.use&&typeof t.use=="object"&&!Array.isArray(t.use)&&(i.use=t.use),Array.isArray(t.tags)&&t.tags.every(n=>typeof n=="string")&&(i.tags=t.tags),(typeof t.skip=="boolean"||typeof t.skip=="string")&&(i.skip=t.skip),(typeof t.fail=="boolean"||typeof t.fail=="string")&&(i.fail=t.fail),t.only===!0&&(i.only=!0),t.slow===!0&&(i.slow=!0),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(i.beforeEach=t.beforeEach),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(i.afterEach=t.afterEach),Array.isArray(t.parameters)&&t.parameters.length>0&&(i.parameters=t.parameters),i}catch{return{}}}function rr(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(rr);let t=e,i=Object.keys(t);if(i.length===1){let o=i[0];if(o.startsWith("{ ")&&o.endsWith(" }")&&t[o]===null)return`{{${o.slice(2,-2)}}}`}let n={};for(let[o,a]of Object.entries(t))n[o]=rr(a);return n}function et(e){if(e.length>Pd)throw new Error(`YAML input too large (${e.length} bytes, max ${Pd})`);let t=rr((0,$.parse)(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return rg(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:ce(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=ce(t.teardown));let n=Po.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let o=n.data;return cr(e,o),o}function rg(e){let t=e.suite;if(!t||typeof t!="object")throw new Error("Invalid suite: expected an object");let i=t.tests;if(!Array.isArray(i)||i.length===0)throw new Error('Suite must have a non-empty "tests" array');let o={tests:i.map(s=>{if(!s.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(s.statements)||s.statements.length===0)throw new Error(`Suite test "${s.name}" must have a non-empty "statements" array`);let l={name:s.name,statements:ce(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=ce(s.teardown)),s.skip!==void 0&&(l.skip=s.skip),typeof s.timeout=="number"&&(l.timeout=s.timeout),s.fail!==void 0&&(l.fail=s.fail),s.only===!0&&(l.only=!0),s.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(o.beforeAll=ce(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(o.afterAll=ce(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(o.beforeEach=ce(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(o.afterEach=ce(t.afterEach));let a=Ui.safeParse(o);if(!a.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(a.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:a.data}}function ce(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(sg)}function sg(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 lg(t);if("WHILE"in t)return cg(t);if("STEP"in t)return dg(t);if("VERIFY"in t){let i=t.VERIFY,n={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(n.code=t.js),{uid:(0,se.v4)(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:n}}}}if("URL"in t){let i=t.URL,n=t.new_tab===!0?!0:void 0,o=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,a={url:typeof i=="string"?i:String(i)};return n&&(a.new_tab=!0),o!==void 0&&(a.timeout_seconds=o),{uid:(0,se.v4)(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:a}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:(0,se.v4)(),type:"ACTION",description:`Wait until: ${i}`,action_entity:{action_description:`Wait until: ${i}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:typeof i=="string"?i:String(i),timeout_seconds:n}}}}}if("WAIT"in t){let i=t.WAIT,n=typeof t.seconds=="number"?t.seconds:3;return{uid:(0,se.v4)(),type:"ACTION",description:typeof i=="string"?i:`Wait ${n}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${n}s`,action_data:{action_name:"wait",kwargs:{seconds:n}}}}}if("CODE"in t){let i=t.CODE;if(i==null)throw new Error('CODE statement has no code. Use "CODE: |" followed by indented code on the next line.');let n=typeof t.description=="string"?t.description:"Code block";return{uid:(0,se.v4)(),type:"ACTION",description:n,action_entity:{action_description:n,action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&!("VERIFY"in t)&&!("action"in t)){if("intent"in t||"desc"in t)throw new Error("A `js:` statement uses `description:`, not `intent:`. Raw JS does not self-heal \u2014 use `description: + js:` for code, or express it as a structured action (`intent:` + `action:`/`locator:`) to keep self-healing.");let i=typeof t.description=="string"&&t.description.trim()!==""?t.description:"Code block",n=t.js;return{uid:(0,se.v4)(),type:"ACTION",description:i,action_entity:{action_description:i,action_data:{action_name:"js_code",kwargs:{code:typeof n=="string"?n:String(n)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...n}=t;return Cd({...n,action:"function",functionName:i})}if("action"in t)return Cd(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:(0,se.v4)(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function Wd(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 lg(e){let t=Wd(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:(0,se.v4)(),type:"IF_ELSE",condition:t,then:ce(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=ce(e.ELSE)),n}function cg(e){let t=Wd(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:(0,se.v4)(),type:"WHILE_LOOP",condition:t,body:ce(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function dg(e){let t=typeof e.STEP=="string"?e.STEP:"";if(!Array.isArray(e.statements))throw new Error("STEP requires a statements array");let i={uid:(0,se.v4)(),type:"STEP",description:t,statements:ce(e.statements)};if(typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),typeof e.template_path=="string"&&(i.template_path=e.template_path),e.template_params&&typeof e.template_params=="object"&&!Array.isArray(e.template_params)){let n=e.template_params,o={};for(let[a,r]of Object.entries(n))o[a]=String(r);i.template_params=o}return i}function Cd(e){let t=typeof e.action=="string"?e.action:String(e.action),i=typeof e.intent=="string"?e.intent:typeof e.desc=="string"?e.desc:"",n=typeof e.locator=="string"?e.locator:void 0,o=typeof e.xpath=="string"?e.xpath:void 0,a=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[d,c]of Object.entries(e))ug.has(d)||(r[d]=c);t==="verify"&&typeof r.js=="string"&&(r.code=r.js,delete r.js),(t==="ai_action"||t==="ai_step")&&r.statement===void 0&&(r.statement=i);let s={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};n&&(s.locator=n),o&&(s.xpath=o);let l={uid:(0,se.v4)(),type:"ACTION",description:i,action_entity:s};return a&&(l.use_pure_vision=!0),l}function cr(e,t){let i;try{i=(0,$.parseDocument)(e)}catch{return}let n=i.contents;if(!n||!(0,$.isMap)(n))return;if(i.commentBefore)t.comment=i.commentBefore;else{let l=n.items?.[0];l?.key&&l.key.commentBefore&&(t.comment=l.key.commentBefore)}let o=n,a=o.get("statements",!0);(0,$.isSeq)(a)&&t.statements&&Pt(a,t.statements);let r=o.get("teardown",!0);(0,$.isSeq)(r)&&t.teardown&&Pt(r,t.teardown)}function Pt(e,t){e.commentBefore&&t.length>0&&(t[0].comment=e.commentBefore);for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=e.items[i];n.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=n.commentBefore);let o=t[i];if(o.type==="STEP"&&(0,$.isMap)(n)){let a=n.get("statements",!0);(0,$.isSeq)(a)&&Pt(a,o.statements)}else if(o.type==="IF_ELSE"&&(0,$.isMap)(n)){let a=n.get("THEN",!0);(0,$.isSeq)(a)&&Pt(a,o.then);let r=n.get("ELSE",!0);(0,$.isSeq)(r)&&o.else&&Pt(r,o.else)}else if(o.type==="WHILE_LOOP"&&(0,$.isMap)(n)){let a=n.get("DO",!0);(0,$.isSeq)(a)&&Pt(a,o.body)}}}var $,se,Ct,ig,Pd,ug,Co=y(()=>{"use strict";ar();$=require("yaml"),se=require("uuid");Ct={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};ig=new Set(["intent","description","action","locator","xpath","frame_path","args","js"]);Pd=1024*1024;ug=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});function dr(e,t){let i=[];t.version!=="1.0"&&i.push(`Unsupported patch version: ${t.version}`),(!Array.isArray(t.operations)||t.operations.length===0)&&i.push("Patch must have at least one operation");for(let n=0;n<t.operations.length;n++){let o=t.operations[n],a=`operations[${n}]`;switch(o.reason||i.push(`${a}: missing reason`),o.op){case"remove":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`);break}case"modify":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}case"insert":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),o.position!=="before"&&o.position!=="after"&&i.push(`${a}: position must be 'before' or 'after'`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}default:i.push(`${a}: unknown operation type "${o.op}"`)}}return{valid:i.length===0,errors:i}}function ur(e,t){let i=dr(e,t);if(!i.valid)throw new Error(`Invalid patch: ${i.errors.join("; ")}`);let n=[...e],o=t.operations.map((s,l)=>({...s,originalOrder:l})),a={remove:0,modify:1,insert:2},r=[...o].sort((s,l)=>s.index!==l.index?l.index-s.index:a[s.op]-a[l.op]);for(let s of r)switch(s.op){case"remove":n.splice(s.index,1);break;case"modify":n[s.index]=s.statement;break;case"insert":s.position==="before"?n.splice(s.index,0,s.statement):n.splice(s.index+1,0,s.statement);break}return n}function Ud(e,t){let i=(0,$o.parse)(e);if(!i||typeof i!="object")throw new Error("Invalid YAML: expected an object at root level");let n=i.statements;if(!Array.isArray(n))throw new Error('YAML must have a "statements" array');let o=ur(n,t);i.statements=o;let a=(0,$o.stringify)(i,{lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"});return et(a),{modifiedYaml:a,modifiedStatements:o}}var $o,Bd=y(()=>{"use strict";Co();$o=require("yaml")});function hr(e){for(let t of e){if(t.type==="STEP"){let n=t;if(n.reference_id||n.template_path)return!0}let i=Pe(t);for(let n of i)if(hr(n.statements))return!0}return!1}function jd(e){let t=new Set;function i(n){for(let o of n){if(o.type==="STEP"){let r=o;r.reference_id&&t.add(r.reference_id)}let a=Pe(o);for(let r of a)i(r.statements)}}return i(e),Array.from(t)}function Xd(e){if(!e?.statements||!Array.isArray(e.statements))return{};let t={};return Ge(e.statements,"main",t),e.teardown&&Array.isArray(e.teardown)&&Ge(e.teardown,"teardown",t),t}function He(e,t,i){let n=e+".",o=t.filter(([c])=>c===e||c.startsWith(n));if(o.length===0)return[];let a=[],r=new Set;for(let[c]of o){let u=c===e?"":c.slice(n.length);if(!u)continue;let m=u.split(".")[0];r.has(m)||r.add(m)}let s=Array.from(r);s.sort((c,u)=>{let m=/^\d+$/.test(c)?parseInt(c,10):-1,g=/^\d+$/.test(u)?parseInt(u,10):-1;return m>=0&&g>=0?m-g:c==="then"&&u==="else"?-1:c==="else"&&u==="then"||c==="body"?1:u==="body"?-1:c.localeCompare(u)});function l(c){return i[c]}function d(c){let u=c.match(/^(IF|WHILE)\s+([\s\S]+)$/);return{type:"AI_MODE",expression:(u?u[2].trim():c)||"true"}}for(let c of s){let u=e?`${e}.${c}`:c,m=l(u),g=m?.description??"",w=u;if(c==="then"){let _=`${e}.then`,k=`${e}.else`,E=He(_,t,i),I=He(k,t,i),P=l(e),L=P?d(P.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"IF_ELSE",condition:L,then:E,...I.length>0?{else:I}:{}});continue}if(c==="else")continue;if(c==="body"){let _=`${e}.body`,k=He(_,t,i),E=l(e),I=E?d(E.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"WHILE_LOOP",condition:I,body:k});continue}let v=`${e}.${c}`,x=t.some(([_])=>_.startsWith(v+".then.")||_===v+".then"),p=t.some(([_])=>_.startsWith(v+".else.")||_===v+".else"),f=t.some(([_])=>_.startsWith(v+".body.")||_===v+".body"),S=t.filter(([_])=>{if(!_.startsWith(v+"."))return!1;let E=_.slice(v.length+1).split(".")[0];return/^\d+$/.test(E)&&E!=="then"&&E!=="else"&&E!=="body"});if(x||p){let _=v+".then",k=v+".else",E=He(_,t,i),I=He(k,t,i),P=m?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:u,type:"IF_ELSE",condition:P,then:E,...I.length>0?{else:I}:{}})}else if(f){let _=v+".body",k=He(_,t,i),E=m?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:u,type:"WHILE_LOOP",condition:E,body:k})}else if(S.length>0){let _=He(v,t,i);a.push({uid:u,type:"STEP",description:g||"Group",statements:_})}else a.push({uid:u,type:"ACTION",description:g||"Action",action_entity:m?.action_entity})}return a}function Yd(e){let t=Object.entries(e),i=n=>{let o=n+".";return t.some(([r])=>r===n||r.startsWith(o))?He(n,t,e):[]};return{before:i("before"),main:i("main"),teardown:i("teardown"),after:i("after")}}var Pe,oe,We,Ue,Be,Gi,Gd,Kd,hg,mg,zd,Vd,Ge,Lo=y(()=>{"use strict";Pe=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},oe=(e,t,i=void 0,n="root")=>{for(let o=0;o<e.length;o++){let a=e[o],r=a.uid;if(r===t)return{stableId:r,path:[o],statement:a,parent:i,containerKey:n,index:o};let s=Pe(a);for(let l of s){let d=oe(l.statements,t,a,l.key);if(d)return{...d,path:[o,l.key,...d.path]}}}return null},We=(e,t,i)=>{let n=oe(e,t);if(!n)return null;let{statement:o,parent:a,containerKey:r,index:s}=n,l=null;switch(o.type){case"DRAFT":case"ACTION":l=Ue(e,n)||Be(e,n);break;case"STEP":if(o.statements&&o.statements.length>0)return o.statements[0];l=Ue(e,n)||Be(e,n);break;case"IF_ELSE":if(i===!0&&o.then&&o.then.length>0)return o.then[0];if(i===!1&&o.else&&o.else.length>0)return o.else[0];l=Ue(e,n)||Be(e,n);break;case"WHILE_LOOP":if(i===!0&&o.body&&o.body.length>0)return o.body[0];l=Ue(e,n)||Be(e,n);break;default:l=Ue(e,n)||Be(e,n);break}if(a&&a.type==="WHILE_LOOP"&&r==="body"){if(!l)return a;let d=oe(e,l.uid);if(!d||d.parent!==a)return a}return l},Ue=(e,t)=>{if(!t.parent)return e[t.index+1]||null;let n=Pe(t.parent).find(o=>o.key===t.containerKey);return n&&t.index+1<n.statements.length?n.statements[t.index+1]:null},Be=(e,t)=>{if(!t.parent)return null;let i=t.parent.uid,n=oe(e,i);return n?Ue(e,n)||Be(e,n):null},Gi=e=>{let t=[],i=n=>{for(let o of n){t.push(o);let a=Pe(o);for(let r of a)i(r.statements)}};return i(e),t},Gd=e=>{switch(e.type){case"DRAFT":case"ACTION":return!0;case"STEP":return!0;case"IF_ELSE":case"WHILE_LOOP":return!0;default:return!1}},Kd=(e,t,i)=>{if(!oe(e,t))return null;if(i===null){let s=[],l=t;for(;l!==null&&oe(e,l);)if(s.push(l),l=We(e,l)?.uid||null,s.length>1e3)return null;return s}if(!oe(e,i))return null;if(t===i)return[];let a=[],r=t;for(;r&&r!==i;){let s=oe(e,r);if(!s)break;if(a.push(r),s.statement.type==="IF_ELSE"){let l=hg(s.statement,i);l?r=We(e,r,l==="then")?.uid||null:r=We(e,r)?.uid||null}else s.statement.type==="WHILE_LOOP"?mg(s.statement,i)?r=We(e,r,!0)?.uid||null:r=We(e,r,!1)?.uid||null:r=We(e,r)?.uid||null;if(a.length>1e3)return null}return r===i?a:null},hg=(e,t)=>{if(e.type!=="IF_ELSE")return null;let i=e;return i.then&&oe(i.then,t)?"then":i.else&&oe(i.else,t)?"else":null},mg=(e,t)=>{if(e.type!=="WHILE_LOOP")return!1;let i=e;return!!(i.body&&oe(i.body,t))};zd=e=>e.startsWith("ai_")?!0:["js_code","function","assert","verify","wait_for_download_complete","extract_activation_code","extract_email_content"].includes(e),Vd=e=>!["js_code","function","assert","ai_assert","verify","ai_extract","ai_wait_until","upload_file","login","extract_activation_code","extract_email_content","ai_step"].includes(e),Ge=(e,t,i)=>{e.forEach((n,o)=>{let a=`${t}.${o}`;n.type==="DRAFT"?i[a]={description:n.description||"Draft",action_entity:void 0}:n.type==="ACTION"?i[a]={description:n.description||"Action",action_entity:n.action_entity,locator:n.locator}:n.type==="STEP"&&n.statements?Ge(n.statements,a,i):n.type==="IF_ELSE"?(i[a]={description:"IF "+(n.condition?.expression||""),action_entity:void 0},n.then&&Ge(n.then,`${a}.then`,i),n.else&&Ge(n.else,`${a}.else`,i)):n.type==="WHILE_LOOP"&&(i[a]={description:"WHILE "+(n.condition?.expression||""),action_entity:void 0},n.body&&Ge(n.body,`${a}.body`,i))})}});function pr(e){let t=0,i=0;for(let n of e)if(n.type==="DRAFT")i++;else if(n.type==="ACTION"){let o=n.action_entity?.action_data?.action_name??"";mr.has(o)||t++}return{action:t,draft:i}}function gg(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function Zd(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function fg(e){let t=e.split(/\r?\n/).map(a=>a.trim()).filter(a=>a.length>0&&!a.startsWith("//")),i=t.length,n=t.join(`
|
|
4549
|
-
`).match(/\bawait\b/g),o=n?n.length:0;return i<=Jd&&o<=qd?null:`${i} non-blank line(s), ${o} await(s) \u2014 limits are ${Jd} lines and ${qd} awaits. The VERIFY js: field is a cache for one natural-language assertion, not a place for multi-step logic. Break this into multiple statements \u2014 one VERIFY per assertion \u2014 so each step is visible in the debugger and self-healable. For freeform setup code (mocking, storage), use the description: + js: escape hatch, which has no complexity cap.`}function Qd(e,t){let i=t?.coverageThreshold??pg,n=[],o=[],a;try{a=et(e)}catch(m){return{valid:!1,errors:[`Invalid YAML: ${m.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}a.goal||n.push('Missing required field: "goal"'),a.statements?.length||n.push('Missing required field: "statements"');let r=[...Gi(a.statements??[]),...a.teardown?Gi(a.teardown):[]],{action:s,draft:l}=pr(r),d="Hint: in YAML double-quoted strings, backslashes are escape characters \u2014 use \\\\/ instead of \\/ for regex, or use single quotes.";for(let m of r){let g=m;if(g.reference_id!==void 0){let w=g.description||m.uid;n.push(`Unresolved cloud template reference on statement "${w}" (reference_id: ${g.reference_id}). Local YAML tests cannot use reference_id \u2014 inline the template statements or use the local "template:" key instead.`)}if(m.type==="ACTION"){let w=m,v=w.action_entity?.action_data?.action_name??"";if(v==="js_code"||v==="js_action"||v==="verify"||v==="ai_assert"){let x=w.action_entity?.action_data?.kwargs?.code;if(typeof x=="string"){let p=gg(x);if(p){let f=w.description||v;n.push(`Invalid JS in "${f}": ${p}. ${d}`)}else if(v==="verify"){let f=fg(x);if(f){let S=w.description||v;n.push(`JS cache for "${S}" is too complex: ${f}`)}}}}}if(m.type==="IF_ELSE"){let w=m;if(w.condition.type==="JS_CODE"){let v=Zd(w.condition.expression);v&&n.push(`Invalid JS in IF condition "${w.condition.expression}": ${v}. ${d}`)}}if(m.type==="WHILE_LOOP"){let w=m;if(w.condition.type==="JS_CODE"){let v=Zd(w.condition.expression);v&&n.push(`Invalid JS in WHILE condition "${w.condition.expression}": ${v}. ${d}`)}}}let c=s+l,u=c>0?Math.round(s/c*100):0;return c>0&&u/100<i&&o.push(`Low action coverage: ${s}/${c} statements (${u}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:n.length===0,errors:n,warnings:o,stats:{total:c,action:s,draft:l,coverage:u}}}var pg,Jd,qd,mr,eu=y(()=>{"use strict";Co();Lo();pg=.5,Jd=5,qd=3,mr=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"])});function tu(e){return e?e.startsWith(he)?"android":e.startsWith(me)?"ios":"web":"web"}function iu(e){return e?e.startsWith(he)||e.startsWith(me):!1}function nu(e){return!!e&&e.startsWith(he)}function ou(e){return!!e&&e.startsWith(me)}function au(e){return e.startsWith(he)?e.slice(he.length):e.startsWith(me)?e.slice(me.length):e}function ru(e){return`${he}${e}`}function su(e){return`${me}${e}`}function Do(e){return e?e.startsWith("http://")||e.startsWith("https://"):!1}function lu(e){return e?!Do(e):!1}function gr(e){return e?Do(e)?["web"]:["android","ios"]:["web","android","ios"]}function cu(e,t){if(!t)return!0;let i=gr(t);return e==="desktop"||e==="mobile"?i.includes("web"):i.includes(e)}var he,me,Oo=y(()=>{"use strict";he="android:",me="ios:"});function du(e){return e.startsWith(me)?e:`${me}${e}`}function uu(e){let t=e.iosVersion?` (iOS ${e.iosVersion})`:"";return e.deviceType==="simulator"?`${e.name}${t} - Simulator`:`${e.name}${t}`}function hu(e){return!!(/^[0-9a-fA-F]{40}$/.test(e)||/^[0-9a-fA-F]{8}-[0-9a-fA-F]{16}$/.test(e))}var mu=y(()=>{"use strict";Oo()});var fr,No,wr,br,yr,xr,vr,_r,kr,Sr,tt,Er,Ki,Tr,Ar,$t,pu,ji,gu,fu,Ro,wu,bu,yu,xu,vu=y(()=>{"use strict";fr="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",No=112,wr=1920,br=1080,yr=1920,xr=1080-No,vr=1280,_r=720,kr=500,Sr=500,tt="Desktop Chrome",Er=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Er||{}),Ki={"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"}},Tr=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Tr||{}),Ar={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"]},$t=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Ar[e].map(n=>Ki[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},pu=()=>Object.keys(Ki),ji=e=>Ki[e],gu={desktop:{label:"Desktop",type:"desktop",devices:$t("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:$t("mobile")}},fu={desktop:{label:"Desktop",type:"desktop",devices:$t("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:$t("mobile",!0)}},Ro=(e,t=!1)=>{let i={userAgent:fr,viewport:{width:yr,height:xr},isMobile:!1,hasTouch:!1};if(!e||e===tt)return i;let n=ji(e);if(!n)return i;let{width:o,height:a}=n.viewport,r=Math.max(kr/o,1),s=Math.max(Sr/a,1),l=Math.max(r,s),d={width:Math.round(o*l),height:Math.round(a*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},wu=e=>{let t={width:wr,height:br};if(!e||e===tt)return t;let i=Ro(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+No}:t},bu=e=>{let t={width:vr,height:_r};if(!e||e===tt)return t;let i=Ro(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},yu=e=>!e||e===tt?void 0:ji(e)?.channel,xu=e=>!e||e===tt?"chromium":ji(e)?.defaultBrowserType??"chromium"});var Mr,Ir,_u=y(()=>{"use strict";Mr=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Mr||{}),Ir=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Ir||{})});function ku(){return{version:"1.0",entries:{}}}function Su(e,t){return{action_entity:e,updated_at:new Date().toISOString(),updated_by:{source:"runner",test_run_id:t}}}function Eu(e,t){let i=t?.entries[e.uid],n=i?.action_entity??e.action_entity;return e.locator&&n?{...n,locator:e.locator}:i?i.action_entity:e.action_entity?e.action_entity:null}function Tu(e,t,i,n){return e.entries[t]={action_entity:i,updated_at:new Date().toISOString(),updated_by:n},e}function Au(e,t){let i=e??{version:"1.0",entries:{}};for(let[n,o]of t)i.entries[n]=o;return i}function Mu(e){return e?Object.keys(e.entries).length===0:!0}function Iu(e){return e?Object.keys(e.entries).length:0}function Pu(e,t){if(!t||Object.keys(t.entries).length===0)return e;let i=Pr(e.statements??[],t),n=e.teardown?Pr(e.teardown,t):void 0;return{...e,statements:i,teardown:n}}function Pr(e,t){return e.map(i=>wg(i,t))}function wg(e,t){if(e.type==="ACTION"){let o=e,a=t.entries[o.uid];return a?{...o,action_entity:a.action_entity}:o}let i=Pe(e);if(i.length===0)return e;let n={};for(let o of i)n[o.key]=Pr(o.statements,t);return{...e,...n}}var Cu=y(()=>{"use strict";Lo()});var Cr,$r,$u,Lu=y(()=>{"use strict";Cr=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(Cr||{}),$r=(e=>(e.JS_CODE="JS_CODE",e.AI_MODE="AI_MODE",e))($r||{}),$u=18e4});var Du,Nu=y(()=>{"use strict";Du=class Ou{data={};sensitive=new Set;get(t){return this.data[t]}set(t,i,n=!1){this.data[t]=i,n?this.sensitive.add(t):this.sensitive.has(t)&&this.sensitive.delete(t)}getAll(){return{...this.data}}isSensitive(t){return this.sensitive.has(t)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(t){return this.sensitive.delete(t),delete this.data[t]}clear(){this.data={},this.sensitive.clear()}has(t){return t in this.data}get size(){return Object.keys(this.data).length}merge(t){for(let[i,n]of Object.entries(t.getAll()))this.set(i,n,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new Ou;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[o,a]of Object.entries(t.data))i.set(o,a,n.has(o))}return i}}});function Ru(e,t=bg()){return{copilot:e?.models?.copilot||t.COPILOT_MODEL||Ho,webagent:e?.models?.webagent||t.WEB_AGENT_MODEL||Nr,computer_use:e?.models?.computer_use||t.COMPUTER_USE_MODEL||Rr}}function Fu(e){if(e){if(e.WEB_AGENT_MODEL)return e.WEB_AGENT_MODEL;if(e.GOOGLE_API_KEY)return Fo;if(e.ANTHROPIC_API_KEY)return Lr;if(e.OPENAI_API_KEY)return Dr;if(e.SHIPLIGHT_API_TOKEN)return Ho}}function Hu(e){if(e){if(e.COMPUTER_USE_MODEL)return e.COMPUTER_USE_MODEL;if(e.GOOGLE_API_KEY)return zi;if(e.OPENAI_API_KEY)return Or;if(e.SHIPLIGHT_API_TOKEN)return zi}}var Lr,Fo,Dr,zi,Or,Ho,Nr,Rr,bg,Wu=y(()=>{"use strict";Lr="claude-haiku-4-5",Fo="gemini-3.1-pro-preview",Dr="gpt-5.4-mini",zi="gemini-3-flash-preview",Or="gpt-5.4",Ho="claude-sonnet-4-6",Nr=Fo,Rr=zi,bg=()=>typeof process<"u"?process.env:{}});var Fr,Uu=y(()=>{"use strict";Fr=(e=>(e.INITIALIZING="initializing",e.READY="ready",e.PROCESSING="processing",e.STOPPING="stopping",e.WAITING_USER="waiting_user",e.COMPLETED="completed",e.FAILED="failed",e))(Fr||{})});function Bu(e){let t=e.trim();if(!t||t.startsWith("List of devices"))return null;let i=t.split(/\s+/);if(i.length<2)return null;let n=i[0],o=i[1],a="usb";return n.startsWith("emulator-")?a="emulator":n.includes(":")&&(a="wifi"),{id:n,state:o,connectionType:a}}function Gu(e){return e.startsWith(he)?e:`${he}${e}`}function Ku(e){return e.model?`${e.model} (${e.id})`:e.connectionType==="emulator"?`Android Emulator (${e.id})`:e.id}var ju=y(()=>{"use strict";Oo()});var Hr={};je(Hr,{ADDRESS_BAR_HEIGHT:()=>No,ANDROID_DEVICE_PREFIX:()=>he,ActionEntitySchema:()=>tr,ActionSchema:()=>nr,AgentStatus:()=>Fr,BaseStatementSchema:()=>Qe,BrowserType:()=>Er,ConditionSchema:()=>Io,ConditionType:()=>$r,ConditionTypeSchema:()=>Qa,DEFAULT_ANTHROPIC_MODEL:()=>Lr,DEFAULT_COMPUTER_USE_MODEL:()=>Rr,DEFAULT_COPILOT_MODEL:()=>Ho,DEFAULT_DEVICE_NAME:()=>tt,DEFAULT_GEMINI_COMPUTER_USE_MODEL:()=>zi,DEFAULT_GOOGLE_MODEL:()=>Fo,DEFAULT_OPENAI_COMPUTER_USE_MODEL:()=>Or,DEFAULT_OPENAI_MODEL:()=>Dr,DEFAULT_WEBAGENT_MODEL:()=>Nr,DEFAULT_WHILE_LOOP_TIMEOUT_MS:()=>$u,DEVICE_CATEGORIES:()=>Ar,DeviceType:()=>Tr,DraftSchema:()=>ir,IOS_DEVICE_PREFIX:()=>me,LoginType:()=>Mr,MIN_WINDOW_HEIGHT:()=>Sr,MIN_WINDOW_WIDTH:()=>kr,NON_INTENT_ACTIONS:()=>mr,NodeJSCodeCommon:()=>yd,PLAYWRIGHT_DEVICES:()=>Ki,RECORD_VIDEO_HEIGHT:()=>_r,RECORD_VIDEO_WIDTH:()=>vr,StatementSchema:()=>ne,StatementType:()=>Cr,StatementTypeSchema:()=>er,TestFlowSchema:()=>Po,TestGroupEntrySchema:()=>or,TestGroupSchema:()=>Ui,TwoFactorAuthType:()=>Ir,UI_DEVICE_CATEGORIES:()=>gu,UI_DEVICE_CATEGORIES_ELECTRON:()=>fu,USER_AGENT:()=>fr,VIEWPORT_HEIGHT:()=>xr,VIEWPORT_WIDTH:()=>yr,VariableStore:()=>Du,WINDOW_HEIGHT:()=>br,WINDOW_WIDTH:()=>wr,actionEntityToYaml:()=>Od,actionStepsMapToTestFlowSections:()=>Yd,allowPureVisionAction:()=>Vd,applyPatchToYaml:()=>ur,applyPatchToYamlString:()=>Ud,collectActionSteps:()=>Ge,convertPlaywrightActionToEntity:()=>Ad,countIntentStatements:()=>pr,createAndroidDeviceName:()=>ru,createEmptyStore:()=>ku,createIOSDeviceName:()=>su,createRunnerStoreEntry:()=>Su,extractActionStepsFromTestFlow:()=>Xd,extractAndAttachComments:()=>cr,extractDeviceIdentifier:()=>au,extractElementDescription:()=>Ja,extractElementDescriptionFromAriaSnapshot:()=>qa,extractLocatorFromCode:()=>Za,extractYamlMetadata:()=>Hd,findNextAfterContainer:()=>Be,findNextSibling:()=>Ue,findNextStatement:()=>We,findPathBetweenStatements:()=>Kd,findStatementPathById:()=>oe,generateUid:()=>Td,getAllDeviceNames:()=>pu,getAllReferenceIds:()=>jd,getAllStatementsInOrder:()=>Gi,getAndroidDeviceDisplayName:()=>Ku,getBrowserWindowSize:()=>wu,getCompatiblePlatforms:()=>gr,getDeviceBrowserType:()=>xu,getDeviceByName:()=>ji,getDeviceChannel:()=>yu,getDeviceOptions:()=>Ro,getDevicesByCategory:()=>$t,getIOSDeviceDisplayName:()=>uu,getLoginConfigPlatform:()=>vd,getRecordVideoSize:()=>bu,getStatementContainers:()=>Pe,getStoreSize:()=>Iu,getTestPlatformFromDeviceName:()=>tu,hasReferenceIds:()=>hr,isAndroidDevice:()=>nu,isAppPackage:()=>lu,isDynamicAction:()=>zd,isExecutableStatement:()=>Gd,isIOSDevice:()=>ou,isNativeDevice:()=>iu,isPhysicalDeviceUDID:()=>hu,isPlatformCompatibleWithUrl:()=>cu,isStoreEmpty:()=>Mu,isWebUrl:()=>Do,mergeActionEntitiesIntoTestFlow:()=>Pu,mergeStoreUpdates:()=>Au,parseAdbDeviceLine:()=>Bu,parseYamlArrayItems:()=>Fd,replaceVariables:()=>kd,resolveActionEntity:()=>Eu,resolveComputerUseModelFromEnv:()=>Hu,resolveModels:()=>Ru,resolveWebAgentModelFromEnv:()=>Fu,suiteToYaml:()=>lr,testFlowToYaml:()=>$d,testFlowToYamlObject:()=>sr,toAndroidDeviceName:()=>Gu,toIOSDeviceName:()=>du,updateStoreEntry:()=>Tu,validatePatch:()=>dr,validateTestYaml:()=>Qd,yamlObjectsToString:()=>Ld,yamlToActionEntity:()=>Nd,yamlToTestFlow:()=>et});var Wr=y(()=>{"use strict";xd();_d();Sd();Md();Bd();eu();Co();ar();mu();vu();_u();Cu();Lo();Lu();Nu();Wu();Uu();ju();Oo()});var vg={};je(vg,{SDK_ENV_ALLOWLIST:()=>ih,applyVarsOverride:()=>th,buildSdkEnv:()=>nh,createTestContext:()=>Zu,expect:()=>Lt.expect,isDeclaredSensitive:()=>eh,parseVarsOverrideEnv:()=>Qu,resolveAuthState:()=>Ju,test:()=>xg});module.exports=ch(vg);var Ce=R(require("path"),1),Yu=R(require("fs"),1),Lt=require("@playwright/test");var ee=R(require("fs"),1),nt=R(require("path"),1),Uo=require("crypto"),Bo=require("os");function Kr(e){return[`--disable-extensions-except=${e}`,`--load-extension=${e}`,"--no-first-run","--disable-default-apps"]}function jr(e){if(!ee.existsSync(e))return console.warn(`[fixture] extensionStorageState file not found: ${e}`),null;let t;try{t=JSON.parse(ee.readFileSync(e,"utf-8"))}catch(a){throw new Error(`[fixture] Failed to parse extensionStorageState at ${e}: ${a}`)}let i=t;if(!Array.isArray(i.cookies))return null;let n=(Date.now()+365*24*60*60*1e3)/1e3,o=i.cookies.filter(a=>a&&typeof a=="object"&&typeof a.name=="string"&&typeof a.domain=="string");return o.length<i.cookies.length&&console.warn(`[fixture] Skipped ${i.cookies.length-o.length} malformed cookies (missing name or domain)`),o.map(a=>({...a,expires:n}))}function zr(e){if(e){let i=nt.resolve(process.cwd(),e),n=nt.join((0,Bo.tmpdir)(),`ext-profile-${(0,Uo.randomUUID)()}`);if(ee.existsSync(i)){try{ee.cpSync(i,n,{recursive:!0})}catch(a){try{ee.rmSync(n,{recursive:!0,force:!0})}catch(r){console.warn("[fixture] Failed to clean up partial profile copy:",n,r)}throw new Error(`[fixture] Failed to copy extension profile from ${i}: ${a}`)}let o=nt.join(n,"SingletonLock");ee.existsSync(o)&&ee.rmSync(o,{force:!0})}else ee.mkdirSync(n,{recursive:!0});return n}let t=nt.join((0,Bo.tmpdir)(),`ext-profile-${(0,Uo.randomUUID)()}`);return ee.mkdirSync(t,{recursive:!0}),t}Va();var Yp=R(require("dotenv"),1),Jp="__shiplightDotenvCache__";function qp(){return globalThis[Jp]}function Xa(){let e=qp();return e===void 0?process.env:e}async function Ju(e){let i=await import(Ce.resolve(process.cwd(),e.auth)),n=i.login||i.default;if(typeof n!="function")throw new Error(`auth module "${e.auth}" must export a login(args) function that returns a storageState file path`);let o=await n(e.args||{});if(typeof o!="string")throw new Error(`auth module "${e.auth}" login() must return a storageState file path (got ${typeof o})`);return o}function zu(e){return!(!e||e==="off")}function qu(e,t){return!e||e==="off"?!1:e==="on"?!0:e==="retain-on-failure"?t.status!==t.expectedStatus:e==="on-first-retry"?t.retry>0:typeof e=="object"&&e!==null&&"mode"in e?qu(e.mode,t):!0}async function Vu(e,t,i){let n=qu(t,i);for(let o of e)try{if(n){let a=await o.path();await i.attach("video",{path:a,contentType:"video/webm"})}else await o.delete()}catch(a){console.warn("[fixture] Failed to process video:",a)}}var Wo;async function Xu(){return Wo||(Wo=await Promise.resolve().then(()=>(Va(),bd)),Wo)}var yg=new Set(["get","set","getAll","has","__variableStore"]);function Zu(e){let t={__variableStore:e,get(i){return e.get(i)},set(i,n,o=!1){e.set(i,n,o)},getAll(){return e.getAll()}};return new Proxy(t,{get(i,n,o){if(n in i)return Reflect.get(i,n,o);if(typeof n=="string")return i.get(n)},set(i,n,o){return typeof n!="string"||yg.has(n)?Reflect.set(i,n,o):(i.set(n,o),!0)},has(i,n){return n in i?!0:typeof n=="string"?e.has?.(n)??!1:!1}})}function Qu(e){if(!e)return null;let t;try{t=JSON.parse(e)}catch(n){throw new Error(`SHIPLIGHT_VARS_OVERRIDE is not valid JSON: ${n.message}`)}if(t===null||typeof t!="object"||Array.isArray(t))throw new Error("SHIPLIGHT_VARS_OVERRIDE must be a JSON object");let i={};for(let[n,o]of Object.entries(t)){if(typeof o!="string")throw new Error(`SHIPLIGHT_VARS_OVERRIDE key "${n}" must be a string`);i[n]=o}return i}function eh(e,t,i){let n=r=>{if(!r||!(e in r))return null;let s=r[e];return s&&typeof s=="object"&&"value"in s?s.sensitive===!0:!1},o=n(i);if(o!==null)return o;let a=n(t);return a!==null?a:!1}function th(e,t,i,n=process.env.SHIPLIGHT_VARS_OVERRIDE){let o=Qu(n);if(o)for(let[a,r]of Object.entries(o)){let s=eh(a,t,i);e.set(a,r,s)}}var ih=["GOOGLE_API_KEY","ANTHROPIC_API_KEY","OPENAI_API_KEY","OPENAI_BASE_URL","ANTHROPIC_MODELS_USE_VERTEXAI","GOOGLE_GENAI_USE_VERTEXAI","GOOGLE_CLOUD_PROJECT","GOOGLE_CLOUD_LOCATION","MAILGUN_API_KEY","MAILGUN_DOMAIN","SHIPLIGHT_API_TOKEN","SHIPLIGHT_API_URL"];function nh(e=Xa()){let t={};for(let i of ih)t[i]=e[i]??"";return t}var xg=Lt.test.extend({account:[void 0,{option:!0}],autoDismissModal:[!1,{option:!0}],variables:[void 0,{option:!0}],extensionDir:[void 0,{option:!0}],userDataDir:[void 0,{option:!0}],extensionStorageState:[void 0,{option:!0}],launchOptions:async({launchOptions:e},t)=>{if(!process.env.SHIPLIGHT_REGISTRY_URL){await t(e);return}let i=e?.args??[],n={...e,args:[...i,"--remote-debugging-port=0"]};await t(n)},browser:async({browser:e},t)=>{let i=null;if(process.env.SHIPLIGHT_REGISTRY_URL)try{let n=await _o(process.pid),o=process.env.TEST_WORKER_INDEX??"?";i=await kt({cdpUrl:n,label:`shiplight test w${o}`,pid:process.pid})}catch{}await t(e),await St(i)},context:async({browser:e,account:t,extensionDir:i,userDataDir:n,extensionStorageState:o},a,r)=>{if(i||n){if(t||r.project.use.auth)throw new Error('Cannot use both "extensionDir"/"userDataDir" and "auth" \u2014 persistent context tests manage their own context. Use extensionStorageState for authentication instead.');let l=r.project.use?.browserName;l&&l!=="chromium"&&console.warn(`[fixture] Persistent context requires Chromium but project is configured for "${l}". Forcing Chromium.`);let d=process.env.PLAYWRIGHT_HEADLESS==="true";i&&d&&console.warn("[fixture] PLAYWRIGHT_HEADLESS=true with extensionDir \u2014 Chrome extensions will not function in headless mode.");let c=zr(n),u=i?Kr(Ce.resolve(process.cwd(),i)):[],m={...r.project.use},{storageState:g,account:w,extensionDir:v,userDataDir:x,extensionStorageState:p,autoDismissModal:f,video:S,..._}=m,k=zu(S)?{dir:r.outputDir}:void 0,E;try{if(E=await Lt.chromium.launchPersistentContext(c,{..._,headless:d,args:u,viewport:_.viewport??{width:1280,height:720},...k?{recordVideo:k}:{}}),o){let I=Ce.resolve(process.cwd(),o),P=jr(I);P&&await E.addCookies(P)}await a(E)}finally{let I=E?.pages().map(P=>P.video()).filter(P=>P!==null)??[];if(await E?.close().catch(P=>{console.warn("[fixture] Failed to close persistent context:",P)}),await Vu(I,S,r),!n)try{Yu.rmSync(c,{recursive:!0,force:!0})}catch(P){console.warn("[fixture] Failed to clean up temp profile dir:",c,P)}}}else{let l={...r.project.use},d=r.project.use,c=d.auth?{auth:d.auth,args:d.args}:t;if(c){if(!c.auth)throw new Error("Auth is declared but missing the script path. Provide auth in playwright.config.ts: use: { auth: './auth.login.ts' }");l.storageState=await Ju(c)}let u=l.video;zu(u)&&!l.recordVideo&&(l.recordVideo={dir:r.outputDir});let m=await e.newContext(l);m.addInitScript(Re);try{await a(m)}finally{let g=m.pages().map(w=>w.video()).filter(w=>w!==null);await m.close(),await Vu(g,u,r)}}},page:async({context:e},t)=>{let i=await e.newPage();await t(i)},testContext:async({variables:e},t,i)=>{let{VariableStore:n}=await Xu(),o=new n,a=l=>{if(l)for(let[d,c]of Object.entries(l))typeof c=="string"?o.set(d,c,!1):c&&typeof c=="object"&&"value"in c&&o.set(d,c.value,c.sensitive===!0)},r=i.project.use.variables;a(r),a(e),th(o,r,e);let s=Zu(o);global.testContext=s,global.$=s,global.ctx=s,await t(s),delete global.testContext,delete global.$,delete global.ctx},$:async({testContext:e},t)=>{await t(e)},ctx:async({testContext:e},t)=>{await t(e)},agent:async({page:e,testContext:t,autoDismissModal:i},n,o)=>{let{WebAgent:a,createAgentContext:r,configureSdk:s,parseSdkLogLevelFromEnv:l}=await Xu(),d=l();s({env:nh(),...d!==void 0&&{logLevel:d}});let{resolveWebAgentModelFromEnv:c,resolveComputerUseModelFromEnv:u}=await Promise.resolve().then(()=>(Wr(),Hr)),m=Xa(),g=c(m);if(!g)throw new Error("No AI model configured. Set WEB_AGENT_MODEL, GOOGLE_API_KEY, ANTHROPIC_API_KEY, OPENAI_API_KEY, or SHIPLIGHT_API_TOKEN in your .env file (or in the runner environment for CI).");let w=u(m),v=t.__variableStore,x=r({model:g,computer_use_model:w,variableStore:v,autoDismissModal:i,downloadDir:Ce.join(o.outputDir,"downloads")}),p=Ce.join(o.outputDir,"artifacts");x.stepTracking={results:{},artifactsDir:p};let f=new a(x),S=e.context();f.agentServices.setupPageTracking(S);for(let _ of S.pages())f.setupDownloadTracking(_),f.setupDialogHandling(_);S.on("page",_=>{f.setupDownloadTracking(_),f.setupDialogHandling(_)}),global.agent=f,await n(f),delete global.agent;try{let _=o.outputDir;await f.writeExecutionResults(_);let k=Ce.join(_,"test-results.json");await(await import("fs/promises")).stat(k).catch(()=>null)&&await o.attach("shiplight-results",{path:k,contentType:"application/json"})}catch(_){console.error("[Shiplight] Failed to attach step results:",_)}try{let _=f.getNewActionEntities();if(_.size>0&&o.status==="passed"){let{createEmptyStore:k,createRunnerStoreEntry:E}=await Promise.resolve().then(()=>(Wr(),Hr)),I=await import("fs/promises"),P=k();for(let[K,X]of _)P.entries[K]=E(X,0);let L=Ce.join(o.outputDir,"new-action-entities.json");await I.writeFile(L,JSON.stringify(P,null,2)),await o.attach("shiplight-new-action-entities",{path:L,contentType:"application/json"}),console.log(`[Shiplight] ${_.size} healed action entit${_.size===1?"y":"ies"} saved`)}}catch(_){console.warn("[Shiplight] Failed to persist new action entities:",_)}}});0&&(module.exports={SDK_ENV_ALLOWLIST,applyVarsOverride,buildSdkEnv,createTestContext,expect,isDeclaredSensitive,parseVarsOverrideEnv,resolveAuthState,test});
|
|
4546
|
+
`;return e}generatePostlude(){return""}}});function Td(e){if(!e)return"desktop";for(let t of ag)if(t.test(e))return"mobile";return"desktop"}var ag,Ad=b(()=>{"use strict";ag=[/iphone/i,/ipad/i,/android/i,/pixel/i,/galaxy/i,/mobile/i,/nexus/i,/blackberry/i,/kindle/i]});function Md(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let s=a.startsWith("$")?a.slice(1):a,r=i[s]??i[`$${s}`];return r!=null?String(r):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,s)=>{let r=n(s.trim());return r!==void 0?r:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,s)=>{let r=n(s);return r!==void 0?r:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,s)=>{let r=n(s.trim());return r!==void 0?r:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,s)=>{let r=n(s);return r!==void 0?r:a}),o}var Id=b(()=>{"use strict"});function Pd(e){return e?e.startsWith(be)?"android":e.startsWith(ye)?"ios":"web":"web"}function Cd(e){return e?e.startsWith(be)||e.startsWith(ye):!1}function $d(e){return!!e&&e.startsWith(be)}function Od(e){return!!e&&e.startsWith(ye)}function Ld(e){return e.startsWith(be)?e.slice(be.length):e.startsWith(ye)?e.slice(ye.length):e}function Dd(e){return`${be}${e}`}function Nd(e){return`${ye}${e}`}function $o(e){return e?e.startsWith("http://")||e.startsWith("https://"):!1}function Rd(e){return e?!$o(e):!1}function ir(e){return e?$o(e)?["web"]:["android","ios"]:["web","android","ios"]}function Fd(e,t){if(!t)return!0;let i=ir(t);return e==="desktop"||e==="mobile"?i.includes("web"):i.includes(e)}var be,ye,Oo=b(()=>{"use strict";be="android:",ye="ios:"});function Hd(e){return e.startsWith(ye)?e:`${ye}${e}`}function Wd(e){let t=e.iosVersion?` (iOS ${e.iosVersion})`:"";return e.deviceType==="simulator"?`${e.name}${t} - Simulator`:`${e.name}${t}`}function Ud(e){return!!(/^[0-9a-fA-F]{40}$/.test(e)||/^[0-9a-fA-F]{8}-[0-9a-fA-F]{16}$/.test(e))}var Bd=b(()=>{"use strict";Oo()});var nr,Lo,or,ar,rr,sr,lr,cr,dr,ur,tt,hr,Ki,mr,pr,Pt,Gd,ji,Kd,jd,Do,zd,Vd,Xd,Yd,Jd=b(()=>{"use strict";nr="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",Lo=112,or=1920,ar=1080,rr=1920,sr=1080-Lo,lr=1280,cr=720,dr=500,ur=500,tt="Desktop Chrome",hr=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(hr||{}),Ki={"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"}},mr=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(mr||{}),pr={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"]},Pt=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),pr[e].map(n=>Ki[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Gd=()=>Object.keys(Ki),ji=e=>Ki[e],Kd={desktop:{label:"Desktop",type:"desktop",devices:Pt("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:Pt("mobile")}},jd={desktop:{label:"Desktop",type:"desktop",devices:Pt("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:Pt("mobile",!0)}},Do=(e,t=!1)=>{let i={userAgent:nr,viewport:{width:rr,height:sr},isMobile:!1,hasTouch:!1};if(!e||e===tt)return i;let n=ji(e);if(!n)return i;let{width:o,height:a}=n.viewport,s=Math.max(dr/o,1),r=Math.max(ur/a,1),l=Math.max(s,r),d={width:Math.round(o*l),height:Math.round(a*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},zd=e=>{let t={width:or,height:ar};if(!e||e===tt)return t;let i=Do(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+Lo}:t},Vd=e=>{let t={width:lr,height:cr};if(!e||e===tt)return t;let i=Do(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Xd=e=>!e||e===tt?void 0:ji(e)?.channel,Yd=e=>!e||e===tt?"chromium":ji(e)?.defaultBrowserType??"chromium"});function fr(e){let t=e.match(/\.getByRole\(['"]([^'"]+)['"]/);if(t&&t[1]){let p=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(p&&p[1]){let S=p[1].replace(/\\(.)/g,"$1");return`${t[1]} element with text "${S}"`}let f=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(f&&f[1]){let S=f[1].replace(/^\/|\/$/g,""),_=S.length>30?`${S.substring(0,27)}...`:S;return`${t[1]} element with text matching "${_}"`}return`${t[1]} element`}let i=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(i&&i[1]){let p=Ct(e),f=i[1].replace(/\\(.)/g,"$1");return`${p} with text "${f}"`}let n=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(n&&n[1])return`${Ct(e)} with text matching ${n[1]}`;let o=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(o&&o[1]){let p=Ct(e),f=o[1].replace(/\\(.)/g,"$1");return`${p} containing "${f}"`}let a=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(a&&a[1]){let p=Ct(e),f=a[1].replace(/\\(.)/g,"$1");return`${p} containing "${f}"`}let s=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(s&&s[1]){let p=Ct(e),f=s[1].replace(/\\(.)/g,"$1");return`${p} not containing "${f}"`}let r=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(r&&r[1]){let p=Ct(e),f=r[1].replace(/\\(.)/g,"$1");return`${p} not containing "${f}"`}let l=e.match(/name:\s*'((?:[^'\\]|\\.)*)'/);if(l&&l[1])return`"${l[1].replace(/\\(.)/g,"$1")}"`;let d=e.match(/name:\s*"((?:[^"\\]|\\.)*)"/);if(d&&d[1])return`"${d[1].replace(/\\(.)/g,"$1")}"`;let c=e.match(/getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(c&&c[1])return`"${c[1].replace(/\\(.)/g,"$1")}"`;let h=e.match(/getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(h&&h[1])return`"${h[1].replace(/\\(.)/g,"$1")}"`;let m=e.match(/getByPlaceholder\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(m&&m[1])return`input with placeholder "${m[1].replace(/\\(.)/g,"$1")}"`;let g=e.match(/getByPlaceholder\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(g&&g[1])return`input with placeholder "${g[1].replace(/\\(.)/g,"$1")}"`;let y=e.match(/getByLabel\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(y&&y[1])return`"${y[1].replace(/\\(.)/g,"$1")}"`;let v=e.match(/getByLabel\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(v&&v[1])return`"${v[1].replace(/\\(.)/g,"$1")}"`;let x=e.match(/getByRole\(['"]([^'"]+)['"]/);return x&&x[1]?`${x[1]} element`:e.length>50?`${e.substring(0,47)}...`:e}function wr(e,t){if(!e||!t)return null;let i=t.replace(/^ref=/,""),n=e.split(`
|
|
4547
|
+
`);for(let o of n){if(!o.includes(`[ref=${i}]`))continue;let r=o.replace(/\s+\[[^\]]+\](?:\s*\[[^\]]+\])*.*$/,"").trim().replace(/^[-–—]\s*/,"").trim().replace(/\\"/g,'"');return r.length>0?r:null}return null}function br(e,t=""){let i=e.match(/page\d*\.(.+?)\.(click|fill|press|check|uncheck|hover|selectOption|dragTo|dblclick|screenshot|setInputFiles|locator|frameLocator)/);if(i&&i[1])return i[1].trim();let n=e.match(/page\d*\.locator\(([^)]+)\)/);if(n&&n[1])return`locator(${n[1]})`;let o=e.match(/page\d*\.frameLocator\(([^)]+)\)/);return o&&o[1]?`frameLocator(${o[1]})`:t}function Ct(e){let t=e.match(/^locator\(['"]([^'"]+)['"]\)/);if(t&&t[1]){let o=t[1],a=o.match(/^([a-zA-Z][\w-]*)/);return a?a[1]:o.length>20?`${o.substring(0,17)}...`:o}let i=e.match(/getByRole\(['"]([^'"]+)['"]/);if(i&&i[1])return i[1];let n=e.match(/getByTestId\(['"]([^'"]+)['"]/);return n&&n[1]?`element with testId "${n[1]}"`:"element"}function gr(e){let t=e.match(/\.fill\(['"]([^'"]*)['"]\)/);if(t&&t[1]!==void 0)return t[1];let i=e.match(/\.press\(['"]([^'"]+)['"]\)/);if(i&&i[1])return i[1];let n=e.match(/\.selectOption\(['"]([^'"]+)['"]\)/);return n&&n[1]?n[1]:""}function rg(e){let t=e.match(/button:\s*['"]([^'"]+)['"]/);return t?t[1]:void 0}function sg(e){let t=e.match(/modifiers:\s*\[([^\]]+)\]/);if(t&&t[1])return t[1].split(",").map(i=>i.trim().replace(/['"]/g,""))}function Qd(e,t){let i=e.name||"unknown",n=br(t,e.selector||""),o=e.ariaSnapshot??e.arIAaSnapshot??"",a=e.ref,s=/getByTestId\s*\(/.test(n),l=(a&&o&&s?wr(o,a):null)??fr(n),d,c,h={};switch(i){case"click":{let m=rg(t),g=sg(t);m==="right"?(d="right_click_on_element",c=`Right click on ${l}`):(d="click_element",c=`Click on ${l}`),h={index:0},m&&m!=="left"&&(h.button=m),g&&(h.modifiers=g);break}case"fill":{let m=e.text||e.value||gr(t)||"";d="fill",c=m?`Fill ${l} with '${m}'`:`Fill ${l}`,h={value:m,index:0};break}case"press":{let m=e.key||gr(t)||"";d="press",c=`Press '${m}' on ${l}`,h={keyComb:m,index:0};break}case"selectOption":{let m=e.options?.[0]||gr(t)||"";d="select_dropdown_option",c=`Select '${m}' from ${l}`,h={text:m,index:0};break}case"check":d="click_element",c=`Check ${l}`,h={index:0};break;case"uncheck":d="click_element",c=`Uncheck ${l}`,h={index:0};break;case"setInputFiles":{let m=e.files||[];d="upload_file",c=m.length>0?`Upload file(s) to ${l}`:`Upload file to ${l}`,h={paths:m,index:0};break}case"navigate":case"goto":d="go_to_url",c=`Navigate to ${e.url||"URL"}`,h={url:e.url||"",new_tab:!1};break;case"dblclick":d="double_click_on_element",c=`Double click on ${l}`,h={index:0};break;case"hover":d="hover",c=`Hover over ${l}`,h={index:0};break;case"wheel":case"scroll":d="scroll",c=`Scroll on ${l}`,h={x:e.deltaX||0,y:e.deltaY||0,index:e.selector?0:-1};break;case"dragTo":d="drag_drop",c=`Drag ${l} to target`,h={index:0};break;case"screenshot":d="wait",c="Take screenshot",h={seconds:.5};break;case"wait":d="wait",c=`Wait for ${e.timeout||1e3}ms`,h={seconds:(e.timeout||1e3)/1e3};break;default:d="click_element",c=`${i} on ${l}`,h={index:0};break}return{locator:n,xpath:e.xpath||"",css_selector:e.css_selector||"",unique_selector:e.selector||e.css_selector||"",frame_path:e.frame_path||[],action_data:{action_name:d,args:[],kwargs:h},action_description:c,url:"",feedback:""}}var qd,Zd,eu=b(()=>{"use strict";qd=require("uuid"),Zd=()=>(0,qd.v4)()});var T,yr,No,xr,it,vr,_r,kr,re,Sr,zi,Ro,Er=b(()=>{"use strict";T=require("zod"),yr=T.z.enum(["JS_CODE","AI_MODE"]),No=T.z.object({type:yr,expression:T.z.string()}),xr=T.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),it=T.z.object({uid:T.z.string(),type:xr,comment:T.z.string().optional()}),vr=T.z.object({action_data:T.z.object({action_name:T.z.string(),kwargs:T.z.record(T.z.any()).optional(),args:T.z.array(T.z.any()).optional()}),action_description:T.z.string().optional(),url:T.z.string().optional(),xpath:T.z.string().nullable().optional(),locator:T.z.string().nullable().optional(),css_selector:T.z.string().nullable().optional(),unique_selector:T.z.string().nullable().optional(),element_index:T.z.number().nullable().optional(),frame_path:T.z.array(T.z.any()).optional(),artifacts:T.z.record(T.z.any()).optional(),feedback:T.z.string().optional(),original_browser_use_action:T.z.any().optional()}).passthrough(),_r=it.extend({type:T.z.literal("DRAFT"),description:T.z.string()}),kr=it.extend({type:T.z.literal("ACTION"),description:T.z.string(),action_entity:vr.optional(),locator:T.z.string().optional(),use_pure_vision:T.z.boolean().optional()}),re=T.z.lazy(()=>T.z.union([_r,kr,it.extend({type:T.z.literal("STEP"),description:T.z.string().optional().default(""),statements:T.z.array(re),reference_id:T.z.number().optional(),template_path:T.z.string().optional(),template_params:T.z.record(T.z.string()).optional()}),it.extend({type:T.z.literal("IF_ELSE"),description:T.z.string().optional(),condition:No,then:T.z.array(re),else:T.z.array(re).optional()}),it.extend({type:T.z.literal("WHILE_LOOP"),description:T.z.string().optional(),condition:No,body:T.z.array(re),timeout_ms:T.z.number().optional()})])),Sr=T.z.object({name:T.z.string(),statements:T.z.array(re),teardown:T.z.array(re).optional(),skip:T.z.union([T.z.boolean(),T.z.string()]).optional(),timeout:T.z.number().optional(),fail:T.z.union([T.z.boolean(),T.z.string()]).optional(),only:T.z.boolean().optional(),slow:T.z.boolean().optional()}),zi=T.z.object({tests:T.z.array(Sr).min(1),beforeAll:T.z.array(re).optional(),afterAll:T.z.array(re).optional(),beforeEach:T.z.array(re).optional(),afterEach:T.z.array(re).optional()}),Ro=T.z.object({comment:T.z.string().optional(),version:T.z.string().optional(),goal:T.z.string().optional(),url:T.z.string().optional(),baseURL:T.z.string().optional(),final_feedback:T.z.string().optional(),completed:T.z.boolean().optional(),success:T.z.boolean().optional(),statements:T.z.array(re).optional(),teardown:T.z.array(re).optional(),last_modified_at:T.z.string().optional(),testGroup:zi.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"})});function Ar(e,t){let i={...t?.test_case_id!==void 0?{test_case_id:t.test_case_id}:{},...t?.name?{name:t.name}:{},...t?.tags&&t.tags.length>0?{tags:t.tags}:{},...t?.skip!==void 0?{skip:t.skip}:{},...t?.fail!==void 0?{fail:t.fail}:{},...t?.only?{only:t.only}:{},...t?.slow?{slow:t.slow}:{},goal:e.goal??"",url:e.url,base_url:e.baseURL,...t?.timeout!==void 0?{timeout:t.timeout}:{},...t?.settings&&Object.keys(t.settings).length>0?{settings:t.settings}:{},...t?.use&&Object.keys(t.use).length>0?{use:t.use}:{},...t?.beforeEach&&t.beforeEach.length>0?{beforeEach:t.beforeEach}:{},...t?.afterEach&&t.afterEach.length>0?{afterEach:t.afterEach}:{},...t?.parameters&&t.parameters.length>0?{parameters:t.parameters}:{},statements:(e.statements??[]).map(pe)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(pe)),i}function ou(e,t){if(e.testGroup)return Mr(e,t);let i=Ar(e,t),n=new $.Document(i),o=n.contents?.get("tags",!0);return(0,$.isSeq)(o)&&(o.flow=!0),e.comment&&(n.commentBefore=e.comment),tu(n,e.statements??[]),e.teardown&&tu(n,e.teardown,"teardown"),n.toString(Ot)}function tu(e,t,i="statements"){let n=e.contents;if(!n||!(0,$.isMap)(n))return;let o=n.get(i,!0);(0,$.isSeq)(o)&&Vi(o,t)}function Vi(e,t){for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=t[i],o=e.items[i];if(i>0&&(o.spaceBefore=!0),n.comment&&(i===0?e.commentBefore=n.comment:o.commentBefore=n.comment),(0,$.isMap)(o)){let a=o;if(n.type==="STEP"){let s=a.get("statements",!0);(0,$.isSeq)(s)&&Vi(s,n.statements)}else if(n.type==="IF_ELSE"){let s=a.get("THEN",!0);(0,$.isSeq)(s)&&Vi(s,n.then);let r=a.get("ELSE",!0);(0,$.isSeq)(r)&&n.else&&Vi(r,n.else)}else if(n.type==="WHILE_LOOP"){let s=a.get("DO",!0);(0,$.isSeq)(s)&&Vi(s,n.body)}}}}function Mr(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),t?.settings&&Object.keys(t.settings).length>0&&(n.settings=t.settings);let o={};e.baseURL&&(o.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(o.beforeAll=i.beforeAll.map(pe)),i.beforeEach&&i.beforeEach.length>0&&(o.beforeEach=i.beforeEach.map(pe)),i.afterEach&&i.afterEach.length>0&&(o.afterEach=i.afterEach.map(pe)),i.afterAll&&i.afterAll.length>0&&(o.afterAll=i.afterAll.map(pe)),o.tests=i.tests.map(r=>{let l={name:r.name};return r.skip!==void 0&&(l.skip=r.skip),r.timeout!==void 0&&(l.timeout=r.timeout),r.fail!==void 0&&(l.fail=r.fail),r.only!==void 0&&(l.only=r.only),r.slow!==void 0&&(l.slow=r.slow),l.statements=r.statements.map(pe),r.teardown&&r.teardown.length>0&&(l.teardown=r.teardown.map(pe)),l}),n.suite=o;let a=new $.Document(n),s=a.contents?.get("tags",!0);return(0,$.isSeq)(s)&&(s.flow=!0),a.toString(Ot)}function au(e){return e.map(t=>(0,$.stringify)(t,Ot)).join(`---
|
|
4548
|
+
`)}function pe(e){switch(e.type){case"DRAFT":return lg(e);case"ACTION":return ru(e);case"STEP":return dg(e);case"IF_ELSE":return ug(e);case"WHILE_LOOP":return hg(e)}}function lg(e){return{intent:e.description}}function ru(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 r=i?.statement;if(typeof r=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l=i?.code;return typeof l=="string"&&l.trim()?{VERIFY:r,js:l}:{VERIFY:r}}}if(t==="go_to_url"){let r=i?.url;if(typeof r=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l={URL:r};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 r=i?.code;if(typeof r=="string"&&r.trim()&&e.description)return{description:e.description,js:r}}if(t==="ai_wait_until"){let r=i?.condition;if(typeof r=="string"){let l={WAIT_UNTIL:r};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="wait"){let r=i?.seconds,d={WAIT:e.description||`Wait ${r}s`};return typeof r=="number"&&(d.seconds=r),d}if(t==="js_code"){let r=i?.code;if(typeof r=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{description:e.description||"Code block",js:r}}if(!e.action_entity)return{intent:e.description};let n=e.action_entity.action_data??e.action_entity.action;if(!n)return{intent:e.description};let o={intent:e.description,action:n.action_name},a=e.locator??e.action_entity.locator;a&&(o.locator=a);let s=e.action_entity.xpath;if(s&&(o.xpath=s),e.use_pure_vision&&(o.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[r,l]of Object.entries(n.kwargs))r!=="uid"&&(r==="statement"&&(t==="ai_action"||t==="ai_step")||(o[r]=l));return n.args&&n.args.length>0&&(o.args=n.args),o}function su(e,t,i){let n={uid:"",type:"ACTION",description:t||e.action_description||"",action_entity:e,locator:i},o=ru(n);if(typeof o=="object"&&o!==null){let a={...o};return delete a.intent,delete a.description,delete a.VERIFY,delete a.WAIT_UNTIL,delete a.WAIT,delete a.statement,Object.keys(a).length>0?(0,$.stringify)(a,Ot).trim():""}return(0,$.stringify)(o,Ot).trim()}function lu(e){let t=(0,$.parse)(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object");if("VERIFY"in t){let c=String(t.VERIFY),h=typeof t.js=="string"?t.js:void 0;return{description:c,actionEntity:{action_description:c,action_data:{action_name:"verify",kwargs:{statement:c,...h?{code:h}:{}}}}}}if("URL"in t){let c=String(t.URL),h={url:c};return t.new_tab===!0&&(h.new_tab=!0),typeof t.timeout_seconds=="number"&&(h.timeout_seconds=t.timeout_seconds),{description:`Navigate to ${c}`,actionEntity:{action_description:`Navigate to ${c}`,action_data:{action_name:"go_to_url",kwargs:h}}}}if("CODE"in t){let c=String(t.CODE);return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:c}}}}}if("js"in t&&typeof t.js=="string"&&!("VERIFY"in t)&&!("action"in t)){let c=typeof t.description=="string"?t.description:typeof t.intent=="string"?t.intent:"";return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:t.js}}}}}if("WAIT_UNTIL"in t){let c=String(t.WAIT_UNTIL),h={condition:c};return typeof t.timeout_seconds=="number"&&(h.timeout_seconds=t.timeout_seconds),{description:`Wait until ${c}`,actionEntity:{action_description:`Wait until ${c}`,action_data:{action_name:"ai_wait_until",kwargs:h}}}}if("WAIT"in t){let c=String(t.WAIT),h={};return typeof t.seconds=="number"&&(h.seconds=t.seconds),{description:c,actionEntity:{action_description:c,action_data:{action_name:"wait",kwargs:h}}}}let i=typeof t.intent=="string"?t.intent:void 0,n=typeof t.action=="string"?t.action:void 0,o=typeof t.locator=="string"?t.locator:void 0,a=typeof t.xpath=="string"?t.xpath:void 0,s=Array.isArray(t.frame_path)?t.frame_path:void 0,r=Array.isArray(t.args)?t.args:void 0,l={};for(let[c,h]of Object.entries(t))cg.has(c)||(l[c]=h);return n?{actionEntity:{action_description:i||"",action_data:{action_name:n,kwargs:l,...r&&r.length>0?{args:r}:{}},...o?{locator:o}:{},...a?{xpath:a}:{},...s?{frame_path:s}:{}},description:i,locator:o}:{description:i,actionEntity:{action_description:i||""}}}function dg(e){if(e.template_path){let i={template:e.template_path};return e.template_params&&Object.keys(e.template_params).length>0&&(i.params=e.template_params),i}let t={STEP:e.description,statements:e.statements.map(pe)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function ug(e){let t={IF:cu(e.condition),THEN:e.then.map(pe)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(pe)),t}function hg(e){let t={WHILE:cu(e.condition),DO:e.body.map(pe)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function cu(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function du(e){let t=(0,$.parseAllDocuments)(e),i;if(t.length>1||t.length===1&&!Array.isArray(t[0]?.toJSON()))i=t.map((n,o)=>n.errors.length>0?{__parseError:`Document ${o+1}: ${n.errors[0].message}`}:n.toJSON());else{let n;try{n=(0,$.parse)(e)}catch(o){throw new Error(`Invalid YAML: ${o instanceof Error?o.message:String(o)}`)}if(!Array.isArray(n))throw new Error("Expected a YAML array or multi-document YAML (separated by ---)");i=n}return i.map((n,o)=>{try{if(n&&typeof n=="object"&&"__parseError"in n)return{error:n.__parseError};if(!n||typeof n!="object")return{error:`Item ${o+1}: expected an object`};let a=n,s=typeof a.name=="string"&&a.name.trim()||void 0,r=typeof a.goal=="string"?a.goal.trim():"";if(!r)return{error:`Item ${o+1}: missing "goal" field`};if(Array.isArray(a.statements))try{let l=(0,$.stringify)(a,Ot),d=nt(l);return{name:s,goal:d.goal??r,testFlow:d}}catch{}return{name:s,goal:r}}catch(a){return{error:`Item ${o+1}: ${a instanceof Error?a.message:String(a)}`}}})}function uu(e){try{let t=(0,$.parse)(e);if(!t||typeof t!="object")return{};let i={};return typeof t.test_case_id=="number"&&Number.isFinite(t.test_case_id)&&(i.test_case_id=t.test_case_id),typeof t.template_id=="number"&&Number.isFinite(t.template_id)&&(i.template_id=t.template_id),typeof t.name=="string"&&t.name.trim()&&(i.name=t.name.trim()),typeof t.timeout=="number"&&Number.isFinite(t.timeout)&&(i.timeout=t.timeout),t.settings&&typeof t.settings=="object"&&!Array.isArray(t.settings)&&(i.settings=t.settings),t.use&&typeof t.use=="object"&&!Array.isArray(t.use)&&(i.use=t.use),Array.isArray(t.tags)&&t.tags.every(n=>typeof n=="string")&&(i.tags=t.tags),(typeof t.skip=="boolean"||typeof t.skip=="string")&&(i.skip=t.skip),(typeof t.fail=="boolean"||typeof t.fail=="string")&&(i.fail=t.fail),t.only===!0&&(i.only=!0),t.slow===!0&&(i.slow=!0),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(i.beforeEach=t.beforeEach),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(i.afterEach=t.afterEach),Array.isArray(t.parameters)&&t.parameters.length>0&&(i.parameters=t.parameters),i}catch{return{}}}function Tr(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(Tr);let t=e,i=Object.keys(t);if(i.length===1){let o=i[0];if(o.startsWith("{ ")&&o.endsWith(" }")&&t[o]===null)return`{{${o.slice(2,-2)}}}`}let n={};for(let[o,a]of Object.entries(t))n[o]=Tr(a);return n}function nt(e){if(e.length>iu)throw new Error(`YAML input too large (${e.length} bytes, max ${iu})`);let t=Tr((0,$.parse)(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return mg(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:ge(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=ge(t.teardown));let n=Ro.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let o=n.data;return Ir(e,o),o}function mg(e){let t=e.suite;if(!t||typeof t!="object")throw new Error("Invalid suite: expected an object");let i=t.tests;if(!Array.isArray(i)||i.length===0)throw new Error('Suite must have a non-empty "tests" array');let o={tests:i.map(r=>{if(!r.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(r.statements)||r.statements.length===0)throw new Error(`Suite test "${r.name}" must have a non-empty "statements" array`);let l={name:r.name,statements:ge(r.statements)};return Array.isArray(r.teardown)&&r.teardown.length>0&&(l.teardown=ge(r.teardown)),r.skip!==void 0&&(l.skip=r.skip),typeof r.timeout=="number"&&(l.timeout=r.timeout),r.fail!==void 0&&(l.fail=r.fail),r.only===!0&&(l.only=!0),r.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(o.beforeAll=ge(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(o.afterAll=ge(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(o.beforeEach=ge(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(o.afterEach=ge(t.afterEach));let a=zi.safeParse(o);if(!a.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(a.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:a.data}}function ge(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(pg)}function pg(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 gg(t);if("WHILE"in t)return fg(t);if("STEP"in t)return wg(t);if("VERIFY"in t){let i=t.VERIFY,n={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(n.code=t.js),{uid:(0,me.v4)(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:n}}}}if("URL"in t){let i=t.URL,n=t.new_tab===!0?!0:void 0,o=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,a={url:typeof i=="string"?i:String(i)};return n&&(a.new_tab=!0),o!==void 0&&(a.timeout_seconds=o),{uid:(0,me.v4)(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:a}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:(0,me.v4)(),type:"ACTION",description:`Wait until: ${i}`,action_entity:{action_description:`Wait until: ${i}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:typeof i=="string"?i:String(i),timeout_seconds:n}}}}}if("WAIT"in t){let i=t.WAIT,n=typeof t.seconds=="number"?t.seconds:3;return{uid:(0,me.v4)(),type:"ACTION",description:typeof i=="string"?i:`Wait ${n}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${n}s`,action_data:{action_name:"wait",kwargs:{seconds:n}}}}}if("CODE"in t){let i=t.CODE;if(i==null)throw new Error('CODE statement has no code. Use "CODE: |" followed by indented code on the next line.');let n=typeof t.description=="string"?t.description:"Code block";return{uid:(0,me.v4)(),type:"ACTION",description:n,action_entity:{action_description:n,action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&!("VERIFY"in t)&&!("action"in t)){if("intent"in t||"desc"in t)throw new Error("A `js:` statement uses `description:`, not `intent:`. Raw JS does not self-heal \u2014 use `description: + js:` for code, or express it as a structured action (`intent:` + `action:`/`locator:`) to keep self-healing.");let i=typeof t.description=="string"&&t.description.trim()!==""?t.description:"Code block",n=t.js;return{uid:(0,me.v4)(),type:"ACTION",description:i,action_entity:{action_description:i,action_data:{action_name:"js_code",kwargs:{code:typeof n=="string"?n:String(n)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...n}=t;return nu({...n,action:"function",functionName:i})}if("action"in t)return nu(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:(0,me.v4)(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function hu(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 gg(e){let t=hu(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:(0,me.v4)(),type:"IF_ELSE",condition:t,then:ge(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=ge(e.ELSE)),n}function fg(e){let t=hu(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:(0,me.v4)(),type:"WHILE_LOOP",condition:t,body:ge(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function wg(e){let t=typeof e.STEP=="string"?e.STEP:"";if(!Array.isArray(e.statements))throw new Error("STEP requires a statements array");let i={uid:(0,me.v4)(),type:"STEP",description:t,statements:ge(e.statements)};if(typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),typeof e.template_path=="string"&&(i.template_path=e.template_path),e.template_params&&typeof e.template_params=="object"&&!Array.isArray(e.template_params)){let n=e.template_params,o={};for(let[a,s]of Object.entries(n))o[a]=String(s);i.template_params=o}return i}function nu(e){let t=typeof e.action=="string"?e.action:String(e.action),i=typeof e.intent=="string"?e.intent:typeof e.desc=="string"?e.desc:"",n=typeof e.locator=="string"?e.locator:void 0,o=typeof e.xpath=="string"?e.xpath:void 0,a=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,s={};for(let[d,c]of Object.entries(e))bg.has(d)||(s[d]=c);t==="verify"&&typeof s.js=="string"&&(s.code=s.js,delete s.js),(t==="ai_action"||t==="ai_step")&&s.statement===void 0&&(s.statement=i);let r={action_description:i,action_data:{action_name:t,kwargs:Object.keys(s).length>0?s:{}}};n&&(r.locator=n),o&&(r.xpath=o);let l={uid:(0,me.v4)(),type:"ACTION",description:i,action_entity:r};return a&&(l.use_pure_vision=!0),l}function Ir(e,t){let i;try{i=(0,$.parseDocument)(e)}catch{return}let n=i.contents;if(!n||!(0,$.isMap)(n))return;if(i.commentBefore)t.comment=i.commentBefore;else{let l=n.items?.[0];l?.key&&l.key.commentBefore&&(t.comment=l.key.commentBefore)}let o=n,a=o.get("statements",!0);(0,$.isSeq)(a)&&t.statements&&$t(a,t.statements);let s=o.get("teardown",!0);(0,$.isSeq)(s)&&t.teardown&&$t(s,t.teardown)}function $t(e,t){e.commentBefore&&t.length>0&&(t[0].comment=e.commentBefore);for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=e.items[i];n.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=n.commentBefore);let o=t[i];if(o.type==="STEP"&&(0,$.isMap)(n)){let a=n.get("statements",!0);(0,$.isSeq)(a)&&$t(a,o.statements)}else if(o.type==="IF_ELSE"&&(0,$.isMap)(n)){let a=n.get("THEN",!0);(0,$.isSeq)(a)&&$t(a,o.then);let s=n.get("ELSE",!0);(0,$.isSeq)(s)&&o.else&&$t(s,o.else)}else if(o.type==="WHILE_LOOP"&&(0,$.isMap)(n)){let a=n.get("DO",!0);(0,$.isSeq)(a)&&$t(a,o.body)}}}var $,me,Ot,cg,iu,bg,Fo=b(()=>{"use strict";Er();$=require("yaml"),me=require("uuid");Ot={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};cg=new Set(["intent","description","action","locator","xpath","frame_path","args","js"]);iu=1024*1024;bg=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});function Pr(e,t){let i=[];t.version!=="1.0"&&i.push(`Unsupported patch version: ${t.version}`),(!Array.isArray(t.operations)||t.operations.length===0)&&i.push("Patch must have at least one operation");for(let n=0;n<t.operations.length;n++){let o=t.operations[n],a=`operations[${n}]`;switch(o.reason||i.push(`${a}: missing reason`),o.op){case"remove":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`);break}case"modify":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}case"insert":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),o.position!=="before"&&o.position!=="after"&&i.push(`${a}: position must be 'before' or 'after'`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}default:i.push(`${a}: unknown operation type "${o.op}"`)}}return{valid:i.length===0,errors:i}}function Cr(e,t){let i=Pr(e,t);if(!i.valid)throw new Error(`Invalid patch: ${i.errors.join("; ")}`);let n=[...e],o=t.operations.map((r,l)=>({...r,originalOrder:l})),a={remove:0,modify:1,insert:2},s=[...o].sort((r,l)=>r.index!==l.index?l.index-r.index:a[r.op]-a[l.op]);for(let r of s)switch(r.op){case"remove":n.splice(r.index,1);break;case"modify":n[r.index]=r.statement;break;case"insert":r.position==="before"?n.splice(r.index,0,r.statement):n.splice(r.index+1,0,r.statement);break}return n}function mu(e,t){let i=(0,Ho.parse)(e);if(!i||typeof i!="object")throw new Error("Invalid YAML: expected an object at root level");let n=i.statements;if(!Array.isArray(n))throw new Error('YAML must have a "statements" array');let o=Cr(n,t);i.statements=o;let a=(0,Ho.stringify)(i,{lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"});return nt(a),{modifiedYaml:a,modifiedStatements:o}}var Ho,pu=b(()=>{"use strict";Fo();Ho=require("yaml")});function $r(e){for(let t of e){if(t.type==="STEP"){let n=t;if(n.reference_id||n.template_path)return!0}let i=Ne(t);for(let n of i)if($r(n.statements))return!0}return!1}function wu(e){let t=new Set;function i(n){for(let o of n){if(o.type==="STEP"){let s=o;s.reference_id&&t.add(s.reference_id)}let a=Ne(o);for(let s of a)i(s.statements)}}return i(e),Array.from(t)}function xu(e){if(!e?.statements||!Array.isArray(e.statements))return{};let t={};return ze(e.statements,"main",t),e.teardown&&Array.isArray(e.teardown)&&ze(e.teardown,"teardown",t),t}function Be(e,t,i){let n=e+".",o=t.filter(([c])=>c===e||c.startsWith(n));if(o.length===0)return[];let a=[],s=new Set;for(let[c]of o){let h=c===e?"":c.slice(n.length);if(!h)continue;let m=h.split(".")[0];s.has(m)||s.add(m)}let r=Array.from(s);r.sort((c,h)=>{let m=/^\d+$/.test(c)?parseInt(c,10):-1,g=/^\d+$/.test(h)?parseInt(h,10):-1;return m>=0&&g>=0?m-g:c==="then"&&h==="else"?-1:c==="else"&&h==="then"||c==="body"?1:h==="body"?-1:c.localeCompare(h)});function l(c){return i[c]}function d(c){let h=c.match(/^(IF|WHILE)\s+([\s\S]+)$/);return{type:"AI_MODE",expression:(h?h[2].trim():c)||"true"}}for(let c of r){let h=e?`${e}.${c}`:c,m=l(h),g=m?.description??"",y=h;if(c==="then"){let _=`${e}.then`,k=`${e}.else`,A=Be(_,t,i),I=Be(k,t,i),O=l(e),C=O?d(O.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"IF_ELSE",condition:C,then:A,...I.length>0?{else:I}:{}});continue}if(c==="else")continue;if(c==="body"){let _=`${e}.body`,k=Be(_,t,i),A=l(e),I=A?d(A.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"WHILE_LOOP",condition:I,body:k});continue}let v=`${e}.${c}`,x=t.some(([_])=>_.startsWith(v+".then.")||_===v+".then"),p=t.some(([_])=>_.startsWith(v+".else.")||_===v+".else"),f=t.some(([_])=>_.startsWith(v+".body.")||_===v+".body"),S=t.filter(([_])=>{if(!_.startsWith(v+"."))return!1;let A=_.slice(v.length+1).split(".")[0];return/^\d+$/.test(A)&&A!=="then"&&A!=="else"&&A!=="body"});if(x||p){let _=v+".then",k=v+".else",A=Be(_,t,i),I=Be(k,t,i),O=m?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:h,type:"IF_ELSE",condition:O,then:A,...I.length>0?{else:I}:{}})}else if(f){let _=v+".body",k=Be(_,t,i),A=m?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:h,type:"WHILE_LOOP",condition:A,body:k})}else if(S.length>0){let _=Be(v,t,i);a.push({uid:h,type:"STEP",description:g||"Group",statements:_})}else a.push({uid:h,type:"ACTION",description:g||"Action",action_entity:m?.action_entity})}return a}function vu(e){let t=Object.entries(e),i=n=>{let o=n+".";return t.some(([s])=>s===n||s.startsWith(o))?Be(n,t,e):[]};return{before:i("before"),main:i("main"),teardown:i("teardown"),after:i("after")}}var Ne,le,Ge,Ke,je,Xi,gu,fu,yg,xg,bu,yu,ze,Wo=b(()=>{"use strict";Ne=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},le=(e,t,i=void 0,n="root")=>{for(let o=0;o<e.length;o++){let a=e[o],s=a.uid;if(s===t)return{stableId:s,path:[o],statement:a,parent:i,containerKey:n,index:o};let r=Ne(a);for(let l of r){let d=le(l.statements,t,a,l.key);if(d)return{...d,path:[o,l.key,...d.path]}}}return null},Ge=(e,t,i)=>{let n=le(e,t);if(!n)return null;let{statement:o,parent:a,containerKey:s,index:r}=n,l=null;switch(o.type){case"DRAFT":case"ACTION":l=Ke(e,n)||je(e,n);break;case"STEP":if(o.statements&&o.statements.length>0)return o.statements[0];l=Ke(e,n)||je(e,n);break;case"IF_ELSE":if(i===!0&&o.then&&o.then.length>0)return o.then[0];if(i===!1&&o.else&&o.else.length>0)return o.else[0];l=Ke(e,n)||je(e,n);break;case"WHILE_LOOP":if(i===!0&&o.body&&o.body.length>0)return o.body[0];l=Ke(e,n)||je(e,n);break;default:l=Ke(e,n)||je(e,n);break}if(a&&a.type==="WHILE_LOOP"&&s==="body"){if(!l)return a;let d=le(e,l.uid);if(!d||d.parent!==a)return a}return l},Ke=(e,t)=>{if(!t.parent)return e[t.index+1]||null;let n=Ne(t.parent).find(o=>o.key===t.containerKey);return n&&t.index+1<n.statements.length?n.statements[t.index+1]:null},je=(e,t)=>{if(!t.parent)return null;let i=t.parent.uid,n=le(e,i);return n?Ke(e,n)||je(e,n):null},Xi=e=>{let t=[],i=n=>{for(let o of n){t.push(o);let a=Ne(o);for(let s of a)i(s.statements)}};return i(e),t},gu=e=>{switch(e.type){case"DRAFT":case"ACTION":return!0;case"STEP":return!0;case"IF_ELSE":case"WHILE_LOOP":return!0;default:return!1}},fu=(e,t,i)=>{if(!le(e,t))return null;if(i===null){let r=[],l=t;for(;l!==null&&le(e,l);)if(r.push(l),l=Ge(e,l)?.uid||null,r.length>1e3)return null;return r}if(!le(e,i))return null;if(t===i)return[];let a=[],s=t;for(;s&&s!==i;){let r=le(e,s);if(!r)break;if(a.push(s),r.statement.type==="IF_ELSE"){let l=yg(r.statement,i);l?s=Ge(e,s,l==="then")?.uid||null:s=Ge(e,s)?.uid||null}else r.statement.type==="WHILE_LOOP"?xg(r.statement,i)?s=Ge(e,s,!0)?.uid||null:s=Ge(e,s,!1)?.uid||null:s=Ge(e,s)?.uid||null;if(a.length>1e3)return null}return s===i?a:null},yg=(e,t)=>{if(e.type!=="IF_ELSE")return null;let i=e;return i.then&&le(i.then,t)?"then":i.else&&le(i.else,t)?"else":null},xg=(e,t)=>{if(e.type!=="WHILE_LOOP")return!1;let i=e;return!!(i.body&&le(i.body,t))};bu=e=>e.startsWith("ai_")?!0:["js_code","function","assert","verify","wait_for_download_complete","extract_activation_code","extract_email_content"].includes(e),yu=e=>!["js_code","function","assert","ai_assert","verify","ai_extract","ai_wait_until","upload_file","login","extract_activation_code","extract_email_content","ai_step"].includes(e),ze=(e,t,i)=>{e.forEach((n,o)=>{let a=`${t}.${o}`;n.type==="DRAFT"?i[a]={description:n.description||"Draft",action_entity:void 0}:n.type==="ACTION"?i[a]={description:n.description||"Action",action_entity:n.action_entity,locator:n.locator}:n.type==="STEP"&&n.statements?ze(n.statements,a,i):n.type==="IF_ELSE"?(i[a]={description:"IF "+(n.condition?.expression||""),action_entity:void 0},n.then&&ze(n.then,`${a}.then`,i),n.else&&ze(n.else,`${a}.else`,i)):n.type==="WHILE_LOOP"&&(i[a]={description:"WHILE "+(n.condition?.expression||""),action_entity:void 0},n.body&&ze(n.body,`${a}.body`,i))})}});function Lr(e){let t=0,i=0;for(let n of e)if(n.type==="DRAFT")i++;else if(n.type==="ACTION"){let o=n.action_entity?.action_data?.action_name??"";Or.has(o)||t++}return{action:t,draft:i}}function _g(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function Su(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function kg(e){let t=e.split(/\r?\n/).map(a=>a.trim()).filter(a=>a.length>0&&!a.startsWith("//")),i=t.length,n=t.join(`
|
|
4549
|
+
`).match(/\bawait\b/g),o=n?n.length:0;return i<=_u&&o<=ku?null:`${i} non-blank line(s), ${o} await(s) \u2014 limits are ${_u} lines and ${ku} awaits. The VERIFY js: field is a cache for one natural-language assertion, not a place for multi-step logic. Break this into multiple statements \u2014 one VERIFY per assertion \u2014 so each step is visible in the debugger and self-healable. For freeform setup code (mocking, storage), use the description: + js: escape hatch, which has no complexity cap.`}function Eu(e,t){let i=t?.coverageThreshold??vg,n=[],o=[],a;try{a=nt(e)}catch(m){return{valid:!1,errors:[`Invalid YAML: ${m.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}a.goal||n.push('Missing required field: "goal"'),a.statements?.length||n.push('Missing required field: "statements"');let s=[...Xi(a.statements??[]),...a.teardown?Xi(a.teardown):[]],{action:r,draft:l}=Lr(s),d="Hint: in YAML double-quoted strings, backslashes are escape characters \u2014 use \\\\/ instead of \\/ for regex, or use single quotes.";for(let m of s){let g=m;if(g.reference_id!==void 0){let y=g.description||m.uid;n.push(`Unresolved cloud template reference on statement "${y}" (reference_id: ${g.reference_id}). Local YAML tests cannot use reference_id \u2014 inline the template statements or use the local "template:" key instead.`)}if(m.type==="ACTION"){let y=m,v=y.action_entity?.action_data?.action_name??"";if(v==="js_code"||v==="js_action"||v==="verify"||v==="ai_assert"){let x=y.action_entity?.action_data?.kwargs?.code;if(typeof x=="string"){let p=_g(x);if(p){let f=y.description||v;n.push(`Invalid JS in "${f}": ${p}. ${d}`)}else if(v==="verify"){let f=kg(x);if(f){let S=y.description||v;n.push(`JS cache for "${S}" is too complex: ${f}`)}}}}}if(m.type==="IF_ELSE"){let y=m;if(y.condition.type==="JS_CODE"){let v=Su(y.condition.expression);v&&n.push(`Invalid JS in IF condition "${y.condition.expression}": ${v}. ${d}`)}}if(m.type==="WHILE_LOOP"){let y=m;if(y.condition.type==="JS_CODE"){let v=Su(y.condition.expression);v&&n.push(`Invalid JS in WHILE condition "${y.condition.expression}": ${v}. ${d}`)}}}let c=r+l,h=c>0?Math.round(r/c*100):0;return c>0&&h/100<i&&o.push(`Low action coverage: ${r}/${c} statements (${h}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:n.length===0,errors:n,warnings:o,stats:{total:c,action:r,draft:l,coverage:h}}}var vg,_u,ku,Or,Tu=b(()=>{"use strict";Fo();Wo();vg=.5,_u=5,ku=3,Or=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"])});function Au(){return{version:"1.0",entries:{}}}function Mu(e,t){return{action_entity:e,updated_at:new Date().toISOString(),updated_by:{source:"runner",test_run_id:t}}}function Iu(e,t){let i=t?.entries[e.uid],n=i?.action_entity??e.action_entity;return e.locator&&n?{...n,locator:e.locator}:i?i.action_entity:e.action_entity?e.action_entity:null}function Pu(e,t,i,n){return e.entries[t]={action_entity:i,updated_at:new Date().toISOString(),updated_by:n},e}function Cu(e,t){let i=e??{version:"1.0",entries:{}};for(let[n,o]of t)i.entries[n]=o;return i}function $u(e){return e?Object.keys(e.entries).length===0:!0}function Ou(e){return e?Object.keys(e.entries).length:0}function Lu(e,t){if(!t||Object.keys(t.entries).length===0)return e;let i=Dr(e.statements??[],t),n=e.teardown?Dr(e.teardown,t):void 0;return{...e,statements:i,teardown:n}}function Dr(e,t){return e.map(i=>Sg(i,t))}function Sg(e,t){if(e.type==="ACTION"){let o=e,a=t.entries[o.uid];return a?{...o,action_entity:a.action_entity}:o}let i=Ne(e);if(i.length===0)return e;let n={};for(let o of i)n[o.key]=Dr(o.statements,t);return{...e,...n}}var Du=b(()=>{"use strict";Wo()});var Nr,Rr,Nu,Ru=b(()=>{"use strict";Nr=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(Nr||{}),Rr=(e=>(e.JS_CODE="JS_CODE",e.AI_MODE="AI_MODE",e))(Rr||{}),Nu=18e4});var Fu,Wu=b(()=>{"use strict";Fu=class Hu{data={};sensitive=new Set;get(t){return this.data[t]}set(t,i,n=!1){this.data[t]=i,n?this.sensitive.add(t):this.sensitive.has(t)&&this.sensitive.delete(t)}getAll(){return{...this.data}}isSensitive(t){return this.sensitive.has(t)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(t){return this.sensitive.delete(t),delete this.data[t]}clear(){this.data={},this.sensitive.clear()}has(t){return t in this.data}get size(){return Object.keys(this.data).length}merge(t){for(let[i,n]of Object.entries(t.getAll()))this.set(i,n,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new Hu;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[o,a]of Object.entries(t.data))i.set(o,a,n.has(o))}return i}}});function Uu(e,t=Eg()){return{copilot:e?.models?.copilot||t.COPILOT_MODEL||Bo,webagent:e?.models?.webagent||t.WEB_AGENT_MODEL||Ur,computer_use:e?.models?.computer_use||t.COMPUTER_USE_MODEL||Br}}function Bu(e){if(e){if(e.WEB_AGENT_MODEL)return e.WEB_AGENT_MODEL;if(e.GOOGLE_API_KEY)return Uo;if(e.ANTHROPIC_API_KEY)return Fr;if(e.OPENAI_API_KEY)return Hr;if(e.SHIPLIGHT_API_TOKEN)return Bo}}function Gu(e){if(e){if(e.COMPUTER_USE_MODEL)return e.COMPUTER_USE_MODEL;if(e.GOOGLE_API_KEY)return Yi;if(e.OPENAI_API_KEY)return Wr;if(e.SHIPLIGHT_API_TOKEN)return Yi}}var Fr,Uo,Hr,Yi,Wr,Bo,Ur,Br,Eg,Ku=b(()=>{"use strict";Fr="claude-haiku-4-5",Uo="gemini-3.1-pro-preview",Hr="gpt-5.4-mini",Yi="gemini-3-flash-preview",Wr="gpt-5.4",Bo="claude-sonnet-4-6",Ur=Uo,Br=Yi,Eg=()=>typeof process<"u"?process.env:{}});var Gr,ju=b(()=>{"use strict";Gr=(e=>(e.INITIALIZING="initializing",e.READY="ready",e.PROCESSING="processing",e.STOPPING="stopping",e.WAITING_USER="waiting_user",e.COMPLETED="completed",e.FAILED="failed",e))(Gr||{})});function zu(e){let t=e.trim();if(!t||t.startsWith("List of devices"))return null;let i=t.split(/\s+/);if(i.length<2)return null;let n=i[0],o=i[1],a="usb";return n.startsWith("emulator-")?a="emulator":n.includes(":")&&(a="wifi"),{id:n,state:o,connectionType:a}}function Vu(e){return e.startsWith(be)?e:`${be}${e}`}function Xu(e){return e.model?`${e.model} (${e.id})`:e.connectionType==="emulator"?`Android Emulator (${e.id})`:e.id}var Yu=b(()=>{"use strict";Oo()});var Kr={};Ve(Kr,{ADDRESS_BAR_HEIGHT:()=>Lo,ANDROID_DEVICE_PREFIX:()=>be,ActionEntitySchema:()=>vr,ActionSchema:()=>kr,AgentStatus:()=>Gr,BaseStatementSchema:()=>it,BrowserType:()=>hr,ConditionSchema:()=>No,ConditionType:()=>Rr,ConditionTypeSchema:()=>yr,DEFAULT_ANTHROPIC_MODEL:()=>Fr,DEFAULT_COMPUTER_USE_MODEL:()=>Br,DEFAULT_COPILOT_MODEL:()=>Bo,DEFAULT_DEVICE_NAME:()=>tt,DEFAULT_GEMINI_COMPUTER_USE_MODEL:()=>Yi,DEFAULT_GOOGLE_MODEL:()=>Uo,DEFAULT_OPENAI_COMPUTER_USE_MODEL:()=>Wr,DEFAULT_OPENAI_MODEL:()=>Hr,DEFAULT_WEBAGENT_MODEL:()=>Ur,DEFAULT_WHILE_LOOP_TIMEOUT_MS:()=>Nu,DEVICE_CATEGORIES:()=>pr,DeviceType:()=>mr,DraftSchema:()=>_r,IOS_DEVICE_PREFIX:()=>ye,LoginType:()=>er,MIN_WINDOW_HEIGHT:()=>ur,MIN_WINDOW_WIDTH:()=>dr,NON_INTENT_ACTIONS:()=>Or,NodeJSCodeCommon:()=>Sd,PLAYWRIGHT_DEVICES:()=>Ki,RECORD_VIDEO_HEIGHT:()=>cr,RECORD_VIDEO_WIDTH:()=>lr,StatementSchema:()=>re,StatementType:()=>Nr,StatementTypeSchema:()=>xr,TestFlowSchema:()=>Ro,TestGroupEntrySchema:()=>Sr,TestGroupSchema:()=>zi,TwoFactorAuthType:()=>tr,UI_DEVICE_CATEGORIES:()=>Kd,UI_DEVICE_CATEGORIES_ELECTRON:()=>jd,USER_AGENT:()=>nr,VIEWPORT_HEIGHT:()=>sr,VIEWPORT_WIDTH:()=>rr,VariableStore:()=>Fu,WINDOW_HEIGHT:()=>ar,WINDOW_WIDTH:()=>or,actionEntityToYaml:()=>su,actionStepsMapToTestFlowSections:()=>vu,allowPureVisionAction:()=>yu,applyPatchToYaml:()=>Cr,applyPatchToYamlString:()=>mu,collectActionSteps:()=>ze,convertPlaywrightActionToEntity:()=>Qd,countIntentStatements:()=>Lr,createAndroidDeviceName:()=>Dd,createEmptyStore:()=>Au,createIOSDeviceName:()=>Nd,createRunnerStoreEntry:()=>Mu,extractActionStepsFromTestFlow:()=>xu,extractAndAttachComments:()=>Ir,extractDeviceIdentifier:()=>Ld,extractElementDescription:()=>fr,extractElementDescriptionFromAriaSnapshot:()=>wr,extractLocatorFromCode:()=>br,extractYamlMetadata:()=>uu,findNextAfterContainer:()=>je,findNextSibling:()=>Ke,findNextStatement:()=>Ge,findPathBetweenStatements:()=>fu,findStatementPathById:()=>le,generateUid:()=>Zd,getAllDeviceNames:()=>Gd,getAllReferenceIds:()=>wu,getAllStatementsInOrder:()=>Xi,getAndroidDeviceDisplayName:()=>Xu,getBrowserWindowSize:()=>zd,getCompatiblePlatforms:()=>ir,getDeviceBrowserType:()=>Yd,getDeviceByName:()=>ji,getDeviceChannel:()=>Xd,getDeviceOptions:()=>Do,getDevicesByCategory:()=>Pt,getIOSDeviceDisplayName:()=>Wd,getLoginConfigPlatform:()=>Td,getRecordVideoSize:()=>Vd,getStatementContainers:()=>Ne,getStoreSize:()=>Ou,getTestPlatformFromDeviceName:()=>Pd,hasReferenceIds:()=>$r,isAndroidDevice:()=>$d,isAppPackage:()=>Rd,isDynamicAction:()=>bu,isExecutableStatement:()=>gu,isIOSDevice:()=>Od,isNativeDevice:()=>Cd,isPhysicalDeviceUDID:()=>Ud,isPlatformCompatibleWithUrl:()=>Fd,isStoreEmpty:()=>$u,isWebUrl:()=>$o,mergeActionEntitiesIntoTestFlow:()=>Lu,mergeStoreUpdates:()=>Cu,parseAdbDeviceLine:()=>zu,parseYamlArrayItems:()=>du,replaceVariables:()=>Md,resolveActionEntity:()=>Iu,resolveComputerUseModelFromEnv:()=>Gu,resolveModels:()=>Uu,resolveWebAgentModelFromEnv:()=>Bu,suiteToYaml:()=>Mr,testFlowToYaml:()=>ou,testFlowToYamlObject:()=>Ar,toAndroidDeviceName:()=>Vu,toIOSDeviceName:()=>Hd,updateStoreEntry:()=>Pu,validatePatch:()=>Pr,validateTestYaml:()=>Eu,yamlObjectsToString:()=>au,yamlToActionEntity:()=>lu,yamlToTestFlow:()=>nt});var jr=b(()=>{"use strict";kd();Ed();Ad();Id();Bd();Jd();eu();pu();Tu();Fo();Er();Du();Wo();Ru();Wu();Ku();ju();Yu();Oo()});var Ig={};Ve(Ig,{EXCLUDED_CONTEXT_OPTION_KEYS:()=>Tg,HANDLED_CONTEXT_OPTION_KEYS:()=>th,SDK_ENV_ALLOWLIST:()=>ch,VIEWPORT_INCOMPATIBLE_OPTIONS:()=>ih,applyVarsOverride:()=>lh,buildSdkEnv:()=>dh,createTestContext:()=>ah,dropViewportIncompatibleOptions:()=>nh,expect:()=>Lt.expect,isDeclaredSensitive:()=>sh,mergeResolvedContextOptions:()=>zr,parseVarsOverrideEnv:()=>rh,resolveAuthState:()=>eh,test:()=>Mg});module.exports=fh(Ig);var Re=H(require("path"),1),Qu=H(require("fs"),1),Lt=require("@playwright/test");var ne=H(require("fs"),1),ot=H(require("path"),1),zo=require("crypto"),Vo=require("os");function Xr(e){return[`--disable-extensions-except=${e}`,`--load-extension=${e}`,"--no-first-run","--disable-default-apps"]}function Yr(e){if(!ne.existsSync(e))return console.warn(`[fixture] extensionStorageState file not found: ${e}`),null;let t;try{t=JSON.parse(ne.readFileSync(e,"utf-8"))}catch(a){throw new Error(`[fixture] Failed to parse extensionStorageState at ${e}: ${a}`)}let i=t;if(!Array.isArray(i.cookies))return null;let n=(Date.now()+365*24*60*60*1e3)/1e3,o=i.cookies.filter(a=>a&&typeof a=="object"&&typeof a.name=="string"&&typeof a.domain=="string");return o.length<i.cookies.length&&console.warn(`[fixture] Skipped ${i.cookies.length-o.length} malformed cookies (missing name or domain)`),o.map(a=>({...a,expires:n}))}function Jr(e){if(e){let i=ot.resolve(process.cwd(),e),n=ot.join((0,Vo.tmpdir)(),`ext-profile-${(0,zo.randomUUID)()}`);if(ne.existsSync(i)){try{ne.cpSync(i,n,{recursive:!0})}catch(a){try{ne.rmSync(n,{recursive:!0,force:!0})}catch(s){console.warn("[fixture] Failed to clean up partial profile copy:",n,s)}throw new Error(`[fixture] Failed to copy extension profile from ${i}: ${a}`)}let o=ot.join(n,"SingletonLock");ne.existsSync(o)&&ne.rmSync(o,{force:!0})}else ne.mkdirSync(n,{recursive:!0});return n}let t=ot.join((0,Vo.tmpdir)(),`ext-profile-${(0,zo.randomUUID)()}`);return ne.mkdirSync(t,{recursive:!0}),t}Za();var ig=H(require("dotenv"),1),ng="__shiplightDotenvCache__";function og(){return globalThis[ng]}function Qa(){let e=og();return e===void 0?process.env:e}async function eh(e){let i=await import(Re.resolve(process.cwd(),e.auth)),n=i.login||i.default;if(typeof n!="function")throw new Error(`auth module "${e.auth}" must export a login(args) function that returns a storageState file path`);let o=await n(e.args||{});if(typeof o!="string")throw new Error(`auth module "${e.auth}" login() must return a storageState file path (got ${typeof o})`);return o}function Ju(e){return!(!e||e==="off")}var th=["acceptDownloads","baseURL","bypassCSP","colorScheme","deviceScaleFactor","extraHTTPHeaders","geolocation","hasTouch","httpCredentials","ignoreHTTPSErrors","isMobile","javaScriptEnabled","locale","offline","permissions","proxy","serviceWorkers","timezoneId","userAgent","viewport"],Tg=["storageState","contextOptions","clientCertificates"],ih=[{key:"deviceScaleFactor",conflicts:e=>e!==void 0},{key:"isMobile",conflicts:e=>!!e}];function nh(e){if(e.viewport!==null)return[];let t=[];for(let{key:i,conflicts:n}of ih)n(e[i])&&(delete e[i],t.push(i));return t}function zr(e,t){let i={...e};for(let[o,a]of Object.entries(t))a!==void 0&&(i[o]=a);let n=nh(i);return n.length>0&&console.warn(`[fixture] "viewport: null" (no fixed viewport) is incompatible with ${n.join(" and ")}; dropping ${n.length>1?"them":"it"} so the browser context can be created.`),i}function oh(e,t){return!e||e==="off"?!1:e==="on"?!0:e==="retain-on-failure"?t.status!==t.expectedStatus:e==="on-first-retry"?t.retry>0:typeof e=="object"&&e!==null&&"mode"in e?oh(e.mode,t):!0}async function qu(e,t,i){let n=oh(t,i);for(let o of e)try{if(n){let a=await o.path();await i.attach("video",{path:a,contentType:"video/webm"})}else await o.delete()}catch(a){console.warn("[fixture] Failed to process video:",a)}}var Go;async function Zu(){return Go||(Go=await Promise.resolve().then(()=>(Za(),_d)),Go)}var Ag=new Set(["get","set","getAll","has","__variableStore"]);function ah(e){let t={__variableStore:e,get(i){return e.get(i)},set(i,n,o=!1){e.set(i,n,o)},getAll(){return e.getAll()}};return new Proxy(t,{get(i,n,o){if(n in i)return Reflect.get(i,n,o);if(typeof n=="string")return i.get(n)},set(i,n,o){return typeof n!="string"||Ag.has(n)?Reflect.set(i,n,o):(i.set(n,o),!0)},has(i,n){return n in i?!0:typeof n=="string"?e.has?.(n)??!1:!1}})}function rh(e){if(!e)return null;let t;try{t=JSON.parse(e)}catch(n){throw new Error(`SHIPLIGHT_VARS_OVERRIDE is not valid JSON: ${n.message}`)}if(t===null||typeof t!="object"||Array.isArray(t))throw new Error("SHIPLIGHT_VARS_OVERRIDE must be a JSON object");let i={};for(let[n,o]of Object.entries(t)){if(typeof o!="string")throw new Error(`SHIPLIGHT_VARS_OVERRIDE key "${n}" must be a string`);i[n]=o}return i}function sh(e,t,i){let n=s=>{if(!s||!(e in s))return null;let r=s[e];return r&&typeof r=="object"&&"value"in r?r.sensitive===!0:!1},o=n(i);if(o!==null)return o;let a=n(t);return a!==null?a:!1}function lh(e,t,i,n=process.env.SHIPLIGHT_VARS_OVERRIDE){let o=rh(n);if(o)for(let[a,s]of Object.entries(o)){let r=sh(a,t,i);e.set(a,s,r)}}var ch=["GOOGLE_API_KEY","ANTHROPIC_API_KEY","OPENAI_API_KEY","OPENAI_BASE_URL","ANTHROPIC_MODELS_USE_VERTEXAI","GOOGLE_GENAI_USE_VERTEXAI","GOOGLE_CLOUD_PROJECT","GOOGLE_CLOUD_LOCATION","MAILGUN_API_KEY","MAILGUN_DOMAIN","SHIPLIGHT_API_TOKEN","SHIPLIGHT_API_URL"];function dh(e=Qa()){let t={};for(let i of ch)t[i]=e[i]??"";return t}var Mg=Lt.test.extend({account:[void 0,{option:!0}],autoDismissModal:[!1,{option:!0}],variables:[void 0,{option:!0}],extensionDir:[void 0,{option:!0}],userDataDir:[void 0,{option:!0}],extensionStorageState:[void 0,{option:!0}],launchOptions:async({launchOptions:e},t)=>{if(!process.env.SHIPLIGHT_REGISTRY_URL){await t(e);return}let i=e?.args??[],n={...e,args:[...i,"--remote-debugging-port=0"]};await t(n)},browser:async({browser:e},t)=>{let i=null;if(process.env.SHIPLIGHT_REGISTRY_URL)try{let n=await Eo(process.pid),o=process.env.TEST_WORKER_INDEX??"?";i=await St({cdpUrl:n,label:`shiplight test w${o}`,pid:process.pid})}catch{}await t(e),await Et(i)},context:async({browser:e,account:t,extensionDir:i,userDataDir:n,extensionStorageState:o,acceptDownloads:a,baseURL:s,bypassCSP:r,colorScheme:l,deviceScaleFactor:d,extraHTTPHeaders:c,geolocation:h,hasTouch:m,httpCredentials:g,ignoreHTTPSErrors:y,isMobile:v,javaScriptEnabled:x,locale:p,offline:f,permissions:S,proxy:_,serviceWorkers:k,timezoneId:A,userAgent:I,viewport:O},C,R)=>{let X=i||n,ce={acceptDownloads:a,baseURL:s,bypassCSP:r,colorScheme:l,deviceScaleFactor:d,extraHTTPHeaders:c,geolocation:h,hasTouch:m,httpCredentials:g,ignoreHTTPSErrors:y,isMobile:v,javaScriptEnabled:x,locale:p,offline:f,permissions:S,proxy:_,serviceWorkers:k,timezoneId:A,userAgent:I,viewport:O},j={};for(let D of th){if(!(D in ce))throw new Error(`[fixture] HANDLED_CONTEXT_OPTION_KEYS lists "${D}" but the context fixture does not resolve it \u2014 add "${D}" to the fixture destructure and fixtureOptionValues so per-test use: overrides apply.`);j[D]=ce[D]}if(X){if(t||R.project.use.auth)throw new Error('Cannot use both "extensionDir"/"userDataDir" and "auth" \u2014 persistent context tests manage their own context. Use extensionStorageState for authentication instead.');let D=R.project.use?.browserName;D&&D!=="chromium"&&console.warn(`[fixture] Persistent context requires Chromium but project is configured for "${D}". Forcing Chromium.`);let q=process.env.PLAYWRIGHT_HEADLESS==="true";i&&q&&console.warn("[fixture] PLAYWRIGHT_HEADLESS=true with extensionDir \u2014 Chrome extensions will not function in headless mode.");let ee=Jr(n),se=i?Xr(Re.resolve(process.cwd(),i)):[],te=zr(R.project.use,j),{storageState:fe,account:B,extensionDir:Z,userDataDir:Q,extensionStorageState:de,autoDismissModal:Ko,video:Dt,...z}=te,Ie=Ju(Dt)?{dir:R.outputDir}:void 0,Nt;try{if(Nt=await Lt.chromium.launchPersistentContext(ee,{...z,headless:q,args:se,viewport:"viewport"in z?z.viewport:{width:1280,height:720},...Ie?{recordVideo:Ie}:{}}),o){let jo=Re.resolve(process.cwd(),o),xe=Yr(jo);xe&&await Nt.addCookies(xe)}await C(Nt)}finally{let jo=Nt?.pages().map(xe=>xe.video()).filter(xe=>xe!==null)??[];if(await Nt?.close().catch(xe=>{console.warn("[fixture] Failed to close persistent context:",xe)}),await qu(jo,Dt,R),!n)try{Qu.rmSync(ee,{recursive:!0,force:!0})}catch(xe){console.warn("[fixture] Failed to clean up temp profile dir:",ee,xe)}}}else{let D=zr(R.project.use,j),q=R.project.use,ee=q.auth?{auth:q.auth,args:q.args}:t;if(ee){if(!ee.auth)throw new Error("Auth is declared but missing the script path. Provide auth in playwright.config.ts: use: { auth: './auth.login.ts' }");D.storageState=await eh(ee)}let se=D.video;Ju(se)&&!D.recordVideo&&(D.recordVideo={dir:R.outputDir});let te=await e.newContext(D);te.addInitScript(We);try{await C(te)}finally{let fe=te.pages().map(B=>B.video()).filter(B=>B!==null);await te.close(),await qu(fe,se,R)}}},page:async({context:e},t)=>{let i=await e.newPage();await t(i)},testContext:async({variables:e},t,i)=>{let{VariableStore:n}=await Zu(),o=new n,a=l=>{if(l)for(let[d,c]of Object.entries(l))typeof c=="string"?o.set(d,c,!1):c&&typeof c=="object"&&"value"in c&&o.set(d,c.value,c.sensitive===!0)},s=i.project.use.variables;a(s),a(e),lh(o,s,e);let r=ah(o);global.testContext=r,global.$=r,global.ctx=r,await t(r),delete global.testContext,delete global.$,delete global.ctx},$:async({testContext:e},t)=>{await t(e)},ctx:async({testContext:e},t)=>{await t(e)},agent:async({page:e,testContext:t,autoDismissModal:i},n,o)=>{let{WebAgent:a,createAgentContext:s,configureSdk:r,parseSdkLogLevelFromEnv:l}=await Zu(),d=l();r({env:dh(),...d!==void 0&&{logLevel:d}});let{resolveWebAgentModelFromEnv:c,resolveComputerUseModelFromEnv:h}=await Promise.resolve().then(()=>(jr(),Kr)),m=Qa(),g=c(m);if(!g)throw new Error("No AI model configured. Set WEB_AGENT_MODEL, GOOGLE_API_KEY, ANTHROPIC_API_KEY, OPENAI_API_KEY, or SHIPLIGHT_API_TOKEN in your .env file (or in the runner environment for CI).");let y=h(m),v=t.__variableStore,x=s({model:g,computer_use_model:y,variableStore:v,autoDismissModal:i,downloadDir:Re.join(o.outputDir,"downloads")}),p=Re.join(o.outputDir,"artifacts");x.stepTracking={results:{},artifactsDir:p};let f=new a(x),S=e.context();f.agentServices.setupPageTracking(S);for(let _ of S.pages())f.setupDownloadTracking(_),f.setupDialogHandling(_);S.on("page",_=>{f.setupDownloadTracking(_),f.setupDialogHandling(_)}),global.agent=f,await n(f),delete global.agent;try{let _=o.outputDir;await f.writeExecutionResults(_);let k=Re.join(_,"test-results.json");await(await import("fs/promises")).stat(k).catch(()=>null)&&await o.attach("shiplight-results",{path:k,contentType:"application/json"})}catch(_){console.error("[Shiplight] Failed to attach step results:",_)}try{let _=f.getNewActionEntities();if(_.size>0&&o.status==="passed"){let{createEmptyStore:k,createRunnerStoreEntry:A}=await Promise.resolve().then(()=>(jr(),Kr)),I=await import("fs/promises"),O=k();for(let[R,X]of _)O.entries[R]=A(X,0);let C=Re.join(o.outputDir,"new-action-entities.json");await I.writeFile(C,JSON.stringify(O,null,2)),await o.attach("shiplight-new-action-entities",{path:C,contentType:"application/json"}),console.log(`[Shiplight] ${_.size} healed action entit${_.size===1?"y":"ies"} saved`)}}catch(_){console.warn("[Shiplight] Failed to persist new action entities:",_)}}});0&&(module.exports={EXCLUDED_CONTEXT_OPTION_KEYS,HANDLED_CONTEXT_OPTION_KEYS,SDK_ENV_ALLOWLIST,VIEWPORT_INCOMPATIBLE_OPTIONS,applyVarsOverride,buildSdkEnv,createTestContext,dropViewportIncompatibleOptions,expect,isDeclaredSensitive,mergeResolvedContextOptions,parseVarsOverrideEnv,resolveAuthState,test});
|